summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPeter2020-06-28 02:21:13 +0100
committerPeter2020-06-28 02:21:13 +0100
commit1bbccbe618021500a3eaa977dad8c322194c9dee (patch)
tree645e568e15248c16f1ae05b7c638416047907647
parent1c96d3c59f7891854c2e639c685041bc9d7ced3a (diff)
downloaddotfiles-1bbccbe618021500a3eaa977dad8c322194c9dee.tar.gz
dotfiles-1bbccbe618021500a3eaa977dad8c322194c9dee.tar.bz2
dotfiles-1bbccbe618021500a3eaa977dad8c322194c9dee.zip
Add basic zshrc
-rw-r--r--.config/zsh/.zshrc123
1 files changed, 123 insertions, 0 deletions
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 <diki1aap@gmail.com>
+# 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%} '