X-Git-Url: https://git.armaanb.net/?p=admone.git;a=blobdiff_plain;f=admone.zsh;h=e41e7e6fc7965e9de61a1588dbbbd95ae2c78d7f;hp=77fd9875fd83e97ed9540f30c4027edadd6bde53;hb=HEAD;hpb=ff98807b753f332ac33c801ac12fd5c7ac76e0dd diff --git a/admone.zsh b/admone.zsh index 77fd987..e41e7e6 100644 --- a/admone.zsh +++ b/admone.zsh @@ -1,74 +1,15 @@ # Admone Zsh prompt -# Copyright Armaan Bhojwani 2020 +# Copyright Armaan Bhojwani 2021 # MIT licensed, see the LICENSE file for more information. -# Git repo at - -####################################################################### -# USER CONFIGURATIONS -####################################################################### PROMPT_CHAR="➤" - # PROMPT_CHAR="❯❯❯" - # PROMPT_CHAR="$" - # PROMPT_CHAR="%" - # PROMPT_CHAR=">" - # PROMPT_CHAR="➢" - # PROMPT_CHAR="➪" -PRE_UPPER="╭" -PRE_LOWER="╰" - # PRE_UPPER="┌" - # PRE_LOWER="└" -BLOCK_SEPARATOR="─" - # BLOCK_SEPARATOR="∙" -BLOCK_LEFT="[" -BLOCK_RIGHT="]" - # BLOCK_LEFT="(" - # BLOCK_RIGHT=")" -SHOW_0_EXIT_CODE="0" -INCLUDE="admone-pwd;admone-vcs;admone-exit-code" -FORMAT_LOWER="%B%F{%(?.cyan.red)}" - -TRANSIENT_PROMPT="0" # This is buggy -SHORT_PROMPT="➤" -FORMAT_SHORT="%B%F{%(?.cyan.red)}" -zstyle ':vcs_info:git:*' formats '%b%u%c' +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 ' +' -####################################################################### -# Functions -####################################################################### - -admone-pwd() { - echo "%F{blue}%~%f" -} -admone-vcs() { - echo "%F{green}${vcs_info_msg_0_}%f" - VCS="1" -} -admone-exit-code() { - ([[ $SHOW_0_EXIT_CODE == "1" ]] && echo "%(?,%F{cyan}%?%f,%F{red}%?%f)") || - echo "%(?,,%F{red}%?%f)" -} -admone-date() { - echo $(date -I) -} -admone-12hr() { - echo $(date +%r) -} -admone-24hr() { - echo $(date +%T) -} -# Intergration with https://codeberg.org/armaan/zsh-command-time -admone-time() { - echo "%F{cyan}$timer_show%f" -} - -####################################################################### -# BACKEND -####################################################################### +################################################################################ # Cursor shape depends on vi mode function zle-keymap-select zle-line-init zle-line-finish { @@ -82,58 +23,21 @@ function zle-keymap-select zle-line-init zle-line-finish { print -n -- "\E]50;CursorShape=1\C-G" ;; esac - zle reset-prompt + # zle reset-prompt zle -R } +# Set everything! set-prompt() { - # Reset prompts - upper="${PRE_UPPER}" - lower="${PRE_LOWER}${FORMAT_LOWER}${PROMPT_CHAR}%f%b " + PROMPT="%B%F{%(?.cyan.red)}${PROMPT_CHAR}%f%b " + RPROMPT="[%F{blue}%~${vcs_info_msg_0_}%f][%(?,%F{cyan}%?,%F{red}%?)%f]" - # Add in functions as defined above - NUM_FUNCS="$(echo $INCLUDE | grep -o ';' | wc -l)" - - THE_COMMAND="$(echo $INCLUDE | cut -d ';' -f 1)" - upper+="$BLOCK_LEFT$($THE_COMMAND)$BLOCK_RIGHT" - - for (( i = 0; i < $NUM_FUNCS; i++ )); do - THE_COMMAND="$(echo $INCLUDE | cut -d ';' -f $(($i + 2)))" - upper+="$BLOCK_SEPARATOR$BLOCK_LEFT$($THE_COMMAND)$BLOCK_RIGHT" - done - - # Add line above [[ -v PS1_NL ]] && echo || PS1_NL= - - PROMPT=$upper$'\n'$lower } - -# Set everything! -if [[ $TRANSIENT_PROMPT == "1" ]]; then - SHORT_PROMPT=$FORMAT_SHORT$SHORT_PROMPT' '%f%b - - set-transient-prompt() { - if [[ $PROMPT != $SHORT_PROMPT ]]; then - PROMPT=$SHORT_PROMPT - zle .reset-prompt - fi - } - - zle-line-finish() { - set-transient-prompt - } - - trap 'set-transient-prompt; return 130' INT -fi - -if [[ $VCS = "1" ]]; then - zstyle ':vcs_info:*' check-for-changes true - autoload -Uz add-zsh-hook vcs-info - add-zsh-hook precmd vcs_info -fi - -autoload -Uz add-zsh-hook +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