Heavy refactor of svn-fast-info

pull/2400/head
LFDM 2014-01-07 10:07:02 +01:00
parent 642ae64bc5
commit 8bf8e1ecf9
1 changed files with 50 additions and 38 deletions

View File

@ -1,4 +1,4 @@
# vim:ft=zsh ts=2 sw=2 sts=2 # vim:ft=zsh ts=2 sw=2 sts=2 et
# #
# Faster alternative to the current SVN plugin implementation. # Faster alternative to the current SVN plugin implementation.
# #
@ -10,57 +10,69 @@
# *** IMPORTANT *** DO NO USE with the simple svn plugin, this plugin acts as a replacement of it. # *** IMPORTANT *** DO NO USE with the simple svn plugin, this plugin acts as a replacement of it.
function svn_prompt_info() { function svn_prompt_info() {
info=$(svn info 2>&1) || return; # capture stdout and stdout local info
in_svn=true info=$(svn info 2>&1) || return 1; # capture stdout and stderr
repo_need_upgrade="$(svn_repo_need_upgrade $info)" local repo_need_upgrade=$(svn_repo_need_upgrade $info)
svn_branch_name="$(svn_get_branch_name $info)"
svn_dirty="$(svn_dirty_choose)"
svn_repo_name="$(svn_get_repo_name $info)"
svn_rev="$(svn_get_revision $info)"
if [ ! -z $repo_need_upgrade ]; then if [ -n $repo_need_upgrade ]; then
echo $ZSH_PROMPT_BASE_COLOR$ZSH_THEME_SVN_PROMPT_PREFIX$ZSH_PROMPT_BASE_COLOR\ printf '%s%s%s%s%s%s%s\n' \
$repo_need_upgrade\ $ZSH_PROMPT_BASE_COLOR \
$ZSH_PROMPT_BASE_COLOR$ZSH_THEME_SVN_PROMPT_SUFFIX$ZSH_PROMPT_BASE_COLOR $ZSH_THEME_SVN_PROMPT_PREFIX \
fi $ZSH_PROMPT_BASE_COLOR \
$repo_need_upgrade \
if [[ ${in_svn} == true && -z $repo_need_upgrade ]]; then $ZSH_PROMPT_BASE_COLOR \
echo "$ZSH_PROMPT_BASE_COLOR$ZSH_THEME_SVN_PROMPT_PREFIX\ $ZSH_THEME_SVN_PROMPT_SUFFIX \
$ZSH_THEME_REPO_NAME_COLOR${svn_branch_name}\ $ZSH_PROMPT_BASE_COLOR \
$ZSH_PROMPT_BASE_COLOR${svn_dirty}\ else
$ZSH_PROMPT_BASE_COLOR$ZSH_THEME_SVN_PROMPT_SUFFIX\ # something left for you to fix -
$ZSH_PROMPT_BASE_COLOR" # repo name and rev aren't used here, did you forget them?
# especially since you set a repo name color
# if the prompt is alright this way, leave it as is and just
# delete the comment. The functions itself could stay imo,
# gives others the chance to use them.
printf '%s%s%s%s%s%s%s%s%s\n' \
$ZSH_PROMPT_BASE_COLOR \
$ZSH_THEME_SVN_PROMPT_PREFIX \
$ZSH_THEME_REPO_NAME_COLOR \
$(svn_get_branch_name $info)
${svn_branch_name}\
$ZSH_PROMPT_BASE_COLOR
$(svn_dirty_choose $info)
$ZSH_PROMPT_BASE_COLOR
$ZSH_THEME_SVN_PROMPT_SUFFIX\
$ZSH_PROMPT_BASE_COLOR
fi fi
} }
function svn_repo_need_upgrade() { function svn_repo_need_upgrade() {
info=$1 grep -q "E155036" <<< ${1:-$(svn info 2> /dev/null)} && \
[ -z "${info}" ] && info=$(svn info 2>&1) echo "E155036: upgrade repo with svn upgrade"
if grep -q "E155036" <<< $info; then echo "E155036: upgrade repo with svn upgrade"; fi
} }
function svn_get_branch_name() { function svn_get_branch_name() {
info=$1 echo ${1:-$(svn info 2> /dev/null)} |\
[ -z "${info}" ] && info=$(svn info 2> /dev/null) grep '^URL:' | egrep -o '(tags|branches)/[^/]+|trunk' |\
echo $info | grep '^URL:' | egrep -o '(tags|branches)/[^/]+|trunk' | egrep -o '[^/]+$' | read SVN_URL egrep -o '[^/]+$'
echo $SVN_URL
} }
function svn_get_repo_name() { function svn_get_repo_name() {
info=$1 # I think this can be further cleaned up as well, not sure how,
[ -z "${info}" ] && info=$(svn info 2> /dev/null) # as I can't test it
echo $info | sed -n 's/Repository\ Root:\ .*\///p' | read SVN_ROOT local svn_root
echo $info | sed -n "s/URL:\ .*$SVN_ROOT\///p" local info=${1:-$(svn info 2> /dev/null)}
echo $info | sed 's/Repository\ Root:\ .*\///p' | read svn_root
echo $info | sed "s/URL:\ .*$svn_root\///p"
} }
function svn_get_revision() { function svn_get_revision() {
info=$1 # does this work as it should?
[ -z "${info}" ] && info=$(svn info 2> /dev/null) echo ${1:-$(svn info 2> /dev/null)} | sed 's/Revision: //p'
echo $info 2> /dev/null | sed -n s/Revision:\ //p
} }
function svn_dirty_choose() { function svn_dirty_choose() {
svn status | grep -E '^\s*[ACDIM!?L]' > /dev/null 2>/dev/null && echo $ZSH_THEME_SVN_PROMPT_DIRTY && return if svn status | grep -E '^\s*[ACDIM!?L]' &> /dev/null; then
echo $ZSH_THEME_SVN_PROMPT_DIRTY
else
echo $ZSH_THEME_SVN_PROMPT_CLEAN echo $ZSH_THEME_SVN_PROMPT_CLEAN
fi
} }