Revision 06bf6ac4248e834a229027908d405f5e42ac96d7 authored by Junio C Hamano on 16 December 2005, 02:52:51 UTC, committed by Junio C Hamano on 16 December 2005, 02:52:51 UTC
Signed-off-by: Junio C Hamano <junkio@cox.net>
1 parent ee34518
git-prune.sh
#!/bin/sh
USAGE='[-n] [--] [<head>...]'
. git-sh-setup
dryrun=
echo=
while case "$#" in 0) break ;; esac
do
case "$1" in
-n) dryrun=-n echo=echo ;;
--) break ;;
-*) usage ;;
*) break ;;
esac
shift;
done
sync
case "$#" in
0) git-fsck-objects --full --cache --unreachable ;;
*) git-fsck-objects --full --cache --unreachable $(git-rev-parse --all) "$@" ;;
esac |
sed -ne '/unreachable /{
s/unreachable [^ ][^ ]* //
s|\(..\)|\1/|p
}' | {
cd "$GIT_OBJECT_DIRECTORY" || exit
xargs $echo rm -f
rmdir 2>/dev/null [0-9a-f][0-9a-f]
}
git-prune-packed $dryrun
redundant=$(git-pack-redundant --all)
if test "" != "$redundant"
then
if test "" = "$dryrun"
then
echo "$redundant" | xargs rm -f
else
echo rm -f "$redundant"
fi
fi
Computing file changes ...