Check and document the options to prevent mistakes.
[gitweb.git] / git-prune.sh
index 9657dbf2711e40bfe035a22ec211811c88c89e8e..c5a5d29aaacf753b70e715169cbb7f74f0193e4a 100755 (executable)
@@ -1,6 +1,7 @@
 #!/bin/sh
 
-. git-sh-setup || die "Not a git archive"
+USAGE='[-n] [--] [<head>...]'
+. git-sh-setup
 
 dryrun=
 echo=
@@ -9,19 +10,35 @@ do
     case "$1" in
     -n) dryrun=-n echo=echo ;;
     --) break ;;
-    -*) echo >&2 "usage: git-prune [ -n ] [ heads... ]"; exit 1 ;;
+    -*) usage ;;
     *)  break ;;
     esac
     shift;
 done
 
-git-fsck-objects --full --cache --unreachable "$@" |
+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
+
+if redundant=$(git-pack-redundant --all 2>/dev/null) && test "" != "$redundant"
+then
+       if test "" = "$dryrun"
+       then
+               echo "$redundant" | xargs rm -f
+       else
+               echo rm -f "$redundant"
+       fi
+fi