summaryrefslogtreecommitdiffstats
path: root/sha1_file.c
diff options
context:
space:
mode:
authorJunio C Hamano <gitster@pobox.com>2011-10-27 20:42:57 +0200
committerJunio C Hamano <gitster@pobox.com>2011-10-27 20:42:57 +0200
commitea4f9685cb432caf357ad8af56a91877b6d04663 (patch)
tree4171553d03d95eadbe6f2323f9870d29f133bd51 /sha1_file.c
parenttree_entry_interesting: make use of local pointer "item" (diff)
downloadgit-ea4f9685cb432caf357ad8af56a91877b6d04663.tar.xz
git-ea4f9685cb432caf357ad8af56a91877b6d04663.zip
unpack_object_header_buffer(): clear the size field upon error
The callers do not use the returned size when the function says it did not use any bytes and sets the type to OBJ_BAD, so this should not matter in practice, but it is a good code hygiene anyway. Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'sha1_file.c')
-rw-r--r--sha1_file.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/sha1_file.c b/sha1_file.c
index 27f3b9b278..833f5b9b58 100644
--- a/sha1_file.c
+++ b/sha1_file.c
@@ -1267,7 +1267,8 @@ unsigned long unpack_object_header_buffer(const unsigned char *buf,
while (c & 0x80) {
if (len <= used || bitsizeof(long) <= shift) {
error("bad object header");
- return 0;
+ size = used = 0;
+ break;
}
c = buf[used++];
size += (c & 0x7f) << shift;