Professional Subversion Hosting
Free SVN Hosting, SSL, ACLs, Petabyte Storage | |||||||||||||||||||||||||||||||||||||||||||||
|
Subversion generally works best without locking, using the “Copy-Modify-Merge” methods described earlier in the section called “The Copy-Modify-Merge Solution”. However there are a few instances when you may need to implement some form of locking policy.
Firstly you need to ensure that your Subversion server is upgraded to at
least version 1.2. Earlier versions do not support locking at all. If you
are using By default, nothing is locked and anyone who has commit access can commit changes to any file at any time. Others will update their working copies periodically and changes in the repository will be merged with local changes. If you Get a Lock on a file, then only you can commit that file. Commits by all other users will be blocked until you release the lock. A locked file cannot be modified in any way in the repository, so it cannot be deleted or renamed either, except by the lock owner.
However, other users will not necessarily know that you have taken
out a lock. Unless they check the lock status regularly, the first
they will know about it is when their commit fails, which in most
cases is not very useful. To make it easier to manage locks, there
is a new Subversion property
Locks are recorded by working copy location as well as by owner. If you have several working copies (at home, at work) then you can only hold a lock in one of those working copies. If one of your co-workers acquires a lock and then goes on holiday without releasing it, what do you doЁ Subversion provides a means to force locks. Releasing a lock held by someone else is referred to as Breaking the lock, and forcibly acquiring a lock which someone else already holds is referred to as Stealing the lock. Naturally these are not things you should do lightly if you want to remain friends with your co-workers. Locks are recorded in the repository, and a lock token is created in your local working copy. If there is a discrepancy, for example if someone else has broken the lock, the local lock token becomes invalid. The repository is always the definitive reference. Select the file(s) in your working copy for which you want to acquire a lock, then select the command → . A dialog appears, allowing you to enter a comment, so others can see why you have locked the file. The comment is optional and currently only used with Svnserve based repositories. If (and only if) you need to steal the lock from someone else, check the Steal lock box, then click on . If you select a folder and then use → the lock dialog will open with every file in every subfolder selected for locking. If you really want to lock an entire hierarchy, that is the way to do it, but you could become very unpopular with your co-workers if you lock them out of the whole project. Use with care ... To make sure you don't forget to release a lock you don't need any more, locked files are shown in the commit dialog and selected by default. If you continue with the commit, locks you hold on the selected files are removed, even if the files haven't been modified. If you don't want to release a lock on certain files, you can uncheck them (if they're not modified). If you want to keep a lock on a file you've modified, you have to enable the Keep locks checkbox before you commit your changes. To release a lock manually, select the file(s) in your working copy for which you want to release the lock, then select the command → There is nothing further to enter so TortoiseSVN will contact the repository and release the locks. You can also use this command on a folder to release all locks recursively.
To see what locks you and others hold, you can use → . Locally held lock tokens show up immediately. To check for locks held by others (and to see if any of your locks are broken or stolen) you need to click on . From the context menu here, you can also get and release locks, as well as breaking and stealing locks held by others. Avoid Breaking and Stealing LocksIf you break or steal someone else's lock without telling them, you could potentially cause loss of work. If you are working with unmergeable file types and you steal someone else's lock, once you release the lock they are free to check in their changes and overwrite yours. Subversion doesn't lose data, but you have lost the team-working protection that locking gave you.
As mentioned above, the most effective way to use locking is to set
the As a reminder, TortoiseSVN uses a special overlay to indicate this. If you operate a policy where every file has to be locked then you may find it easier to use Subversion's auto-props feature to set the property automatically every time you add new files. Read the section called “TortoiseSVN's Settings” for further information.
When you create a new repository with Subversion 1.2 or higher,
four hook templates are created in the repository
It is a good idea to install a You might also use hooks to disallow breaking or stealing of locks, or perhaps limit it to a named administrator. Or maybe you want to email the owner when one of their locks is broken or stolen. Read the section called “Hook Scripts” to find out more. | All Plans Include
| ||||||||||||||||||||||||||||||||||||||||||||