svn: using vim to merge conflicts

后端 未结 1 1638
别那么骄傲
别那么骄傲 2021-01-31 12:27

I am trying see how merging in svn can be made easy.

This page mentions that external tools can be used for merging. Can vim be used as the external merge tool?

1条回答
  •  天涯浪人
    2021-01-31 12:44

    Step 1:

    Save the following script, e.g: merger.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"
    

    Step 2:

    Edit .subversion/config and add following line:

    merge-tool-cmd = /path/to/merger.sh
    

    Step 3:

    When you get following options during svn merge command, select option 'l'. This is to launch external tool to resolve conflicts.

    Conflict discovered in 'main.h'.
    Select: (p) postpone, (df) diff-full, (e) edit,
            (mc) mine-conflict, (tc) theirs-conflict,
            (s) show all options: l
    

    Step 4: Now vim will be opened in diff mode with 3 files - mine, theirs and merged. Make the required changes in the merged file, and do save and exit (:wqa).

    Step 5:

    Now below options will appear again, select 'r' (to accept the merged version) now.

    Select: (p) postpone, (df) diff-full, (e) edit,
                (mc) mine-conflict, (tc) theirs-conflict,
                (s) show all options: r
    

    0 讨论(0)
提交回复
热议问题