Commit 1304ed8d authored by Brice Dutheil's avatar Brice Dutheil
Browse files

Report the SVN need upgrade

This happen when subversion 1.7+ is used on a repository created with subversion up to 1.6
parent 9ce1b628
...@@ -10,7 +10,7 @@ ...@@ -10,7 +10,7 @@
# *** 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 parse_svn() { function parse_svn() {
info=$(svn info 2> /dev/null) || return info=$(svn info 2>&1) || return; # capture stdout and stdout
in_svn=true in_svn=true
repo_need_upgrade="$(svn_repo_need_upgrade $info)" repo_need_upgrade="$(svn_repo_need_upgrade $info)"
svn_branch_name="$(svn_get_branch_name $info)" svn_branch_name="$(svn_get_branch_name $info)"
...@@ -22,7 +22,13 @@ function parse_svn() { ...@@ -22,7 +22,13 @@ function parse_svn() {
function svn_prompt_info() { function svn_prompt_info() {
eval parse_svn eval parse_svn
if [ ${in_svn} ]; then if [ ! -z $repo_need_upgrade ]; then
echo $ZSH_PROMPT_BASE_COLOR$ZSH_THEME_SVN_PROMPT_PREFIX$ZSH_PROMPT_BASE_COLOR\
$repo_need_upgrade\
$ZSH_PROMPT_BASE_COLOR$ZSH_THEME_SVN_PROMPT_SUFFIX$ZSH_PROMPT_BASE_COLOR
fi
if [[ ${in_svn} == true && -z $repo_need_upgrade ]]; then
echo "$ZSH_PROMPT_BASE_COLOR$ZSH_THEME_SVN_PROMPT_PREFIX\ echo "$ZSH_PROMPT_BASE_COLOR$ZSH_THEME_SVN_PROMPT_PREFIX\
$ZSH_THEME_REPO_NAME_COLOR${svn_branch_name}\ $ZSH_THEME_REPO_NAME_COLOR${svn_branch_name}\
$ZSH_PROMPT_BASE_COLOR${svn_dirty}\ $ZSH_PROMPT_BASE_COLOR${svn_dirty}\
...@@ -34,8 +40,8 @@ $ZSH_PROMPT_BASE_COLOR" ...@@ -34,8 +40,8 @@ $ZSH_PROMPT_BASE_COLOR"
function svn_repo_need_upgrade() { function svn_repo_need_upgrade() {
info=$1 info=$1
[ -z "${info}" ] && info=$(svn info 2> /dev/null) [ -z "${info}" ] && info=$(svn info 2>&1)
[ "${info}" = "E155036" ] && echo "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() {
...@@ -61,4 +67,4 @@ function svn_get_revision() { ...@@ -61,4 +67,4 @@ function svn_get_revision() {
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 svn status | grep -E '^\s*[ACDIM!?L]' > /dev/null 2>/dev/null && echo $ZSH_THEME_SVN_PROMPT_DIRTY && return
echo $ZSH_THEME_SVN_PROMPT_CLEAN echo $ZSH_THEME_SVN_PROMPT_CLEAN
} }
\ No newline at end of file
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