replace: peel tag when passing a tag as parent to --graft
commitf8e44a81bf82ae35e37500f9597e93b0bdfc05e4
authorChristian Couder <christian.couder@gmail.com>
Sun, 31 Mar 2019 13:46:58 +0000 (31 15:46 +0200)
committerJunio C Hamano <gitster@pobox.com>
Mon, 15 Apr 2019 02:31:42 +0000 (15 11:31 +0900)
tree0c504d4c8f098c802acd5ab6bbd5f004be74d9f8
parent587617016744448ace200804aed9edccb436f38e
replace: peel tag when passing a tag as parent to --graft

When passing a tag as a parent argument to `git replace --graft`,
it can be useful to accept it and use the underlying commit as a
parent.

This already works for lightweight tags, but unfortunately
for annotated tags we have been using the hash of the tag object
instead of the hash of the underlying commit as a parent in the
replacement object we create.

This created invalid objects, but the replace succeeded even if
it showed an error like:

error: object A is a tag, not a commit

This patch fixes that by using the hash of the underlying commit
when an annotated tag is passed.

While at it, let's also update an error message to make it
clearer.

Reviewed-by: Taylor Blau <me@ttaylorr.com>
Signed-off-by: Christian Couder <chriscool@tuxfamily.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin/replace.c
t/t6050-replace.sh