2009-10-16 06:07:02 +02:00
|
|
|
autoload -U add-zsh-hook
|
|
|
|
autoload -Uz vcs_info
|
|
|
|
|
|
|
|
zstyle ':vcs_info:*' actionformats \
|
2012-07-24 04:36:18 +02:00
|
|
|
'%F{5}(%f%s%F{5})%F{3}-%F{5}[%F{2}%b%F{3}|%F{1}%a%F{5}]%f '
|
|
|
|
zstyle ':vcs_info:*' formats '%F{2}%s%F{7}:%F{2}(%F{1}%b%F{2})%f '
|
2009-10-16 06:07:02 +02:00
|
|
|
zstyle ':vcs_info:(sv[nk]|bzr):*' branchformat '%b%F{1}:%F{3}%r'
|
|
|
|
zstyle ':vcs_info:*' enable git
|
|
|
|
|
2012-07-16 01:59:30 +02:00
|
|
|
add-zsh-hook precmd prompt_vcs
|
2009-10-16 06:07:02 +02:00
|
|
|
|
2012-07-16 01:59:30 +02:00
|
|
|
prompt_vcs () {
|
2009-10-16 06:07:02 +02:00
|
|
|
vcs_info
|
|
|
|
|
|
|
|
if [ "${vcs_info_msg_0_}" = "" ]; then
|
|
|
|
dir_status="%F{2}→%f"
|
|
|
|
elif [[ $(git diff --cached --name-status 2>/dev/null ) != "" ]]; then
|
|
|
|
dir_status="%F{1}▶%f"
|
|
|
|
elif [[ $(git diff --name-status 2>/dev/null ) != "" ]]; then
|
|
|
|
dir_status="%F{3}▶%f"
|
|
|
|
else
|
|
|
|
dir_status="%F{2}▶%f"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2012-07-24 04:36:18 +02:00
|
|
|
function {
|
2012-07-16 01:59:30 +02:00
|
|
|
if [[ -n "$SSH_CLIENT" ]]; then
|
2012-07-24 04:36:18 +02:00
|
|
|
PROMPT_HOST=" ($HOST)"
|
2012-07-16 01:59:30 +02:00
|
|
|
else
|
2012-07-24 04:36:18 +02:00
|
|
|
PROMPT_HOST=''
|
2012-07-16 01:59:30 +02:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2009-10-16 06:07:02 +02:00
|
|
|
local ret_status="%(?:%{$fg_bold[green]%}Ξ:%{$fg_bold[red]%}%S↑%s%?)"
|
|
|
|
|
2020-08-04 15:55:04 +02:00
|
|
|
PROMPT='${ret_status}%{$fg[blue]%}${PROMPT_HOST}%{$fg_bold[green]%} %{$fg_bold[yellow]%}%2~ ${vcs_info_msg_0_}${dir_status}%{$reset_color%} '
|
2009-10-16 06:07:02 +02:00
|
|
|
|
|
|
|
# vim: set ft=zsh ts=4 sw=4 et:
|