ubuntu(linux) svn(1.7) 使用kdiff3 merge主干

原因:在linux下面不能使用小乌龟(TortoiseSVN),idea下面不能使用svn merge主干代码,为了解决每次merge代码时启动虚拟机,又能像小乌龟(TortoiseSVN)一样方便。

方法:

1、安装kdiff3。跨系统且比较流行代码diff工具。

sudo apt-get install  kdiff3

2、安装svn工具。

1) sudo apt-get install subversion subversion-tools

2)降级安装svn(1.7),参考: KUbuntu/Ubuntu 14.04 (降级)安装 svn 1.7

3、配置脚本。

1)下载svndiffwrapper.txt。http://download.csdn.net/detail/love254443233/7941913

2)复制:sudo cp svndiffwrapper.txt  /usr/bin/svndiffwrapper

3) 设置可运行权限。sudo chmod a+x /usr/bin/svndiffwrapper

4、修改svn配置信息

1)打开配置文件:vim ~/.subversion/config

2)修改diff工具及merge-tool-cmd工具的配置

### Set diff-cmd to the absolute path of your 'diff' program.
###   This will override the compile-time default, which is to use
###   Subversion's internal diff implementation.
# diff-cmd = diff_program (diff, gdiff, etc.)
diff-cmd = svndiffwrapper
### Set diff3-cmd to the absolute path of your 'diff3' program.
###   This will override the compile-time default, which is to use
###   Subversion's internal diff3 implementation.
# diff3-cmd = diff3_program (diff3, gdiff3, etc.)
diff3-cmd = svndiffwrapper
### Set diff3-has-program-arg to 'yes' if your 'diff3' program
###   accepts the '--diff-program' option.
# diff3-has-program-arg = [yes | no]
### Set merge-tool-cmd to the command used to invoke your external
### merging tool of choice. Subversion will pass 4 arguments to
### the specified command: base theirs mine merged
# merge-tool-cmd = merge_command
merge-tool-cmd =Kdiff3 "$1" "$2" "$3" -o "$4"
5、merge主干。

1)命令行进入本地分支的工作目录,如/home/xx/work/svn/xx-hotel-image

提交分支(以防不测)。svn commit -m "merge trunk"

2)copy主干(trunk)url,如 http://svn.xx.xx.com/svn/xx/xx/xx-api/trunk

3)merge代码 (最后面的“.”号可省略,因为操作第1)步)。

svn merge  http://svn.corp.qunar.com/svn/mobile/mobfx/hms-api/trunk  .

4)运行过程中遇到冲突时会提示,可选择(M)erge进入kdiff3界面操作,该界面跟windows下面使用小乌龟(TortoiseSVN)进行merge大致一样。

附:

1、界面操作方法

1)第一栏为分支新建的版本文件。第二栏是分支正在开发的文件。第三栏为trunk的文件。下面一栏是比较后输出的文件(output)。

2)output文件可以编辑,当不能满足merge需要时可以人为的修改。

2、svn merge其它常用命令

1)merge主干到本地分支:svn merge  http://svn.xx.xx.com/svn/xx/xx/xx-api/trunk .
2)merge出错时使用回退该操作:

svn revert — 取消所有的本地编辑。恢复一整个目录的文件,可以使用--depth=infinity选项:
Svn revert --depth=infinity .

3)提交本地修改到服务器:

svn commit -m "merge trunk"     

4)遇到如下错误:

svn: E155015: 提交失败(细节如下): 
svn: E155015: 提交终止: “/home/xx/work/svn/xx-hotel-image/versions.mapping” 处于冲突状态

解决方法:svn resolved /home/xx/work/svn/xx-hotel-image/versions.mapping

5)等待建议。



郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。