aboutsummaryrefslogtreecommitdiffstats
path: root/builtin/gc.c
diff options
context:
space:
mode:
authorPatrick Steinhardt <ps@pks.im>2025-05-07 09:21:39 +0200
committerJunio C Hamano <gitster@pobox.com>2025-05-07 10:50:14 -0700
commitae76c1c99089903ce2b786a42a7e5598a7be5c5c (patch)
tree73e8295c7ff271c502ac70e6a6891dd463dce3fe /builtin/gc.c
parente3a69d72b1e48b85f9dad8139797a6fe50d4059d (diff)
downloadgit-ae76c1c99089903ce2b786a42a7e5598a7be5c5c.tar.gz
builtin/gc: move pruning of worktrees into a separate function
In a subsequent commit we will introduce a new "worktree-prune" task for git-maintenance(1). To prepare for this, refactor the code that spawns `git worktree prune` into a separate function. Signed-off-by: Patrick Steinhardt <ps@pks.im> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'builtin/gc.c')
-rw-r--r--builtin/gc.c25
1 files changed, 15 insertions, 10 deletions
diff --git a/builtin/gc.c b/builtin/gc.c
index ba4b30c24b..d91b6b7b8c 100644
--- a/builtin/gc.c
+++ b/builtin/gc.c
@@ -333,6 +333,18 @@ static int maintenance_task_reflog_expire(struct maintenance_run_opts *opts UNUS
return run_command(&cmd);
}
+static int maintenance_task_worktree_prune(struct maintenance_run_opts *opts UNUSED,
+ struct gc_config *cfg)
+{
+ struct child_process prune_worktrees_cmd = CHILD_PROCESS_INIT;
+
+ prune_worktrees_cmd.git_cmd = 1;
+ strvec_pushl(&prune_worktrees_cmd.args, "worktree", "prune", "--expire", NULL);
+ strvec_push(&prune_worktrees_cmd.args, cfg->prune_worktrees_expire);
+
+ return run_command(&prune_worktrees_cmd);
+}
+
static int too_many_loose_objects(struct gc_config *cfg)
{
/*
@@ -913,16 +925,9 @@ int cmd_gc(int argc,
}
}
- if (cfg.prune_worktrees_expire) {
- struct child_process prune_worktrees_cmd = CHILD_PROCESS_INIT;
-
- prune_worktrees_cmd.git_cmd = 1;
- strvec_pushl(&prune_worktrees_cmd.args, "worktree", "prune", "--expire", NULL);
- strvec_push(&prune_worktrees_cmd.args, cfg.prune_worktrees_expire);
-
- if (run_command(&prune_worktrees_cmd))
- die(FAILED_RUN, prune_worktrees_cmd.args.v[0]);
- }
+ if (cfg.prune_worktrees_expire &&
+ maintenance_task_worktree_prune(&opts, &cfg))
+ die(FAILED_RUN, "worktree");
rerere_cmd.git_cmd = 1;
strvec_pushl(&rerere_cmd.args, "rerere", "gc", NULL);