]> git.ipfire.org Git - thirdparty/git.git/commitdiff
server-info: clean up after writing info/packs
authorJeff King <peff@peff.net>
Sat, 13 Sep 2014 20:19:38 +0000 (16:19 -0400)
committerJunio C Hamano <gitster@pobox.com>
Mon, 15 Sep 2014 18:39:54 +0000 (11:39 -0700)
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>
server-info.c

index d54a3d624c488aaf65bc5b46f509c2481fe73103..31f4a749fbad73b9f7bc1f1ebf9b11fd743ab374 100644 (file)
@@ -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;
 }