X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=git-prune-script;h=ec9f72de793f88a82ea7b9780c76c4f665264d02;hb=fc865468d88d45e76e21a9db2445a4b970f7423b;hp=c0ffb1dcba3bc59fe5717ca8d89645ce899452b5;hpb=d19938ab6053e3dad75a68a60ef8cad1f378b0e5;p=git.git diff --git a/git-prune-script b/git-prune-script index c0ffb1dc..ec9f72de 100755 --- a/git-prune-script +++ b/git-prune-script @@ -11,30 +11,15 @@ do shift; done -# Defaulting to include .git/refs/*/* may be debatable from the -# purist POV but power users can always give explicit parameters -# to the script anyway. - -case "$#" in -0) - x_40='[0-9a-f][0-9a-f][0-9a-f][0-9a-f][0-9a-f]' - x_40="$x_40$x_40$x_40$x_40$x_40$x_40$x_40$x_40" - set x $(sed -ne "/^$x_40\$/p" .git/HEAD .git/refs/*/* 2>/dev/null) - shift ;; -esac +: ${GIT_DIR=.git} +: ${GIT_OBJECT_DIRECTORY="${SHA1_FILE_DIRECTORY-"$GIT_DIR/objects"}"} git-fsck-cache --cache --unreachable "$@" | sed -ne '/unreachable /{ s/unreachable [^ ][^ ]* // s|\(..\)|\1/|p }' | { - for d in "$GIT_OBJECT_DIRECTORY" "$SHA1_FILE_DIRECTORY" '' - do - test "$d" != "" && test -d "$d" && break - done - case "$d" in - '') cd .git/objects/ ;; - *) cd "$d" ;; - esac || exit + cd "$GIT_OBJECT_DIRECTORY" || exit xargs -r $dryrun rm -f } +