diff options
author | Jeff King <peff@peff.net> | 2014-09-13 22:19:38 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2014-09-15 20:39:54 +0200 |
commit | 3907a4078a89cffde2e2e0e61a3bd41efba96c49 (patch) | |
tree | bd5ad6621db53131f3e3362b1f5a0fe21256594b | |
parent | make update-server-info more robust (diff) | |
download | git-3907a4078a89cffde2e2e0e61a3bd41efba96c49.tar.xz git-3907a4078a89cffde2e2e0e61a3bd41efba96c49.zip |
server-info: clean up after writing info/packs
We allocate pack information in a static global list but
never clean it up. This leaks memory, and means that calling
update_server_info twice will generate a buggy file (it will
have duplicate entries).
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to '')
-rw-r--r-- | server-info.c | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/server-info.c b/server-info.c index d54a3d624c..31f4a749fb 100644 --- a/server-info.c +++ b/server-info.c @@ -233,6 +233,14 @@ static void init_pack_info(const char *infofile, int force) info[i]->new_num = i; } +static void free_pack_info(void) +{ + int i; + for (i = 0; i < num_pack; i++) + free(info[i]); + free(info); +} + static int write_pack_info_file(FILE *fp) { int i; @@ -252,6 +260,7 @@ static int update_info_packs(int force) init_pack_info(infofile, force); ret = update_info_file(infofile, write_pack_info_file); + free_pack_info(); free(infofile); return ret; } |