Merge branch 'refactor/fossil' into develop

Close #274
https://github.com/nojhan/liquidprompt/pull/274
This commit is contained in:
Olivier Mengué 2014-03-28 17:16:02 +01:00
commit 465d008ebd

View File

@ -926,9 +926,9 @@ _lp_fossil_branch()
{ {
[[ "$LP_ENABLE_FOSSIL" != 1 ]] && return [[ "$LP_ENABLE_FOSSIL" != 1 ]] && return
local branch local branch
branch="$(fossil status 2>/dev/null | grep tags: | cut -c17-)" branch=$(fossil status 2>/dev/null | sed -n "s/tags:[ ]*\(\w*\)$/\1/Ip")
if [[ -n "$branch" ]] ; then if [ -n "$branch" ]; then
_lp_escape "$branch" echo "$branch"
else else
if fossil info &>/dev/null ; then if fossil info &>/dev/null ; then
echo "no-tag" echo "no-tag"
@ -951,76 +951,30 @@ _lp_fossil_branch_color()
local branch local branch
branch="$(_lp_fossil_branch)" branch="$(_lp_fossil_branch)"
if [[ -n "$branch" ]] ; then if [ -n "$branch" ]; then
local C2E # Modified files (added or edited) local -i C2E # Modified files (added or edited)
local C2D # Deleted files
local C2A # Extras files local C2A # Extras files
local C2AA # Added files
local PLUSLINE # Added lines
local MINUSLINE # Deleted lines
local ret local ret
C2E=$(fossil changes | wc -l) C2E=$(fossil changes | wc -l)
C2A=$(fossil extras | wc -l) C2A=$(fossil extras | wc -l)
PLUSLINE=$(fossil diff | egrep -c '^\+[^+].+$') ret=$(fossil diff -i -v | awk "/^(+[^+])|(+$)/ { plus+=1; } /^(-[^-])|(-$)/ { minus+=1; } END { total=\"\"; if(plus>0){ total=\"+\"plus; if(minus>0) total=total\"/\"; } if(minus>0) total=total\"-\"minus; print total;}")
MINUSLINE=$(fossil diff | egrep -c '^-[^-].+$')
ret=""
C2AA=$(fossil changes | grep -c "ADDED") if (( C2E > 0 )); then
if [[ $C2AA -gt 0 ]] ; then [[ -n "$ret" ]] && ret+=" in "
# We count the line "à la" git ret="(${LP_COLOR_DIFF}${ret}${C2E}${NO_COL})"
local ADDFILE
local FILE
ADDFILE=$(fossil changes | grep ADDED | sed -e 's/\s\{2,\}/ /g' | cut -d" " -f2)
for FILE in $ADDFILE ; do
PLULI=$(wc -l < $FILE)
let PLUSLINE=$PLUSLINE+$PLULI
done
fi fi
if [[ $PLUSLINE -gt 0 ]] ; then if (( $C2A > 0 )); then
ret+="+$PLUSLINE" C2A="$LP_COLOR_CHANGES$LP_MARK_UNTRACKED"
fi
C2D=$(fossil changes | grep -c "DELETED")
if [[ $C2D -gt 0 ]] ; then
# We count the line "à la" git
local DELFILE
local FILE
DELFILE=$(fossil changes | grep DELETED | sed -e 's/\s\{2,\}/ /g' | cut -d" " -f2)
for FILE in $DELFILE ; do
MINLI=$(wc -l < $FILE)
let MINUSLINE=$MINUSLINE+$MINLI
done
fi
if [[ $MINUSLINE -gt 0 ]] ; then
if [[ "$ret" = "" ]] ; then
ret+="-$MINUSLINE"
else
ret+="/-$MINUSLINE"
fi
fi
if [[ "$C2E" -gt 0 ]] ; then
ret+=" in $C2E"
fi
if [[ "$C2A" -gt 0 ]] ; then
C2A="$LP_MARK_UNTRACKED"
else else
C2A="" C2A=""
fi fi
if [[ "$ret" != "" ]] ; then if [[ "$branch" = "no-tag" ]]; then
ret="(${LP_COLOR_DIFF}$ret${NO_COL})"
fi
if [[ "$branch" = "no-tag" ]] ; then
# Warning, your branch has no tag name ! # Warning, your branch has no tag name !
branch="${LP_COLOR_COMMITS}$branch${NO_COL}$ret${LP_COLOR_COMMITS}$C2A${NO_COL}" branch="${LP_COLOR_COMMITS}$branch${NO_COL}$ret${LP_COLOR_COMMITS}$C2A${NO_COL}"
else else
if [[ "$C2E" -eq 0 && "$C2D" -eq 0 ]] ; then if (( C2E == 0 )); then
# All is up-to-date # All is up-to-date
branch="${LP_COLOR_UP}$branch$C2A${NO_COL}" branch="${LP_COLOR_UP}$branch$C2A${NO_COL}"
else else
@ -1028,7 +982,7 @@ _lp_fossil_branch_color()
branch="${LP_COLOR_CHANGES}$branch${NO_COL}$ret${LP_COLOR_CHANGES}$C2A${NO_COL}" branch="${LP_COLOR_CHANGES}$branch${NO_COL}$ret${LP_COLOR_CHANGES}$C2A${NO_COL}"
fi fi
fi fi
_lp_escape "$branch" echo "$branch"
fi fi
} }