Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Sync lock toggle #954

Open
wants to merge 3 commits into
base: master
Choose a base branch
from
Open

Sync lock toggle #954

wants to merge 3 commits into from

Conversation

NcxyZero
Copy link

In the company where I work, we sometimes have trouble with the sync lock. We have to ask someone every 5 seconds to unsync just to test something. Everything we write is stored on GitHub, so even if something is overridden, we can just resync and get our files back. It can be really problematic when someone is on break, and we have to wait or kick them from Team Create just to do something. Sticking to an older version of Rojo is not a viable long-term solution, so I implemented a Sync Lock toggle. This allows you to toggle it on and off (it is on by default).

NcxyZero added 3 commits July 30, 2024 19:21
	modified:   Cargo.lock
	modified:   Cargo.toml
	modified:   plugin/Version.txt
@Dekkonot
Copy link
Member

Dekkonot commented Aug 2, 2024

Howdy.

Please revert the changes to the version included in the PR and put the changelog entry under the Unreleased Changes header instead.

@Dekkonot Dekkonot requested a review from boatbomber August 2, 2024 17:07
@Dekkonot Dekkonot added the scope: plugin Relevant to the Roblox Studio plugin label Aug 2, 2024
@@ -1,5 +1,8 @@
# Rojo Changelog

## [7.4.3] - 31 July, 2024
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You should put this in the ## Unreleased Changes section, you are not making a new release.

@@ -1752,7 +1752,7 @@ dependencies = [

[[package]]
name = "rojo"
version = "7.4.0"
version = "7.4.3"
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Undo version change.

@@ -1,6 +1,6 @@
[package]
name = "rojo"
version = "7.4.0"
version = "7.4.3"
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Undo version change.

7.4.3
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Undo version change.

SyncLock = e(Setting, {
id = "syncLock",
name = "Sync Lock",
description = "Toggle sync lock",
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This description is not clear at all, and doesn't explain any more than the title already says.

Suggested change
description = "Toggle sync lock",
description = "Enables Team Create sync locking to prevent conflicts and overwrites between multiple users.",

SyncLock = e(Setting, {
id = "syncLock",
name = "Sync Lock",
description = "Toggle sync lock",
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Add tag = "caution" and add that tag type to the TAG_TYPES here.

@@ -299,7 +299,7 @@ function App:getHostAndPort()
return if #host > 0 then host else Config.defaultHost, if #port > 0 then port else Config.defaultPort
end

function App:isSyncLockAvailable()
function App:isSyncLockAvailable()
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Remove whitespace. Make sure to always format your changes with StyLua.

local claimedLock, priorOwner = self:claimSyncLock()
if not claimedLock then
local msg = string.format("Could not sync because user '%s' is already syncing", tostring(priorOwner))
local syncLockEnabled = Settings:get("syncLock")
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is the wrong way to go about this.

Consider the case of two users, Zack and Micah. Zack has locking enabled, Micah has it disabled. Zack is currently syncing and claimed the lock.

With your implementation, Micah can steal the lock from Zack but Zack cannot steal it back. Zack's settings made it clear that he did not want anyone else to sync over him. Micah doesn't mind if people sync over him, yet Zack still cannot because his setting is checking the lock.

The correct way to implement this setting would be that users with locking disabled simply do not claim the lock themselves, thus allowing other users to claim it. If everyone on your team disables it, then the lock is always unclaimed and anyone can sync whenever.
The setting is saying "I don't care about locking", but that should not override users who do care about locking. The lock must always be respected.

Copy link
Member

@boatbomber boatbomber Aug 3, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Also, what do we do in the case where someone without locking is syncing, and then someone with locking starts syncing? The new user doesn't want other people syncing. Should the unlocked user be forced to stop syncing?

Your feature needs to consider all the cases, not just your use case of the entire team setting it the same way.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
scope: plugin Relevant to the Roblox Studio plugin
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants