Commit e6df0e03 authored by Marc Cornellà's avatar Marc Cornellà
Browse files

Clean up and refactor code in svn plugin

parent f573247a
# vim:ft=zsh ts=2 sw=2 sts=2 svn_prompt_info() {
#
function svn_prompt_info() {
local _DISPLAY local _DISPLAY
if in_svn; then if in_svn; then
if [ "x$SVN_SHOW_BRANCH" = "xtrue" ]; then if [[ "$SVN_SHOW_BRANCH" = true ]]; then
unset SVN_SHOW_BRANCH unset SVN_SHOW_BRANCH
_DISPLAY=$(svn_get_branch_name) _DISPLAY=$(svn_get_branch_name)
else else
...@@ -16,21 +14,18 @@ $ZSH_THEME_REPO_NAME_COLOR$_DISPLAY$ZSH_PROMPT_BASE_COLOR$ZSH_THEME_SVN_PROMPT_S ...@@ -16,21 +14,18 @@ $ZSH_THEME_REPO_NAME_COLOR$_DISPLAY$ZSH_PROMPT_BASE_COLOR$ZSH_THEME_SVN_PROMPT_S
} }
function in_svn() { in_svn() {
if $(svn info >/dev/null 2>&1); then svn info >/dev/null 2>&1
return 0
fi
return 1
} }
function svn_get_repo_name() { svn_get_repo_name() {
if in_svn; then if in_svn; then
LANG=C svn info | sed -n 's/^Repository\ Root:\ .*\///p' | read SVN_ROOT LANG=C svn info | sed -n 's/^Repository\ Root:\ .*\///p' | read SVN_ROOT
LANG=C svn info | sed -n "s/^URL:\ .*$SVN_ROOT\///p" LANG=C svn info | sed -n "s/^URL:\ .*$SVN_ROOT\///p"
fi fi
} }
function svn_get_branch_name() { svn_get_branch_name() {
local _DISPLAY=$( local _DISPLAY=$(
LANG=C svn info 2> /dev/null | \ LANG=C svn info 2> /dev/null | \
awk -F/ \ awk -F/ \
...@@ -45,23 +40,27 @@ function svn_get_branch_name() { ...@@ -45,23 +40,27 @@ function svn_get_branch_name() {
}' }'
) )
if [ "x$_DISPLAY" = "x" ]; then if [[ -z "$_DISPLAY" ]]; then
svn_get_repo_name svn_get_repo_name
else else
echo $_DISPLAY echo $_DISPLAY
fi fi
} }
function svn_get_rev_nr() { svn_get_rev_nr() {
if in_svn; then if in_svn; then
LANG=C svn info 2> /dev/null | sed -n 's/Revision:\ //p' LANG=C svn info 2> /dev/null | sed -n 's/Revision:\ //p'
fi fi
} }
function svn_dirty_choose() { svn_dirty() {
svn_dirty_choose $ZSH_THEME_SVN_PROMPT_DIRTY $ZSH_THEME_SVN_PROMPT_CLEAN
}
svn_dirty_choose() {
if in_svn; then if in_svn; then
local root=`LANG=C svn info 2> /dev/null | sed -n 's/^Working Copy Root Path: //p'` local root=$(LANG=C svn info 2> /dev/null | sed -n 's/^Working Copy Root Path: //p')
if $(svn status $root 2> /dev/null | command grep -Eq '^\s*[ACDIM!?L]'); then if svn status $root 2> /dev/null | command grep -Eq '^\s*[ACDIM!?L]'; then
# Grep exits with 0 when "One or more lines were selected", return "dirty". # Grep exits with 0 when "One or more lines were selected", return "dirty".
echo $1 echo $1
else else
...@@ -71,14 +70,13 @@ function svn_dirty_choose() { ...@@ -71,14 +70,13 @@ function svn_dirty_choose() {
fi fi
} }
function svn_dirty() { svn_dirty_pwd () {
svn_dirty_choose $ZSH_THEME_SVN_PROMPT_DIRTY $ZSH_THEME_SVN_PROMPT_CLEAN svn_dirty_choose_pwd $ZSH_THEME_SVN_PROMPT_DIRTY_PWD $ZSH_THEME_SVN_PROMPT_CLEAN_PWD
} }
function svn_dirty_choose_pwd () { svn_dirty_choose_pwd () {
if in_svn; then if in_svn; then
local root=$PWD if svn status "$PWD" 2> /dev/null | command grep -Eq '^\s*[ACDIM!?L]'; then
if $(svn status $root 2> /dev/null | command grep -Eq '^\s*[ACDIM!?L]'); then
# Grep exits with 0 when "One or more lines were selected", return "dirty". # Grep exits with 0 when "One or more lines were selected", return "dirty".
echo $1 echo $1
else else
...@@ -87,9 +85,3 @@ function svn_dirty_choose_pwd () { ...@@ -87,9 +85,3 @@ function svn_dirty_choose_pwd () {
fi fi
fi fi
} }
function svn_dirty_pwd () {
svn_dirty_choose_pwd $ZSH_THEME_SVN_PROMPT_DIRTY_PWD $ZSH_THEME_SVN_PROMPT_CLEAN_PWD
}
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment