X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=git-prune-script;h=1a97ccc91ded1522d3016d76cbdf62557585d514;hb=7ab6f3d437b9dbe5c139162777ee46d224371ee7;hp=9ba89a5b9d0d484aee54d0bdb6deabdc71962c85;hpb=9e30dd7c0ecc9f10372f31539d0122db97418353;p=git.git diff --git a/git-prune-script b/git-prune-script index 9ba89a5b..1a97ccc9 100755 --- a/git-prune-script +++ b/git-prune-script @@ -11,6 +11,9 @@ do shift; done +: ${GIT_DIR=.git} +: ${GIT_OBJECT_DIRECTORY="${SHA1_FILE_DIRECTORY-"$GIT_DIR/objects"}"} + # Defaulting to include .git/refs/*/* may be debatable from the # purist POV but power users can always give explicit parameters # to the script anyway. @@ -19,7 +22,8 @@ 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) + set x $(sed -ne "/^$x_40\$/p" \ + "$GIT_DIR"/HEAD "$GIT_DIR"/refs/*/* /dev/null 2>/dev/null) shift ;; esac @@ -28,9 +32,7 @@ sed -ne '/unreachable /{ s/unreachable [^ ][^ ]* // s|\(..\)|\1/|p }' | { - case "$SHA1_FILE_DIRECTORY" in - '') cd .git/objects/ ;; - *) cd "$SHA1_FILE_DIRECTORY" ;; - esac || exit + cd "$GIT_OBJECT_DIRECTORY" || exit xargs -r $dryrun rm -f } +