X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=git-prune-script;h=a8e338c488865b1579071ea363fc18fa8e3d8890;hb=0b124bb4bf8eafae8a4eae9c1fc44bf63da2e62e;hp=a24ba616dd4181dd5a5bd97a2d05228080894545;hpb=4feb7a016ae0b237af5e667277fa632326a58eac;p=git.git diff --git a/git-prune-script b/git-prune-script index a24ba616..a8e338c4 100755 --- a/git-prune-script +++ b/git-prune-script @@ -1,4 +1,25 @@ #!/bin/sh -REFS=$(cat .git/refs/*/*) -[ "$REFS" ] || exit 1 -git-fsck-cache --unreachable $REFS | grep unreachable | cut -d' ' -f3 | sed 's:^\(..\):.git/objects/\1/:' | xargs -r rm + +. git-sh-setup-script || die "Not a git archive" + +dryrun= +while case "$#" in 0) break ;; esac +do + case "$1" in + -n) dryrun=echo ;; + --) break ;; + -*) echo >&2 "usage: git-prune-script [ -n ] [ heads... ]"; exit 1 ;; + *) break ;; + esac + shift; +done + +git-fsck-cache --full --cache --unreachable "$@" | +sed -ne '/unreachable /{ + s/unreachable [^ ][^ ]* // + s|\(..\)|\1/|p +}' | { + cd "$GIT_OBJECT_DIRECTORY" || exit + xargs $dryrun rm -f +} +