1
0
Fork 0
mirror of https://github.com/ohmyzsh/ohmyzsh.git synced 2024-11-22 13:50:09 +00:00

perf(mercurial): speed up mercurial plugin (#4591)

* speed up mercurial plugin

* removed unnecesay limit to current dir from hg status
This commit is contained in:
Michał Duszyk 2021-06-13 19:40:07 +02:00 committed by GitHub
parent 70a0577712
commit 027189b294
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -19,37 +19,38 @@ alias hglr='hg pull --rebase'
alias hgo='hg outgoing' alias hgo='hg outgoing'
function in_hg() { function in_hg() {
if [[ -d .hg ]] || $(hg summary > /dev/null 2>&1); then if $(hg branch > /dev/null 2>&1); then
echo 1 echo 1
fi fi
} }
function hg_get_branch_name() { function hg_get_branch_name() {
if [ $(in_hg) ]; then branch=`hg branch 2>/dev/null`
echo $(hg branch) if [ $? -eq 0 ]; then
echo $branch
fi fi
unset branch
} }
function hg_prompt_info { function hg_prompt_info {
if [ $(in_hg) ]; then _DISPLAY=`hg branch 2>/dev/null`
_DISPLAY=$(hg_get_branch_name) if [ $? -eq 0 ]; then
echo "$ZSH_PROMPT_BASE_COLOR$ZSH_THEME_HG_PROMPT_PREFIX\ echo "$ZSH_PROMPT_BASE_COLOR$ZSH_THEME_HG_PROMPT_PREFIX\
$ZSH_THEME_REPO_NAME_COLOR$_DISPLAY$ZSH_PROMPT_BASE_COLOR$ZSH_PROMPT_BASE_COLOR$(hg_dirty)$ZSH_THEME_HG_PROMPT_SUFFIX$ZSH_PROMPT_BASE_COLOR" $ZSH_THEME_REPO_NAME_COLOR$_DISPLAY$ZSH_PROMPT_BASE_COLOR$ZSH_PROMPT_BASE_COLOR$(hg_dirty)$ZSH_THEME_HG_PROMPT_SUFFIX$ZSH_PROMPT_BASE_COLOR"
unset _DISPLAY
fi fi
unset _DISPLAY
} }
function hg_dirty_choose { function hg_dirty_choose {
if [ $(in_hg) ]; then hg status -mar 2> /dev/null | command grep -Eq '^\s*[ACDIM!?L]'
hg status 2> /dev/null | command grep -Eq '^\s*[ACDIM!?L]' if [ $? -eq 0 ]; then
if [ $pipestatus[-1] -eq 0 ]; then if [ $pipestatus[-1] -eq 0 ]; then
# Grep exits with 0 when "One or more lines were selected", return "dirty". # Grep exits with 0 when "One or more lines were selected", return "dirty".
echo $1 echo $1
else return
# Otherwise, no lines were found, or an error occurred. Return clean.
echo $2
fi fi
fi fi
echo $2
} }
function hg_dirty { function hg_dirty {
@ -57,11 +58,11 @@ function hg_dirty {
} }
function hgic() { function hgic() {
hg incoming "$@" | grep "changeset" | wc -l hg incoming "$@" | grep "changeset" | wc -l
} }
function hgoc() { function hgoc() {
hg outgoing "$@" | grep "changeset" | wc -l hg outgoing "$@" | grep "changeset" | wc -l
} }
function hg_get_bookmark_name() { function hg_get_bookmark_name() {