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
@ -20,8 +20,9 @@ test_expect_failure 'traverse unexpected non-blob entry (lone)' '
|
||||
test_must_fail git rev-list --objects $broken_tree
|
||||
'
|
||||
|
||||
test_expect_failure 'traverse unexpected non-blob entry (seen)' '
|
||||
test_must_fail git rev-list --objects $tree $broken_tree
|
||||
test_expect_success 'traverse unexpected non-blob entry (seen)' '
|
||||
test_must_fail git rev-list --objects $tree $broken_tree >output 2>&1 &&
|
||||
test_i18ngrep "is not a blob" output
|
||||
'
|
||||
|
||||
test_expect_success 'setup unexpected non-tree entry' '
|
||||
|
Reference in New Issue
Block a user