Skip to content

Commit

Permalink
Merge branch 'nd/daemonize-gc'
Browse files Browse the repository at this point in the history
"git gc --auto" was recently changed to run in the background to
give control back early to the end-user sitting in front of the
terminal, but it forgot that housekeeping involving reflogs should
be done without other processes competing for accesses to the refs.

* nd/daemonize-gc:
  gc --auto: do not lock refs in the background
  • Loading branch information
Junio C Hamano committed Jun 16, 2014
2 parents 8dbd313 + 62aad18 commit 1a81f6c
Showing 1 changed file with 20 additions and 6 deletions.
26 changes: 20 additions & 6 deletions builtin/gc.c
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ static const char * const builtin_gc_usage[] = {
};

static int pack_refs = 1;
static int prune_reflogs = 1;
static int aggressive_depth = 250;
static int aggressive_window = 250;
static int gc_auto_threshold = 6700;
Expand Down Expand Up @@ -258,6 +259,19 @@ static const char *lock_repo_for_gc(int force, pid_t* ret_pid)
return NULL;
}

static int gc_before_repack(void)
{
if (pack_refs && run_command_v_opt(pack_refs_cmd.argv, RUN_GIT_CMD))
return error(FAILED_RUN, pack_refs_cmd.argv[0]);

if (prune_reflogs && run_command_v_opt(reflog.argv, RUN_GIT_CMD))
return error(FAILED_RUN, reflog.argv[0]);

pack_refs = 0;
prune_reflogs = 0;
return 0;
}

int cmd_gc(int argc, const char **argv, const char *prefix)
{
int aggressive = 0;
Expand Down Expand Up @@ -320,12 +334,15 @@ int cmd_gc(int argc, const char **argv, const char *prefix)
fprintf(stderr, _("Auto packing the repository for optimum performance.\n"));
fprintf(stderr, _("See \"git help gc\" for manual housekeeping.\n"));
}
if (detach_auto)
if (detach_auto) {
if (gc_before_repack())
return -1;
/*
* failure to daemonize is ok, we'll continue
* in foreground
*/
daemonize();
}
} else
add_repack_all_option();

Expand All @@ -337,11 +354,8 @@ int cmd_gc(int argc, const char **argv, const char *prefix)
name, (uintmax_t)pid);
}

if (pack_refs && run_command_v_opt(pack_refs_cmd.argv, RUN_GIT_CMD))
return error(FAILED_RUN, pack_refs_cmd.argv[0]);

if (run_command_v_opt(reflog.argv, RUN_GIT_CMD))
return error(FAILED_RUN, reflog.argv[0]);
if (gc_before_repack())
return -1;

if (run_command_v_opt(repack.argv, RUN_GIT_CMD))
return error(FAILED_RUN, repack.argv[0]);
Expand Down

0 comments on commit 1a81f6c

Please sign in to comment.