perf(mercurial): optimize utility functions

parent d058801a
...@@ -21,65 +21,86 @@ alias hgo='hg outgoing' ...@@ -21,65 +21,86 @@ alias hgo='hg outgoing'
alias hglg='hg log --stat -v' alias hglg='hg log --stat -v'
alias hglgp='hg log --stat -p -v' alias hglgp='hg log --stat -p -v'
function in_hg() { function hgic() {
if $(hg branch > /dev/null 2>&1); then hg incoming "$@" | grep "changeset" | wc -l
echo 1
fi
} }
function hg_get_branch_name() { function hgoc() {
branch=`hg branch 2>/dev/null` hg outgoing "$@" | grep "changeset" | wc -l
if [ $? -eq 0 ]; then }
echo $branch
# functions
function hg_root() {
local dir="$PWD"
while [[ "$dir" != "/" ]]; do
if [[ -d "$dir/.hg" ]]; then
echo "$dir"
return 0
fi fi
unset branch dir="${dir:h}"
done
return 1
} }
function hg_prompt_info { function in_hg() {
local info rev branch dirty hg_root >/dev/null
}
if ! info=$(hg id --id --branch 2>/dev/null); then function hg_get_branch_name() {
local dir
if ! dir=$(hg_root); then
return return
fi fi
rev="${info[(w)1]}" if [[ ! -f "$dir/.hg/branch" ]]; then
branch="${${info[(w)2]}:gs/%/%%}" echo default
return
if [[ "$rev" = *+ ]]; then
dirty="$ZSH_THEME_HG_PROMPT_DIRTY"
else
dirty="$ZSH_THEME_HG_PROMPT_CLEAN"
fi fi
echo "${ZSH_THEME_HG_PROMPT_PREFIX}${branch}${dirty}${ZSH_THEME_HG_PROMPT_SUFFIX}" echo "$(<"$dir/.hg/branch")"
} }
function hg_dirty_choose { function hg_get_bookmark_name() {
hg status -mar 2> /dev/null | command grep -Eq '^\s*[ACDIM!?L]' local dir
if [ $? -eq 0 ]; then if ! dir=$(hg_root); then
if [ $pipestatus[-1] -eq 0 ]; then
# Grep exits with 0 when "One or more lines were selected", return "dirty".
echo $1
return return
fi fi
if [[ ! -f "$dir/.hg/bookmarks.current" ]]; then
return
fi fi
echo $2
}
function hg_dirty { echo "$(<"$dir/.hg/bookmarks.current")"
hg_dirty_choose $ZSH_THEME_HG_PROMPT_DIRTY $ZSH_THEME_HG_PROMPT_CLEAN
} }
function hgic() { function hg_prompt_info {
hg incoming "$@" | grep "changeset" | wc -l local dir branch dirty
} if ! dir=$(hg_root); then
return
fi
function hgoc() { if [[ ! -f "$dir/.hg/branch" ]]; then
hg outgoing "$@" | grep "changeset" | wc -l branch=default
else
branch="$(<"$dir/.hg/branch")"
fi
dirty="$(hg_dirty)"
echo "${ZSH_THEME_HG_PROMPT_PREFIX}${branch:gs/%/%%}${dirty}${ZSH_THEME_HG_PROMPT_SUFFIX}"
} }
function hg_get_bookmark_name() { function hg_dirty {
if [ $(in_hg) ]; then local hg_status
echo $(hg id -B) if ! hg_status="$(hg status -mar 2>/dev/null)"; then
return
fi fi
# grep exits with 0 when dirty
if command grep -Eq '^\s*[ACDIM!?L]' <<< "$hg_status"; then
echo $ZSH_THEME_HG_PROMPT_DIRTY
return
fi
echo $ZSH_THEME_HG_PROMPT_CLEAN
} }
...@@ -2,19 +2,21 @@ ZSH_THEME_GIT_PROMPT_PREFIX="%{$reset_color%}%{$fg[white]%}[" ...@@ -2,19 +2,21 @@ ZSH_THEME_GIT_PROMPT_PREFIX="%{$reset_color%}%{$fg[white]%}["
ZSH_THEME_GIT_PROMPT_SUFFIX="" ZSH_THEME_GIT_PROMPT_SUFFIX=""
ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg[red]%}●%{$fg[white]%}]%{$reset_color%} " ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg[red]%}●%{$fg[white]%}]%{$reset_color%} "
ZSH_THEME_GIT_PROMPT_CLEAN="]%{$reset_color%} " ZSH_THEME_GIT_PROMPT_CLEAN="]%{$reset_color%} "
ZSH_THEME_SVN_PROMPT_PREFIX=$ZSH_THEME_GIT_PROMPT_PREFIX
ZSH_THEME_SVN_PROMPT_SUFFIX=$ZSH_THEME_GIT_PROMPT_SUFFIX ZSH_THEME_SVN_PROMPT_PREFIX="$ZSH_THEME_GIT_PROMPT_PREFIX"
ZSH_THEME_SVN_PROMPT_DIRTY=$ZSH_THEME_GIT_PROMPT_DIRTY ZSH_THEME_SVN_PROMPT_SUFFIX="$ZSH_THEME_GIT_PROMPT_SUFFIX"
ZSH_THEME_SVN_PROMPT_CLEAN=$ZSH_THEME_GIT_PROMPT_CLEAN ZSH_THEME_SVN_PROMPT_DIRTY="$ZSH_THEME_GIT_PROMPT_DIRTY"
ZSH_THEME_HG_PROMPT_PREFIX=$ZSH_THEME_GIT_PROMPT_PREFIX ZSH_THEME_SVN_PROMPT_CLEAN="$ZSH_THEME_GIT_PROMPT_CLEAN"
ZSH_THEME_HG_PROMPT_SUFFIX=$ZSH_THEME_GIT_PROMPT_SUFFIX
ZSH_THEME_HG_PROMPT_DIRTY=$ZSH_THEME_GIT_PROMPT_DIRTY ZSH_THEME_HG_PROMPT_PREFIX="$ZSH_THEME_GIT_PROMPT_PREFIX"
ZSH_THEME_HG_PROMPT_CLEAN=$ZSH_THEME_GIT_PROMPT_CLEAN ZSH_THEME_HG_PROMPT_SUFFIX="$ZSH_THEME_GIT_PROMPT_SUFFIX"
ZSH_THEME_HG_PROMPT_DIRTY="$ZSH_THEME_GIT_PROMPT_DIRTY"
ZSH_THEME_HG_PROMPT_CLEAN="$ZSH_THEME_GIT_PROMPT_CLEAN"
vcs_status() { vcs_status() {
if [[ $(whence in_svn) != "" ]] && in_svn; then if (( ${+functions[in_svn]} )) && in_svn; then
svn_prompt_info svn_prompt_info
elif [[ $(whence in_hg) != "" ]] && in_hg; then elif (( ${+functions[in_hg]} )) && in_hg; then
hg_prompt_info hg_prompt_info
else else
git_prompt_info git_prompt_info
......
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