我找到了各种关于如何恢复SVN提交的示例,例如

svn merge -r [current_version]:[previous_version] [repository_url]

or

svn merge -c -[R] .

但这两种方法似乎都不管用。我尝试了这些命令,并检查了手动更改的文件。

如何恢复修订号为1944的提交?我如何检查恢复已经完成(没有在实际文件中查看已恢复的更改)?


当前回答

下面将做一个演练,正如它所说。HEAD是当前版本,PREV是之前的版本,然后是文件或提交项的路径:

svn merge --dry-run -rHEAD:PREV https://example.com/svn/myproject/trunk

如果试运行看起来不错,那么运行命令时不要使用——dry-run

验证修订中的更改并重新提交。要浏览版本号,请尝试:

svn log

其他回答

F=code.c
REV=123
svn diff -c $REV $F | patch -R -p0 \
    && svn commit -m "undid rev $REV" $F

如果您希望完全从历史记录中删除提交,还可以在特定修订时转储回购,然后导入该转储。具体地说:

svnrdump dump -r 1:<rev> <url> > filename.dump

svndump命令与svnadmin dump功能相同,但工作在远程repo上。

接下来,只需将转储文件导入您所选择的回购。这种方法在《豆茎》上被测试效果很好。

“取消提交”修订是不可能的,但是您可以将工作副本恢复到1943版本,并将其提交为1945版本。1943年和1945年的版本将是相同的,有效地恢复了变化。

svn merge -c -M PATH

这救了我的命。

我也有同样的问题,在恢复后,我也没有看到旧的代码。 运行上述命令后,我得到了一个干净的旧版本代码。

非常老的线程,但是Intellij没有答案。还原一次提交:

至: 颠覆>集成目录…