在使用SVN解决冲突时时,大多数情况下我们所面临的都是文件的冲突,即同一文件在本地working copy和远程repository中的内容冲突,而也有不少情况下我们会遇到tree conflict,即svn目录树的冲突,最典型的就是别人将repository里的一个文件删除、重命名或移动位置,而我们自已本地对这个文件进行了修改,这个时候如果执行svn update,将repository的内容同步到本地,就会出现tree conflict的情况。
考虑下面这种情况,repository里文件foo.c被重命名为文件bar.c,本地仍在foo.c的基础上进行修改,下面分两种情况来讨论一下解决tree conflict的方法:
- 接受repository里的重命名
此时要删除本地的foo.c,但在删除之前需要本地的修改应用到bar.c上,那么怎么将本地对foo.c的修改应用到重命名之后的bar.c上呢,可以使用svn的diff和patch命令。
svn diff foo.c > patchfile
将本的foo.c的diff写入patchfile中,内容如下:
Index: foo.c =================================================================== --- foo.c (working copy) +++ foo.c (working copy) ...... ...... ......
将其中的文件名foo.c修改成bar.c
Index: bar.c =================================================================== --- bar.c (working copy) +++ bar.c (working copy) ...... ...... ......
最后执行svn的patch命名
$ svn patch patchfile
- 不接受repository里的重命名
此只需要删除bar.c以及撤消与重命名相关的修改即可