SVN分支合并项目有问题,问题出在哪里?怎么解决?
头文件1.3和1.4部分相同,两边该来改去,大量的冲突,导致最后的头文件1.3和1.4都不能用了,请问这样怎么解决,是操作方式不对(没有使用好SVN),还是方法不对(SV...
头文件1.3和1.4部分相同,两边该来改去,大量的冲突,导致最后的头文件1.3和1.4都不能用了,请问这样怎么解决,是操作方式不对(没有使用好SVN),还是方法不对(SVN根本不能这样搞,还是要分开,各走各的流程,各自先update,然后提交,然后合并,不能这样合并)。
展开
展开全部
你没有提到图中“局域网开发环境”的文件夹结构,关键就在这里了。
我理解你遇到的问题应该是这样:软件的多个版本在同时开发或维护,但在服务器上这多个版本存放在同一个文件夹,导致发生冲突。
如果是这样的话,我建议你合理使用SVN的分支功能。给你描述一下对于多版本同时开发环境下,SVN的规划吧:
1、按照SVN官方建议,在版本库的根目录下先建立3个文件夹:trunk、branches、tags。
2、trunk文件夹是开发主干,最新版本的开发成果都存放在这里,这里的内容是不稳定的,甚至是未经测试的,经常发生变化。
3、branches是存放各分支,每当要形成一个相对稳定的测试版时,就从trunk拉出一个分支(svn copy)到branches下,比如branches下会因此形成1.0a版、1.0b版、1.0release版、1.0.1a版等多个子文件夹,然后部署测试环境就从这些文件夹中获取代码,测试时发现bug进行的修复也在这些分支文件夹中进行,与此同时主干上的开发正常进行,两边互不干扰。
4、当测试完成后要正式发布时,就从这个分支下将其拉到tags下,tags下存放的就是各个版本的正式发布版,会因此形成1.0release、1.1release、1.2release等多个文件夹。
5、当需要将某个测试版中的某项修复成果应用到其他版本或主干上时,就进行branches下不同分支或分支与主干之间的合并操作,这时合并可能会发生冲突,在这时进行冲突解决。
6、这样的话,最新版本开发始终在主干中进行,对某个版本的测试/修复或对之前版本的维护在branches下该版本的子文件夹中进行,要发布的正式版始终从tags中获得,整个库就井井有条了。
我理解你遇到的问题应该是这样:软件的多个版本在同时开发或维护,但在服务器上这多个版本存放在同一个文件夹,导致发生冲突。
如果是这样的话,我建议你合理使用SVN的分支功能。给你描述一下对于多版本同时开发环境下,SVN的规划吧:
1、按照SVN官方建议,在版本库的根目录下先建立3个文件夹:trunk、branches、tags。
2、trunk文件夹是开发主干,最新版本的开发成果都存放在这里,这里的内容是不稳定的,甚至是未经测试的,经常发生变化。
3、branches是存放各分支,每当要形成一个相对稳定的测试版时,就从trunk拉出一个分支(svn copy)到branches下,比如branches下会因此形成1.0a版、1.0b版、1.0release版、1.0.1a版等多个子文件夹,然后部署测试环境就从这些文件夹中获取代码,测试时发现bug进行的修复也在这些分支文件夹中进行,与此同时主干上的开发正常进行,两边互不干扰。
4、当测试完成后要正式发布时,就从这个分支下将其拉到tags下,tags下存放的就是各个版本的正式发布版,会因此形成1.0release、1.1release、1.2release等多个文件夹。
5、当需要将某个测试版中的某项修复成果应用到其他版本或主干上时,就进行branches下不同分支或分支与主干之间的合并操作,这时合并可能会发生冲突,在这时进行冲突解决。
6、这样的话,最新版本开发始终在主干中进行,对某个版本的测试/修复或对之前版本的维护在branches下该版本的子文件夹中进行,要发布的正式版始终从tags中获得,整个库就井井有条了。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询