aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2008-04-28 16:27:49 -0700
committerJunio C Hamano <gitster@pobox.com>2008-04-28 16:27:49 -0700
commit72269ad9564b700e6aab30338e35b4e6ffea854d (patch)
tree5b4277ada63369870bceef2e259d7e3b65b6b899
parente42251a221e44c0bd8438019da1c307def9a4ca8 (diff)
downloadgit-72269ad9564b700e6aab30338e35b4e6ffea854d.tar.gz
git-72269ad9564b700e6aab30338e35b4e6ffea854d.tar.xz
fetch-pack: do not stop traversing an already parsed commit
f3ec549 (fetch-pack: check parse_commit/object results, 2008-03-03) broke common ancestor computation by stopping traversal when it sees an already parsed commit. This should fix it. Signed-off-by: Junio C Hamano <gitster@pobox.com>
-rw-r--r--builtin-fetch-pack.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/builtin-fetch-pack.c b/builtin-fetch-pack.c
index 65350ca52..fe8cfa0cb 100644
--- a/builtin-fetch-pack.c
+++ b/builtin-fetch-pack.c
@@ -117,15 +117,15 @@ static const unsigned char* get_rev(void)
while (commit == NULL) {
unsigned int mark;
- struct commit_list *parents = NULL;
+ struct commit_list *parents;
if (rev_list == NULL || non_common_revs == 0)
return NULL;
commit = rev_list->item;
- if (!(commit->object.parsed))
- if (!parse_commit(commit))
- parents = commit->parents;
+ if (commit->object.parsed)
+ parse_commit(commit);
+ parents = commit->parents;
commit->object.flags |= POPPED;
if (!(commit->object.flags & COMMON))