]>
git.madduck.net Git - etc/zsh.git/blobdiff - .zsh/zshrc/60_vcsprompt
madduck's git repository
Every one of the projects in this repository is available at the canonical
URL git://git.madduck.net/madduck/pub/<projectpath> — see
each project's metadata for the exact URL.
All patches and comments are welcome. Please squash your changes to logical
commits before using git-format-patch and git-send-email to
patches@ git. madduck. net .
If you'd read over the Git project's submission guidelines and adhered to them,
I'd be especially grateful.
SSH access, as well as push access can be individually
arranged .
If you use my repositories frequently, consider adding the following
snippet to ~/.gitconfig and using the third clone URL listed for each
project:
[url "git://git.madduck.net/madduck/"]
insteadOf = madduck:
local dir
while true; do
[ -d ${dir}.git ] && echo git && break
local dir
while true; do
[ -d ${dir}.git ] && echo git && break
+ [ -d "$GIT_DIR" ] && echo git && break
[ -d ${dir}.bzr ] && echo bzr && break
[ -d ${dir}.hg ] && echo hg && break
[ "$(readlink -f ${dir:-.})" = / ] && echo NONE && break
[ -d ${dir}.bzr ] && echo bzr && break
[ -d ${dir}.hg ] && echo hg && break
[ "$(readlink -f ${dir:-.})" = / ] && echo NONE && break
# shortcut: if there are no arguments, return a default prompt
if [ -z "${1:-}" ]; then
# shortcut: if there are no arguments, return a default prompt
if [ -z "${1:-}" ]; then
- pwdnamed="${(%):-'%${_PROMPT_PATH_MAXLEN}<..<%~%<<' }"
+ pwdnamed="${(%):-%${_PROMPT_PATH_MAXLEN}<..<%~%<< }"
echo "$pwdnamed"
return
fi
echo "$pwdnamed"
return
fi
precomps=$(($#apwdnamed - $postcomps))
local postfix
precomps=$(($#apwdnamed - $postcomps))
local postfix
- (( $postcomps > 0 )) && postfix="${(%):-'%${postcomps}~' }"
+ (( $postcomps > 0 )) && postfix="${(%):-%${postcomps}~ }"
# we don't want the prompt to get too long, so keep the total prompt length
# under $_PROMPT_PATH_MAXLEN (25), but ensure that the prefix is not shorter
# we don't want the prompt to get too long, so keep the total prompt length
# under $_PROMPT_PATH_MAXLEN (25), but ensure that the prefix is not shorter
prelen=$((${_PROMPT_PATH_MAXLEN:-25} - $#branch - $#postfix))
minlen=${_PROMPT_PATH_MINLEN:-10}
(( $prelen < $minlen )) && prelen=$minlen
prelen=$((${_PROMPT_PATH_MAXLEN:-25} - $#branch - $#postfix))
minlen=${_PROMPT_PATH_MINLEN:-10}
(( $prelen < $minlen )) && prelen=$minlen
- prefix="${(%):-'%${prelen}<..<%-${precomps}~%<<' }"
+ prefix="${(%):-%${prelen}<..<%-${precomps}~%<< }"
echo "'$prefix'" "'$branch'" "'$postfix'"
}
echo "'$prefix'" "'$branch'" "'$postfix'"
}
branch="$(__git_get_branch)" ||
{ error "could not determine git branch"; return 1 }
eval set -- $(__vcs_get_prompt_path_components "$reporoot" "$branch")
branch="$(__git_get_branch)" ||
{ error "could not determine git branch"; return 1 }
eval set -- $(__vcs_get_prompt_path_components "$reporoot" "$branch")
- [ -d "$GIT_DIR" ] && set -- "$GIT_DIR" "$2" "$1"
+ if [ -d "$GIT_DIR" ]; then
+ # poor man's replace until I find out how to do named dirs properly
+ # here:
+ local _D="${GIT_DIR/$HOME/~}"
+ set -- "$_D" "$2" "${${1#$_D}%/}"
+ fi
;;
hg)
reporoot="$(__hg_get_reporoot)" ||
;;
hg)
reporoot="$(__hg_get_reporoot)" ||