From: Junio C Hamano Date: Sun, 1 Feb 2009 02:08:22 +0000 (-0800) Subject: Merge branch 'jc/maint-allow-uninteresting-missing' X-Git-Tag: v1.6.2-rc0~44 X-Git-Url: https://git.lorimer.id.au/gitweb.git/diff_plain/2d40cadc25b4cfcf93a23777b74ca36bb5b3ad59?ds=inline;hp=-c Merge branch 'jc/maint-allow-uninteresting-missing' * jc/maint-allow-uninteresting-missing: revision traversal: allow UNINTERESTING objects to be missing --- 2d40cadc25b4cfcf93a23777b74ca36bb5b3ad59 diff --combined revision.c index b0651845bf,1663ac80ea..8603c14581 --- a/revision.c +++ b/revision.c @@@ -183,8 -183,11 +183,11 @@@ static struct commit *handle_commit(str if (!tag->tagged) die("bad tag"); object = parse_object(tag->tagged->sha1); - if (!object) + if (!object) { + if (flags & UNINTERESTING) + return NULL; die("bad object %s", sha1_to_hex(tag->tagged->sha1)); + } } /* @@@ -479,9 -482,10 +482,10 @@@ static int add_parents_to_list(struct r while (parent) { struct commit *p = parent->item; parent = parent->next; + if (p) + p->object.flags |= UNINTERESTING; if (parse_commit(p) < 0) - return -1; - p->object.flags |= UNINTERESTING; + continue; if (p->parents) mark_parents_uninteresting(p); if (p->object.flags & SEEN) @@@ -1263,7 -1267,6 +1267,7 @@@ int setup_revisions(int argc, const cha if (!strcmp(arg, "--all")) { handle_refs(revs, flags, for_each_ref); + handle_refs(revs, flags, head_ref); continue; } if (!strcmp(arg, "--branches")) {