论坛首页 编程语言技术论坛

文件版本管理-文件合并

浏览 3802 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2009-07-15   最后修改:2009-07-15

用过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:昨晚想了好久,临睡前想到了,呵呵。。。今晚回去实现并上传代码

   发表时间:2009-07-15  
晚上被领导抓去吃饭去了,呵呵。现在更新下代码
运行代码需要安装一下sqlalchemy
代码是在python3.0环境下写的,与python2.x的兼容性可能存在问题
sqlalchemy的版本是0.6b1
如有任何问题,欢迎提问或给我发邮件:phyeas@163.com
0 请登录后投票
   发表时间:2009-07-28  
我觉得不如引进锁,一个人在保存版本的时候,不允许另一个人同时保存版本,这样就不存在冲突,也无需解决合并问题了
0 请登录后投票
   发表时间:2009-07-28  
文件合并是为了让多人同时修改文档的不同部分。我觉得引进锁的话修改的效率就低很多了。
0 请登录后投票
   发表时间:2009-08-09  
锁是老式解决方案。
0 请登录后投票
论坛首页 编程语言技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics