Suppose I have a set of commits in a repository folder...
123 (250 new files, 137 changed files, 14 deleted files)
122 (150 changed files)
121 (renamed folder)
120 (90 changed files)
119 (115 changed files, 14 deleted files, 12 added files)
118 (113 changed files)
117 (10 changed files)
I want to get a working copy that includes all changes from revision 117 onward but does NOT include the changes for revisions 118 and 120.
EDIT: To perhaps make the problem clearer, I want to undo the changes that were made in 118 and 120 while retaining all other changes. The folder contains thousands of files in hundreds of subfolders.
What is the best way to achieve this?
The answer, thanks to Bruno and Bert, is the command (in this case, for removing 120 after the full merge was performed)
svn merge -c -120 .
Note that the revision number must be specified with a leading minus. '-120' not '120'
There's a more straightforward way if you use TortoiseSVN, a Windows client for Subversion. You just click to view the log in your updated work copy, select the revisions you want to undo, right click, and select "Revert changes from these revisions".
It is a safe operation because the changes are applied just in your workspace. You still have to commit to modify your repository.
It is one of the best features of TortoiseSVN. I've always been a command line guy, but Tortoise changed my mind.
To undo revisions 118 and 120:
Also see the description in Undoing changes.
Note the minus in the
-c -120
argument. The-c
(or--change
) switch is supported since Subversion 1.4, older versions can use-r 120:119
.I suppose you could create a branch from revision 117, then merge everything except 118 and 120.
Then checkout this branch and from there do
svnmerge.py merge -r119,120-123
EDIT: This doesn't undo the revisions in the branch/trunk. Use
svn merge
instead.