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="${(%)pwdnamed}"
+ pwdnamed="${(%):-%${_PROMPT_PATH_MAXLEN}<..<%~%<<}"
echo "$pwdnamed"
return
fi
echo "$pwdnamed"
return
fi
# replace named directories in the PWD, we need thi for the proper component
# count later
# replace named directories in the PWD, we need thi for the proper component
# count later
- local pwdnamed="%~"
- pwdnamed="${(%)pwdnamed}"
+ local pwdnamed
+ pwdnamed="${(%):-%~}"
# store paths in arrays for component count calculation
typeset -la apwd apwdnamed areporoot
# store paths in arrays for component count calculation
typeset -la apwd apwdnamed areporoot
precomps=$(($#apwdnamed - $postcomps))
local postfix
precomps=$(($#apwdnamed - $postcomps))
local postfix
- if (( $postcomps > 0 )); then
- postfix="%${postcomps}~"
- postfix="${(%)postfix}"
- fi
+ (( $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="${(%)prefix}"
+ 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:
+ _D="${GIT_DIR/$HOME/~}"
+ set -- "$_D" "$2" "${${1#$_D}%/}"
+ unset _D
+ fi
;;
hg)
reporoot="$(__hg_get_reporoot)" ||
;;
hg)
reporoot="$(__hg_get_reporoot)" ||
- psvar[1]="$1"
- psvar[2]="$2"
- psvar[3]="$3"