rerere gc: honor configuration and document it

Two configuration to control the expiration of rerere records
are introduced and documented.

Signed-off-by: Junio C Hamano <junkio@cox.net>
This commit is contained in:
Junio C Hamano 2006-12-27 01:24:05 -08:00
parent ae72f68541
commit 48c3242450
3 changed files with 29 additions and 2 deletions

View File

@ -192,6 +192,16 @@ format.headers::
Additional email headers to include in a patch to be submitted Additional email headers to include in a patch to be submitted
by mail. See gitlink:git-format-patch[1]. by mail. See gitlink:git-format-patch[1].
gc.rerereresolved::
Records of conflicted merge you resolved earlier are
kept for this many days when `git rerere gc` is run.
The default is 60 days. See gitlink:git-rerere[1].
gc.rerereunresolved::
Records of conflicted merge you have not resolved are
kept for this many days when `git rerere gc` is run.
The default is 15 days. See gitlink:git-rerere[1].
gitcvs.enabled:: gitcvs.enabled::
Whether the cvs pserver interface is enabled for this repository. Whether the cvs pserver interface is enabled for this repository.
See gitlink:git-cvsserver[1]. See gitlink:git-cvsserver[1].

View File

@ -7,7 +7,7 @@ git-rerere - Reuse recorded resolve
SYNOPSIS SYNOPSIS
-------- --------
'git-rerere' [clear|diff|status] 'git-rerere' [clear|diff|status|gc]
DESCRIPTION DESCRIPTION
----------- -----------
@ -55,7 +55,11 @@ for resolutions.
'gc':: 'gc'::
This command is used to prune records of conflicted merge that This command is used to prune records of conflicted merge that
occurred long time ago. occurred long time ago. By default, conflicts older than 15
days that you have not recorded their resolution, and conflicts
older than 60 days, are pruned. These are controlled with
`gc.rerereunresolved` and `gc.rerereresolved` configuration
variables.
DISCUSSION DISCUSSION

View File

@ -362,6 +362,17 @@ tail_optimization:
return write_rr(rr, fd); return write_rr(rr, fd);
} }
static int git_rerere_config(const char *var, const char *value)
{
if (!strcmp(var, "gc.rerereresolved"))
cutoff_resolve = git_config_int(var, value);
else if (!strcmp(var, "gc.rerereunresolved"))
cutoff_noresolve = git_config_int(var, value);
else
return git_default_config(var, value);
return 0;
}
int cmd_rerere(int argc, const char **argv, const char *prefix) int cmd_rerere(int argc, const char **argv, const char *prefix)
{ {
struct path_list merge_rr = { NULL, 0, 0, 1 }; struct path_list merge_rr = { NULL, 0, 0, 1 };
@ -371,6 +382,8 @@ int cmd_rerere(int argc, const char **argv, const char *prefix)
if (stat(git_path("rr-cache"), &st) || !S_ISDIR(st.st_mode)) if (stat(git_path("rr-cache"), &st) || !S_ISDIR(st.st_mode))
return 0; return 0;
git_config(git_rerere_config);
merge_rr_path = xstrdup(git_path("rr-cache/MERGE_RR")); merge_rr_path = xstrdup(git_path("rr-cache/MERGE_RR"));
fd = hold_lock_file_for_update(&write_lock, merge_rr_path, 1); fd = hold_lock_file_for_update(&write_lock, merge_rr_path, 1);
read_rr(&merge_rr); read_rr(&merge_rr);