aboutsummaryrefslogtreecommitdiffstats
path: root/_zsh/30-prompt.zsh
blob: 3d439c7207f4da5126afb1dde17a1bf9636a8fc1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
#
# zsh/prompt.zsh
#

function git_prompt_info {
    local ref=$(=git symbolic-ref HEAD 2> /dev/null)
    local gitst="$(=git status --untracked-files=no 2> /dev/null)"

    if [[ -f .git/MERGE_HEAD ]]; then
        if [[ ${gitst} =~ "unmerged" ]]; then
        gitstatus=" %{$fg[red]%}unmerged%{$reset_color%}"
        else
        gitstatus=" %{$fg[green]%}merged%{$reset_color%}"
        fi
    elif [[ ${gitst} =~ "Changes to be committed" ]]; then
        gitstatus=" %{$fg[blue]%}!%{$reset_color%}"
    elif [[ ${gitst} =~ "use \"git add" ]]; then
        gitstatus=" %{$fg[red]%}!%{$reset_color%}"
    else
        gitstatus=''
    fi

    if [[ -n $ref ]]; then
        echo "%{$fg_bold[green]%}/${ref#refs/heads/}%{$reset_color%}$gitstatus"
    fi
}

PROMPT='%{$fg_bold[blue]%}%~%<< $(git_prompt_info)%{$fg_bold[red]%}%(?..[%?])${PR_BOLD_WHITE}>%{$reset_color%} '

SPROMPT="zsh: correct %{$fg_bold[red]%}%R%{$reset_color%} to %{$fg_bold[green]%}%r%{$reset_color%} [(y)es (n)o (a)bort (e)dit]? "

# vim: set ts=8 sw=4 tw=0 fenc=utf-8 ft=zsh: #