diff options
author | Sergey Vlasov <vsu@altlinux.ru> | 2005-08-03 14:11:00 +0200 |
---|---|---|
committer | Junio C Hamano <junkio@cox.net> | 2005-08-03 21:57:55 +0200 |
commit | ee639140c9d3d7d0c8821e6b7d36c75ae578b326 (patch) | |
tree | 854f18fff3074980176d4383fbea3f926a5d37fe /unpack-objects.c | |
parent | send-pack: handle partial pushes correctly. (diff) | |
download | git-ee639140c9d3d7d0c8821e6b7d36c75ae578b326.tar.xz git-ee639140c9d3d7d0c8821e6b7d36c75ae578b326.zip |
[PATCH] Plug memory leaks in git-unpack-objects
- 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>
Diffstat (limited to '')
-rw-r--r-- | unpack-objects.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/unpack-objects.c b/unpack-objects.c index 19874d004a..7e7be5cbd4 100644 --- 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; } + inflateEnd(&stream); 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]; + int result; 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)); - 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) |