__git_get_branch()
{
# return the name of the git branch we're on
- local ref
- ref=$(git --git-dir="$PWD" symbolic-ref -q HEAD 2>/dev/null \
- || git --git-dir="$PWD" name-rev --name-only HEAD 2>/dev/null) || return 1
+ local ref gitdir
+ gitdir="$(git rev-parse --git-dir)"
+ ref=$(git --git-dir="$gitdir" symbolic-ref -q HEAD 2>/dev/null \
+ || git --git-dir="$gitdir" name-rev --name-only HEAD 2>/dev/null) || return 1
echo "${ref#refs/heads/}"
}
branch="$(__git_get_branch)" ||
{ error "could not determine git branch"; return 1 }
eval set -- $(__vcs_get_prompt_path_components "$reporoot" "$branch")
- if [ -d "$GIT_DIR" ]; then
+ if [ -n "$VCSH_REPO_NAME" ]; then
+ set -- "vcsh/$VCSH_REPO_NAME" "$2" "$3"
+ elif [ -d "$GIT_DIR" ]; then
# poor man's replace until I find out how to do named dirs properly
# here:
local _D="${GIT_DIR/$HOME/~}"