From 1bbccbe618021500a3eaa977dad8c322194c9dee Mon Sep 17 00:00:00 2001 From: Peter Date: Sun, 28 Jun 2020 02:21:13 +0100 Subject: Add basic zshrc --- .config/zsh/.zshrc | 123 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 123 insertions(+) create mode 100644 .config/zsh/.zshrc (limited to '.config/zsh') diff --git a/.config/zsh/.zshrc b/.config/zsh/.zshrc new file mode 100644 index 0000000..4c1ecdf --- /dev/null +++ b/.config/zsh/.zshrc @@ -0,0 +1,123 @@ +# Created by newuser for 5.8 + +export SYNCDIR="$HOME/vault" + +# dotfiles alias: dotfiles config --local status.showUntrackedFiles no +alias dotfiles='git --git-dir=$SYNCDIR/src/dotfiles/ --work-tree=$HOME' + +# create a zkbd compatible hash; +# to add other keys to this hash, see: man 5 terminfo +typeset -g -A key + +key[Home]="${terminfo[khome]}" +key[End]="${terminfo[kend]}" +key[Insert]="${terminfo[kich1]}" +key[Backspace]="${terminfo[kbs]}" +key[Delete]="${terminfo[kdch1]}" +key[Up]="${terminfo[kcuu1]}" +key[Down]="${terminfo[kcud1]}" +key[Left]="${terminfo[kcub1]}" +key[Right]="${terminfo[kcuf1]}" +key[PageUp]="${terminfo[kpp]}" +key[PageDown]="${terminfo[knp]}" +key[Shift-Tab]="${terminfo[kcbt]}" + +# setup key accordingly +[[ -n "${key[Home]}" ]] && bindkey -- "${key[Home]}" beginning-of-line +[[ -n "${key[End]}" ]] && bindkey -- "${key[End]}" end-of-line +[[ -n "${key[Insert]}" ]] && bindkey -- "${key[Insert]}" overwrite-mode +[[ -n "${key[Backspace]}" ]] && bindkey -- "${key[Backspace]}" backward-delete-char +[[ -n "${key[Delete]}" ]] && bindkey -- "${key[Delete]}" delete-char +[[ -n "${key[Up]}" ]] && bindkey -- "${key[Up]}" up-line-or-history +[[ -n "${key[Down]}" ]] && bindkey -- "${key[Down]}" down-line-or-history +[[ -n "${key[Left]}" ]] && bindkey -- "${key[Left]}" backward-char +[[ -n "${key[Right]}" ]] && bindkey -- "${key[Right]}" forward-char +[[ -n "${key[PageUp]}" ]] && bindkey -- "${key[PageUp]}" beginning-of-buffer-or-history +[[ -n "${key[PageDown]}" ]] && bindkey -- "${key[PageDown]}" end-of-buffer-or-history +[[ -n "${key[Shift-Tab]}" ]] && bindkey -- "${key[Shift-Tab]}" reverse-menu-complete + +# Finally, make sure the terminal is in application mode, when zle is +# active. Only then are the values from $terminfo valid. +if (( ${+terminfo[smkx]} && ${+terminfo[rmkx]} )); then + autoload -Uz add-zle-hook-widget + function zle_application_mode_start { echoti smkx } + function zle_application_mode_stop { echoti rmkx } + add-zle-hook-widget -Uz zle-line-init zle_application_mode_start + add-zle-hook-widget -Uz zle-line-finish zle_application_mode_stop +fi + +bindkey "^[[1;5C" forward-word +bindkey "^[[1;5D" backward-word + +# Oxide theme for Zsh +# +# Author: Diki Ananta +# Repository: https://github.com/dikiaap/dotfiles +# License: MIT + +# Prompt: +# %F => Color codes +# %f => Reset color +# %~ => Current path +# %(x.true.false) => Specifies a ternary expression +# ! => True if the shell is running with root privileges +# ? => True if the exit status of the last command was success +# +# Git: +# %a => Current action (rebase/merge) +# %b => Current branch +# %c => Staged changes +# %u => Unstaged changes +# +# Terminal: +# \n => Newline/Line Feed (LF) + +setopt PROMPT_SUBST + +autoload -U add-zsh-hook +autoload -Uz vcs_info + +# Use True color (24-bit) if available. +if [[ "${terminfo[colors]}" -ge 256 ]]; then + oxide_turquoise="%F{73}" + oxide_orange="%F{179}" + oxide_red="%F{167}" + oxide_limegreen="%F{107}" +else + oxide_turquoise="%F{cyan}" + oxide_orange="%F{yellow}" + oxide_red="%F{red}" + oxide_limegreen="%F{green}" +fi + +# Reset color. +oxide_reset_color="%f" + +# VCS style formats. +FMT_UNSTAGED="%{$oxide_reset_color%} %{$oxide_orange%}●" +FMT_STAGED="%{$oxide_reset_color%} %{$oxide_limegreen%}✚" +FMT_ACTION="(%{$oxide_limegreen%}%a%{$oxide_reset_color%})" +FMT_VCS_STATUS="on %{$oxide_turquoise%} %b%u%c%{$oxide_reset_color%}" + +zstyle ':vcs_info:*' enable git svn +zstyle ':vcs_info:*' check-for-changes true +zstyle ':vcs_info:*' unstagedstr "${FMT_UNSTAGED}" +zstyle ':vcs_info:*' stagedstr "${FMT_STAGED}" +zstyle ':vcs_info:*' actionformats "${FMT_VCS_STATUS} ${FMT_ACTION}" +zstyle ':vcs_info:*' formats "${FMT_VCS_STATUS}" +zstyle ':vcs_info:*' nvcsformats "" +zstyle ':vcs_info:git*+set-message:*' hooks git-untracked + +# Check for untracked files. ++vi-git-untracked() { + if [[ $(git rev-parse --is-inside-work-tree 2> /dev/null) == 'true' ]] && \ + git status --porcelain | grep --max-count=1 '^??' &> /dev/null; then + hook_com[staged]+="%{$oxide_reset_color%} %{$oxide_red%}●" + fi +} + +# Executed before each prompt. +add-zsh-hook precmd vcs_info + +# Oxide prompt style. +PROMPT=$'\n%{$oxide_limegreen%}%~%{$oxide_reset_color%} ${vcs_info_msg_0_}\n%(?.%{%F{white}%}.%{$oxide_red%})%(!.#.❯)%{$oxide_reset_color%} ' -- cgit v1.2.3