list-objects.c: handle unexpected non-blob entries
Fix one of the cases described in the previous commit where a tree-entry that is promised to a blob is in fact a non-blob. When 'lookup_blob()' returns NULL, it is because Git has cached the requested object as a non-blob. In this case, prevent a SIGSEGV by 'die()'-ing immediately before attempting to dereference the result. Signed-off-by: Taylor Blau <me@ttaylorr.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
committed by
Junio C Hamano
parent
0616617c7e
commit
23c204455b
@@ -133,6 +133,11 @@ static void process_tree_contents(struct traversal_context *ctx,
|
||||
base, entry.path);
|
||||
else {
|
||||
struct blob *b = lookup_blob(ctx->revs->repo, &entry.oid);
|
||||
if (!b) {
|
||||
die(_("entry '%s' in tree %s has blob mode, "
|
||||
"but is not a blob"),
|
||||
entry.path, oid_to_hex(&tree->object.oid));
|
||||
}
|
||||
b->object.flags |= NOT_USER_GIVEN;
|
||||
process_blob(ctx, b, base, entry.path);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user