259:25fdca9c13ed
Anton Shestakov <av6@dwimlabs.net>, 2023-01-19
.vimrc: use airline's tabline extension instead of minibufexplorer minibufexplorer is causing vim to occasionally spew errors when using completeopt=popup.

previous change 182:adcdefc73227

.bash_prompt

Permissions: -rw-r--r--

Other formats: Feeds:
0
0:226664158c55 Added .bashrc with hg prompt example.
Anton Shestakov <engored@ya.ru>
previous changes:
line | diff
#!/bin/bash
0:226664158c55 Added .bashrc with hg prompt example.
Anton Shestakov <engored@ya.ru>
previous changes:
line | diff
42
42:34ee83bd5ad2 local again. Lotsa colors. hg prompt is back, controlled by USE_HG_PROMPT.
Anton Shestakov <engored@ya.ru>
previous changes: 40:48d26a4c35ba
line | diff
function prompt_command {
42:34ee83bd5ad2 local again. Lotsa colors. hg prompt is back, controlled by USE_HG_PROMPT.
Anton Shestakov <engored@ya.ru>
previous changes: 40:48d26a4c35ba
line | diff
local RETURN_CODE="$?"
42:34ee83bd5ad2 local again. Lotsa colors. hg prompt is back, controlled by USE_HG_PROMPT.
Anton Shestakov <engored@ya.ru>
previous changes: 40:48d26a4c35ba
line | diff
42:34ee83bd5ad2 local again. Lotsa colors. hg prompt is back, controlled by USE_HG_PROMPT.
Anton Shestakov <engored@ya.ru>
previous changes: 40:48d26a4c35ba
line | diff
# dark, light, bold
161
161:606cda98621a .bash_prompt: some more colors, but mostly shellcheck-detectable nits
Anton Shestakov <av6@dwimlabs.net>
previous changes: 133:1b82b9501856
line | diff
local Kd='\[\e[0;30m\]'; local K='\[\e[0;90m\]'; local Kb='\[\e[1;30m\]'
161:606cda98621a .bash_prompt: some more colors, but mostly shellcheck-detectable nits
Anton Shestakov <av6@dwimlabs.net>
previous changes: 133:1b82b9501856
line | diff
local Rd='\[\e[0;31m\]'; local R='\[\e[0;91m\]'; local Rb='\[\e[1;31m\]'
161:606cda98621a .bash_prompt: some more colors, but mostly shellcheck-detectable nits
Anton Shestakov <av6@dwimlabs.net>
previous changes: 133:1b82b9501856
line | diff
local Gd='\[\e[0;32m\]'; local G='\[\e[0;92m\]'; local Gb='\[\e[1;32m\]'
161:606cda98621a .bash_prompt: some more colors, but mostly shellcheck-detectable nits
Anton Shestakov <av6@dwimlabs.net>
previous changes: 133:1b82b9501856
line | diff
local Yd='\[\e[0;33m\]'; local Y='\[\e[0;93m\]'; local Yb='\[\e[1;33m\]'
161:606cda98621a .bash_prompt: some more colors, but mostly shellcheck-detectable nits
Anton Shestakov <av6@dwimlabs.net>
previous changes: 133:1b82b9501856
line | diff
local Bd='\[\e[0;34m\]'; local B='\[\e[0;94m\]'; local Bb='\[\e[1;34m\]'
161:606cda98621a .bash_prompt: some more colors, but mostly shellcheck-detectable nits
Anton Shestakov <av6@dwimlabs.net>
previous changes: 133:1b82b9501856
line | diff
local Pd='\[\e[0;35m\]'; local P='\[\e[0;95m\]'; local Pb='\[\e[1;35m\]'
161:606cda98621a .bash_prompt: some more colors, but mostly shellcheck-detectable nits
Anton Shestakov <av6@dwimlabs.net>
previous changes: 133:1b82b9501856
line | diff
local Cd='\[\e[0;36m\]'; local C='\[\e[0;96m\]'; local Cb='\[\e[1;36m\]'
35
35:44a6ddc7f222 Unlocal colors, lose double quotes where not needed.
Anton Shestakov <engored@ya.ru>
previous changes: 34:6d42e8d89e7e
line | diff
42
42:34ee83bd5ad2 local again. Lotsa colors. hg prompt is back, controlled by USE_HG_PROMPT.
Anton Shestakov <engored@ya.ru>
previous changes: 40:48d26a4c35ba
line | diff
if [[ $TERM == 'linux' ]] ; then
161
161:606cda98621a .bash_prompt: some more colors, but mostly shellcheck-detectable nits
Anton Shestakov <av6@dwimlabs.net>
previous changes: 133:1b82b9501856
line | diff
K=$Kb
42
42:34ee83bd5ad2 local again. Lotsa colors. hg prompt is back, controlled by USE_HG_PROMPT.
Anton Shestakov <engored@ya.ru>
previous changes: 40:48d26a4c35ba
line | diff
R=$Rb
42:34ee83bd5ad2 local again. Lotsa colors. hg prompt is back, controlled by USE_HG_PROMPT.
Anton Shestakov <engored@ya.ru>
previous changes: 40:48d26a4c35ba
line | diff
G=$Gb
42:34ee83bd5ad2 local again. Lotsa colors. hg prompt is back, controlled by USE_HG_PROMPT.
Anton Shestakov <engored@ya.ru>
previous changes: 40:48d26a4c35ba
line | diff
Y=$Yb
42:34ee83bd5ad2 local again. Lotsa colors. hg prompt is back, controlled by USE_HG_PROMPT.
Anton Shestakov <engored@ya.ru>
previous changes: 40:48d26a4c35ba
line | diff
B=$Bb
42:34ee83bd5ad2 local again. Lotsa colors. hg prompt is back, controlled by USE_HG_PROMPT.
Anton Shestakov <engored@ya.ru>
previous changes: 40:48d26a4c35ba
line | diff
P=$Pb
42:34ee83bd5ad2 local again. Lotsa colors. hg prompt is back, controlled by USE_HG_PROMPT.
Anton Shestakov <engored@ya.ru>
previous changes: 40:48d26a4c35ba
line | diff
C=$Cb
42:34ee83bd5ad2 local again. Lotsa colors. hg prompt is back, controlled by USE_HG_PROMPT.
Anton Shestakov <engored@ya.ru>
previous changes: 40:48d26a4c35ba
line | diff
fi
35
35:44a6ddc7f222 Unlocal colors, lose double quotes where not needed.
Anton Shestakov <engored@ya.ru>
previous changes: 34:6d42e8d89e7e
line | diff
161
161:606cda98621a .bash_prompt: some more colors, but mostly shellcheck-detectable nits
Anton Shestakov <av6@dwimlabs.net>
previous changes: 133:1b82b9501856
line | diff
local BOLD='\[\e[1m\]'
161:606cda98621a .bash_prompt: some more colors, but mostly shellcheck-detectable nits
Anton Shestakov <av6@dwimlabs.net>
previous changes: 133:1b82b9501856
line | diff
local RESET='\[\e[0m\]'
42
42:34ee83bd5ad2 local again. Lotsa colors. hg prompt is back, controlled by USE_HG_PROMPT.
Anton Shestakov <engored@ya.ru>
previous changes: 40:48d26a4c35ba
line | diff
42:34ee83bd5ad2 local again. Lotsa colors. hg prompt is back, controlled by USE_HG_PROMPT.
Anton Shestakov <engored@ya.ru>
previous changes: 40:48d26a4c35ba
line | diff
local TIME="${G}\t${RESET}"
35
35:44a6ddc7f222 Unlocal colors, lose double quotes where not needed.
Anton Shestakov <engored@ya.ru>
previous changes: 34:6d42e8d89e7e
line | diff
42
42:34ee83bd5ad2 local again. Lotsa colors. hg prompt is back, controlled by USE_HG_PROMPT.
Anton Shestakov <engored@ya.ru>
previous changes: 40:48d26a4c35ba
line | diff
if [[ $RETURN_CODE != 0 ]] ; then
42:34ee83bd5ad2 local again. Lotsa colors. hg prompt is back, controlled by USE_HG_PROMPT.
Anton Shestakov <engored@ya.ru>
previous changes: 40:48d26a4c35ba
line | diff
local RETCODE="${R}${RETURN_CODE}${RESET} "
42:34ee83bd5ad2 local again. Lotsa colors. hg prompt is back, controlled by USE_HG_PROMPT.
Anton Shestakov <engored@ya.ru>
previous changes: 40:48d26a4c35ba
line | diff
fi
42:34ee83bd5ad2 local again. Lotsa colors. hg prompt is back, controlled by USE_HG_PROMPT.
Anton Shestakov <engored@ya.ru>
previous changes: 40:48d26a4c35ba
line | diff
35
35:44a6ddc7f222 Unlocal colors, lose double quotes where not needed.
Anton Shestakov <engored@ya.ru>
previous changes: 34:6d42e8d89e7e
line | diff
if [[ $EUID == 0 ]] ; then
161
161:606cda98621a .bash_prompt: some more colors, but mostly shellcheck-detectable nits
Anton Shestakov <av6@dwimlabs.net>
previous changes: 133:1b82b9501856
line | diff
local PROMPT_COLOR=$R
78
78:e9fd8738ae54 prompt: trailing spaces
Anton Shestakov <engored@ya.ru>
previous changes: 69:3e6ac54990dd
line | diff
7
7:d3613e95e03f Git info. Git and Mercurial symbols (credit goes to Steve Losh and his extravagant zsh prompt).
Anton Shestakov <engored@ya.ru>
previous changes: 5:7b2ad8123a53
line | diff
# getting hg and git info is disabled for root
5
5:7b2ad8123a53 virtualenv support.
Anton Shestakov <engored@ya.ru>
previous changes: 3:cb307dcaf2ef
line | diff
local HG_INFO=" ${P}-${RESET}"
7
7:d3613e95e03f Git info. Git and Mercurial symbols (credit goes to Steve Losh and his extravagant zsh prompt).
Anton Shestakov <engored@ya.ru>
previous changes: 5:7b2ad8123a53
line | diff
local GIT_INFO=" ${G}-${RESET}"
2
2:9c916e36d032 Renamed .bashrc to .bash_prompt. Disabled any hg interaction for root.
Anton Shestakov <engored@ya.ru>
previous changes: 1:ef4ec926e9a4
line | diff
else
161
161:606cda98621a .bash_prompt: some more colors, but mostly shellcheck-detectable nits
Anton Shestakov <av6@dwimlabs.net>
previous changes: 133:1b82b9501856
line | diff
local PROMPT_COLOR=$G
78
78:e9fd8738ae54 prompt: trailing spaces
Anton Shestakov <engored@ya.ru>
previous changes: 69:3e6ac54990dd
line | diff
65
65:f9947eb0c34a Use upsearch for detecting if pwd is tracked
Anton Shestakov <engored@ya.ru>
previous changes: 57:c40d524fc90c
line | diff
case "$(_upsearch)" in
65:f9947eb0c34a Use upsearch for detecting if pwd is tracked
Anton Shestakov <engored@ya.ru>
previous changes: 57:c40d524fc90c
line | diff
'hg')
65:f9947eb0c34a Use upsearch for detecting if pwd is tracked
Anton Shestakov <engored@ya.ru>
previous changes: 57:c40d524fc90c
line | diff
local HG_INFO=
65:f9947eb0c34a Use upsearch for detecting if pwd is tracked
Anton Shestakov <engored@ya.ru>
previous changes: 57:c40d524fc90c
line | diff
_set_hg_info
65:f9947eb0c34a Use upsearch for detecting if pwd is tracked
Anton Shestakov <engored@ya.ru>
previous changes: 57:c40d524fc90c
line | diff
;;
65:f9947eb0c34a Use upsearch for detecting if pwd is tracked
Anton Shestakov <engored@ya.ru>
previous changes: 57:c40d524fc90c
line | diff
'git')
65:f9947eb0c34a Use upsearch for detecting if pwd is tracked
Anton Shestakov <engored@ya.ru>
previous changes: 57:c40d524fc90c
line | diff
local GIT_INFO=
65:f9947eb0c34a Use upsearch for detecting if pwd is tracked
Anton Shestakov <engored@ya.ru>
previous changes: 57:c40d524fc90c
line | diff
_set_git_info
65:f9947eb0c34a Use upsearch for detecting if pwd is tracked
Anton Shestakov <engored@ya.ru>
previous changes: 57:c40d524fc90c
line | diff
;;
65:f9947eb0c34a Use upsearch for detecting if pwd is tracked
Anton Shestakov <engored@ya.ru>
previous changes: 57:c40d524fc90c
line | diff
esac
0
0:226664158c55 Added .bashrc with hg prompt example.
Anton Shestakov <engored@ya.ru>
previous changes:
line | diff
fi
0:226664158c55 Added .bashrc with hg prompt example.
Anton Shestakov <engored@ya.ru>
previous changes:
line | diff
35
35:44a6ddc7f222 Unlocal colors, lose double quotes where not needed.
Anton Shestakov <engored@ya.ru>
previous changes: 34:6d42e8d89e7e
line | diff
if [[ $VIRTUAL_ENV ]] ; then
5
5:7b2ad8123a53 virtualenv support.
Anton Shestakov <engored@ya.ru>
previous changes: 3:cb307dcaf2ef
line | diff
local VENV="${G}+"$(basename "$VIRTUAL_ENV")"${RESET}"
5:7b2ad8123a53 virtualenv support.
Anton Shestakov <engored@ya.ru>
previous changes: 3:cb307dcaf2ef
line | diff
fi
5:7b2ad8123a53 virtualenv support.
Anton Shestakov <engored@ya.ru>
previous changes: 3:cb307dcaf2ef
line | diff
176
176:c55a72f7e47f .bash_prompt: set terminal title on its own line
Anton Shestakov <av6@dwimlabs.net>
previous changes: 175:b8ac40257cb4
line | diff
PS1="\
182
182:adcdefc73227 .bash_prompt: (re?)add debian_chroot support
Anton Shestakov <av6@dwimlabs.net>
previous changes: 176:c55a72f7e47f
line | diff
${K}[${RESET}${TIME} ${debian_chroot:+${Y}(c)${RESET} }\\u@\\h \
161
161:606cda98621a .bash_prompt: some more colors, but mostly shellcheck-detectable nits
Anton Shestakov <av6@dwimlabs.net>
previous changes: 133:1b82b9501856
line | diff
${RETCODE}\\W${VENV}${HG_INFO}${GIT_INFO}${K}]${RESET}\
0
0:226664158c55 Added .bashrc with hg prompt example.
Anton Shestakov <engored@ya.ru>
previous changes:
line | diff
${PROMPT_COLOR}\\\$${RESET} "
176
176:c55a72f7e47f .bash_prompt: set terminal title on its own line
Anton Shestakov <av6@dwimlabs.net>
previous changes: 175:b8ac40257cb4
line | diff
182
182:adcdefc73227 .bash_prompt: (re?)add debian_chroot support
Anton Shestakov <av6@dwimlabs.net>
previous changes: 176:c55a72f7e47f
line | diff
PS1="\\[\\033]0;${debian_chroot:+($debian_chroot) }\\u@\\h: \\W\\007\\]$PS1"
0
0:226664158c55 Added .bashrc with hg prompt example.
Anton Shestakov <engored@ya.ru>
previous changes:
line | diff
}
0:226664158c55 Added .bashrc with hg prompt example.
Anton Shestakov <engored@ya.ru>
previous changes:
line | diff
65
65:f9947eb0c34a Use upsearch for detecting if pwd is tracked
Anton Shestakov <engored@ya.ru>
previous changes: 57:c40d524fc90c
line | diff
function _upsearch {
65:f9947eb0c34a Use upsearch for detecting if pwd is tracked
Anton Shestakov <engored@ya.ru>
previous changes: 57:c40d524fc90c
line | diff
test "$PWD" == '/' && return || test -e '.hg' && echo 'hg' && return || test -e '.git' && echo 'git' && return || cd .. && _upsearch
65:f9947eb0c34a Use upsearch for detecting if pwd is tracked
Anton Shestakov <engored@ya.ru>
previous changes: 57:c40d524fc90c
line | diff
}
65:f9947eb0c34a Use upsearch for detecting if pwd is tracked
Anton Shestakov <engored@ya.ru>
previous changes: 57:c40d524fc90c
line | diff
54
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
function _set_hg_info {
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
if [[ $USE_HG_PROMPT ]] ; then
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
local PROMPT_TEMPLATE="${P}{branch|quiet}{${Rd}{closed}}${P}☿{rev}{${B}+{tags|quiet|+}}{${Gd}*{bookmark}}{${R}{update}}{${G}+{rev|merge}}${R}{status|modified}${RESET}"
123
123:6a444ba3ef7a .bash_prompt: use HGPLAIN=1 for prompts
Anton Shestakov <av6@dwimlabs.net>
previous changes: 88:f5cd956da0c3
line | diff
HG_INFO=" $(HGPLAIN=1 hg prompt $PROMPT_TEMPLATE)"
54
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
else
123
123:6a444ba3ef7a .bash_prompt: use HGPLAIN=1 for prompts
Anton Shestakov <av6@dwimlabs.net>
previous changes: 88:f5cd956da0c3
line | diff
local SUM=$(HGPLAIN=1 hg sum 2>/dev/null)
54
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
local PARENTS=($(grep -Po '(?<=parent: ).*(?=:)' <<< "$SUM"))
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
local BRANCH=$(grep -Po '(?<=branch: ).*$' <<< "$SUM")
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
local COMMIT=$(grep -Po '(?<=commit: ).*$' <<< "$SUM")
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
local UPDATE=$(grep -Po '(?<=update: ).*$' <<< "$SUM")
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
local REV=${PARENTS[0]}
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
local MERGEREV=${PARENTS[1]}
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
133
133:1b82b9501856 .bash_prompt: drop revision number if it's -1
Anton Shestakov <av6@dwimlabs.net>
previous changes: 132:f5a8f3d36842
line | diff
if [[ $REV = '-1' ]] ; then REV='' ; fi
131
131:642440fd7edb .bash_prompt: don't just replace "default" with nothing ("default-is-good")
Anton Shestakov <av6@dwimlabs.net>
previous changes: 123:6a444ba3ef7a
line | diff
if [[ $BRANCH = 'default' ]] ; then BRANCH='' ; fi
132
132:f5a8f3d36842 .bash_prompt: use if instead of `test || cmd`
Anton Shestakov <av6@dwimlabs.net>
previous changes: 131:642440fd7edb
line | diff
if [[ $MERGEREV ]] ; then MERGEREV="+$MERGEREV" ; fi
54
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
case "$COMMIT" in
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
*'(clean)'*)
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
COMMIT=''
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
;;
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
*added*|*modified*|*deleted*)
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
COMMIT='!'
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
;;
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
esac
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
case "$UPDATE" in
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
*'(update)'*)
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
UPDATE='^'
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
;;
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
*'(merge)'*)
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
UPDATE=''
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
;;
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
*'(current)'*)
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
UPDATE=''
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
;;
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
esac
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
HG_INFO=" ${P}${BRANCH}${REV}${R}${UPDATE}${G}${MERGEREV}${R}${COMMIT}${RESET}"
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
fi
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
}
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
function _set_git_info {
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
local STATUS=$(LC_ALL=C git status 2>/dev/null)
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
local BRANCH=$(grep -Po '(?<=On branch ).*$' <<< "$STATUS")
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
local REV=$(LC_ALL=C git rev-parse --short HEAD 2>/dev/null)
68
68:c90c3504fbb3 git prompt: show merges (without conflict)
Anton Shestakov <engored@ya.ru>
previous changes: 66:584e8e0b08ee
line | diff
local MERGEREV=$(LC_ALL=C git rev-parse --short MERGE_HEAD 2>/dev/null)
66
66:584e8e0b08ee git prompt: mark non-empty stash
Anton Shestakov <engored@ya.ru>
previous changes: 65:f9947eb0c34a
line | diff
local STASH=$(LC_ALL=C git stash list 2>/dev/null)
54
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
if [[ $STATUS == *'Your branch is behind'* ]] ; then
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
local BEHIND="$R^"
88
88:f5cd956da0c3 git prompt: better regexes
Anton Shestakov <engored@ya.ru>
previous changes: 78:e9fd8738ae54
line | diff
[[ $STATUS =~ 'behind '[^$'\n']+' '([0-9]+)' commit' ]] && BEHIND+=${BASH_REMATCH[1]}
54
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
fi
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
if [[ $STATUS == *'Your branch is ahead'* ]] ; then
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
local AHEAD="$Y^"
88
88:f5cd956da0c3 git prompt: better regexes
Anton Shestakov <engored@ya.ru>
previous changes: 78:e9fd8738ae54
line | diff
[[ $STATUS =~ 'ahead '[^$'\n']+' '([0-9]+)' commit' ]] && AHEAD+=${BASH_REMATCH[1]}
54
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
fi
57
57:c40d524fc90c Color detached differently.
Anton Shestakov <engored@ya.ru>
previous changes: 54:065779098328
line | diff
if [[ $STATUS == *detached* ]] ; then
57:c40d524fc90c Color detached differently.
Anton Shestakov <engored@ya.ru>
previous changes: 54:065779098328
line | diff
REV="$P$REV"
57:c40d524fc90c Color detached differently.
Anton Shestakov <engored@ya.ru>
previous changes: 54:065779098328
line | diff
else
57:c40d524fc90c Color detached differently.
Anton Shestakov <engored@ya.ru>
previous changes: 54:065779098328
line | diff
REV="$G$REV"
57:c40d524fc90c Color detached differently.
Anton Shestakov <engored@ya.ru>
previous changes: 54:065779098328
line | diff
fi
54
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
if [[ $STATUS == *'Changes to be committed'* ]] ; then
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
local STAGED="$R!"
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
fi
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
if [[ $STATUS == *'Changes not staged'* ]] ; then
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
local UNSTAGED="$P?"
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
fi
69
69:3e6ac54990dd git prompt: show merges with conflicts
Anton Shestakov <engored@ya.ru>
previous changes: 68:c90c3504fbb3
line | diff
if [[ $STATUS == *'You have unmerged paths.'* ]] ; then
69:3e6ac54990dd git prompt: show merges with conflicts
Anton Shestakov <engored@ya.ru>
previous changes: 68:c90c3504fbb3
line | diff
local MERGE="$R+$MERGEREV"
69:3e6ac54990dd git prompt: show merges with conflicts
Anton Shestakov <engored@ya.ru>
previous changes: 68:c90c3504fbb3
line | diff
fi
68
68:c90c3504fbb3 git prompt: show merges (without conflict)
Anton Shestakov <engored@ya.ru>
previous changes: 66:584e8e0b08ee
line | diff
if [[ $STATUS == *'All conflicts fixed but you are still merging.'* ]] ; then
68:c90c3504fbb3 git prompt: show merges (without conflict)
Anton Shestakov <engored@ya.ru>
previous changes: 66:584e8e0b08ee
line | diff
local MERGE="$B+$MERGEREV"
68:c90c3504fbb3 git prompt: show merges (without conflict)
Anton Shestakov <engored@ya.ru>
previous changes: 66:584e8e0b08ee
line | diff
fi
66
66:584e8e0b08ee git prompt: mark non-empty stash
Anton Shestakov <engored@ya.ru>
previous changes: 65:f9947eb0c34a
line | diff
if [[ ! -z $STASH ]] ; then
66:584e8e0b08ee git prompt: mark non-empty stash
Anton Shestakov <engored@ya.ru>
previous changes: 65:f9947eb0c34a
line | diff
STASH='S'
66:584e8e0b08ee git prompt: mark non-empty stash
Anton Shestakov <engored@ya.ru>
previous changes: 65:f9947eb0c34a
line | diff
fi
54
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
68
68:c90c3504fbb3 git prompt: show merges (without conflict)
Anton Shestakov <engored@ya.ru>
previous changes: 66:584e8e0b08ee
line | diff
GIT_INFO=" ${G}${BRANCH}±${REV}${MERGE}${BEHIND}${AHEAD}${STAGED}${UNSTAGED}${C}${STASH}${RESET}"
54
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
}
54:065779098328 Move hg and git info getting in procedures.
Anton Shestakov <engored@ya.ru>
previous changes: 45:a12c1aeefbfe
line | diff
44
44:a6137e70b11c Guess USE_HG_PROMPT.
Anton Shestakov <engored@ya.ru>
previous changes: 42:34ee83bd5ad2
line | diff
# first find prompt in hgrc, then check it's actually enabled
44:a6137e70b11c Guess USE_HG_PROMPT.
Anton Shestakov <engored@ya.ru>
previous changes: 42:34ee83bd5ad2
line | diff
if grep -w '^prompt' ~/.hgrc &>/dev/null && hg help prompt &>/dev/null ; then
44:a6137e70b11c Guess USE_HG_PROMPT.
Anton Shestakov <engored@ya.ru>
previous changes: 42:34ee83bd5ad2
line | diff
USE_HG_PROMPT=1
44:a6137e70b11c Guess USE_HG_PROMPT.
Anton Shestakov <engored@ya.ru>
previous changes: 42:34ee83bd5ad2
line | diff
fi
44:a6137e70b11c Guess USE_HG_PROMPT.
Anton Shestakov <engored@ya.ru>
previous changes: 42:34ee83bd5ad2
line | diff
35
35:44a6ddc7f222 Unlocal colors, lose double quotes where not needed.
Anton Shestakov <engored@ya.ru>
previous changes: 34:6d42e8d89e7e
line | diff
export VIRTUAL_ENV_DISABLE_PROMPT=1
0
0:226664158c55 Added .bashrc with hg prompt example.
Anton Shestakov <engored@ya.ru>
previous changes:
line | diff
export PROMPT_COMMAND=prompt_command