X-Git-Url: https://git.armaanb.net/?p=admone.git;a=blobdiff_plain;f=admone.zsh;h=e41e7e6fc7965e9de61a1588dbbbd95ae2c78d7f;hp=6569ffc8363a48638118397708bdfa7cf4c96114;hb=HEAD;hpb=fcf03a1295b9efbfcec29f5d48d5a85799624455 diff --git a/admone.zsh b/admone.zsh index 6569ffc..e41e7e6 100644 --- a/admone.zsh +++ b/admone.zsh @@ -1,98 +1,45 @@ -####################################################################### -# Admone ZSH prompt. Copyright Armaan Bhojwani. MIT licensed, see the # -# LICENSE file or https://www.opensource.org/licenses/MIT for more # -# information. Git repo at https://codeberg.org/armaan/admone # -####################################################################### +# Admone Zsh prompt +# Copyright Armaan Bhojwani 2021 +# MIT licensed, see the LICENSE file for more information. -# -# USER CONFIGURATIONS -# +PROMPT_CHAR="➤" -ADMONE_PROMPT_CHAR="❯❯❯" -ADMONE_PRE_UPPER="╭ " -ADMONE_PRE_LOWER="╰ " -ADMONE_BLOCK_SEPARATOR="-" -ADMONE_BLOCK_LEFT="[" -ADMONE_BLOCK_RIGHT="]" -ADMONE_VI_MODE_CURSOR="1" -ADMONE_INCLUDE="admone-pwd;admone-git;admone-exit-code;admone-time" -ADMONE_FORMAT_LOWER="%B%F{%(?.cyan.red)}" +zstyle ':vcs_info:git:*' formats '%f|%F{green}%b%u%c' +zstyle ':vcs_info:git:*' actionformats '%b|%a%u%c' +zstyle ':vcs_info:*' unstagedstr ' *' +zstyle ':vcs_info:*' stagedstr ' +' -function admone-pwd { - echo "%F{blue}%~%f%F{240}" -} -function admone-git { - local git_branch="$(git rev-parse --abbrev-ref HEAD 2>/dev/null)" - echo "%F{green}${git_branch//\%/%%}%f" -} -function admone-exit-code { - echo "%(?,,%F{1}%?%F{240})" -} -function admone-date { - echo $(date -I) -} -function admone-12hr { - echo $(date +%r) -} -function admone-24hr { - echo $(date +%x) -} -function admone-time { - # Intergration with https://codeberg.org/armaan/zsh-command-time - echo "%F{cyan}$timer_show%f" -} - -####################################################################### - -# -# BACKEND -# +################################################################################ # Cursor shape depends on vi mode function zle-keymap-select zle-line-init zle-line-finish { - if [[ $ADMONE_VI_MODE_CURSOR == 1 ]]; then - case $KEYMAP in - vicmd) - # Block - print -n -- "\E]50;CursorShape=0\C-G" - ;; - viins|main) - # Beam - print -n -- "\E]50;CursorShape=1\C-G" - ;; - esac - - zle reset-prompt - zle -R - fi + case $KEYMAP in + vicmd) + # Block + print -n -- "\E]50;CursorShape=0\C-G" + ;; + viins|main) + # Beam + print -n -- "\E]50;CursorShape=1\C-G" + ;; + esac + # zle reset-prompt + zle -R } -function set-prompt() { - # Reset prompts - upper="${ADMONE_PRE_UPPER}" - lower="${ADMONE_PRE_LOWER}${ADMONE_FORMAT_LOWER}${ADMONE_PROMPT_CHAR}%f%b " - - # Add in functions as defined above - NUM_FUNCS="$(echo $ADMONE_INCLUDE | grep -o ';' | wc -l)" - for (( i = 0; i <= $NUM_FUNCS; i++ )); do - (( val = $i + 1 )) - THE_COMMAND="$(echo $ADMONE_INCLUDE | cut -d ';' -f $val)" - if [[ $val == 1 ]]; then - upper+="$ADMONE_BLOCK_LEFT$($THE_COMMAND)$ADMONE_BLOCK_RIGHT" - else - upper+="$ADMONE_BLOCK_SEPARATOR$ADMONE_BLOCK_LEFT$($THE_COMMAND)$ADMONE_BLOCK_RIGHT" - fi - done +# Set everything! +set-prompt() { + PROMPT="%B%F{%(?.cyan.red)}${PROMPT_CHAR}%f%b " + RPROMPT="[%F{blue}%~${vcs_info_msg_0_}%f][%(?,%F{cyan}%?,%F{red}%?)%f]" - # Add line above [[ -v PS1_NL ]] && echo || PS1_NL= - - PROMPT=$upper$'\n'$lower } -# Set everything! +zstyle ':vcs_info:*' check-for-changes true +autoload -Uz add-zsh-hook vcs-info +add-zsh-hook precmd vcs_info +add-zsh-hook precmd set-prompt + zle -N zle-line-init zle -N zle-line-finish zle -N zle-keymap-select -autoload -Uz add-zsh-hook -add-zsh-hook precmd set-prompt