summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: c35dfe8)
raw | patch | inline | side by side (parent: c35dfe8)
author | Linus Torvalds <torvalds@ppc970.osdl.org> | |
Sun, 24 Apr 2005 21:31:57 +0000 (14:31 -0700) | ||
committer | Linus Torvalds <torvalds@ppc970.osdl.org> | |
Sun, 24 Apr 2005 21:31:57 +0000 (14:31 -0700) |
That would SIGSEGV.
commit.c | patch | blob | history | |
tree.c | patch | blob | history |
diff --git a/commit.c b/commit.c
index c6fdfd49197df99cdabf761e8e307f781a45086d..9fbcbd33c7530275a31c701207a34c4bc462da05 100644 (file)
--- a/commit.c
+++ b/commit.c
sha1_to_hex(item->object.sha1));
get_sha1_hex(bufptr + 5, parent);
item->tree = lookup_tree(parent);
- add_ref(&item->object, &item->tree->object);
+ if (item->tree)
+ add_ref(&item->object, &item->tree->object);
bufptr += 46; /* "tree " + "hex sha1" + "\n" */
while (!memcmp(bufptr, "parent ", 7) &&
!get_sha1_hex(bufptr + 7, parent)) {
struct commit *new_parent = lookup_commit(parent);
- commit_list_insert(new_parent, &item->parents);
- add_ref(&item->object, &new_parent->object);
+ if (new_parent) {
+ commit_list_insert(new_parent, &item->parents);
+ add_ref(&item->object, &new_parent->object);
+ }
bufptr += 48;
}
item->date = parse_commit_date(bufptr);
index 3537c115584e66309f50447d6e89404bd4631519..26b79270804cf401ccb1b292757169aa73569024 100644 (file)
--- a/tree.c
+++ b/tree.c
entry->item.blob = lookup_blob(file_sha1);
obj = &entry->item.blob->object;
}
- add_ref(&item->object, obj);
+ if (obj)
+ add_ref(&item->object, obj);
*list_p = entry;
list_p = &entry->next;