]> git.ipfire.org Git - thirdparty/git.git/commitdiff
builtin/fast-import: plug trivial memory leaks
authorPatrick Steinhardt <ps@pks.im>
Wed, 14 Aug 2024 06:52:23 +0000 (08:52 +0200)
committerJunio C Hamano <gitster@pobox.com>
Wed, 14 Aug 2024 17:07:59 +0000 (10:07 -0700)
Plug some trivial memory leaks in git-fast-import(1).

Signed-off-by: Patrick Steinhardt <ps@pks.im>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin/fast-import.c
t/t9300-fast-import.sh
t/t9304-fast-import-marks.sh

index d21c4053a7e4d96e785b8d5424660ee5e9a42d08..6dfeb0166587b92660992ebef244599adbde7094 100644 (file)
@@ -206,8 +206,8 @@ static unsigned int object_entry_alloc = 5000;
 static struct object_entry_pool *blocks;
 static struct hashmap object_table;
 static struct mark_set *marks;
-static const char *export_marks_file;
-static const char *import_marks_file;
+static char *export_marks_file;
+static char *import_marks_file;
 static int import_marks_file_from_stream;
 static int import_marks_file_ignore_missing;
 static int import_marks_file_done;
@@ -3274,6 +3274,7 @@ static void option_import_marks(const char *marks,
                        read_marks();
        }
 
+       free(import_marks_file);
        import_marks_file = make_fast_import_path(marks);
        import_marks_file_from_stream = from_stream;
        import_marks_file_ignore_missing = ignore_missing;
@@ -3316,6 +3317,7 @@ static void option_active_branches(const char *branches)
 
 static void option_export_marks(const char *marks)
 {
+       free(export_marks_file);
        export_marks_file = make_fast_import_path(marks);
 }
 
@@ -3357,6 +3359,8 @@ static void option_rewrite_submodules(const char *arg, struct string_list *list)
        free(f);
 
        string_list_insert(list, s)->util = ms;
+
+       free(s);
 }
 
 static int parse_one_option(const char *option)
index 1e68426852f92c2fe4a7bb4eeea199e910df04dd..3b3c371740a3922013e3be4c792eeb1d03e9699a 100755 (executable)
@@ -7,6 +7,7 @@ test_description='test git fast-import utility'
 GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME=main
 export GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME
 
+TEST_PASSES_SANITIZE_LEAK=true
 . ./test-lib.sh
 . "$TEST_DIRECTORY"/lib-diff.sh ;# test-lib chdir's into trash
 
index 410a871c52af87cd9fe9ab9da5350b032fc5689d..1f776a80f3b4b9c12b16914069f5717950ae7ac8 100755 (executable)
@@ -1,6 +1,8 @@
 #!/bin/sh
 
 test_description='test exotic situations with marks'
+
+TEST_PASSES_SANITIZE_LEAK=true
 . ./test-lib.sh
 
 test_expect_success 'setup dump of basic history' '