diff options
author | Taylor Blau <me@ttaylorr.com> | 2021-03-05 10:21:37 -0500 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2021-03-05 11:33:52 -0800 |
commit | f25e33c1566fecb097a460f0649ac1a20c418843 (patch) | |
tree | d64cdd765f6ea5596408c37bac984fdd00fd56a9 /t/t4254-am-corrupt.sh | |
parent | builtin/repack.c: add '--geometric' option (diff) | |
download | tgif-f25e33c1566fecb097a460f0649ac1a20c418843.tar.xz |
builtin/repack.c: do not repack single packs with --geometric
In 0fabafd0b9 (builtin/repack.c: add '--geometric' option, 2021-02-22),
the 'git repack --geometric' code aborts early when there is zero or one
pack.
When there are no packs, this code does the right thing by placing the
split at "0". But when there is exactly one pack, the split is placed at
"1", which means that "git repack --geometric" (with any factor)
repacks all of the objects in a single pack.
This is wasteful, and the remaining code in split_pack_geometry() does
the right thing (not repacking the objects in a single pack) even when
only one pack is present.
Loosen the guard to only stop when there aren't any packs, and let the
rest of the code do the right thing. Add a test to ensure that this is
the case.
Noticed-by: Junio C Hamano <gitster@pobox.com>
Signed-off-by: Taylor Blau <me@ttaylorr.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 't/t4254-am-corrupt.sh')
0 files changed, 0 insertions, 0 deletions