You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
107 lines
2.5 KiB
107 lines
2.5 KiB
/* |
|
* git gc builtin command |
|
* |
|
* Cleanup unreachable files and optimize the repository. |
|
* |
|
* Copyright (c) 2007 James Bowes |
|
* |
|
* Based on git-gc.sh, which is |
|
* |
|
* Copyright (c) 2006 Shawn O. Pearce |
|
*/ |
|
|
|
#include "builtin.h" |
|
#include "cache.h" |
|
#include "run-command.h" |
|
|
|
#define FAILED_RUN "failed to run %s" |
|
|
|
static const char builtin_gc_usage[] = "git-gc [--prune] [--aggressive]"; |
|
|
|
static int pack_refs = 1; |
|
static int aggressive_window = -1; |
|
|
|
#define MAX_ADD 10 |
|
static const char *argv_pack_refs[] = {"pack-refs", "--all", "--prune", NULL}; |
|
static const char *argv_reflog[] = {"reflog", "expire", "--all", NULL}; |
|
static const char *argv_repack[MAX_ADD] = {"repack", "-a", "-d", "-l", NULL}; |
|
static const char *argv_prune[] = {"prune", NULL}; |
|
static const char *argv_rerere[] = {"rerere", "gc", NULL}; |
|
|
|
static int gc_config(const char *var, const char *value) |
|
{ |
|
if (!strcmp(var, "gc.packrefs")) { |
|
if (!strcmp(value, "notbare")) |
|
pack_refs = -1; |
|
else |
|
pack_refs = git_config_bool(var, value); |
|
return 0; |
|
} |
|
if (!strcmp(var, "gc.aggressivewindow")) { |
|
aggressive_window = git_config_int(var, value); |
|
return 0; |
|
} |
|
return git_default_config(var, value); |
|
} |
|
|
|
static void append_option(const char **cmd, const char *opt, int max_length) |
|
{ |
|
int i; |
|
|
|
for (i = 0; cmd[i]; i++) |
|
; |
|
|
|
if (i + 2 >= max_length) |
|
die("Too many options specified"); |
|
cmd[i++] = opt; |
|
cmd[i] = NULL; |
|
} |
|
|
|
int cmd_gc(int argc, const char **argv, const char *prefix) |
|
{ |
|
int i; |
|
int prune = 0; |
|
char buf[80]; |
|
|
|
git_config(gc_config); |
|
|
|
if (pack_refs < 0) |
|
pack_refs = !is_bare_repository(); |
|
|
|
for (i = 1; i < argc; i++) { |
|
const char *arg = argv[i]; |
|
if (!strcmp(arg, "--prune")) { |
|
prune = 1; |
|
continue; |
|
} |
|
if (!strcmp(arg, "--aggressive")) { |
|
append_option(argv_repack, "-f", MAX_ADD); |
|
if (aggressive_window > 0) { |
|
sprintf(buf, "--window=%d", aggressive_window); |
|
append_option(argv_repack, buf, MAX_ADD); |
|
} |
|
continue; |
|
} |
|
/* perhaps other parameters later... */ |
|
break; |
|
} |
|
if (i != argc) |
|
usage(builtin_gc_usage); |
|
|
|
if (pack_refs && run_command_v_opt(argv_pack_refs, RUN_GIT_CMD)) |
|
return error(FAILED_RUN, argv_pack_refs[0]); |
|
|
|
if (run_command_v_opt(argv_reflog, RUN_GIT_CMD)) |
|
return error(FAILED_RUN, argv_reflog[0]); |
|
|
|
if (run_command_v_opt(argv_repack, RUN_GIT_CMD)) |
|
return error(FAILED_RUN, argv_repack[0]); |
|
|
|
if (prune && run_command_v_opt(argv_prune, RUN_GIT_CMD)) |
|
return error(FAILED_RUN, argv_prune[0]); |
|
|
|
if (run_command_v_opt(argv_rerere, RUN_GIT_CMD)) |
|
return error(FAILED_RUN, argv_rerere[0]); |
|
|
|
return 0; |
|
}
|
|
|