refs: allow @{n} to work with n-sized reflog
commit6436a20284f33d42103cac93bd82e65bebb31526
authorDenton Liu <liu.denton@gmail.com>
Thu, 7 Jan 2021 10:36:59 +0000 (7 02:36 -0800)
committerJunio C Hamano <gitster@pobox.com>
Mon, 11 Jan 2021 22:13:50 +0000 (11 14:13 -0800)
treecdf5f66dce357743da868af7f898cee3f306f6a7
parent95c2a71820c8fc2bd333921dee71c35871923716
refs: allow @{n} to work with n-sized reflog

This sequence works

$ git checkout -b newbranch
$ git commit --allow-empty -m one
$ git show -s newbranch@{1}

and shows the state that was immediately after the newbranch was
created.

But then if you do

$ git reflog expire --expire=now refs/heads/newbranch
$ git commit --allow=empty -m two
$ git show -s newbranch@{1}

you'd be scolded with

fatal: log for 'newbranch' only has 1 entries

While it is true that it has only 1 entry, we have enough
information in that single entry that records the transition between
the state in which the tip of the branch was pointing at commit
'one' to the new commit 'two' built on it, so we should be able to
answer "what object newbranch was pointing at?". But we refuse to
do so.

Make @{0} the special case where we use the new side to look up that
entry. Otherwise, look up @{n} using the old side of the (n-1)th entry
of the reflog.

Suggested-by: Junio C Hamano <gitster@pobox.com>
Signed-off-by: Denton Liu <liu.denton@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
refs.c
t/t1503-rev-parse-verify.sh
t/t1508-at-combinations.sh