2011-06-10 13:38:59 +00:00
|
|
|
# Mercurial
|
2012-01-05 22:39:13 +00:00
|
|
|
alias hgc='hg commit'
|
|
|
|
alias hgb='hg branch'
|
2011-06-10 13:38:59 +00:00
|
|
|
alias hgba='hg branches'
|
2013-04-09 10:11:51 +00:00
|
|
|
alias hgbk='hg bookmarks'
|
2011-06-10 13:38:59 +00:00
|
|
|
alias hgco='hg checkout'
|
|
|
|
alias hgd='hg diff'
|
|
|
|
alias hged='hg diffmerge'
|
|
|
|
# pull and update
|
2013-03-11 10:24:12 +00:00
|
|
|
alias hgi='hg incoming'
|
2012-01-05 22:39:13 +00:00
|
|
|
alias hgl='hg pull -u'
|
2013-03-27 06:16:46 +00:00
|
|
|
alias hglr='hg pull --rebase'
|
2013-03-11 10:24:12 +00:00
|
|
|
alias hgo='hg outgoing'
|
2012-01-05 22:39:13 +00:00
|
|
|
alias hgp='hg push'
|
|
|
|
alias hgs='hg status'
|
2014-03-10 03:41:25 +00:00
|
|
|
alias hgsl='hg log --limit 20 --template "{node|short} | {date|isodatesec} | {author|user}: {desc|strip|firstline}\n" '
|
2015-11-26 14:08:53 +00:00
|
|
|
alias hgca='hg commit --amend'
|
2013-10-18 13:23:27 +00:00
|
|
|
# list unresolved files (since hg does not list unmerged files in the status command)
|
|
|
|
alias hgun='hg resolve --list'
|
2012-10-05 20:27:05 +00:00
|
|
|
|
2018-02-18 23:54:32 +00:00
|
|
|
function hg_get_dir() {
|
|
|
|
# Defines path as current directory
|
|
|
|
local current_dir=$PWD
|
|
|
|
# While current path is not root path
|
|
|
|
while [[ $current_dir != '/' ]]; do
|
|
|
|
if [[ -d "${current_dir}/.hg" ]]; then
|
|
|
|
echo "${current_dir}/.hg"
|
|
|
|
return
|
|
|
|
fi
|
|
|
|
# Defines path as parent directory and keeps looking for
|
|
|
|
current_dir="${current_dir:h}"
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
2013-04-24 06:33:02 +00:00
|
|
|
function in_hg() {
|
2018-02-18 23:54:32 +00:00
|
|
|
if [[ $(hg_get_dir) != "" ]]; then
|
2013-04-24 06:33:02 +00:00
|
|
|
echo 1
|
2012-10-05 20:27:05 +00:00
|
|
|
fi
|
2013-03-11 10:24:12 +00:00
|
|
|
}
|
2013-04-24 06:33:02 +00:00
|
|
|
|
|
|
|
function hg_get_branch_name() {
|
2018-02-18 23:54:32 +00:00
|
|
|
local hg_dir=$(hg_get_dir)
|
|
|
|
if [[ $hg_dir != "" ]]; then
|
|
|
|
if [[ -f "${hg_dir}/branch" ]]; then
|
|
|
|
echo $(<"${hg_dir}/branch")
|
|
|
|
else
|
|
|
|
echo "default"
|
|
|
|
fi
|
2013-04-24 06:33:02 +00:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
function hg_prompt_info {
|
2018-02-18 23:54:32 +00:00
|
|
|
local branch=$(hg_get_branch_name)
|
|
|
|
if [[ $branch != "" ]]; then
|
2013-04-24 06:33:02 +00:00
|
|
|
echo "$ZSH_PROMPT_BASE_COLOR$ZSH_THEME_HG_PROMPT_PREFIX\
|
2018-02-18 23:54:32 +00:00
|
|
|
$ZSH_THEME_REPO_NAME_COLOR${branch}$ZSH_PROMPT_BASE_COLOR$ZSH_PROMPT_BASE_COLOR$(hg_dirty)$ZSH_THEME_HG_PROMPT_SUFFIX$ZSH_PROMPT_BASE_COLOR"
|
2013-04-24 06:33:02 +00:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
function hg_dirty_choose {
|
|
|
|
if [ $(in_hg) ]; then
|
2014-11-16 08:47:35 +00:00
|
|
|
hg status 2> /dev/null | command grep -Eq '^\s*[ACDIM!?L]'
|
2013-04-24 06:33:02 +00:00
|
|
|
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
|
|
|
|
}
|
2013-06-25 18:52:26 +00:00
|
|
|
|
|
|
|
function hgic() {
|
2018-02-18 23:54:32 +00:00
|
|
|
hg incoming "$@" | grep "changeset" | wc -l
|
2013-06-25 18:52:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function hgoc() {
|
2018-02-18 23:54:32 +00:00
|
|
|
hg outgoing "$@" | grep "changeset" | wc -l
|
2013-06-25 18:52:26 +00:00
|
|
|
}
|