]> git.ipfire.org Git - thirdparty/git.git/commitdiff
builtin/repack.c: pass "packdir" when removing packs
authorTaylor Blau <me@ttaylorr.com>
Wed, 15 Oct 2025 22:28:10 +0000 (18:28 -0400)
committerJunio C Hamano <gitster@pobox.com>
Thu, 16 Oct 2025 17:08:54 +0000 (10:08 -0700)
builtin/repack.c defines a static "packdir" to instruct pack-objects on
where to write any new packfiles. This is also the directory scanned
when removing any packfiles which were made redundant by the latest
repack.

Prepare to move the "existing_packs_remove_redundant" function to its
own compilation unit by passing in this information as a parameter to
that function.

Signed-off-by: Taylor Blau <me@ttaylorr.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin/repack.c

index 31137cf711265a84e6b302103c71d05dcaa432f7..c5a88eda1296df512cf11001b411e0896a05a64f 100644 (file)
@@ -209,7 +209,8 @@ static void existing_packs_mark_for_deletion(struct existing_packs *existing,
 }
 
 static void remove_redundant_packs_1(struct repository *repo,
-                                    struct string_list *packs)
+                                    struct string_list *packs,
+                                    const char *packdir)
 {
        struct string_list_item *item;
        for_each_string_list_item(item, packs) {
@@ -219,10 +220,13 @@ static void remove_redundant_packs_1(struct repository *repo,
        }
 }
 
-static void existing_packs_remove_redundant(struct existing_packs *existing)
+static void existing_packs_remove_redundant(struct existing_packs *existing,
+                                           const char *packdir)
 {
-       remove_redundant_packs_1(existing->repo, &existing->non_kept_packs);
-       remove_redundant_packs_1(existing->repo, &existing->cruft_packs);
+       remove_redundant_packs_1(existing->repo, &existing->non_kept_packs,
+                                packdir);
+       remove_redundant_packs_1(existing->repo, &existing->cruft_packs,
+                                packdir);
 }
 
 static void existing_packs_release(struct existing_packs *existing)
@@ -1659,7 +1663,7 @@ int cmd_repack(int argc,
 
        if (delete_redundant) {
                int opts = 0;
-               existing_packs_remove_redundant(&existing);
+               existing_packs_remove_redundant(&existing, packdir);
 
                if (geometry.split_factor)
                        geometry_remove_redundant_packs(&geometry, &names,