repack: turn on "ref paranoia" when doing a destructive repack
If we are repacking with "-ad", we will drop any unreachable objects. Likewise, using "-Ad --unpack-unreachable=<time>" will drop any old, unreachable objects. In these cases, we want to make sure the reachability we compute with "--all" is complete. We can do this by passing GIT_REF_PARANOIA=1 in the environment to pack-objects. Note that "-Ad" is safe already, because it only loosens unreachable objects. It is up to "git prune" to avoid deleting them. Signed-off-by: Jeff King <peff@peff.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
ff4056bbc3
commit
8d42299361
@ -228,13 +228,17 @@ int cmd_repack(int argc, const char **argv, const char *prefix)
|
||||
get_non_kept_pack_filenames(&existing_packs);
|
||||
|
||||
if (existing_packs.nr && delete_redundant) {
|
||||
if (unpack_unreachable)
|
||||
if (unpack_unreachable) {
|
||||
argv_array_pushf(&cmd.args,
|
||||
"--unpack-unreachable=%s",
|
||||
unpack_unreachable);
|
||||
else if (pack_everything & LOOSEN_UNREACHABLE)
|
||||
argv_array_push(&cmd.env_array, "GIT_REF_PARANOIA=1");
|
||||
} else if (pack_everything & LOOSEN_UNREACHABLE) {
|
||||
argv_array_push(&cmd.args,
|
||||
"--unpack-unreachable");
|
||||
} else {
|
||||
argv_array_push(&cmd.env_array, "GIT_REF_PARANOIA=1");
|
||||
}
|
||||
}
|
||||
} else {
|
||||
argv_array_push(&cmd.args, "--unpacked");
|
||||
|
@ -38,7 +38,7 @@ test_expect_success 'put bogus object into pack' '
|
||||
verbose git cat-file -e $bogus
|
||||
'
|
||||
|
||||
test_expect_failure 'destructive repack keeps packed object' '
|
||||
test_expect_success 'destructive repack keeps packed object' '
|
||||
test_might_fail git repack -Ad --unpack-unreachable=now &&
|
||||
verbose git cat-file -e $bogus &&
|
||||
test_might_fail git repack -ad &&
|
||||
|
Loading…
Reference in New Issue
Block a user