diff options
author | Shawn Pearce <spearce@spearce.org> | 2006-10-29 04:37:54 -0500 |
---|---|---|
committer | Junio C Hamano <junkio@cox.net> | 2006-10-29 12:46:21 -0800 |
commit | ce8590748b918687abc4c7cd2d432dd23f07ae40 (patch) | |
tree | bcf008a75c38ad40a8da08d52ab5ab0b99c90e7b /exec_cmd.c | |
parent | d4ff6d92c3d7020233a9b4990a3545ee54a5c033 (diff) | |
download | git-ce8590748b918687abc4c7cd2d432dd23f07ae40.tar.gz git-ce8590748b918687abc4c7cd2d432dd23f07ae40.tar.xz |
Only repack active packs by skipping over kept packs.
During `git repack -a -d` only repack objects which are loose or
which reside in an active (a non-kept) pack. This allows the user
to keep large packs as-is without continuous repacking and can be
very helpful on large repositories. It should also help us resolve
a race condition between `git repack -a -d` and the new pack store
functionality in `git-receive-pack`.
Kept packs are those which have a corresponding .keep file in
$GIT_OBJECT_DIRECTORY/pack. That is pack-X.pack will be kept
(not repacked and not deleted) if pack-X.keep exists in the same
directory when `git repack -a -d` starts.
Currently this feature is not documented and there is no user
interface to keep an existing pack.
Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>
Diffstat (limited to 'exec_cmd.c')
0 files changed, 0 insertions, 0 deletions