TortoiseSVN中分支和合并实践Word文档格式.docx
- 文档编号:19834658
- 上传时间:2023-01-10
- 格式:DOCX
- 页数:12
- 大小:227.84KB
TortoiseSVN中分支和合并实践Word文档格式.docx
《TortoiseSVN中分支和合并实践Word文档格式.docx》由会员分享,可在线阅读,更多相关《TortoiseSVN中分支和合并实践Word文档格式.docx(12页珍藏版)》请在冰豆网上搜索。
你可能会说,那我在开发的过程中不提交不就行了,等到我全部开发结束我再提交,是,你可以这么做,那还要版本控制干什么呢?
也许等到你最后提交代码的时候(也许一周,也许两周?
),你会发现有一大堆conflict等着你resolve。
那么,正确的做法是什么?
使用branch,从trunk创建branch,然后在你的branch上开发,开发完成后再合并到trunk中。
关于branch先讲到这里,下面说说什么叫做合并。
很好理解,当branch开发完成后(包括必要的测试),将branch中的修改同步到trunk中,这个过程有可能包括修改文件、增加文件、删除文件等等。
说到这里,貌似本文差不多可以结束了,不就是分支和合并么?
只要再简单地说说如何建立分支和如何合并就可以收尾了,可能只需两个命令,也可能只需鼠标点几下然后键盘敲两下即可。
其实事情远非这么简单,爱动脑筋的同学可能会问了,将branch的改动merge到trunk的时候,和上文说的直接在trunk中全部开发完然后提交有何区别?
你最后还不是要处理一大堆conflict?
这个问题问得非常好,其实这正是本文的重点:
branch和trunk在并行开发的过程中如何感知对方,branch如何才能在开发过程中不会和trunk越走越远,导致最后无法合并?
试想一下,如果在你开发branch的过程中,trunk中的某个类文件已经被删除了(这可能是另外一个家伙在另一个branch上开发了两周后才合并到trunk的),而你竟然在这个类文件上做了大量修改,试问你到最后合并回trunk的时候该有多蛋疼?
解决这一问题的唯一手段是,branch要不停地和trunk保持同步,你要及时地知道trunk都做了什么修改,这些修改是否会影响你正在开发的新功能,如果需要,你必须及时调整branch的代码,使之能与trunk“兼容”。
那么如何让branch和trunk保持同步?
合并,从trunk合并到branch,你没听错,是从trunk合并到branch。
关于TortoiseSVN的合并,有几点需要注意:
∙TortoiseSVN的合并发生在本地,也即你的workingcopy中,你无需过多担心会对repository中的代码造成影响
∙不管是从trunk合并到branch还是最终从branch合并回trunk,在每次合并前最好先update,然后将本地的修改先全部commit,保护好现场,万一合并不理想随时都可以revert
∙合并完成后看是否能正确编译,然后测试验证,最后将合并后的改动提交到repository
下面我将stepbystep地演示如何一次完整的branching和merging,包括创建分支、分支开发、分支和主线同步,分支合并到主线的全过程,甚至包括如何在本地创建一个测试用的repository。
首先需要安装TortoiseSVN,我安装的版本是:
TortoiseSVN1.6.15,Build21041-32Bit,2011/03/2318:
00:
27
1、本地Repository的创建
repository的创建很简单,假设我要在D:
\TortoiseSVN\TestRepository目录中创建repository,只需右键TestRepository目录,依次选择"
TortoiseSVN"
->
"
Createrepositoryhere"
便完成了repository的创建。
2、Checkout
假设要checkout到D:
\TortoiseSVN\TestSVN,同样很简单,在D:
\TortoiseSVN目录下创建TestSVN目录,然后在该目录上右键,选择"
SVNCheckout..."
,在弹出的窗口中的"
URLofrepository"
中填入"
file:
///D:
/TortoiseSVN/TestRepository"
,其他默认即可,最后点击ok。
3、trunk创建新项目MyProject
相当简单就不赘述了,只列出本次操作所作出的修改:
4、创建branch
在/trunk/MyProject目录上右键,依次选择"
Branch/tag..."
,在弹出窗口的"
ToURL"
中填入分支的地址,在这里目标revision选择HEADrevision,如下图所示,添加log后点击ok分支便建立了。
这个操作速度非常快,新建的branch在repository中其实只是一个指向trunk某个revision的软连接而已,并没有真的复制文件。
5、Checkout分支
右键TestSVN目录选择"
TortoiseSVNUpdate"
即可将刚刚建立的分支下载回本地。
进入/branches/MyProject目录下你会发现其文件结构和/trunk/MyProject一模一样。
6、branch提交一个新文件
7、trunk紧接着提交一个修改
8、branch再次提交一个修改
9、将trunk中的修改同步到branch
6-8演示的是branch和trunk在独立、并行地开发。
为了防止在“错误”的道路上越走越远,现在branch意识到是时候和trunk来一次同步了(将trunk合并到branch)。
首先,在本地trunk中先update一下,有冲突的解决冲突,保证trunk和repository已经完全同步,然后在/branches/MyProject上右键,依次选择"
“Merge...”,在弹出的窗口中选择第一项"
Mergearangeofrevision"
,这个类型的Merge已经介绍得很清楚,适用于将某个分支或主线上提交的多个revision间的变化合并到另外一个分支上。
点击next后,出现如下窗口:
由于是要从trunk合并到branch,理所当然这里的"
URLtomergefrom"
应该填trunk的路径,"
Revisionrangetomerge"
很好理解,就是你要将trunk的哪些revision所对应的变化合并到branch中,可以是某一连串的revision,比如4-7,15-HEAD,也可以是某个单独的revision号。
由于在r4中,trunk修改了Person.java中的talk()方法,所以这里的revision只需填4即可。
点击next后出现下图:
在这里只需保留默认设置即可。
在点击Merge按钮前你可以先Testmerge一把,看成功与否,以及merge的详细信息。
点击Merge按钮后trunk所做的修改将同步到branch中。
10、提交合并后的branch
至此,branch已经完全和trunk同步,branch和trunk的代码相处很融洽,没有任何冲突,如果branch已经开发结束,那是时候将branch合并回trunk了,当然,如果branch还要继续开发,那你将不断地重复6-10这几个步骤。
11、将branch合并回trunk
在/trunk/MyProject上右键(注意是在主线的目录上右键),依次选择"
Merge..."
,在弹出的窗口中,Mergetype选择第二项"
Reintegrateabranch"
,这种类型的合并适合在分支开发结束后将所有的改动合并回主线。
点击next后出现如下窗口:
在这里,"
FromURL"
选择/branches/MyProject,无需选择revision号,Reintegrate会将branch上所有修改合并到trunk。
后面的步骤和上文第9步中的一样,不再啰嗦了。
如无意外,branch将成功合并到trunk,你需要做的只是将合并后的trunk赶紧commit!
12、提交合并后的trunk
soeasy...
13、删除branch
如果你认为你新加的功能已经开发完成了,你可以删除你的分支
到这里,我已经给你演示完了整个过程,我一身的汗也下来了,我想罢工了,不过最后我们还是看看所有的log信息吧,通过log能发现我们干的所有事情:
r1-r7正是我上文在干的事情,从Message中你能发现我对trunk和branch都干了什么,另外,在LogMessages窗口的左下角勾选了"
Includemergedrevisions"
你还能看到额外的Mergeinformation:
图中灰色的是和merge相关的log,共发生了两次merge,第一次是在r6,在r6中,branch合并了trunk在r4时提交的变化;
第二次是在r7,在r7中,trunk合并了branch从r2到r6的所有变化。
终于可以写写总结了:
∙branch主要用于新功能的开发
∙合并发生在本地workingcopy,只要你不提交就不会影响到repository
∙合并前一定要先update、commit,保证不会outofday,并将本地的修改保存到repository
∙branch和trunk并行开发的过程中,要经常同步,将trunk的修改合并到branch,合并时选择"
∙branch最后合并回trunk时,mergetype选择"
原文:
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- TortoiseSVN 中分 和合 实践