summaryrefslogtreecommitdiff
path: root/plugins/mercurial/mercurial.plugin.zsh
diff options
context:
space:
mode:
authoryleo77 <ylep77@gmail.com>2013-07-16 16:37:18 +0800
committeryleo77 <ylep77@gmail.com>2013-07-16 16:37:18 +0800
commit67b2781f6200a0dff35055eb67937a0df2be2c51 (patch)
tree73b692f4146042966f7d2fed10ab88946cbc077b /plugins/mercurial/mercurial.plugin.zsh
parent6b832b93588567cb00b9a9e8170a5ebf539dea51 (diff)
parent7f74294d7aa7ab86e18e70a1153c15fa373c5849 (diff)
downloadzsh-67b2781f6200a0dff35055eb67937a0df2be2c51.tar.gz
zsh-67b2781f6200a0dff35055eb67937a0df2be2c51.tar.bz2
zsh-67b2781f6200a0dff35055eb67937a0df2be2c51.zip
Merge remote-tracking branch 'robbyrussell/master'
Diffstat (limited to 'plugins/mercurial/mercurial.plugin.zsh')
-rw-r--r--plugins/mercurial/mercurial.plugin.zsh47
1 files changed, 43 insertions, 4 deletions
diff --git a/plugins/mercurial/mercurial.plugin.zsh b/plugins/mercurial/mercurial.plugin.zsh
index 9aa2d167a..c18aa726c 100644
--- a/plugins/mercurial/mercurial.plugin.zsh
+++ b/plugins/mercurial/mercurial.plugin.zsh
@@ -1,4 +1,3 @@
-
# Mercurial
alias hgc='hg commit'
alias hgb='hg branch'
@@ -17,8 +16,48 @@ 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
+}
+
+function hgic() {
+ hg incoming "$@" | grep "changeset" | wc -l
+}
+
+function hgoc() {
+ hg outgoing "$@" | grep "changeset" | wc -l
+}