aboutsummaryrefslogtreecommitdiff
path: root/branch.h
diff options
context:
space:
mode:
authorJunio C Hamano <gitster@pobox.com>2011-01-11 15:00:38 -0500
committerJunio C Hamano <gitster@pobox.com>2011-01-11 13:14:56 -0800
commit0cb6ad3c3d8e9c738686ef8dc6f173f725e509bc (patch)
treec218deb54009b1f59a959103a0390fc7d330f2a7 /branch.h
parent6e97ef31ce20ff93a4cc0e3c6ab5171fd6dda5f3 (diff)
downloadgit-0cb6ad3c3d8e9c738686ef8dc6f173f725e509bc.tar.gz
git-0cb6ad3c3d8e9c738686ef8dc6f173f725e509bc.tar.xz
checkout: fix bug with ambiguous refs
The usual dwim_ref lookup prefers tags to branches. Because checkout primarily works on branches, though, we switch that behavior to prefer branches. However, there was a bug in the implementation in which we used lookup_commit_reference (which used the regular lookup rules) to get the actual commit to checkout. Checking out an ambiguous ref therefore ended up putting us in an extremely broken state in which we wrote the branch ref into HEAD, but actually checked out the tree for the tag. This patch fixes the bug by always attempting to pull the commit to be checked out from the branch-ified version of the name we were given. Patch by Junio, tests and commit message from Jeff King. Signed-off-by: Jeff King <peff@peff.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'branch.h')
0 files changed, 0 insertions, 0 deletions