diff options
author | Michael J Gruber <git@drmicha.warpmail.net> | 2009-05-11 16:42:54 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2009-05-14 09:43:54 -0700 |
commit | 57ffc5f85a17416a718d4e7baf71d8356c9c7808 (patch) | |
tree | 304ab7b66df7c784d81670e53603bcae372f14d3 /remote.c | |
parent | 1be570f4ebb5f3c4e0a56341db166a760829782a (diff) | |
download | git-57ffc5f85a17416a718d4e7baf71d8356c9c7808.tar.gz |
Fix behavior with non-commit upstream references
stat_tracking_info() assumes that upstream references (as specified by
--track or set up automatically) are commits. By calling lookup_commit()
on them, create_objects() creates objects for them with type commit no
matter what their real type is; this disturbs lookup_tag() later on in the
call sequence, leading to git status, git branch -v and git checkout
erroring out.
Fix this by using lookup_commit_reference() instead so that (annotated)
tags can be used as upstream references.
Signed-off-by: Michael J Gruber <git@drmicha.warpmail.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'remote.c')
-rw-r--r-- | remote.c | 4 |
1 files changed, 2 insertions, 2 deletions
@@ -1296,13 +1296,13 @@ int stat_tracking_info(struct branch *branch, int *num_ours, int *num_theirs) base = branch->merge[0]->dst; if (!resolve_ref(base, sha1, 1, NULL)) return 0; - theirs = lookup_commit(sha1); + theirs = lookup_commit_reference(sha1); if (!theirs) return 0; if (!resolve_ref(branch->refname, sha1, 1, NULL)) return 0; - ours = lookup_commit(sha1); + ours = lookup_commit_reference(sha1); if (!ours) return 0; |