1
0

Add UserID Coloring

This commit is contained in:
2026-02-08 12:57:52 +01:00
parent 5d4b32d4d2
commit 839dd79943

View File

@@ -22,112 +22,116 @@
# TODO to refactor with switch / using someting else than grep # TODO to refactor with switch / using someting else than grep
# Might be faster using ripgrep too # Might be faster using ripgrep too
git_prompt_status() { git_prompt_status() {
local INDEX STATUS local INDEX STATUS
INDEX=$(command git status --porcelain -b 2> /dev/null) INDEX=$(command git status --porcelain -b 2> /dev/null)
STATUS="" STATUS=""
if $(echo "$INDEX" | command grep -E '^\?\? ' &> /dev/null); then if $(echo "$INDEX" | command grep -E '^\?\? ' &> /dev/null); then
STATUS="$ZSH_THEME_GIT_PROMPT_UNTRACKED$STATUS" STATUS="$ZSH_THEME_GIT_PROMPT_UNTRACKED$STATUS"
fi fi
if $(echo "$INDEX" | grep '^A ' &> /dev/null); then if $(echo "$INDEX" | grep '^A ' &> /dev/null); then
STATUS="$ZSH_THEME_GIT_PROMPT_ADDED$STATUS" STATUS="$ZSH_THEME_GIT_PROMPT_ADDED$STATUS"
elif $(echo "$INDEX" | grep '^M ' &> /dev/null); then elif $(echo "$INDEX" | grep '^M ' &> /dev/null); then
STATUS="$ZSH_THEME_GIT_PROMPT_ADDED$STATUS" STATUS="$ZSH_THEME_GIT_PROMPT_ADDED$STATUS"
elif $(echo "$INDEX" | grep '^MM ' &> /dev/null); then elif $(echo "$INDEX" | grep '^MM ' &> /dev/null); then
STATUS="$ZSH_THEME_GIT_PROMPT_ADDED$STATUS" STATUS="$ZSH_THEME_GIT_PROMPT_ADDED$STATUS"
fi fi
if $(echo "$INDEX" | grep '^ M ' &> /dev/null); then if $(echo "$INDEX" | grep '^ M ' &> /dev/null); then
STATUS="$ZSH_THEME_GIT_PROMPT_MODIFIED$STATUS" STATUS="$ZSH_THEME_GIT_PROMPT_MODIFIED$STATUS"
elif $(echo "$INDEX" | grep '^AM ' &> /dev/null); then elif $(echo "$INDEX" | grep '^AM ' &> /dev/null); then
STATUS="$ZSH_THEME_GIT_PROMPT_MODIFIED$STATUS" STATUS="$ZSH_THEME_GIT_PROMPT_MODIFIED$STATUS"
elif $(echo "$INDEX" | grep '^MM ' &> /dev/null); then elif $(echo "$INDEX" | grep '^MM ' &> /dev/null); then
STATUS="$ZSH_THEME_GIT_PROMPT_MODIFIED$STATUS" STATUS="$ZSH_THEME_GIT_PROMPT_MODIFIED$STATUS"
elif $(echo "$INDEX" | grep '^ T ' &> /dev/null); then elif $(echo "$INDEX" | grep '^ T ' &> /dev/null); then
STATUS="$ZSH_THEME_GIT_PROMPT_MODIFIED$STATUS" STATUS="$ZSH_THEME_GIT_PROMPT_MODIFIED$STATUS"
fi fi
if $(echo "$INDEX" | grep '^R ' &> /dev/null); then if $(echo "$INDEX" | grep '^R ' &> /dev/null); then
STATUS="$ZSH_THEME_GIT_PROMPT_RENAMED$STATUS" STATUS="$ZSH_THEME_GIT_PROMPT_RENAMED$STATUS"
fi fi
if $(echo "$INDEX" | grep '^ D ' &> /dev/null); then if $(echo "$INDEX" | grep '^ D ' &> /dev/null); then
STATUS="$ZSH_THEME_GIT_PROMPT_DELETED$STATUS" STATUS="$ZSH_THEME_GIT_PROMPT_DELETED$STATUS"
elif $(echo "$INDEX" | grep '^D ' &> /dev/null); then elif $(echo "$INDEX" | grep '^D ' &> /dev/null); then
STATUS="$ZSH_THEME_GIT_PROMPT_DELETED$STATUS" STATUS="$ZSH_THEME_GIT_PROMPT_DELETED$STATUS"
elif $(echo "$INDEX" | grep '^AD ' &> /dev/null); then elif $(echo "$INDEX" | grep '^AD ' &> /dev/null); then
STATUS="$ZSH_THEME_GIT_PROMPT_DELETED$STATUS" STATUS="$ZSH_THEME_GIT_PROMPT_DELETED$STATUS"
fi fi
if $(command git rev-parse --verify refs/stash >/dev/null 2>&1); then if $(command git rev-parse --verify refs/stash >/dev/null 2>&1); then
STATUS="$ZSH_THEME_GIT_PROMPT_STASHED$STATUS" STATUS="$ZSH_THEME_GIT_PROMPT_STASHED$STATUS"
fi fi
if $(echo "$INDEX" | grep '^UU ' &> /dev/null); then if $(echo "$INDEX" | grep '^UU ' &> /dev/null); then
STATUS="$ZSH_THEME_GIT_PROMPT_UNMERGED$STATUS" STATUS="$ZSH_THEME_GIT_PROMPT_UNMERGED$STATUS"
fi fi
if $(echo "$INDEX" | grep '^## [^ ]\+ .*ahead' &> /dev/null); then if $(echo "$INDEX" | grep '^## [^ ]\+ .*ahead' &> /dev/null); then
STATUS="$ZSH_THEME_GIT_PROMPT_AHEAD$STATUS" STATUS="$ZSH_THEME_GIT_PROMPT_AHEAD$STATUS"
fi fi
if $(echo "$INDEX" | grep '^## [^ ]\+ .*behind' &> /dev/null); then if $(echo "$INDEX" | grep '^## [^ ]\+ .*behind' &> /dev/null); then
STATUS="$ZSH_THEME_GIT_PROMPT_BEHIND$STATUS" STATUS="$ZSH_THEME_GIT_PROMPT_BEHIND$STATUS"
fi fi
if $(echo "$INDEX" | grep '^## [^ ]\+ .*diverged' &> /dev/null); then if $(echo "$INDEX" | grep '^## [^ ]\+ .*diverged' &> /dev/null); then
STATUS="$ZSH_THEME_GIT_PROMPT_DIVERGED$STATUS" STATUS="$ZSH_THEME_GIT_PROMPT_DIVERGED$STATUS"
fi fi
if [[ ! -z "$STATUS" ]]; then if [[ ! -z "$STATUS" ]]; then
echo " [ $STATUS]" echo " [ $STATUS]"
fi fi
} }
prompt_git_branch() { prompt_git_branch() {
autoload -Uz vcs_info autoload -Uz vcs_info
precmd_vcs_info() { vcs_info } precmd_vcs_info() { vcs_info }
precmd_functions+=( precmd_vcs_info ) precmd_functions+=( precmd_vcs_info )
setopt prompt_subst setopt prompt_subst
zstyle ':vcs_info:git:*' formats '%b' zstyle ':vcs_info:git:*' formats '%b'
} }
prompt_git_info() { prompt_git_info() {
[ ! -z "$vcs_info_msg_0_" ] && echo "$ZSH_THEME_GIT_PROMPT_PREFIX%F{white}$vcs_info_msg_0_%f$ZSH_THEME_GIT_PROMPT_SUFFIX" [ ! -z "$vcs_info_msg_0_" ] && echo "$ZSH_THEME_GIT_PROMPT_PREFIX%F{white}$vcs_info_msg_0_%f$ZSH_THEME_GIT_PROMPT_SUFFIX"
} }
prompt_purity_precmd() { prompt_purity_precmd() {
# Pass a line before each prompt # Pass a line before each prompt
print -P '' #print -P ''
} }
prompt_purification_setup() { prompt_purification_setup() {
# Display git branch # Display git branch
autoload -Uz add-zsh-hook autoload -Uz add-zsh-hook
add-zsh-hook precmd prompt_purity_precmd add-zsh-hook precmd prompt_purity_precmd
ZSH_THEME_GIT_PROMPT_PREFIX=" %F{red}λ%f:" ZSH_THEME_GIT_PROMPT_PREFIX=" %F{red}λ%f:"
ZSH_THEME_GIT_PROMPT_DIRTY="" ZSH_THEME_GIT_PROMPT_DIRTY=""
ZSH_THEME_GIT_PROMPT_CLEAN="" ZSH_THEME_GIT_PROMPT_CLEAN=""
ZSH_THEME_GIT_PROMPT_ADDED="%F{green}+%f " ZSH_THEME_GIT_PROMPT_ADDED="%F{green}+%f "
ZSH_THEME_GIT_PROMPT_MODIFIED="%F{blue}*%f " ZSH_THEME_GIT_PROMPT_MODIFIED="%F{blue}*%f "
ZSH_THEME_GIT_PROMPT_DELETED="%F{red}x%f " ZSH_THEME_GIT_PROMPT_DELETED="%F{red}x%f "
ZSH_THEME_GIT_PROMPT_RENAMED="%F{magenta}R%f " ZSH_THEME_GIT_PROMPT_RENAMED="%F{magenta}R%f "
ZSH_THEME_GIT_PROMPT_UNMERGED="%F{yellow}=%f " ZSH_THEME_GIT_PROMPT_UNMERGED="%F{yellow}=%f "
ZSH_THEME_GIT_PROMPT_UNTRACKED="%F{white}U%f " ZSH_THEME_GIT_PROMPT_UNTRACKED="%F{white}U%f "
ZSH_THEME_GIT_PROMPT_STASHED="%B%F{red}!%f%b " ZSH_THEME_GIT_PROMPT_STASHED="%B%F{red}!%f%b "
ZSH_THEME_GIT_PROMPT_BEHIND="%B%F{red}B%f%b " ZSH_THEME_GIT_PROMPT_BEHIND="%B%F{red}B%f%b "
ZSH_THEME_GIT_PROMPT_AHEAD="%B%F{green}A%f%b " ZSH_THEME_GIT_PROMPT_AHEAD="%B%F{green}A%f%b "
prompt_git_branch prompt_git_branch
RPROMPT='$(prompt_git_info) $(git_prompt_status)' RPROMPT='$(prompt_git_info) $(git_prompt_status)'
PROMPT=$'%F{white}%~ %B%F{blue}>%f%b ' if [ $UID -eq 0 ]; then
PROMPT=$'%F{white}%~ %B%F{red}>%f%b '
else
PROMPT=$'%F{white}%~ %B%F{blue}>%f%b '
fi
} }
prompt_purification_setup prompt_purification_setup