X-Git-Url: https://git.madduck.net/etc/zsh.git/blobdiff_plain/f47f496110c9cad7ed628f28a02c73303cc521a3..05175deb43e4643176c377b9c7d2fe828c9dae30:/.zsh/func/vcsh?ds=sidebyside diff --git a/.zsh/func/vcsh b/.zsh/func/vcsh index 0959784..655c9ea 100755 --- a/.zsh/func/vcsh +++ b/.zsh/func/vcsh @@ -10,28 +10,32 @@ # Source repository: http://git.madduck.net/v/etc/zsh.git # -FGIT_BASE="$HOME/.fgits" +local FGIT_BASE="$HOME/.fgits" if [ "${1:---help}" = '--help' ] || [ $# -gt 1 ]; then - echo "usage: ${0%/*} reponame" >&2 - echo "usage: ${0%/*} -l" >&2 + echo "usage: ${0##*/} reponame" >&2 + echo "usage: ${0##*/} -l" >&2 [ "$1" = '--help' ] - exit $? + return $? elif [ "$1" = '-l' ]; then for i in $FGIT_BASE/*.git; do i="${i#$FGIT_BASE/}" echo "${i%.git}" done - exit 0 + return 0 fi if [ ! -d "$FGIT_BASE/${1}.git" ]; then echo E: no repository found for "$1" >&2 - exit 2 + return 2 fi -export GIT_DIR=$FGIT_BASE/${1}.git +export GIT_DIR="$FGIT_BASE/${1}.git" +local _WORKTREE="$(git config --get core.worktree)" +export GIT_WORK_TREE="$(readlink -f $GIT_DIR/$_WORKTREE)" +unset _WORKTREE + git status -PS1="{VCSH:$1}$PS1" $SHELL -i +PS1="%S{${0##*/}:$1}%s$PS1" $SHELL -i