diff options
author | Robby Russell <robby@planetargon.com> | 2013-06-25 09:13:26 -0700 |
---|---|---|
committer | Robby Russell <robby@planetargon.com> | 2013-06-25 09:13:26 -0700 |
commit | 0868d71307b1528852dfa166a2dfb24731475bbf (patch) | |
tree | 943ccd3f6c6dd654946daad6a40f14c16fb515dc | |
parent | 4f8d6a8b15e807989ec814bdf4bcb408ccdde1c9 (diff) | |
parent | bf9645224b529be0e03655b4cef9c32f66c76015 (diff) | |
download | zsh-0868d71307b1528852dfa166a2dfb24731475bbf.tar.gz zsh-0868d71307b1528852dfa166a2dfb24731475bbf.tar.bz2 zsh-0868d71307b1528852dfa166a2dfb24731475bbf.zip |
Merge pull request #1708 from tessi/extend_mercurial_plugin
extend mercurial plugin
-rw-r--r-- | plugins/mercurial/mercurial.plugin.zsh | 38 |
1 files changed, 35 insertions, 3 deletions
diff --git a/plugins/mercurial/mercurial.plugin.zsh b/plugins/mercurial/mercurial.plugin.zsh index 9aa2d167a..83dd578b3 100644 --- a/plugins/mercurial/mercurial.plugin.zsh +++ b/plugins/mercurial/mercurial.plugin.zsh @@ -17,8 +17,40 @@ alias hgs='hg status' # this is the 'git commit --amend' equivalent alias hgca='hg qimport -r tip ; hg qrefresh -e ; hg qfinish tip' -function hg_current_branch() { - if [ -d .hg ]; then - echo hg:$(hg branch) +function in_hg() { + if [[ -d .hg ]] || $(hg summary > /dev/null 2>&1); then + echo 1 fi } + +function hg_get_branch_name() { + if [ $(in_hg) ]; then + echo $(hg branch) + fi +} + +function hg_prompt_info { + if [ $(in_hg) ]; then + _DISPLAY=$(hg_get_branch_name) + echo "$ZSH_PROMPT_BASE_COLOR$ZSH_THEME_HG_PROMPT_PREFIX\ +$ZSH_THEME_REPO_NAME_COLOR$_DISPLAY$ZSH_PROMPT_BASE_COLOR$ZSH_THEME_HG_PROMPT_SUFFIX$ZSH_PROMPT_BASE_COLOR$(hg_dirty)$ZSH_PROMPT_BASE_COLOR" + unset _DISPLAY + fi +} + +function hg_dirty_choose { + if [ $(in_hg) ]; then + hg status 2> /dev/null | grep -Eq '^\s*[ACDIM!?L]' + if [ $pipestatus[-1] -eq 0 ]; then + # Grep exits with 0 when "One or more lines were selected", return "dirty". + echo $1 + else + # Otherwise, no lines were found, or an error occurred. Return clean. + echo $2 + fi + fi +} + +function hg_dirty { + hg_dirty_choose $ZSH_THEME_HG_PROMPT_DIRTY $ZSH_THEME_HG_PROMPT_CLEAN +} |