我在一个工作文件夹中有很多更改,在尝试进行更新时出错了。
现在当我发出'svn cleanup'时,我得到:
>svn cleanup .
svn: In directory '.'
svn: Error processing command 'modify-wcprop' in '.'
svn: 'MemPoolTests.cpp' is not under version control
MemPoolTests.cpp是另一个开发人员添加的新文件,在更新中被删除了。以前我的工作文件夹里不存在。
我能做些什么来尝试并继续前进,而不必签出存储库的新副本吗?
澄清:感谢您提出的关于将目录移出并删除一个新副本的建议。我知道这是一个选项,但这是我想避免的,因为有许多更改嵌套在几个目录深处(这应该是一个分支…)
我希望有一种更积极的方式来做清理,也许以某种方式迫使文件SVN有麻烦回到一个已知的状态(我尝试删除它的工作副本…这并没有帮助)。
在终端中运行svn cleanup命令(如果它在Eclipse中失败,这是我的情况):
~/path/to/svn-folder/$ svn cleanup
我尝试了这里解释的不同解决方案,但没有一个奏效。
行动小组→更新头部失败:
svn: E155004:“/home/user/path/to/svn-folder”下有未完成的工作项;先运行'svn cleanup'。
Action Team→清理失败,错误相同。
解决方案:在终端上执行svn cleanup命令。
命令执行成功。
然后Team→Update in Eclipse再次工作。
注意:我的SVN版本是1.9.3。
如果svn cleanup不起作用,还检查Chris的回答。
每当我有类似的问题,我使用rsync(注意:我使用Linux或Mac OS X)来帮助这样:
# Go to the parent directory
cd dir_above_borked
# Rename corrupted directory
mv borked_dir borked_dir.bak
# Checkout a fresh copy
svn checkout svn://... borked_dir
# Copy the modified files to the fresh checkout
# - test rsync
# (possibly use -c to verify all content and show only actually changed files)
rsync -nav --exclude=.svn borked_dir.bak/ borked_dir/
# - If all ok, run rsync for real
# (possibly using -c again, possibly not using -v)
rsync -av --exclude=.svn borked_dir.bak/ borked_dir/
这样您就有了一个新的签出,但是使用相同的工作文件。
对我来说,这总是很有效。