]> git.armaanb.net Git - admone.git/blobdiff - admone.zsh
Combine VCS and PWD
[admone.git] / admone.zsh
index dfbb9c398c939b4cc7da5db1a12f595254ba8a9d..e41e7e6fc7965e9de61a1588dbbbd95ae2c78d7f 100644 (file)
-#######################################################################
-# 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 <me@armaanb.net>
+# MIT licensed, see the LICENSE file for more information.
 
-#
-# USER CONFIGURATIONS
-#
+PROMPT_CHAR="➤"
 
-ADMONE_PROMPT_CHAR="➤"
-  # ADMONE_PROMPT_CHAR="❯❯❯"
-  # ADMONE_PROMPT_CHAR="$"
-  # ADMONE_PROMPT_CHAR="%"
-  # ADMONE_PROMPT_CHAR=">"
-  # ADMONE_PROMPT_CHAR="➢"
-  # ADMONE_PROMPT_CHAR="➪"
-ADMONE_PRE_UPPER="╭"
-ADMONE_PRE_LOWER="╰"
-  # ADMONE_PRE_UPPER="┌"
-  # ADMONE_PRE_LOWER="└"
-ADMONE_BLOCK_SEPARATOR="─"
-  # ADMONE_BLOCK_SEPARATOR="∙"
-ADMONE_BLOCK_LEFT="["
-ADMONE_BLOCK_RIGHT="]"
-  # ADMONE_BLOCK_LEFT="{"
-  # ADMONE_BLOCK_RIGHT="}"
-  # ADMONE_BLOCK_LEFT="("
-  # ADMONE_BLOCK_RIGHT=")"
-ADMONE_VI_MODE_CURSOR="1"
-  # ADMONE_VI_MODE_CURSOR="1"
-ADMONE_SHOW_0_EXIT_CODE="0"
-ADMONE_GIT_SHOW_BLANK="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"
-}
-function admone-git {
-  git_branch="$(git rev-parse --abbrev-ref HEAD 2>/dev/null)"
-  if [[ $ADMONE_GIT_SHOW_BLANK == "0" ]]; then
-    if [[ ${git_branch//\%/%%} == "" ]]; then
-      echo "%F{blue}n/a%f"
-    else
-      echo "%F{green}${git_branch//\%/%%}%f"
-    fi
-  else
-    echo "%F{green}${git_branch//\%/%%}%f"
-  fi
-}
-function admone-exit-code {
-  if [[ $ADMONE_SHOW_0_EXIT_CODE == "1" ]]; then
-    echo "%(?,%F{cyan}%?%f,%F{red}%?%f)"
-  elif [[ $ADMONE_SHOW_0_EXIT_CODE == "0" ]]; then
-    echo "%(?,,%F{red}%?%f)"
-  fi
-}
-function admone-date {
-  echo $(date -I)
-}
-function admone-12hr {
-  echo $(date +%r)
-}
-function admone-24hr {
-  echo $(date +%T)
-}
-# Intergration with https://codeberg.org/armaan/zsh-command-time
-function 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 {
-  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 [[ $i == 0 ]]; 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