文件版本管理-文件合并

用过svn或者cvs的人都知道,文件版本冲突的时候应该将两个冲突的版本进行比较,然后进行合并,如果不能合并则抛出异常。这个在程序里怎么实现呢,这个是否可以合并不是很好判断啊。分析一下,这里有三个文件,一个是版本一(最老的版本),版本2(现在正在库中的版本),版本3(引发冲突的版本),现在要将版本2的内容合并到版本3中而不破坏版本3的修改。那么我们就需要一个修改记录清单。用版本1分别和版本2、版本3进行比较,得出两个"修改记录清单",清单类似这样:

["修改了2到5的字符为xxxx"],那么将其中的2和5替换为变量,类似["修改了a到b的字符为xxxx"],下面所要做的工作就是将两份清单合并成一份,并且按照a排序。得出的一份合并后的清单,在合并的过程中要注意下一个"变更记录"要添加到清单的哪个位置?要添加的"变更记录"在不在上一个"变更记录"的范围内?如果在,也就是说是这种情况["修改了2-5的字符为xxxx","修改了3-8的字符为tttt"]。这种情况要视为冲突并不允许合并。。。如果不存在这种情况,就可以根据变更列表进行合并,合并必须在最老的版本上进行。、、、

 

--PS:昨晚想了好久,临睡前想到了,呵呵。。。今晚回去实现并上传代码

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值