2 # git-mergetool--lib is a library for common merge tool functions
4 test "$TOOL_MODE" = diff
8 test "$TOOL_MODE" = merge
11 translate_merge_tool_path
() {
16 if test "$MERGED" -nt "$BACKUP"
22 echo "$MERGED seems unchanged."
23 printf "Was the merge successful? [y/n] "
24 read answer ||
return 1
26 y
*|Y
*) status
=0; break ;;
27 n
*|N
*) status
=1; break ;;
33 valid_tool_config
() {
34 if test -n "$(get_merge_tool_cmd "$1")"
43 setup_tool
"$1" || valid_tool_config
"$1"
55 mergetools
="$(git --exec-path)/mergetools"
57 # Load the default definitions
58 .
"$mergetools/defaults"
59 if ! test -f "$mergetools/$tool"
64 # Load the redefined functions
67 if merge_mode
&& ! can_merge
69 echo "error: '$tool' can not be used to resolve merges" >&2
71 elif diff_mode
&& ! can_diff
73 echo "error: '$tool' can only be used to resolve merges" >&2
79 get_merge_tool_cmd
() {
80 # Prints the custom command for a merge tool
84 echo "$(git config difftool.$merge_tool.cmd ||
85 git config mergetool.$merge_tool.cmd)"
87 echo "$(git config mergetool.$merge_tool.cmd)"
91 # Entry point for running tools
93 # If GIT_PREFIX is empty then we cannot use it in tools
94 # that expect to be able to chdir() to its value.
95 GIT_PREFIX
=${GIT_PREFIX:-.}
98 merge_tool_path
="$(get_merge_tool_path "$1")" ||
exit
102 # Bring tool-specific functions into scope
114 list_merge_tool_candidates
() {
117 tools
="tortoisemerge"
121 if test -n "$DISPLAY"
123 if test -n "$GNOME_DESKTOP_SESSION_ID"
125 tools
="meld opendiff kdiff3 tkdiff xxdiff $tools"
127 tools
="opendiff kdiff3 tkdiff xxdiff meld $tools"
129 tools
="$tools gvimdiff diffuse ecmerge p4merge araxis bc3 codecompare"
131 case "${VISUAL:-$EDITOR}" in
133 tools
="$tools vimdiff emerge"
136 tools
="$tools emerge vimdiff"
141 guess_merge_tool
() {
142 list_merge_tool_candidates
143 echo >&2 "merge tool candidates: $tools"
145 # Loop over each candidate and stop when a valid merge tool is found.
148 merge_tool_path
="$(translate_merge_tool_path "$i")"
149 if type "$merge_tool_path" >/dev
/null
2>&1
156 echo >&2 "No known merge resolution program available."
160 get_configured_merge_tool
() {
161 # Diff mode first tries diff.tool and falls back to merge.tool.
162 # Merge mode only checks merge.tool
165 merge_tool
=$
(git config
diff.tool || git config merge.tool
)
167 merge_tool
=$
(git config merge.tool
)
169 if test -n "$merge_tool" && ! valid_tool
"$merge_tool"
171 echo >&2 "git config option $TOOL_MODE.tool set to unknown tool: $merge_tool"
172 echo >&2 "Resetting to default..."
178 get_merge_tool_path
() {
179 # A merge tool has been set, so verify that it's valid.
181 if ! valid_tool
"$merge_tool"
183 echo >&2 "Unknown merge tool $merge_tool"
188 merge_tool_path
=$
(git config difftool.
"$merge_tool".path ||
189 git config mergetool.
"$merge_tool".path
)
191 merge_tool_path
=$
(git config mergetool.
"$merge_tool".path
)
193 if test -z "$merge_tool_path"
195 merge_tool_path
="$(translate_merge_tool_path "$merge_tool")"
197 if test -z "$(get_merge_tool_cmd "$merge_tool")" &&
198 ! type "$merge_tool_path" >/dev
/null
2>&1
200 echo >&2 "The $TOOL_MODE tool $merge_tool is not available as"\
204 echo "$merge_tool_path"
208 # Check if a merge tool has been configured
209 merge_tool
="$(get_configured_merge_tool)"
210 # Try to guess an appropriate merge tool if no tool has been set.
211 if test -z "$merge_tool"
213 merge_tool
="$(guess_merge_tool)" ||
exit