summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: bc7a96a)
raw | patch | inline | side by side (parent: bc7a96a)
author | David Aguilar <davvid@gmail.com> | |
Fri, 19 Aug 2011 09:14:45 +0000 (02:14 -0700) | ||
committer | Junio C Hamano <gitster@pobox.com> | |
Fri, 19 Aug 2011 17:52:16 +0000 (10:52 -0700) |
meld 1.5.0 and newer allow the output file to be specified
when merging multiple files. Check whether the meld command
supports '--output' and use it when available.
Signed-off-by: David Aguilar <davvid@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
when merging multiple files. Check whether the meld command
supports '--output' and use it when available.
Signed-off-by: David Aguilar <davvid@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
mergetools/meld | patch | blob | history |
diff --git a/mergetools/meld b/mergetools/meld
index 73d70ae28ad1e6a5b38e051442e08c26c074bb22..eaa115ccb7a1154715c1d9dd9b7d4d360234aa01 100644 (file)
--- a/mergetools/meld
+++ b/mergetools/meld
}
merge_cmd () {
+ if test -z "${meld_has_output_option:+set}"
+ then
+ check_meld_for_output_version
+ fi
touch "$BACKUP"
- "$merge_tool_path" "$LOCAL" "$MERGED" "$REMOTE"
+ if test "$meld_has_output_option" = true
+ then
+ "$merge_tool_path" --output "$MERGED" \
+ "$LOCAL" "$BASE" "$REMOTE"
+ else
+ "$merge_tool_path" "$LOCAL" "$MERGED" "$REMOTE"
+ fi
check_unchanged
}
+
+# Check whether 'meld --output <file>' is supported
+check_meld_for_output_version () {
+ meld_path="$(git config mergetool.meld.path)"
+ meld_path="${meld_path:-meld}"
+
+ if "$meld_path" --output /dev/null --help >/dev/null 2>&1
+ then
+ meld_has_output_option=true
+ else
+ meld_has_output_option=false
+ fi
+}