I have a svn working copy which I attempted to reverse merge a couple of recent revisions into. I cancelled the merge before it completed as I changed my mind. Now my working copy has a couple of thousand "changes" from updates to the ancestry related properties on most of the files. I have about 10 files with real code changes mixed in which I don't want to have to seperate out by hand.
Is there a way for me to revert all of the property changes without affecting the content changes?
svn revert `svn status | grep '^ M' | sed 's/^ M \+//g'`
If you use the revert option --depth empty
, you'll revert changes only to paths explicitly specified on the command line and not recursively. So if those changes are property changes, that will be the only thing you revert.
Example: if you have the directory foo
with unwanted property changes, but its content has modifications, the following will revert the property changes, but keep the modifications of its content:
$ svn revert --depth empty foo
as is demonstrated here:
$ svn status foo
M foo
M foo/bar
$ svn revert --depth empty foo
$ svn status foo
M foo/bar
Turns out that Tortoise SVN can do this really nicely. In the commit dialog you can sort the "modified" files by "text status" or "properties status". I simply sorted by text status and then reverted all the "modified" files which had "normal" "text status".
You can submit your changes and then revert the property changes from that revision:
svn merge -c -REV -depth empty
where REV is the revision where you want to revert the property changes
Revert all property changes with PowerShell.
> @(svn status) -match '^ M' | `
>>> % { ($_ -split 'M\s+')[1] } | `
>>> % { svn revert --depth empty $_ }
Credit to Jerome Jaglale and TheJuice for the general approach.
Note the backtick `
symbol indicates a new line.
我只会复制/备份 10 个文件,并在其他地方更改真实代码,然后svn revert -R
整个项目,然后复制回 10 个文件。
The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.