Andrew's git
/
gitweb.git
/ diff
summary
|
log
|
commit
| diff |
tree
commit
grep
author
committer
pickaxe
?
re
[PATCH] Plug memory leaks in git-unpack-objects
author
Sergey Vlasov
<vsu@altlinux.ru>
Wed, 3 Aug 2005 12:11:00 +0000
(16:11 +0400)
committer
Junio C Hamano
<junkio@cox.net>
Wed, 3 Aug 2005 19:57:55 +0000
(12:57 -0700)
- Call inflateEnd to release zlib state after use.
- After resolving delta, free base object data.
Signed-off-by: Sergey Vlasov <vsu@altlinux.ru>
Signed-off-by: Junio C Hamano <junkio@cox.net>
unpack-objects.c
patch
|
blob
|
history
raw
|
patch
|
inline
| side by side (parent:
40b64d4
)
diff --git
a/unpack-objects.c
b/unpack-objects.c
index 19874d004a03531b12922f1bd48a28f18e8d2897..7e7be5cbd42e2f6ad178f1a2832673c8e9279e4e 100644
(file)
--- a/
unpack-objects.c
+++ b/
unpack-objects.c
@@
-75,6
+75,7
@@
static void *get_data(unsigned long size)
stream.next_in = fill(1);
stream.avail_in = len;
}
stream.next_in = fill(1);
stream.avail_in = len;
}
+ inflateEnd(&stream);
return buf;
}
return buf;
}
@@
-167,6
+168,7
@@
static int unpack_delta_entry(unsigned long delta_size)
unsigned long base_size;
char type[20];
unsigned char base_sha1[20];
unsigned long base_size;
char type[20];
unsigned char base_sha1[20];
+ int result;
memcpy(base_sha1, fill(20), 20);
use(20);
memcpy(base_sha1, fill(20), 20);
use(20);
@@
-184,7
+186,9
@@
static int unpack_delta_entry(unsigned long delta_size)
base = read_sha1_file(base_sha1, type, &base_size);
if (!base)
die("failed to read delta-pack base object %s", sha1_to_hex(base_sha1));
base = read_sha1_file(base_sha1, type, &base_size);
if (!base)
die("failed to read delta-pack base object %s", sha1_to_hex(base_sha1));
- return resolve_delta(type, base, base_size, delta_data, delta_size);
+ result = resolve_delta(type, base, base_size, delta_data, delta_size);
+ free(base);
+ return result;
}
static void unpack_one(unsigned nr, unsigned total)
}
static void unpack_one(unsigned nr, unsigned total)