我正在和一个朋友一起做一个项目,我想返回到我们代码的旧版本,并将其设置为当前版本。我该怎么做?

我在vs08上使用“anksvn”。

我的电脑上有我想要的版本,但提交失败;我得到的信息是 "提交失败,文件或目录已过期。"

我的电脑上也有subversion客户端。


当前回答

乔恩·斯基特的回答基本上就是一个简单的解决方案,但如果你和我一样,你可能想要一个解释。Subversion手册将其称为

择优挑选合并

从手册页。

This form is called a 'cherry-pick' merge: '-r N:M' refers to the difference in the history of the source branch between revisions N and M. A 'reverse range' can be used to undo changes. For example, when source and target refer to the same branch, a previously committed revision can be 'undone'. In a reverse range, N is greater than M in '-r N:M', or the '-c' option is used with a negative number: '-c -M' is equivalent to '-r M:'. Undoing changes like this is also known as performing a 'reverse merge'.


如果源是一个文件,则对该文件应用差异 文件(用于反向合并早期更改)。否则, 如果源是一个目录,那么目标默认为'.'。 在正常使用情况下,工作副本应该是最新的 修订,没有局部修改和切换子树。

例子:

svn merge -r 2983:289 path/to/file

这将用来自服务器的修订289替换本地副本[2983](根据上面的引用,它应该与服务器同步—您的责任)。更改发生在本地,这意味着如果您有一个干净的签出,那么可以在提交更改之前检查更改。

其他回答

以前的大多数答案都是使用反向合并,这通常是正确的答案。然而,有一种情况(刚刚发生在我身上)却不是这样。

我不小心将一个Unix行结束符的文件更改为DOS行结束符时做了一个小更改,并提交了它。这很容易取消,可以通过更改行结束符并再次提交,也可以通过反向合并,但它的效果是使svn blame list my edit作为文件每一行的源。(有趣的是,Windows上的TortoiseSVN不受此影响;只有命令行责备SVN。)

如果要维护svn blame上报的历史记录,我认为需要做以下工作:

删除文件并提交。 在存储库中,将文件先前的良好副本复制到头文件中,并提交。 恢复您想要保留的任何编辑。

删除有点可怕,但请记住,您始终将文件保存在存储库中,因此恢复它不是什么大问题。下面是一些演示步骤的代码。假设xxx是最后一个好的副本的修订号。

svn rm svn+ssh://path/to/file
svn copy svn+ssh://path/to/file@xxx svn+ssh://path/to -m"Restore good copy"
svn update
<restore the edits>
svn commit -m"Restore edits"

注意,对于存储库中的副本,目标需要是目录,而不是文件名。

基本上你需要“向后合并”——将当前版本和以前版本之间的差异应用到当前版本(因此你最终会得到一个看起来像旧版本的工作副本),然后再次提交。例如,从150版(目前)回到140版:

svn update
svn merge -r 150:140 .
svn commit -m "Rolled back to r140"

Subversion红皮书对此有一个很好的章节。

乔恩·斯基特的回答基本上就是一个简单的解决方案,但如果你和我一样,你可能想要一个解释。Subversion手册将其称为

择优挑选合并

从手册页。

This form is called a 'cherry-pick' merge: '-r N:M' refers to the difference in the history of the source branch between revisions N and M. A 'reverse range' can be used to undo changes. For example, when source and target refer to the same branch, a previously committed revision can be 'undone'. In a reverse range, N is greater than M in '-r N:M', or the '-c' option is used with a negative number: '-c -M' is equivalent to '-r M:'. Undoing changes like this is also known as performing a 'reverse merge'.


如果源是一个文件,则对该文件应用差异 文件(用于反向合并早期更改)。否则, 如果源是一个目录,那么目标默认为'.'。 在正常使用情况下,工作副本应该是最新的 修订,没有局部修改和切换子树。

例子:

svn merge -r 2983:289 path/to/file

这将用来自服务器的修订289替换本地副本[2983](根据上面的引用,它应该与服务器同步—您的责任)。更改发生在本地,这意味着如果您有一个干净的签出,那么可以在提交更改之前检查更改。

这页上有很多危险的答案。请注意,从SVN版本1.6开始,执行更新-r可能会导致树冲突,这将迅速升级为可能丢失数据的kafkeresque噩梦,您需要在谷歌上搜索关于树冲突的信息。

恢复版本的正确方法是:

svn merge -r HEAD:12345 .

其中12345是版本号。别忘了这个点。

同步到旧版本并提交。这应该能奏效。

这里还解释了撤消更改。