1
0
Fork 0

zsh: small refactor

This commit is contained in:
Von Random 2025-10-20 14:36:21 +03:00
parent ed07b3a79f
commit edad183fc7

View file

@ -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
} }