X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=git-sh-setup.sh;h=42f9b1c125578a7158392b53ec8792d6c6bbb273;hb=9b8dc263e1b0d470cc67a824837d8884ae3e7136;hp=dbb98842bf6327210c604ae65a128cdfc785b32c;hpb=8ac3a61f59173d4a9a328518be83a25df610a5ef;p=git.git diff --git a/git-sh-setup.sh b/git-sh-setup.sh index dbb98842b..42f9b1c12 100755 --- a/git-sh-setup.sh +++ b/git-sh-setup.sh @@ -1,10 +1,9 @@ #!/bin/sh # -# Set up GIT_DIR and GIT_OBJECT_DIRECTORY -# and return true if everything looks ok -# -: ${GIT_DIR=.git} -: ${GIT_OBJECT_DIRECTORY="$GIT_DIR/objects"} +# This is included in commands that either have to be run from the toplevel +# of the repository, or with GIT_DIR environment variable properly. +# If the GIT_DIR does not look like the right correct git-repository, +# it dies. # Having this variable in your environment would break scripts because # you would cause "cd" to be be taken to unexpected places. If you @@ -17,9 +16,31 @@ die() { exit 1 } -case "$(GIT_DIR="$GIT_DIR" git-symbolic-ref HEAD 2>/dev/null)" in -refs/*) : ;; -*) false ;; -esac && -[ -d "$GIT_DIR/refs" ] && -[ -d "$GIT_OBJECT_DIRECTORY/" ] +usage() { + die "Usage: $0 $USAGE" +} + +if [ -z "$LONG_USAGE" ] +then + LONG_USAGE="Usage: $0 $USAGE" +else + LONG_USAGE="Usage: $0 $USAGE + +$LONG_USAGE" +fi + +case "$1" in + -h|--h|--he|--hel|--help) + echo "$LONG_USAGE" + exit +esac + +# Make sure we are in a valid repository of a vintage we understand. +if [ -z "$SUBDIRECTORY_OK" ] +then + : ${GIT_DIR=.git} + GIT_DIR=$(GIT_DIR="$GIT_DIR" git-rev-parse --git-dir) || exit +else + GIT_DIR=$(git-rev-parse --git-dir) || exit +fi +: ${GIT_OBJECT_DIRECTORY="$GIT_DIR/objects"}