On Fri, Nov 04, 2011 at 04:10:59PM -0700, Linus Torvalds wrote: > I'm pretty sure people have already done "git merge v3.1" kind of > things using local tags (where no peeling of FETCH_HEAD has been > done). See > > git log --merges --grep 'Merge.*v[23]\.[0-9]' > > for a ton of examples of this (and there's something odd going on: we > have "Merge commit .." and "Merge tag ..", and I suspect the latter is > people editing it to be correct by hand, but I dunno). It looks like fmt-merge-msg looks in FETCH_HEAD to see if each line is marked as "branch" or "tag". So I get "Merge tag ..." with: git pull . tag v1.0 but I get "Merge commit ..." with: git merge v1.0 When "git merge" is run, it actually creates a fake FETCH_HEAD in memory and feeds it to fmt-merge-msg. But that process doesn't seem to bother looking at tags. I think we just need this: --- diff --git a/builtin/merge.c b/builtin/merge.c index dffd5ec..6a44b6d 100644 --- a/builtin/merge.c +++ b/builtin/merge.c @@ -439,10 +439,15 @@ static void merge_name(const char *remote, struct strbuf *msg) if (!prefixcmp(found_ref, "refs/heads/")) { strbuf_addf(msg, "%s\t\tbranch '%s' of .\n", sha1_to_hex(branch_head), remote); goto cleanup; } + if (!prefixcmp(found_ref, "refs/tags/")) { + strbuf_addf(msg, "%s\t\ttag '%s' of .\n", + sha1_to_hex(branch_head), remote); + goto cleanup; + } if (!prefixcmp(found_ref, "refs/remotes/")) { strbuf_addf(msg, "%s\t\tremote-tracking branch '%s' of .\n", sha1_to_hex(branch_head), remote); goto cleanup; } where the result of merge_name is just fed to fmt-merge-msg eventually. -Peff -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html