If all objects are reachable via an alternate object store then we still have to remove all obsolete local packs. Signed-off-by: Martin Waitz <tali@xxxxxxxxxxxxxx> --- Without this patch I got the following behaviour: ".git/objects/info/alternates" [Neu] 1L, 38C geschrieben admingilde:~/src/linux-2.6 > git count-objects 107852 objects, 665596 kilobytes admingilde:~/src/linux-2.6 > git repack -a -l -d Generating pack... Done counting 0 objects. Nothing new to pack. admingilde:~/src/linux-2.6 > git prune admingilde:~/src/linux-2.6 > git count-objects 0 objects, 0 kilobytes admingilde:~/src/linux-2.6 > ls .git/objects/pack pack-b3c6fbdfa36a326815de6358885c7a570a986b1b.idx pack-b3c6fbdfa36a326815de6358885c7a570a986b1b.pack pack-e0d76ffe354ef5665028a6cb4506ea902f72e1d0.idx pack-e0d76ffe354ef5665028a6cb4506ea902f72e1d0.pack After changing git-repack, objects/pack was empty, as expected. git-repack.sh | 14 +++++++------- 1 files changed, 7 insertions(+), 7 deletions(-) c58513fa76e10007fdf15b49a593a2b9c6a080be diff --git a/git-repack.sh b/git-repack.sh index e0c9f32..4fb3f26 100755 --- a/git-repack.sh +++ b/git-repack.sh @@ -48,15 +48,15 @@ name=$(git-rev-list --objects --all $rev exit 1 if [ -z "$name" ]; then echo Nothing new to pack. - exit 0 -fi -echo "Pack pack-$name created." +else + echo "Pack pack-$name created." -mkdir -p "$PACKDIR" || exit + mkdir -p "$PACKDIR" || exit -mv .tmp-pack-$name.pack "$PACKDIR/pack-$name.pack" && -mv .tmp-pack-$name.idx "$PACKDIR/pack-$name.idx" || -exit + mv .tmp-pack-$name.pack "$PACKDIR/pack-$name.pack" && + mv .tmp-pack-$name.idx "$PACKDIR/pack-$name.idx" || + exit +fi if test "$remove_redundant" = t then -- 1.3.1.g8971-dirty -- Martin Waitz - : send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html