summaryrefslogtreecommitdiff
path: root/.zshrc
diff options
context:
space:
mode:
authorThanos Apollo <[email protected]>2023-01-25 14:54:22 +0200
committerThanos Apollo <[email protected]>2023-01-25 14:54:22 +0200
commit9c5819681bad2773c8a6f2fbfa68aca4e38d6d23 (patch)
tree97f69aeb97b23a1cfef9257a4be773d8e06cc888 /.zshrc
parent74da30ee6d568287a6b356e27bd84371982ba43a (diff)
Add zshrc
Diffstat (limited to '.zshrc')
-rw-r--r--.zshrc65
1 files changed, 65 insertions, 0 deletions
diff --git a/.zshrc b/.zshrc
new file mode 100644
index 0000000..d7d32ba
--- /dev/null
+++ b/.zshrc
@@ -0,0 +1,65 @@
+# create a zkbd compatible hash;
+# to add other keys to this hash, see: man 5 terminfo
+
+
+# enable starship prompt
+
+source ~/.shells/alias
+source ~/.shells/exports
+
+source ~/.scripts/zsh-syntax-highlighting/zsh-syntax-highlighting.zsh
+source ~/.scripts/zsh-autosuggestions/zsh-autosuggestions.zsh
+
+#export PATH=/home/apollo/.local/bin:$PATH
+
+eval "$(/gnu/store/9f5mw8sy3ng95ays3alymag3qnxb0mna-starship-1.12.0/starship init zsh)"
+
+autoload -Uz compinit
+compinit
+
+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
+
+# History search
+autoload -Uz up-line-or-beginning-search down-line-or-beginning-search
+zle -N up-line-or-beginning-search
+zle -N down-line-or-beginning-search
+
+[[ -n "${key[Up]}" ]] && bindkey -- "${key[Up]}" up-line-or-beginning-search
+[[ -n "${key[Down]}" ]] && bindkey -- "${key[Down]}" down-line-or-beginning-search