zsh: small refactor
This commit is contained in:
parent
ed07b3a79f
commit
edad183fc7
1 changed files with 26 additions and 43 deletions
|
@ -7,7 +7,6 @@ prompt_fifo=$HOME/.zsh_gitstatus_$$
|
||||||
prompt_blimit=50
|
prompt_blimit=50
|
||||||
kube_config=$HOME/.kube/config
|
kube_config=$HOME/.kube/config
|
||||||
typeset -A prompt_symbols=(
|
typeset -A prompt_symbols=(
|
||||||
sep_a $'\ue0b0'
|
|
||||||
ellipsis $'\u2026'
|
ellipsis $'\u2026'
|
||||||
git $'\ue0a0'
|
git $'\ue0a0'
|
||||||
git_unstaged '~'
|
git_unstaged '~'
|
||||||
|
@ -19,7 +18,6 @@ typeset -A prompt_symbols=(
|
||||||
)
|
)
|
||||||
|
|
||||||
typeset -A prompt_colors=(
|
typeset -A prompt_colors=(
|
||||||
# fg '15'
|
|
||||||
root '1'
|
root '1'
|
||||||
ssh '15'
|
ssh '15'
|
||||||
cwd '4'
|
cwd '4'
|
||||||
|
@ -33,33 +31,35 @@ typeset -A prompt_colors=(
|
||||||
bang '8'
|
bang '8'
|
||||||
)
|
)
|
||||||
|
|
||||||
prompt.set_bang() {
|
function prompt.set_bang {
|
||||||
(( $# )) || return 1
|
(( $# )) || return 1
|
||||||
prompt_symbols[bang]=$1
|
prompt_symbols[bang]=$1
|
||||||
}
|
}
|
||||||
|
|
||||||
precmd.window_title() {
|
function precmd.window_title {
|
||||||
typeset dir=$(pwd)
|
typeset dir
|
||||||
|
dir=$(pwd)
|
||||||
printf '\033]0;%s:%s\007' ${HOST%%.*} ${dir##*/}
|
printf '\033]0;%s:%s\007' ${HOST%%.*} ${dir##*/}
|
||||||
}
|
}
|
||||||
|
|
||||||
precmd.has_kube() {
|
function precmd.has_kube {
|
||||||
[[ -r $kube_config ]]
|
[[ -r $kube_config ]]
|
||||||
}
|
}
|
||||||
|
|
||||||
precmd.kube_context() {
|
function precmd.kube_context {
|
||||||
typeset kube_context=$(awk -F- '($1 == "current") {print $3}' $kube_config)
|
typeset kube_context
|
||||||
|
kube_context=$(awk -F- '($1 == "current") {print $3}' $kube_config)
|
||||||
precmd.prompt.add $prompt_symbols[helm]
|
precmd.prompt.add $prompt_symbols[helm]
|
||||||
precmd.prompt.add $kube_context $prompt_colors[kube_context]
|
precmd.prompt.add $kube_context $prompt_colors[kube_context]
|
||||||
}
|
}
|
||||||
|
|
||||||
precmd.is_git_repo() {
|
function precmd.is_git_repo {
|
||||||
typeset prompt_git_dir
|
typeset prompt_git_dir
|
||||||
prompt_git_dir=$(git rev-parse --git-dir 2>/dev/null) || return 1
|
prompt_git_dir=$(git rev-parse --git-dir 2>/dev/null) || return 1
|
||||||
[[ ! -e $prompt_git_dir/nozsh ]]
|
[[ ! -e $prompt_git_dir/nozsh ]]
|
||||||
}
|
}
|
||||||
|
|
||||||
precmd.prompt.add() {
|
function precmd.prompt.add {
|
||||||
(( $# )) || return 1
|
(( $# )) || return 1
|
||||||
typeset data=$1 color=$2
|
typeset data=$1 color=$2
|
||||||
[[ -n $prompt_string ]] && prompt_string+=" "
|
[[ -n $prompt_string ]] && prompt_string+=" "
|
||||||
|
@ -70,30 +70,17 @@ precmd.prompt.add() {
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
precmd.prompt.add_pl() {
|
function precmd.prompt.apply {
|
||||||
(( $# < 2 )) && return 1
|
|
||||||
typeset data=$1 color=$2
|
|
||||||
if [[ -z $prompt_string ]]; then
|
|
||||||
prompt_string+="%K{$color}%F{$prompt_colors[fg]} $data "
|
|
||||||
else
|
|
||||||
prompt_string+="%F{$prev_color}%K{$color}$prompt_symbols[sep_a]%F{$prompt_colors[fg]} $data "
|
|
||||||
fi
|
|
||||||
prev_color=$color
|
|
||||||
}
|
|
||||||
|
|
||||||
precmd.prompt.apply() {
|
|
||||||
PROMPT=$prompt_string
|
PROMPT=$prompt_string
|
||||||
unset prompt_string
|
unset prompt_string
|
||||||
}
|
}
|
||||||
|
|
||||||
precmd.prompt.pre_git() {
|
function precmd.prompt.pre_git {
|
||||||
precmd.prompt.add "$prompt_symbols[git] $prompt_symbols[ellipsis]" $prompt_colors[git_branch]
|
precmd.prompt.add "$prompt_symbols[git] $prompt_symbols[ellipsis]" $prompt_colors[git_branch]
|
||||||
}
|
}
|
||||||
|
|
||||||
precmd.prompt.git() {
|
function precmd.prompt.git {
|
||||||
typeset raw_status IFS=
|
typeset IFS=
|
||||||
raw_status=$(git status --porcelain -bu 2>/dev/null) || return 0
|
|
||||||
|
|
||||||
typeset -A count
|
typeset -A count
|
||||||
while read line; do
|
while read line; do
|
||||||
case $line[1,2] in
|
case $line[1,2] in
|
||||||
|
@ -110,21 +97,19 @@ precmd.prompt.git() {
|
||||||
('??') (( ++count[git_untracked] )) ;|
|
('??') (( ++count[git_untracked] )) ;|
|
||||||
([ADU][ADU]) (( ++count[git_unmerged] ))
|
([ADU][ADU]) (( ++count[git_unmerged] ))
|
||||||
esac
|
esac
|
||||||
done <<< $raw_status
|
done < <(git status --porcelain -bu 2>/dev/null)
|
||||||
|
|
||||||
for i in git_untracked git_unmerged git_unstaged git_staged; do
|
for i in git_untracked git_unmerged git_unstaged git_staged; do
|
||||||
(( count[$i] )) && precmd.prompt.add "$count[$i]$prompt_symbols[$i]" $prompt_colors[$i]
|
(( count[$i] )) && precmd.prompt.add "$count[$i]$prompt_symbols[$i]" $prompt_colors[$i]
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
precmd.prompt() {
|
function precmd.prompt {
|
||||||
typeset -g prompt_string= prev_color=
|
typeset -g prompt_string=
|
||||||
|
|
||||||
precmd.prompt.add '[' $prompt_colors[brackets]
|
precmd.prompt.add '[' $prompt_colors[brackets]
|
||||||
(( UID )) \
|
[[ $UID -eq 0 ]] && precmd.prompt.add '#' $prompt_colors[root]
|
||||||
|| precmd.prompt.add '#' $prompt_colors[root]
|
[[ -n $SSH_CONNECTION ]] && precmd.prompt.add %n@%m $prompt_colors[ssh]
|
||||||
[[ -n $SSH_CONNECTION ]]\
|
|
||||||
&& precmd.prompt.add %n@%m $prompt_colors[ssh]
|
|
||||||
|
|
||||||
precmd.prompt.add %~ $prompt_colors[cwd]
|
precmd.prompt.add %~ $prompt_colors[cwd]
|
||||||
|
|
||||||
|
@ -132,29 +117,27 @@ precmd.prompt() {
|
||||||
precmd.kube_context
|
precmd.kube_context
|
||||||
fi
|
fi
|
||||||
|
|
||||||
[[ $1 == pre_git ]]\
|
[[ $1 == 'pre_git' ]] && precmd.prompt.pre_git
|
||||||
&& precmd.prompt.pre_git
|
[[ $1 == 'git' ]] && precmd.prompt.git
|
||||||
[[ $1 == git ]]\
|
|
||||||
&& precmd.prompt.git
|
|
||||||
|
|
||||||
precmd.prompt.add $']\n' $prompt_colors[brackets]
|
precmd.prompt.add $']\n' $prompt_colors[brackets]
|
||||||
prompt_string+="%F{$prompt_colors[bang]}$prompt_symbols[bang]%f "
|
prompt_string+="%F{$prompt_colors[bang]}$prompt_symbols[bang]%f "
|
||||||
}
|
}
|
||||||
|
|
||||||
precmd.git_update() {
|
function precmd.git_update {
|
||||||
precmd.prompt git
|
precmd.prompt git
|
||||||
[[ ! -p $prompt_fifo ]] && mkfifo -m 0600 $prompt_fifo
|
[[ ! -p $prompt_fifo ]] && mkfifo -m 0600 $prompt_fifo
|
||||||
echo -n $prompt_string > $prompt_fifo &!
|
echo -n $prompt_string > $prompt_fifo &!
|
||||||
kill -s USR1 $$
|
kill -s USR1 $$
|
||||||
}
|
}
|
||||||
|
|
||||||
precmd.prompt.update() {
|
function precmd.prompt.update {
|
||||||
typeset -g prompt_string=$(<$prompt_fifo)
|
typeset -g prompt_string=$(<$prompt_fifo)
|
||||||
precmd.prompt.apply
|
precmd.prompt.apply
|
||||||
zle && zle reset-prompt
|
zle && zle reset-prompt
|
||||||
}
|
}
|
||||||
|
|
||||||
precmd() {
|
function precmd {
|
||||||
precmd.window_title
|
precmd.window_title
|
||||||
if precmd.is_git_repo; then
|
if precmd.is_git_repo; then
|
||||||
precmd.prompt pre_git
|
precmd.prompt pre_git
|
||||||
|
@ -165,11 +148,11 @@ precmd() {
|
||||||
precmd.prompt.apply
|
precmd.prompt.apply
|
||||||
}
|
}
|
||||||
|
|
||||||
TRAPUSR1() {
|
function TRAPUSR1 {
|
||||||
precmd.prompt.update
|
precmd.prompt.update
|
||||||
}
|
}
|
||||||
|
|
||||||
TRAPEXIT() {
|
function TRAPEXIT {
|
||||||
[[ -p $prompt_fifo ]] && rm $prompt_fifo
|
[[ -p $prompt_fifo ]] && rm $prompt_fifo
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue