我想看看如何在 svn 中合并变得容易。
此 page提到可以使用外部工具进行合并。
vim 可以用作外部合并工具吗?
一些额外的要求:
例如:如
最佳答案
第 1 步:
保存以下脚本,例如:merge.sh:
#!/bin/sh
#
BASE=${1}
THEIRS=${2}
MINE=${3}
MERGED=${4}
WCPATH=${5}
vimdiff $MINE $THEIRS -c ":botright split $MERGED" -c ":diffthis" -c "setl statusline=MERGED | wincmd W | setl statusline=THEIRS | wincmd W | setl statusline=MINE"
第 2 步:
编辑
.subversion/config
并添加以下行:merge-tool-cmd = /path/to/merger.sh
第 3 步:
当您在 svn merge 命令期间获得以下选项时,请选择选项“
l
” '。这是为了启动外部工具来解决冲突。
Conflict discovered in 'main.h'.
Select: (p) postpone, (df) diff-full, (e) edit,
(mc) mine-conflict, (tc) theirs-conflict,
(s) show all options: l
第 4 步:
现在 vim 将在 diff 模式下打开 3 个文件 - 我的、他们的和合并的。
在合并的文件中进行所需的更改,然后保存并退出 (
:wqa
)。第 5 步:
现在下面的选项将再次出现,选择'
r
'(接受合并版本)现在。Select: (p) postpone, (df) diff-full, (e) edit,
(mc) mine-conflict, (tc) theirs-conflict,
(s) show all options: r
关于svn:使用vim合并冲突,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19678860/