svn tree conflict

在使用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以及撤消与重命名相关的修改即可

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值