* [PATCH] fixup! mergetool: add automerge configuration @ 2021-01-09 21:49 David Aguilar 2021-01-09 21:59 ` brian m. carlson 0 siblings, 1 reply; 24+ messages in thread From: David Aguilar @ 2021-01-09 21:49 UTC (permalink / raw) To: Junio C Hamano, Seth House, Felipe Contreras; +Cc: git The use of "\r\?" in sed is not portable to macOS and possibly other unix flavors. Replace "\r" with a substituted variable that contains "\r". Replace "\?" with "\{0,1\}". Signed-off-by: David Aguilar <davvid@gmail.com> --- This is based on top of fc/mergetool-automerge and can be squashed in (with the addition of my sign-off) if desired. Let me know if you'd prefer a separate patch. I figured we'd want a squash to preserve bisectability. git-mergetool.sh | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/git-mergetool.sh b/git-mergetool.sh index a44afd3822..12c3e83aa7 100755 --- a/git-mergetool.sh +++ b/git-mergetool.sh @@ -243,9 +243,16 @@ auto_merge () { git merge-file --diff3 --marker-size=7 -q -p "$LOCAL" "$BASE" "$REMOTE" >"$DIFF3" if test -s "$DIFF3" then - sed -e '/^<<<<<<< /,/^||||||| /d' -e '/^=======\r\?$/,/^>>>>>>> /d' "$DIFF3" >"$BASE" - sed -e '/^||||||| /,/^>>>>>>> /d' -e '/^<<<<<<< /d' "$DIFF3" >"$LOCAL" - sed -e '/^<<<<<<< /,/^=======\r\?$/d' -e '/^>>>>>>> /d' "$DIFF3" >"$REMOTE" + cr=$(printf '\x0d') + sed -e '/^<<<<<<< /,/^||||||| /d' \ + -e "/^=======$cr\{0,1\}$/,/^>>>>>>> /d" \ + "$DIFF3" >"$BASE" + sed -e '/^||||||| /,/^>>>>>>> /d' \ + -e '/^<<<<<<< /d' \ + "$DIFF3" >"$LOCAL" + sed -e "/^<<<<<<< /,/^=======$cr\{0,1\}$/d" \ + -e '/^>>>>>>> /d' \ + "$DIFF3" >"$REMOTE" fi rm -- "$DIFF3" } -- 2.30.0.rc1.6.g2bc636d1d6 ^ permalink raw reply related [flat|nested] 24+ messages in thread
* Re: [PATCH] fixup! mergetool: add automerge configuration 2021-01-09 21:49 [PATCH] fixup! mergetool: add automerge configuration David Aguilar @ 2021-01-09 21:59 ` brian m. carlson 2021-01-09 22:42 ` [PATCH v2] " David Aguilar 2021-01-09 23:21 ` [PATCH] " Junio C Hamano 0 siblings, 2 replies; 24+ messages in thread From: brian m. carlson @ 2021-01-09 21:59 UTC (permalink / raw) To: David Aguilar; +Cc: Junio C Hamano, Seth House, Felipe Contreras, git [-- Attachment #1: Type: text/plain, Size: 1711 bytes --] On 2021-01-09 at 21:49:22, David Aguilar wrote: > The use of "\r\?" in sed is not portable to macOS and possibly > other unix flavors. > > Replace "\r" with a substituted variable that contains "\r". > Replace "\?" with "\{0,1\}". Ah, yes, this is true. The statement about "\r" is also true for Linux with POSIXLY_CORRECT, IIRC. > Signed-off-by: David Aguilar <davvid@gmail.com> > --- > This is based on top of fc/mergetool-automerge and can be squashed in > (with the addition of my sign-off) if desired. > > Let me know if you'd prefer a separate patch. I figured we'd want > a squash to preserve bisectability. > > git-mergetool.sh | 13 ++++++++++--- > 1 file changed, 10 insertions(+), 3 deletions(-) > > diff --git a/git-mergetool.sh b/git-mergetool.sh > index a44afd3822..12c3e83aa7 100755 > --- a/git-mergetool.sh > +++ b/git-mergetool.sh > @@ -243,9 +243,16 @@ auto_merge () { > git merge-file --diff3 --marker-size=7 -q -p "$LOCAL" "$BASE" "$REMOTE" >"$DIFF3" > if test -s "$DIFF3" > then > - sed -e '/^<<<<<<< /,/^||||||| /d' -e '/^=======\r\?$/,/^>>>>>>> /d' "$DIFF3" >"$BASE" > - sed -e '/^||||||| /,/^>>>>>>> /d' -e '/^<<<<<<< /d' "$DIFF3" >"$LOCAL" > - sed -e '/^<<<<<<< /,/^=======\r\?$/d' -e '/^>>>>>>> /d' "$DIFF3" >"$REMOTE" > + cr=$(printf '\x0d') Unfortunately, printf is not specified by POSIX to take hex escapes, so this, too is nonportable. We are unfortunately allowed to use only octal escapes (yuck). However, we can write this: cr=$(printf '\r') or cr=$(printf '\015') I think the former is clearer, since that's what we were writing before. -- brian m. carlson (he/him or they/them) Houston, Texas, US [-- Attachment #2: signature.asc --] [-- Type: application/pgp-signature, Size: 263 bytes --] ^ permalink raw reply [flat|nested] 24+ messages in thread
* [PATCH v2] fixup! mergetool: add automerge configuration 2021-01-09 21:59 ` brian m. carlson @ 2021-01-09 22:42 ` David Aguilar 2021-01-09 22:54 ` Seth House 2021-01-09 23:18 ` Junio C Hamano 2021-01-09 23:21 ` [PATCH] " Junio C Hamano 1 sibling, 2 replies; 24+ messages in thread From: David Aguilar @ 2021-01-09 22:42 UTC (permalink / raw) To: Junio C Hamano, Seth House, Felipe Contreras, brian m. carlson; +Cc: git "\r\?" in sed is not portable to macOS and possibly others. "\r" is not valid on Linux with POSIXLY_CORRECT. Replace "\r" with a substituted variable that contains "\r". Replace "\?" with "\{0,1\}". Helped-by: brian m. carlson <sandals@crustytoothpaste.net> Signed-off-by: David Aguilar <davvid@gmail.com> --- This is based on top of fc/mergetool-automerge and can be squashed in (with the addition of my sign-off) if desired. Changes since last time: - printf '\r' instead of printf '\x0d' - The commit message now mentions POSIXLY_CORRECT. git-mergetool.sh | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/git-mergetool.sh b/git-mergetool.sh index a44afd3822..9029a79431 100755 --- a/git-mergetool.sh +++ b/git-mergetool.sh @@ -243,9 +243,16 @@ auto_merge () { git merge-file --diff3 --marker-size=7 -q -p "$LOCAL" "$BASE" "$REMOTE" >"$DIFF3" if test -s "$DIFF3" then - sed -e '/^<<<<<<< /,/^||||||| /d' -e '/^=======\r\?$/,/^>>>>>>> /d' "$DIFF3" >"$BASE" - sed -e '/^||||||| /,/^>>>>>>> /d' -e '/^<<<<<<< /d' "$DIFF3" >"$LOCAL" - sed -e '/^<<<<<<< /,/^=======\r\?$/d' -e '/^>>>>>>> /d' "$DIFF3" >"$REMOTE" + cr=$(printf '\r') + sed -e '/^<<<<<<< /,/^||||||| /d' \ + -e "/^=======$cr\{0,1\}$/,/^>>>>>>> /d" \ + "$DIFF3" >"$BASE" + sed -e '/^||||||| /,/^>>>>>>> /d' \ + -e '/^<<<<<<< /d' \ + "$DIFF3" >"$LOCAL" + sed -e "/^<<<<<<< /,/^=======$cr\{0,1\}$/d" \ + -e '/^>>>>>>> /d' \ + "$DIFF3" >"$REMOTE" fi rm -- "$DIFF3" } -- 2.30.0.rc1.6.g3f22546b2b.dirty ^ permalink raw reply related [flat|nested] 24+ messages in thread
* Re: [PATCH v2] fixup! mergetool: add automerge configuration 2021-01-09 22:42 ` [PATCH v2] " David Aguilar @ 2021-01-09 22:54 ` Seth House 2021-01-10 1:17 ` Junio C Hamano 2021-01-09 23:18 ` Junio C Hamano 1 sibling, 1 reply; 24+ messages in thread From: Seth House @ 2021-01-09 22:54 UTC (permalink / raw) To: David Aguilar; +Cc: Junio C Hamano, Felipe Contreras, brian m. carlson, git On Sat, Jan 09, 2021 at 02:42:36PM -0800, David Aguilar wrote: > Replace "\r" with a substituted variable that contains "\r". > Replace "\?" with "\{0,1\}". Nice. I was (very slowly) converging on that as the culprit. Thanks for the elegant fix! I'm running the test suite on Windows and OSX (now that they're set up locally) with this included and I'll send a v10 once complete. ^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: [PATCH v2] fixup! mergetool: add automerge configuration 2021-01-09 22:54 ` Seth House @ 2021-01-10 1:17 ` Junio C Hamano 2021-01-10 6:40 ` Re* " Junio C Hamano 0 siblings, 1 reply; 24+ messages in thread From: Junio C Hamano @ 2021-01-10 1:17 UTC (permalink / raw) To: Seth House; +Cc: David Aguilar, Felipe Contreras, brian m. carlson, git Seth House <seth@eseth.com> writes: > On Sat, Jan 09, 2021 at 02:42:36PM -0800, David Aguilar wrote: >> Replace "\r" with a substituted variable that contains "\r". >> Replace "\?" with "\{0,1\}". > > Nice. I was (very slowly) converging on that as the culprit. Thanks for > the elegant fix! I'm running the test suite on Windows and OSX (now that > they're set up locally) with this included and I'll send a v10 once > complete. Note that the topic fails t7800.5 even with the fix-up (and without these fix-up on a platform with sed that do not need the portability fix-up). ^ permalink raw reply [flat|nested] 24+ messages in thread
* Re* [PATCH v2] fixup! mergetool: add automerge configuration 2021-01-10 1:17 ` Junio C Hamano @ 2021-01-10 6:40 ` Junio C Hamano 2021-01-10 7:29 ` Seth House 0 siblings, 1 reply; 24+ messages in thread From: Junio C Hamano @ 2021-01-10 6:40 UTC (permalink / raw) To: Seth House; +Cc: David Aguilar, Felipe Contreras, brian m. carlson, git Junio C Hamano <gitster@pobox.com> writes: > Seth House <seth@eseth.com> writes: > >> On Sat, Jan 09, 2021 at 02:42:36PM -0800, David Aguilar wrote: >>> Replace "\r" with a substituted variable that contains "\r". >>> Replace "\?" with "\{0,1\}". >> >> Nice. I was (very slowly) converging on that as the culprit. Thanks for >> the elegant fix! I'm running the test suite on Windows and OSX (now that >> they're set up locally) with this included and I'll send a v10 once >> complete. > > Note that the topic fails t7800.5 even with the fix-up (and without > these fix-up on a platform with sed that do not need the portability > fix-up). It seems that 51b27370 (mergetool: break setup_tool out into separate initialization function, 2020-12-28) is the culprit. git-difftool--helper is taught to do this: diff --git a/git-difftool--helper.sh b/git-difftool--helper.sh index 46af3e60b7..234dd6944e 100755 --- a/git-difftool--helper.sh +++ b/git-difftool--helper.sh ... @@ -79,6 +80,7 @@ if test -n "$GIT_DIFFTOOL_DIRDIFF" then LOCAL="$1" REMOTE="$2" + initialize_merge_tool "$merge_tool" && run_merge_tool "$merge_tool" false else # Launch the merge tool on each path provided by 'git diff' But the thing is, t7800.5 gives a name of merge-tool that does not exist, and expects difftool to notice it and error out. The callchain starting from the above "run_merge_tool" should look like run_merge_tool () { merge_tool_path=$(get_merge_tool_path ...) || exit ... which in turn calls get_merge_tool_path () { # A merge tool has been set, so verify that it's valid. merge_tool="$1" if ! valid_tool "$merge_tool" then echo >&2 "Unknown merge tool $merge_tool" exit 1 fi and "valid_tool bad-tool" would return false, which lets us safely exit with the error message. But the call to initialize_merge_tool inserted above, that makes us to SKIP the call to run_merge_tool, would defeat the error detection. An ugly workaround patch that caters only to difftool breakage is attached at the end; I did not look if a similar treatment is necessary for the mergetool side. By the way, debugging this was somewhat painful as difftool is partly rewritten in C. If it were still pure script, it would have been a lot easier to diagnose with a single "set -x" somewhere X-<. ----- >8 ---------- >8 ---------- >8 ---------- >8 ----- From: Junio C Hamano <gitster@pobox.com> Date: Sat, 9 Jan 2021 22:35:18 -0800 Subject: [PATCH] fixup! mergetool: break setup_tool out into separate initialization function At least difftool wants to see even a broken tool name in its call to run_merge_tool and have it diagnose an error. &&-cascading the call to initialize_merge_tool and run_merge_tool means that a bogus tool name that does not please initialize_merge_tool is not even seen by run_merge_tool and the error goes unnoticed. I didn't audit the original commit for its use of initialize_merge_tool on the merge-tool side. It may share the same issue, or it may not. This should fix the errors we've been seeing in t7800.5 (and possibly others) with this topic. --- git-difftool--helper.sh | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/git-difftool--helper.sh b/git-difftool--helper.sh index 234dd6944e..992124cc67 100755 --- a/git-difftool--helper.sh +++ b/git-difftool--helper.sh @@ -61,7 +61,9 @@ launch_merge_tool () { export BASE eval $GIT_DIFFTOOL_EXTCMD '"$LOCAL"' '"$REMOTE"' else - initialize_merge_tool "$merge_tool" && + initialize_merge_tool "$merge_tool" + # ignore the error from the above --- run_merge_tool + # will diagnose unusable tool by itself run_merge_tool "$merge_tool" fi } @@ -80,7 +82,9 @@ if test -n "$GIT_DIFFTOOL_DIRDIFF" then LOCAL="$1" REMOTE="$2" - initialize_merge_tool "$merge_tool" && + initialize_merge_tool "$merge_tool" + # ignore the error from the above --- run_merge_tool + # will diagnose unusable tool by itself run_merge_tool "$merge_tool" false else # Launch the merge tool on each path provided by 'git diff' -- 2.30.0-311-g8a3956654a ^ permalink raw reply related [flat|nested] 24+ messages in thread
* Re: Re* [PATCH v2] fixup! mergetool: add automerge configuration 2021-01-10 6:40 ` Re* " Junio C Hamano @ 2021-01-10 7:29 ` Seth House 2021-01-10 11:24 ` Junio C Hamano 0 siblings, 1 reply; 24+ messages in thread From: Seth House @ 2021-01-10 7:29 UTC (permalink / raw) To: Junio C Hamano; +Cc: David Aguilar, Felipe Contreras, brian m. carlson, git On Sat, Jan 09, 2021 at 10:40:20PM -0800, Junio C Hamano wrote: > An ugly workaround patch that caters only to difftool breakage is > attached at the end; I did not look if a similar treatment is > necessary for the mergetool side. That fixup does the trick on my machine too. Thank you. How wary are you of continuing with `initialize_merge_tool`? Do you see a better approach to get `automerge_enabled `into scope? While it is a nice feature to have, is it worth the risk vs. reward? ^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: Re* [PATCH v2] fixup! mergetool: add automerge configuration 2021-01-10 7:29 ` Seth House @ 2021-01-10 11:24 ` Junio C Hamano 2021-01-16 4:24 ` Seth House 0 siblings, 1 reply; 24+ messages in thread From: Junio C Hamano @ 2021-01-10 11:24 UTC (permalink / raw) To: Seth House; +Cc: David Aguilar, Felipe Contreras, brian m. carlson, git Seth House <seth@eseth.com> writes: > On Sat, Jan 09, 2021 at 10:40:20PM -0800, Junio C Hamano wrote: >> An ugly workaround patch that caters only to difftool breakage is >> attached at the end; I did not look if a similar treatment is >> necessary for the mergetool side. > > That fixup does the trick on my machine too. Thank you. Note that with t7800 fixed with the patch, non Windows jobs all seem to pass, but t7610 seems to have problem(s) on Windows. https://github.com/git/git/runs/1675932107?check_suite_focus=true#step:7:10373 > How wary are you of continuing with `initialize_merge_tool`? Do you see > a better approach to get `automerge_enabled `into scope? While it is > a nice feature to have, is it worth the risk vs. reward? Hmph. We need to have a way to define helper routines customized for the tool, and in the codebase without this series, it is the job for setup_tool. It defines fallback implementations, allows tool specific customizations. Your initialize_merge_tool is just a thin wrapper around setup_tool. It calls setup_tool, and if the function exits with non-zero status, returns with status==1 (and otherwise returns with status==0). As I expect all the callers of setup_tool or initialize_merge_tool would either ignore the status or check if it succeeded (i.e. compare $? against 0 and any non-zero values are treated equally), it does not seem to do anything useful. I think we may be able to get rid of initialize_merge_tool, but you would need to call setup_tool in places initialize_merge_tool was called in your patch, as you must have needed to make sure that the tool specific customizations have been carried out before going forward in these places. So, no, I do not see a reason to be wary of initialize/setup. With or without the seemingly needless initialize wrapper, I think calling setup before starting to do certain operations that need tool specific customization is just necessary. The same machanism has been in use to give can_merge/can_diff to each tool and the way it works ought to be fairly well understood. It is a different story if it makes sense not to exit when you see failure from initialize/setup, and instead _skip_ running helpers like run_merge_tool. It was just a mistake we all make every once in a while (i.e. a bug), and I am reasonably sure that we will introduce more of them but we will be capable of fixing all. Thanks. ^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: Re* [PATCH v2] fixup! mergetool: add automerge configuration 2021-01-10 11:24 ` Junio C Hamano @ 2021-01-16 4:24 ` Seth House 2021-01-20 23:24 ` automerge implementation ideas for Windows Seth House 2021-01-22 2:50 ` Re* [PATCH v2] fixup! mergetool: add automerge configuration brian m. carlson 0 siblings, 2 replies; 24+ messages in thread From: Seth House @ 2021-01-16 4:24 UTC (permalink / raw) To: Junio C Hamano; +Cc: David Aguilar, Felipe Contreras, brian m. carlson, git On Sun, Jan 10, 2021 at 03:24:48AM -0800, Junio C Hamano wrote: > Note that with t7800 fixed with the patch, non Windows jobs all seem > to pass, but t7610 seems to have problem(s) on Windows. The autocrlf test is breaking because the sed that ships with some mingw versions (and also some minsys and cygwin versions) will *automatically* remove carriage returns: $ printf 'foo\r\nbar\r\n' | sed -e '/bar/d' | cat -A foo$ $ printf 'foo\r\nbar\r\n' | sed -b -e '/bar/d' | cat -A foo^M$ (Note: the -b flag above is just for comparison. We can't use it here. It's not in POSIX and is not present in sed for busybox or OSX.) I haven't found official docs that describe this behavior yet but I found a few discussions about it across a few lists. E.g.: https://cygwin.com/pipermail/cygwin/2017-June/233121.html Suggestions welcome. Obviously we could try to detect crlf's before the sed and then try to re-add them back in after sed but that strikes me as error-prone. I recall someone mentioning calling merge-file twice, once with --ours and once with --theirs, to independently generate each "side" of the conflict instead of using sed to split MERGED. Is that a viable approach? ^ permalink raw reply [flat|nested] 24+ messages in thread
* automerge implementation ideas for Windows 2021-01-16 4:24 ` Seth House @ 2021-01-20 23:24 ` Seth House 2021-01-21 22:50 ` Junio C Hamano 2021-01-22 2:50 ` Re* [PATCH v2] fixup! mergetool: add automerge configuration brian m. carlson 1 sibling, 1 reply; 24+ messages in thread From: Seth House @ 2021-01-20 23:24 UTC (permalink / raw) To: Junio C Hamano; +Cc: David Aguilar, Felipe Contreras, brian m. carlson, git On Fri, Jan 15, 2021 at 09:24:59PM -0700, Seth House wrote: > The autocrlf test is breaking because the sed that ships with some mingw > versions (and also some minsys and cygwin versions) will *automatically* > remove carriage returns: So the mingw builds of both sed and awk change carriage returns. So far I haven't found documentation on it so I'm not aware of a portable way to disable the behavior. Instead I've been playing with alternate approaches. The two patches below work and pass the autocrlf test on Windows, however they are first-draft implementations. Feedback welcome. One other point of discussion: I would like to change the name of this feature. "Automerge" is a bit of an overloaded term and, IMO, doesn't describe this feature very well. Several of the GUI diff programs have a feature that they call "automerge" or "auto merge", and there's a flag for Meld already in Git called "mergetool.meld.useAutoMerge" which could cause confusion. Instead, I'd like to propose "mergetool.hideResolved" or the more verbose "mergetool.hideResolvedConflicts" as the name. We're not really merging anything (Git aleady did that before the mergetool is invoked), but rather we're just not showing any conflicts that Git was already able to resolve. ---------->8--------->8--------->8--------->8------- #1: Use POSIX read and a while loop to emulate an awk-like approach: diff --git a/git-mergetool.sh b/git-mergetool.sh index 246d6b76fc..94728dd518 100755 --- a/git-mergetool.sh +++ b/git-mergetool.sh @@ -240,19 +240,46 @@ checkout_staged_file () { } auto_merge () { + C0="<<<<<<< " + C1="||||||| " + C2="=======" + C3=">>>>>>> " + inl=0 + inb=0 + inr=0 + git merge-file --diff3 --marker-size=7 -q -p "$LOCAL" "$BASE" "$REMOTE" >"$DIFF3" + if test -s "$DIFF3" then - C0="^<<<<<<< " - C1="^||||||| " - C2="^=======$(printf '\015')\{0,1\}$" - C3="^>>>>>>> " - - sed -e "/$C0/,/$C1/d" -e "/$C2/,/$C3/d" "$DIFF3" >"$BASE" - sed -e "/$C1/,/$C3/d" -e "/$C0/d" "$DIFF3" >"$LOCAL" - sed -e "/$C0/,/$C2/d" -e "/$C3/d" "$DIFF3" >"$REMOTE" + touch "$LCONFL" "$BCONFL" "$RCONFL" + + while read -r line + do + case $line in + $C0*) inl=1; continue ;; + $C1*) inl=0; inb=1; continue ;; + $C2*) inb=0; inr=1; continue ;; + $C3*) inr=0; continue ;; + esac + + case 1 in + $inl) printf '%s\n' "$line" >>"$LCONFL" ;; + $inb) printf '%s\n' "$line" >>"$BCONFL" ;; + $inr) printf '%s\n' "$line" >>"$RCONFL" ;; + *) + printf '%s\n' "$line" >>"$LCONFL" + printf '%s\n' "$line" >>"$BCONFL" + printf '%s\n' "$line" >>"$RCONFL" + ;; + esac + done < "$DIFF3" + + mv -- "$LCONFL" "$LOCAL" + mv -- "$BCONFL" "$BASE" + mv -- "$RCONFL" "$REMOTE" + rm -- "$DIFF3" fi - rm -- "$DIFF3" } merge_file () { @@ -295,8 +322,11 @@ merge_file () { DIFF3="$MERGETOOL_TMPDIR/${BASE}_DIFF3_$$$ext" BACKUP="$MERGETOOL_TMPDIR/${BASE}_BACKUP_$$$ext" LOCAL="$MERGETOOL_TMPDIR/${BASE}_LOCAL_$$$ext" + LCONFL="$MERGETOOL_TMPDIR/${BASE}_LOCAL_LCONFL_$$$ext" REMOTE="$MERGETOOL_TMPDIR/${BASE}_REMOTE_$$$ext" + RCONFL="$MERGETOOL_TMPDIR/${BASE}_REMOTE_RCONFL_$$$ext" BASE="$MERGETOOL_TMPDIR/${BASE}_BASE_$$$ext" + BCONFL="$MERGETOOL_TMPDIR/${BASE}_BASE_BCONFL_$$$ext" base_mode= local_mode= remote_mode= ---------->8--------->8--------->8--------->8------- #2: Call merge-file twice: A much simpler implementation but probably less performant. Is it enough to matter? diff --git a/git-mergetool.sh b/git-mergetool.sh index 246d6b76fc..1cb45a7437 100755 --- a/git-mergetool.sh +++ b/git-mergetool.sh @@ -240,19 +240,10 @@ checkout_staged_file () { } auto_merge () { - git merge-file --diff3 --marker-size=7 -q -p "$LOCAL" "$BASE" "$REMOTE" >"$DIFF3" - if test -s "$DIFF3" - then - C0="^<<<<<<< " - C1="^||||||| " - C2="^=======$(printf '\015')\{0,1\}$" - C3="^>>>>>>> " - - sed -e "/$C0/,/$C1/d" -e "/$C2/,/$C3/d" "$DIFF3" >"$BASE" - sed -e "/$C1/,/$C3/d" -e "/$C0/d" "$DIFF3" >"$LOCAL" - sed -e "/$C0/,/$C2/d" -e "/$C3/d" "$DIFF3" >"$REMOTE" - fi - rm -- "$DIFF3" + git merge-file --ours -q -p "$LOCAL" "$BASE" "$REMOTE" >"$LCONFL" + git merge-file --theirs -q -p "$LOCAL" "$BASE" "$REMOTE" >"$RCONFL" + mv -- "$LCONFL" "$LOCAL" + mv -- "$RCONFL" "$REMOTE" } merge_file () { @@ -295,7 +286,9 @@ merge_file () { DIFF3="$MERGETOOL_TMPDIR/${BASE}_DIFF3_$$$ext" BACKUP="$MERGETOOL_TMPDIR/${BASE}_BACKUP_$$$ext" LOCAL="$MERGETOOL_TMPDIR/${BASE}_LOCAL_$$$ext" + LCONFL="$MERGETOOL_TMPDIR/${BASE}_LOCAL_LCONFL_$$$ext" REMOTE="$MERGETOOL_TMPDIR/${BASE}_REMOTE_$$$ext" + RCONFL="$MERGETOOL_TMPDIR/${BASE}_REMOTE_RCONFL_$$$ext" BASE="$MERGETOOL_TMPDIR/${BASE}_BASE_$$$ext" base_mode= local_mode= remote_mode= ^ permalink raw reply related [flat|nested] 24+ messages in thread
* Re: automerge implementation ideas for Windows 2021-01-20 23:24 ` automerge implementation ideas for Windows Seth House @ 2021-01-21 22:50 ` Junio C Hamano 2021-01-22 1:09 ` Seth House 0 siblings, 1 reply; 24+ messages in thread From: Junio C Hamano @ 2021-01-21 22:50 UTC (permalink / raw) To: Seth House; +Cc: David Aguilar, Felipe Contreras, brian m. carlson, git Seth House <seth@eseth.com> writes: > One other point of discussion: I would like to change the name of this > feature. "Automerge" is a bit of an overloaded term and, IMO, doesn't > describe this feature very well. Several of the GUI diff programs have > a feature that they call "automerge" or "auto merge", and there's a flag > for Meld already in Git called "mergetool.meld.useAutoMerge" which could > cause confusion. > > Instead, I'd like to propose "mergetool.hideResolved" or the more > verbose "mergetool.hideResolvedConflicts" as the name. We're not really > merging anything (Git aleady did that before the mergetool is invoked), > but rather we're just not showing any conflicts that Git was already > able to resolve. I have no objetion. I didn't think 'automerge' was bad, but it probably is too broad a word as you discuss in the above. "hide resolved" sounds like the name that describes what it does quite well. > #1: Use POSIX read and a while loop to emulate an awk-like approach: I'd rather not to see us do "text processing" in shell, especially with "read -r". I just do not trust it (even with the "-r" option). Having said that, I am not familiar enough to the Windows environment to know what is trustworthy and what is not (apparently, things like "sed" that I would intuitively place as much trust as anything else is giving us so much trouble out of box), so I'll shut up and listen to others. ^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: automerge implementation ideas for Windows 2021-01-21 22:50 ` Junio C Hamano @ 2021-01-22 1:09 ` Seth House 2021-01-22 2:26 ` Junio C Hamano 0 siblings, 1 reply; 24+ messages in thread From: Seth House @ 2021-01-22 1:09 UTC (permalink / raw) To: Junio C Hamano; +Cc: David Aguilar, Felipe Contreras, brian m. carlson, git On Thu, Jan 21, 2021 at 02:50:12PM -0800, Junio C Hamano wrote: > I'd rather not to see us do "text processing" in shell Agreed. What are your thoughts on the #2 approach? I noticed the comment in `git/xdiff-interface.h` about xdiff's gigabyte limit so I created a 973 MB text file with a conflict and ran #2 through a few mergetools to see how it went. I put /usr/bin/time in front of the two `git merge-file` invocations. I know one person's machine is not a benchmark but perhaps it's a discussion point? Each `git merge-file` call took ~11 seconds on my middle-tier laptop and did not use enough RAM to hit swap. Writing the near-gigabyte LOCAL, BASE, REMOTE, & BACKUP files went pretty quick. The mergetools themselves had mixed results: - vimdiff took several minutes (and a lot of swap) to open all four files but did eventually work. - tkdiff crashed. - Meld spun for ~10 minutes and never opened. My takeaway: when trying to use a mergetool on a very large file, the two `git merge-file` invocations are not likely to be where the performance concern is. #2 is my preferred approach so far. ^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: automerge implementation ideas for Windows 2021-01-22 1:09 ` Seth House @ 2021-01-22 2:26 ` Junio C Hamano 0 siblings, 0 replies; 24+ messages in thread From: Junio C Hamano @ 2021-01-22 2:26 UTC (permalink / raw) To: Seth House; +Cc: David Aguilar, Felipe Contreras, brian m. carlson, git Seth House <seth@eseth.com> writes: > On Thu, Jan 21, 2021 at 02:50:12PM -0800, Junio C Hamano wrote: >> I'd rather not to see us do "text processing" in shell > > Agreed. What are your thoughts on the #2 approach? > > I noticed the comment in `git/xdiff-interface.h` about xdiff's gigabyte > limit so I created a 973 MB text file with a conflict and ran #2 through > a few mergetools to see how it went. I put /usr/bin/time in front of the > two `git merge-file` invocations. I know one person's machine is not > a benchmark but perhaps it's a discussion point? > > Each `git merge-file` call took ~11 seconds on my middle-tier laptop and > did not use enough RAM to hit swap. > > Writing the near-gigabyte LOCAL, BASE, REMOTE, & BACKUP files went > pretty quick. The mergetools themselves had mixed results: > > - vimdiff took several minutes (and a lot of swap) to open all four > files but did eventually work. > - tkdiff crashed. > - Meld spun for ~10 minutes and never opened. > > My takeaway: when trying to use a mergetool on a very large file, the > two `git merge-file` invocations are not likely to be where the > performance concern is. #2 is my preferred approach so far. Yeah, I am no expert about Windows, but at least I know how well "git merge-file" should work _anywhere_ (as opposed to "read -r" plus shell loop that I would not trust on a platform where even basic things like "sed" behaves differently from what we expect X-<), so from that point of view, it is vastly more preferrable, if the choices were only between #1 and #2. ^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: Re* [PATCH v2] fixup! mergetool: add automerge configuration 2021-01-16 4:24 ` Seth House 2021-01-20 23:24 ` automerge implementation ideas for Windows Seth House @ 2021-01-22 2:50 ` brian m. carlson 2021-01-22 16:29 ` Johannes Schindelin 1 sibling, 1 reply; 24+ messages in thread From: brian m. carlson @ 2021-01-22 2:50 UTC (permalink / raw) To: Seth House; +Cc: Junio C Hamano, David Aguilar, Felipe Contreras, git [-- Attachment #1: Type: text/plain, Size: 1128 bytes --] On 2021-01-16 at 04:24:54, Seth House wrote: > On Sun, Jan 10, 2021 at 03:24:48AM -0800, Junio C Hamano wrote: > > Note that with t7800 fixed with the patch, non Windows jobs all seem > > to pass, but t7610 seems to have problem(s) on Windows. > > The autocrlf test is breaking because the sed that ships with some mingw > versions (and also some minsys and cygwin versions) will *automatically* > remove carriage returns: > > $ printf 'foo\r\nbar\r\n' | sed -e '/bar/d' | cat -A > foo$ > > $ printf 'foo\r\nbar\r\n' | sed -b -e '/bar/d' | cat -A > foo^M$ > > (Note: the -b flag above is just for comparison. We can't use it here. > It's not in POSIX and is not present in sed for busybox or OSX.) Can you report this as a bug? This behavior isn't compliant with POSIX and it makes it really hard for folks to write portable code if these versions implement POSIX utilities in a nonstandard way. As a non-Windows user, I have no hope of writing code that works on Windows if we can't rely on our standard utilities working properly. -- brian m. carlson (he/him or they/them) Houston, Texas, US [-- Attachment #2: signature.asc --] [-- Type: application/pgp-signature, Size: 263 bytes --] ^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: Re* [PATCH v2] fixup! mergetool: add automerge configuration 2021-01-22 2:50 ` Re* [PATCH v2] fixup! mergetool: add automerge configuration brian m. carlson @ 2021-01-22 16:29 ` Johannes Schindelin 2021-01-22 23:25 ` brian m. carlson 0 siblings, 1 reply; 24+ messages in thread From: Johannes Schindelin @ 2021-01-22 16:29 UTC (permalink / raw) To: brian m. carlson Cc: Seth House, Junio C Hamano, David Aguilar, Felipe Contreras, git Hi brian, On Fri, 22 Jan 2021, brian m. carlson wrote: > On 2021-01-16 at 04:24:54, Seth House wrote: > > On Sun, Jan 10, 2021 at 03:24:48AM -0800, Junio C Hamano wrote: > > > Note that with t7800 fixed with the patch, non Windows jobs all seem > > > to pass, but t7610 seems to have problem(s) on Windows. > > > > The autocrlf test is breaking because the sed that ships with some mingw > > versions (and also some minsys and cygwin versions) will *automatically* > > remove carriage returns: > > > > $ printf 'foo\r\nbar\r\n' | sed -e '/bar/d' | cat -A > > foo$ > > > > $ printf 'foo\r\nbar\r\n' | sed -b -e '/bar/d' | cat -A > > foo^M$ > > > > (Note: the -b flag above is just for comparison. We can't use it here. > > It's not in POSIX and is not present in sed for busybox or OSX.) > > Can you report this as a bug? This behavior isn't compliant with POSIX > and it makes it really hard for folks to write portable code if these > versions implement POSIX utilities in a nonstandard way. As a > non-Windows user, I have no hope of writing code that works on Windows > if we can't rely on our standard utilities working properly. I fear that the Windows-based tools do the correct thing, though: they are meant to process _text_, and newlines are supposed to be platform-dependent in text. From that perspective, it sounds to me as if we're trying to ask `sed` to do something it was not designed to do: binary editing. Ciao, Dscho ^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: Re* [PATCH v2] fixup! mergetool: add automerge configuration 2021-01-22 16:29 ` Johannes Schindelin @ 2021-01-22 23:25 ` brian m. carlson 2021-01-26 14:32 ` Johannes Schindelin 0 siblings, 1 reply; 24+ messages in thread From: brian m. carlson @ 2021-01-22 23:25 UTC (permalink / raw) To: Johannes Schindelin Cc: Seth House, Junio C Hamano, David Aguilar, Felipe Contreras, git [-- Attachment #1: Type: text/plain, Size: 1997 bytes --] On 2021-01-22 at 16:29:46, Johannes Schindelin wrote: > Hi brian, > > On Fri, 22 Jan 2021, brian m. carlson wrote: > > > On 2021-01-16 at 04:24:54, Seth House wrote: > > > The autocrlf test is breaking because the sed that ships with some mingw > > > versions (and also some minsys and cygwin versions) will *automatically* > > > remove carriage returns: > > > > > > $ printf 'foo\r\nbar\r\n' | sed -e '/bar/d' | cat -A > > > foo$ > > > > > > $ printf 'foo\r\nbar\r\n' | sed -b -e '/bar/d' | cat -A > > > foo^M$ > > > > > > (Note: the -b flag above is just for comparison. We can't use it here. > > > It's not in POSIX and is not present in sed for busybox or OSX.) > > > > Can you report this as a bug? This behavior isn't compliant with POSIX > > and it makes it really hard for folks to write portable code if these > > versions implement POSIX utilities in a nonstandard way. As a > > non-Windows user, I have no hope of writing code that works on Windows > > if we can't rely on our standard utilities working properly. > > I fear that the Windows-based tools do the correct thing, though: they are > meant to process _text_, and newlines are supposed to be > platform-dependent in text. Ah, but POSIX gives a very specific meaning to "newline", and it refers to a single byte. If you want tools that process CRLF line endings like that, then that should be opt-in as either different tools or additional options, not the default behavior of a POSIX tool. This behavior is not conforming to POSIX and it is therefore a defect. > From that perspective, it sounds to me as if we're trying to ask `sed` to > do something it was not designed to do: binary editing. Most Windows tools are perfectly capable of handling LF line endings. Even the famously incapable Notepad can now handle LF without CR. With the advent of WSL, handling LF line endings is now pretty much required. -- brian m. carlson (he/him or they/them) Houston, Texas, US [-- Attachment #2: signature.asc --] [-- Type: application/pgp-signature, Size: 263 bytes --] ^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: Re* [PATCH v2] fixup! mergetool: add automerge configuration 2021-01-22 23:25 ` brian m. carlson @ 2021-01-26 14:32 ` Johannes Schindelin 2021-01-26 18:06 ` Seth House 0 siblings, 1 reply; 24+ messages in thread From: Johannes Schindelin @ 2021-01-26 14:32 UTC (permalink / raw) To: brian m. carlson Cc: Seth House, Junio C Hamano, David Aguilar, Felipe Contreras, git Hi brian, On Fri, 22 Jan 2021, brian m. carlson wrote: > On 2021-01-22 at 16:29:46, Johannes Schindelin wrote: > > > > On Fri, 22 Jan 2021, brian m. carlson wrote: > > > > > On 2021-01-16 at 04:24:54, Seth House wrote: > > > > The autocrlf test is breaking because the sed that ships with some mingw > > > > versions (and also some minsys and cygwin versions) will *automatically* > > > > remove carriage returns: > > > > > > > > $ printf 'foo\r\nbar\r\n' | sed -e '/bar/d' | cat -A > > > > foo$ > > > > > > > > $ printf 'foo\r\nbar\r\n' | sed -b -e '/bar/d' | cat -A > > > > foo^M$ > > > > > > > > (Note: the -b flag above is just for comparison. We can't use it here. > > > > It's not in POSIX and is not present in sed for busybox or OSX.) > > > > > > Can you report this as a bug? This behavior isn't compliant with POSIX > > > and it makes it really hard for folks to write portable code if these > > > versions implement POSIX utilities in a nonstandard way. As a > > > non-Windows user, I have no hope of writing code that works on Windows > > > if we can't rely on our standard utilities working properly. > > > > I fear that the Windows-based tools do the correct thing, though: they are > > meant to process _text_, and newlines are supposed to be > > platform-dependent in text. > > Ah, but POSIX gives a very specific meaning to "newline", and it refers > to a single byte. If you want tools that process CRLF line endings like > that, then that should be opt-in as either different tools or additional > options, not the default behavior of a POSIX tool. This behavior is not > conforming to POSIX and it is therefore a defect. If we needed another reminder that we never say "It's in POSIX; we'll happily ignore your needs should your system not conform to it." (https://github.com/git/git/blob/v2.30.0/Documentation/CodingGuidelines), then we have it right here ;-) > > From that perspective, it sounds to me as if we're trying to ask `sed` to > > do something it was not designed to do: binary editing. > > Most Windows tools are perfectly capable of handling LF line endings. > Even the famously incapable Notepad can now handle LF without CR. With > the advent of WSL, handling LF line endings is now pretty much required. I have two comments on that: 1. We could spend a splendid time questioning MSYS2's (and before that, MSys') choices regarding newlines, but I think we can spend that time a lot better. 2. Newer software _seems_ to handle LF line endings just fine. And the `sed` invocation you mentioned above does so: it groks input delimited by Line Feed as newline characters. That does not mean that its output is LF-only by default. I seem to remember that recent Visual Studio versions did something similar: happily read an LF-only `.xml` file, but then write out a modified version using CR/LF. Would I wish that Windows used LF-only instead of CR/LF, just like macOS switched away from CR-only to LF-only after MacOS 9? Sure I do. It would remove quite a few obstacles in my daily work. Can I do anything about it? No. So I'd rather see `git mergetool` be turned into a portable C program, or alternatively using a built-in helper that _is_ written in C, to perform that desired text munging instead of losing the battle to the challenge of cross-platform, advanced text processing in pure shell script. Ciao, Dscho ^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: Re* [PATCH v2] fixup! mergetool: add automerge configuration 2021-01-26 14:32 ` Johannes Schindelin @ 2021-01-26 18:06 ` Seth House 2021-01-26 20:10 ` Junio C Hamano 0 siblings, 1 reply; 24+ messages in thread From: Seth House @ 2021-01-26 18:06 UTC (permalink / raw) To: Johannes Schindelin Cc: brian m. carlson, Junio C Hamano, David Aguilar, Felipe Contreras, git On Tue, Jan 26, 2021 at 03:32:13PM +0100, Johannes Schindelin wrote: > So I'd rather see `git mergetool` be turned into a portable C program, or > alternatively using a built-in helper that _is_ written in C, to perform > that desired text munging I tend to agree. Though my personal preference is Cygwin's (eventual) approach, I can appreciate the arguments made by the MSYS2 folk. But setting that aside, IMO, the ideal place to handle this would be the same place where the conflict markers are written in the first place, xmerge.c if my limited C literacy is correct. I don't see a big distinction between writing a single file with conflict markers and writing two, diff-able files with each "side" of the conflict -- they're ultimately two different formats for expressing the same information. That would give us the portability you described and the (pretty amazing) performance that merge-file already enjoys. :) I'm more than happy with calling merge-file twice for now. A future C optimisation, perhaps exposed via merge-file as a new (e.g.) --write-conflict-files flag, would be even more awesome. ^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: Re* [PATCH v2] fixup! mergetool: add automerge configuration 2021-01-26 18:06 ` Seth House @ 2021-01-26 20:10 ` Junio C Hamano 2021-01-27 3:37 ` Seth House 0 siblings, 1 reply; 24+ messages in thread From: Junio C Hamano @ 2021-01-26 20:10 UTC (permalink / raw) To: Seth House Cc: Johannes Schindelin, brian m. carlson, David Aguilar, Felipe Contreras, git Seth House <seth@eseth.com> writes: > On Tue, Jan 26, 2021 at 03:32:13PM +0100, Johannes Schindelin wrote: >> So I'd rather see `git mergetool` be turned into a portable C program, or >> alternatively using a built-in helper that _is_ written in C, to perform >> that desired text munging > > I tend to agree. Though my personal preference is Cygwin's (eventual) > approach, I can appreciate the arguments made by the MSYS2 folk. But > setting that aside, IMO, the ideal place to handle this would be the > same place where the conflict markers are written in the first place, > xmerge.c if my limited C literacy is correct. > > I don't see a big distinction between writing a single file with > conflict markers and writing two, diff-able files with each "side" of > the conflict -- they're ultimately two different formats for expressing > the same information. That would give us the portability you described > and the (pretty amazing) performance that merge-file already enjoys. :) > > I'm more than happy with calling merge-file twice for now. A future > C optimisation, perhaps exposed via merge-file as a new (e.g.) > --write-conflict-files flag, would be even more awesome. I am OK with that "two merge-file invocations, one with --ours and then another with --theirs" approach, as I already said in https://lore.kernel.org/git/xmqqh7n9aer5.fsf@gitster.c.googlers.com/ ^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: Re* [PATCH v2] fixup! mergetool: add automerge configuration 2021-01-26 20:10 ` Junio C Hamano @ 2021-01-27 3:37 ` Seth House 2021-01-29 0:41 ` Junio C Hamano 0 siblings, 1 reply; 24+ messages in thread From: Seth House @ 2021-01-27 3:37 UTC (permalink / raw) To: Junio C Hamano Cc: Johannes Schindelin, brian m. carlson, David Aguilar, Felipe Contreras, git On Tue, Jan 26, 2021 at 12:10:17PM -0800, Junio C Hamano wrote: > I am OK with that "two merge-file invocations, one with --ours and > then another with --theirs" approach, as I already said in > https://lore.kernel.org/git/xmqqh7n9aer5.fsf@gitster.c.googlers.com/ Sorry if it seemed like I left that thread hanging (busy week). Thanks for your reply(s). I'm finishing a v10 patchset with that change which I'll submit to the list for review this week. ^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: Re* [PATCH v2] fixup! mergetool: add automerge configuration 2021-01-27 3:37 ` Seth House @ 2021-01-29 0:41 ` Junio C Hamano 0 siblings, 0 replies; 24+ messages in thread From: Junio C Hamano @ 2021-01-29 0:41 UTC (permalink / raw) To: Seth House Cc: Johannes Schindelin, brian m. carlson, David Aguilar, Felipe Contreras, git Seth House <seth@eseth.com> writes: > Sorry if it seemed like I left that thread hanging (busy week). Thanks > for your reply(s). I'm finishing a v10 patchset with that change which > I'll submit to the list for review this week. Thanks. ^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: [PATCH v2] fixup! mergetool: add automerge configuration 2021-01-09 22:42 ` [PATCH v2] " David Aguilar 2021-01-09 22:54 ` Seth House @ 2021-01-09 23:18 ` Junio C Hamano 2021-01-10 1:52 ` Junio C Hamano 1 sibling, 1 reply; 24+ messages in thread From: Junio C Hamano @ 2021-01-09 23:18 UTC (permalink / raw) To: David Aguilar; +Cc: Seth House, Felipe Contreras, brian m. carlson, git David Aguilar <davvid@gmail.com> writes: > "\r\?" in sed is not portable to macOS and possibly others. > "\r" is not valid on Linux with POSIXLY_CORRECT. > > Replace "\r" with a substituted variable that contains "\r". > Replace "\?" with "\{0,1\}". > > Helped-by: brian m. carlson <sandals@crustytoothpaste.net> > Signed-off-by: David Aguilar <davvid@gmail.com> > --- > This is based on top of fc/mergetool-automerge and can be squashed in > (with the addition of my sign-off) if desired. > > Changes since last time: > - printf '\r' instead of printf '\x0d' > - The commit message now mentions POSIXLY_CORRECT. > > git-mergetool.sh | 13 ++++++++++--- > 1 file changed, 10 insertions(+), 3 deletions(-) > > diff --git a/git-mergetool.sh b/git-mergetool.sh > index a44afd3822..9029a79431 100755 > --- a/git-mergetool.sh > +++ b/git-mergetool.sh > @@ -243,9 +243,16 @@ auto_merge () { > git merge-file --diff3 --marker-size=7 -q -p "$LOCAL" "$BASE" "$REMOTE" >"$DIFF3" > if test -s "$DIFF3" > then > - sed -e '/^<<<<<<< /,/^||||||| /d' -e '/^=======\r\?$/,/^>>>>>>> /d' "$DIFF3" >"$BASE" > - sed -e '/^||||||| /,/^>>>>>>> /d' -e '/^<<<<<<< /d' "$DIFF3" >"$LOCAL" > - sed -e '/^<<<<<<< /,/^=======\r\?$/d' -e '/^>>>>>>> /d' "$DIFF3" >"$REMOTE" > + cr=$(printf '\r') > + sed -e '/^<<<<<<< /,/^||||||| /d' \ > + -e "/^=======$cr\{0,1\}$/,/^>>>>>>> /d" \ > + "$DIFF3" >"$BASE" > + sed -e '/^||||||| /,/^>>>>>>> /d' \ > + -e '/^<<<<<<< /d' \ > + "$DIFF3" >"$LOCAL" > + sed -e "/^<<<<<<< /,/^=======$cr\{0,1\}$/d" \ > + -e '/^>>>>>>> /d' \ > + "$DIFF3" >"$REMOTE" > fi > rm -- "$DIFF3" > } I was hoping that we can avoid repetition that can cause bugs with something like diff --git i/git-mergetool.sh w/git-mergetool.sh index a44afd3822..e07dabbf72 100755 --- i/git-mergetool.sh +++ w/git-mergetool.sh @@ -243,9 +243,13 @@ auto_merge () { git merge-file --diff3 --marker-size=7 -q -p "$LOCAL" "$BASE" "$REMOTE" >"$DIFF3" if test -s "$DIFF3" then - sed -e '/^<<<<<<< /,/^||||||| /d' -e '/^=======\r\?$/,/^>>>>>>> /d' "$DIFF3" >"$BASE" - sed -e '/^||||||| /,/^>>>>>>> /d' -e '/^<<<<<<< /d' "$DIFF3" >"$LOCAL" - sed -e '/^<<<<<<< /,/^=======\r\?$/d' -e '/^>>>>>>> /d' "$DIFF3" >"$REMOTE" + C0="^<<<<<<< " + C1="^||||||| " + C2="^=======$(printf '\015')*\$" + C3="^>>>>>>> " + sed -e "/$C0/,/$C1/d" -e "/$C2/,/$C3/d" "$DIFF3" >"$BASE" + sed -e "/$C1/,/$C3/d" -e "/$C0/d" "$DIFF3" >"$LOCAL" + sed -e "/$C0/,/$C2/d" -e "/$C3 /d" "$DIFF3" >"$REMOTE" fi rm -- "$DIFF3" } ^ permalink raw reply related [flat|nested] 24+ messages in thread
* Re: [PATCH v2] fixup! mergetool: add automerge configuration 2021-01-09 23:18 ` Junio C Hamano @ 2021-01-10 1:52 ` Junio C Hamano 0 siblings, 0 replies; 24+ messages in thread From: Junio C Hamano @ 2021-01-10 1:52 UTC (permalink / raw) To: David Aguilar; +Cc: Seth House, Felipe Contreras, brian m. carlson, git Junio C Hamano <gitster@pobox.com> writes: > I was hoping that we can avoid repetition that can cause bugs with > something like > ... Here is a cleaned-up version that would apply cleanly on top of yours. I suspect that it would make it even easier to follow the logic if the two sed "-e" expressions are swapped for the $LOCAL one. It would clarify that we remove $C0 (separator before ours) and $C1..$C3 (ancestor's and theirs, including the separators) to get the local version. The other two are already described in the correct order. Thanks. git-mergetool.sh | 18 ++++++++---------- 1 file changed, 8 insertions(+), 10 deletions(-) diff --git a/git-mergetool.sh b/git-mergetool.sh index 9029a79431..ed152a4187 100755 --- a/git-mergetool.sh +++ b/git-mergetool.sh @@ -243,16 +243,14 @@ auto_merge () { git merge-file --diff3 --marker-size=7 -q -p "$LOCAL" "$BASE" "$REMOTE" >"$DIFF3" if test -s "$DIFF3" then - cr=$(printf '\r') - sed -e '/^<<<<<<< /,/^||||||| /d' \ - -e "/^=======$cr\{0,1\}$/,/^>>>>>>> /d" \ - "$DIFF3" >"$BASE" - sed -e '/^||||||| /,/^>>>>>>> /d' \ - -e '/^<<<<<<< /d' \ - "$DIFF3" >"$LOCAL" - sed -e "/^<<<<<<< /,/^=======$cr\{0,1\}$/d" \ - -e '/^>>>>>>> /d' \ - "$DIFF3" >"$REMOTE" + C0="^<<<<<<< " + C1="^||||||| " + C2="^=======$(printf '\015')\{0,1\}$" + C3="^>>>>>>> " + + sed -e "/$C0/,/$C1/d" -e "/$C2/,/$C3/d" "$DIFF3" >"$BASE" + sed -e "/$C1/,/$C3/d" -e "/$C0/d" "$DIFF3" >"$LOCAL" + sed -e "/$C0/,/$C2/d" -e "/$C3/d" "$DIFF3" >"$REMOTE" fi rm -- "$DIFF3" } -- 2.30.0-307-g37795e20d9 ^ permalink raw reply related [flat|nested] 24+ messages in thread
* Re: [PATCH] fixup! mergetool: add automerge configuration 2021-01-09 21:59 ` brian m. carlson 2021-01-09 22:42 ` [PATCH v2] " David Aguilar @ 2021-01-09 23:21 ` Junio C Hamano 1 sibling, 0 replies; 24+ messages in thread From: Junio C Hamano @ 2021-01-09 23:21 UTC (permalink / raw) To: brian m. carlson; +Cc: David Aguilar, Seth House, Felipe Contreras, git "brian m. carlson" <sandals@crustytoothpaste.net> writes: > Ah, yes, this is true. The statement about "\r" is also true for Linux > with POSIXLY_CORRECT, IIRC. It's nice to have a way to reproduce without having a separate toolchain. Thanks for the suggestion. > Unfortunately, printf is not specified by POSIX to take hex escapes, so > this, too is nonportable. We are unfortunately allowed to use only > octal escapes (yuck). However, we can write this: > > cr=$(printf '\r') > > or > > cr=$(printf '\015') > > I think the former is clearer, since that's what we were writing before. The latter however appears more portable at least to traditionalists ;-) ^ permalink raw reply [flat|nested] 24+ messages in thread
end of thread, other threads:[~2021-01-29 0:42 UTC | newest] Thread overview: 24+ messages (download: mbox.gz / follow: Atom feed) -- links below jump to the message on this page -- 2021-01-09 21:49 [PATCH] fixup! mergetool: add automerge configuration David Aguilar 2021-01-09 21:59 ` brian m. carlson 2021-01-09 22:42 ` [PATCH v2] " David Aguilar 2021-01-09 22:54 ` Seth House 2021-01-10 1:17 ` Junio C Hamano 2021-01-10 6:40 ` Re* " Junio C Hamano 2021-01-10 7:29 ` Seth House 2021-01-10 11:24 ` Junio C Hamano 2021-01-16 4:24 ` Seth House 2021-01-20 23:24 ` automerge implementation ideas for Windows Seth House 2021-01-21 22:50 ` Junio C Hamano 2021-01-22 1:09 ` Seth House 2021-01-22 2:26 ` Junio C Hamano 2021-01-22 2:50 ` Re* [PATCH v2] fixup! mergetool: add automerge configuration brian m. carlson 2021-01-22 16:29 ` Johannes Schindelin 2021-01-22 23:25 ` brian m. carlson 2021-01-26 14:32 ` Johannes Schindelin 2021-01-26 18:06 ` Seth House 2021-01-26 20:10 ` Junio C Hamano 2021-01-27 3:37 ` Seth House 2021-01-29 0:41 ` Junio C Hamano 2021-01-09 23:18 ` Junio C Hamano 2021-01-10 1:52 ` Junio C Hamano 2021-01-09 23:21 ` [PATCH] " Junio C Hamano
This is an external index of several public inboxes, see mirroring instructions on how to clone and mirror all data and code used by this external index.