On Sat, Apr 18, 2015 at 06:39:20PM -0700, Junio C Hamano wrote: > This is primarily note-to-self; even though I haven't got around > bisecting yet, I think I know I did some bad change myself. > > "git pull $URL $tag" seems to: > > * fail to invoke the editor without "--edit". > * show the summary merge log message twice.
I think that "git merge -m $msg $commit" is not quite the same as "git merge $msg HEAD $commit". The former suppresses the editor. This makes sense, as it's consistent with "commit -m", etc. You can override that with "--edit". But the latter also respects merge.log. Which also makes sense, because the contents of "-m" are generally user-created, not the output of fmt-merge-msg. So it is merge's job to format the content appropriately. It is tempting to "solve" both by dropping the call to git-fmt-merge-msg right before calling git-merge. Then "git-merge" will call fmt-merge-msg itself. However, we feed it only the sha1 of the merge-head, whereas our fmt-merge-msg call gets to see FETCH_HEAD. So we would lose the nice "Merge tag 'v1.0' of git://..." part of the message. Instead we get "Merge tag '1234abcd'". So this is _almost_ enough: diff --git a/git-pull.sh b/git-pull.sh index 252969e..63493ee 100755 --- a/git-pull.sh +++ b/git-pull.sh @@ -323,7 +323,7 @@ then fi fi -merge_name=$(git fmt-merge-msg $log_arg <"$GIT_DIR/FETCH_HEAD") || exit +merge_name=$(git fmt-merge-msg --no-log <"$GIT_DIR/FETCH_HEAD") || exit case "$rebase" in true) eval="git-rebase $diffstat $strategy_args $merge_args $rebase_args $verbosity" @@ -334,7 +334,7 @@ true) eval="git-merge $diffstat $no_commit $verify_signatures $edit $squash $no_ff $ff_only" eval="$eval $log_arg $strategy_args $merge_args $verbosity $progress" eval="$eval $gpg_sign_args" - eval="$eval -m \"\$merge_name\" $merge_head" + eval="$eval --edit -m \"\$merge_name\" $merge_head" ;; esac eval "exec $eval" But that is starting to feel pretty hacky. Moreover, both fmt-merge-msg and "merge -m" will verify the tag signature and output the tag message. I don't see a way to suppress that. So it really would be nice to be able to just drop the extra fmt-merge-msg call and have git-merge do it all internally, which would mean telling it to use FETCH_HEAD and not $merge_name. Which I guess is just: diff --git a/git-pull.sh b/git-pull.sh index 252969e..15d9431 100755 --- a/git-pull.sh +++ b/git-pull.sh @@ -323,7 +323,6 @@ then fi fi -merge_name=$(git fmt-merge-msg $log_arg <"$GIT_DIR/FETCH_HEAD") || exit case "$rebase" in true) eval="git-rebase $diffstat $strategy_args $merge_args $rebase_args $verbosity" @@ -334,7 +333,7 @@ true) eval="git-merge $diffstat $no_commit $verify_signatures $edit $squash $no_ff $ff_only" eval="$eval $log_arg $strategy_args $merge_args $verbosity $progress" eval="$eval $gpg_sign_args" - eval="$eval -m \"\$merge_name\" $merge_head" + eval="$eval FETCH_HEAD" ;; esac eval "exec $eval" as we seem to special-case the name FETCH_HEAD. It assumes that git-merge's parsing of FETCH_HEAD is the same as what we do in git-pull, but that seems safe. Unfortunately we still have to compute $merge_head ourselves here for the "git pull --rebase" case. -Peff -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html