X-Git-Url: https://git.madduck.net/code/vcsh.git/blobdiff_plain/3a4566421e1f718a9b2dc2c69212c291660b296c..875822eef55e3a00043c56ebfb02d983580c5b9c:/vcsh diff --git a/vcsh b/vcsh index c26b50a..62310a7 100755 --- a/vcsh +++ b/vcsh @@ -19,7 +19,7 @@ help() { init Initialize a new repository clone - Clone from an existing repository + [] Clone from an existing repository exit Exit vcsh mode" >&2 } @@ -40,12 +40,12 @@ use() { init() { [[ -e $GIT_DIR ]] && - echo "$(basename $0): fatal: $GIT_DIR exists" && + echo "$SELF: fatal: $GIT_DIR exists" && return 21 export GIT_WORK_TREE="$HOME" mkdir -p $GIT_WORK_TREE cd $GIT_WORK_TREE || - (echo "$(basename $0): fatal: could not enter $GIT_WORK_TREE" && + (echo "$SELF: fatal: could not enter $GIT_WORK_TREE" && exit 20) || exit 20 cd $GIT_WORK_TREE git init @@ -80,7 +80,7 @@ elif [ "$1" = 'use' ]; then if [[ -o NO_IGNORE_EOF ]]; then export VCSH_NO_IGNORE_EOF=1 setopt IGNORE_EOF - vcsh_exit() {vcsh exit; zle reset-prompt} + vcsh_exit() {vcsh exit; zle reset-prompt;} zle -N vcsh_exit bindkey '^d' 'vcsh_exit' fi @@ -89,8 +89,10 @@ elif [ "$1" = 'use' ]; then return 0 elif [ "$1" = 'clone' ]; then - export GIT_REMOTE="$2" - export REPO_NAME="$3" + GIT_REMOTE="$2" + REPO_NAME="$3" + [[ -z $REPO_NAME ]] && REPO_NAME=$(basename $GIT_REMOTE .git) + export REPO_NAME export GIT_DIR="$VCSH_BASE/$REPO_NAME.git" init @@ -100,11 +102,11 @@ elif [ "$1" = 'clone' ]; then git fetch for i in $(git ls-tree -r origin/master | awk '{print $4}'); do [[ -e $i ]] && - echo "$(basename $0): error: $i exists." && + echo "$SELF: error: $i exists." && CONFLICT=1; done [[ -n $CONFLICT ]] && - echo "$(basename $0): fatal: will stop after fetching and not try to merge!\n" && + echo "$SELF: fatal: will stop after fetching and not try to merge!\n" && exit 3 git merge origin/master vcsh use $REPO_NAME