]> git.sev.monster Git - dotfiles.git/blobdiff - base/.zshrc
link src/docker-abuild/dabuild -> bin/ if present
[dotfiles.git] / base / .zshrc
index 393d2298b8eddbc23188630f53b6df5d7e51c9c6..96f14c5157c4db28a88f3a8a8cba4c6d34181150 100644 (file)
@@ -1,12 +1,26 @@
-### options
-setopt autocd extendedglob
-unsetopt beep
+### imports
+source ~/bin/.check-busybox
+
+### user-local fpath
+fpath=(~/.zsh ~/.zsh/functions/Prompts "${fpath[@]}")
 
-### history
-setopt appendhistory
+### options
+setopt NO_BEEP NO_CLOBBER
+## cd
+setopt AUTO_CD CDABLE_VARS
+## completion
+setopt GLOB_COMPLETE
+## line
+setopt EXTENDED_GLOB GLOB_DOTS MARK_DIRS NOMATCH NUMERIC_GLOB_SORT
+## prompt
+setopt PROMPT_SUBST
+## jobs
+setopt AUTO_CONTINUE
+## history
+setopt NO_HIST_SAVE_BY_COPY HIST_IGNORE_DUPS SHARE_HISTORY
 HISTFILE=~/.histfile
-HISTSIZE=100
-SAVEHIST=100
+HISTSIZE=1000
+SAVEHIST=1000
 
 ### keys
 bindkey -v
@@ -19,40 +33,51 @@ bindkey -a "^[[8~" end-of-line
 bindkey    "^[[3~" delete-char       #Del
 bindkey -a "^[[3~" delete-char
 ## 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
+autoload -Uz up-line-or-beginning-search down-line-or-beginning-search && {
+    if [[ -n "$key[Up]" ]] {
+        zle -N up-line-or-beginning-search
+        bindkey -- "$key[Up]"   up-line-or-beginning-search
+    }
+    if [[ -n "$key[Down]" ]] {
+        bindkey -- "$key[Down]" down-line-or-beginning-search
+        zle -N down-line-or-beginning-search
+    }
+}
 
 ### aliases
 alias h="history -25"
 alias j="jobs -l"
 alias l="ls -AF"
+alias e="${EDITOR:-vi}" # TODO: make sure vi is there or use safe default
 if [[ "$OSTYPE" =~ '^(free|net)bsd' ]] {
     alias ll="ls -lAFho"
 } else {
     alias ll="ls -lAFh"
 }
 ## ps
-local p=""
-if { which pstree >/dev/null 2>&1 && [[ ! "$(readlink -f $(which pstree))" =~ "/busybox" ]] } {
+local p=
+if which pstree >/dev/null 2>&1 && ! check-busybox pstree; then
+    # use pstree, but NOT busybox pstree because it kinda sucks
     p="pstree -wg3"
-} elif [[ "$OSTYPE" =~ '^freebsd' ]] {
+elif [[ "$OSTYPE" =~ '^freebsd' ]]; then
     p="ps -aSdfxwwouser=USR -ogroup=GRP -opid,nice=NI \
        -o%cpu,%mem,tty,stat,start=START -oetime,command"
-} elif [[ "$(readlink -f $(which ps))" =~ "/busybox" ]] {
+elif check-busybox ps; then
     # busybox compatible
     p="ps -eouser='USR     ' -ogroup='GRP     ' \
        -opid='  PID' -onice=' NI' -ovsz=' MEM' \
        -otty,stat,etime,comm"
-} else {
+else
     # XXX: untested, posix
     # TODO: support gnu ps
     p="ps -eouser=USR -ogroup=GRP -opid,nice=NI \
        -opcpu=CPU -ovsz=MEM -otty,stat,etime,comm"
+fi
+if [[ "$(basename "$PAGER")" = "less" ]] {
+    p="$p | less -SE"
+} else {
+    p="$p | \"${PAGER:-more}\""
 }
-p="$p | ${PAGER:-more} -Se"
 alias pa="$p"
 alias spa="sudo $p"
 unset p
@@ -66,54 +91,24 @@ if [[ "$OSTYPE" =~ '^freebsd' ]] {
     # don't confirm if only a few files are deleted
     alias rm='rm -I'
 } else {
-    # TODO: similar behavior for non-freebsd
+    # TODO: similar behavior for non-freebsd, or impliment in zsh
     alias rm='rm -i'
 }
-
-### prompt
-setopt prompt_subst
-# DEPR: color reset added to NetBSD in PR/53245, following is not needed for recent releases
-#local f=
-#XXX: can't think of a way to tell if ssh client is on wscons, just kludge 24/7
-#if [[ "$OSTYPE" = "netbsd" && ( "$TERM" =~ "^wsvt" || "$TERM" =~ '^vt' ) ]] {
-#    # fix for wscons
-#    f="%F{white}"
-#} else {
-#    f="%f"
-#}
-PROMPT='%F{$VICOL}%n%f@%F{$VICOL}%2m%f%(?../%F{red}$?%f)%# '
-RPROMPT='%F{yellow}${vcs_info_msg_0_:-%~}%f %T'
-
-## change color based on zle vi mode
-function zle-line-init zle-keymap-select {
-    VICOL="${${KEYMAP:/vicmd/red}:/(main|viins)/green}"
-    zle reset-prompt
+## go up directories
+function up() {
+    cd $(printf '../%.0s' {1..${1:-1}})
 }
-zle -N zle-line-init
-zle -N zle-keymap-select
-
-## vcs
-autoload -Uz vcs_info
-zstyle ':vcs_info:*' enable git
-zstyle ':vcs_info:git*' formats '%c%u%%F{green}%r/%b%%F{white}/%%F{yellow}%S%%f'
-zstyle ':vcs_info:git*' actionformats '%%F{red}(%a)%f %c%u%%F{green}%r/%b%f/%%F{yellow}%S%f'
-#zstyle ':vcs_info:git*' check-for-changes true #too slow
-zstyle ':vcs_info:git*:dotfiles' check-for-changes true
-zstyle ':vcs_info:git*' check-for-staged-changes true
-zstyle ':vcs_info:git*' stagedstr   "%F{blue}+"
-zstyle ':vcs_info:git*' unstagedstr "%F{red}*"
-
-#unset f
 
 ### hooks
 local _exectime=
 function precmd {
     # change terminal title
+    # TODO: update and send BEL when job status changes
     print -Pn "\e]2;%(1j,%j,)%#${SSH_CLIENT+$USER@$HOST:}%~\e\\"
-    # update vcs
-    vcs_info
     # bell if exec takes 5s
     if ((SECONDS - _exectime >= 5)) print "\a"
+    # we could update vcs_info here, but let prompt take care of it
+    # if it doesn't use vcs, it can be ignored safely
 }
 function preexec {
     # change terminal title to show command
@@ -177,10 +172,21 @@ case "$OSTYPE"; in
     *)
         ## sound
         # TODO: test alsa/oss/sndio/portaudio/pulse in order of importance
+        function s() {}
+        function vol() {}
 esac
 
+### modules & styles
+## vcs
+autoload -Uz vcs_info
+zstyle ':vcs_info:*' enable git
+#zstyle ':vcs_info:git*' check-for-changes true #too slow
+zstyle ':vcs_info:git*:dotfiles' check-for-changes true
+zstyle ':vcs_info:git*' check-for-staged-changes true
+
+## compinit
 # The following lines were added by compinstall
-zstyle ':completion:*' auto-description 'specify: %d'
+zstyle ':completion:*' auto-description '[arg] %d'
 zstyle ':completion:*' expand suffix
 zstyle ':completion:*' format '# %d'
 zstyle ':completion:*' group-name ''
@@ -200,4 +206,13 @@ autoload -Uz compinit
 compinit
 # End of lines added by compinstall
 
-# vim: ts=8:sts=4:sw=4:et:tw=79
+## prompt
+# do this last so prompt can potentially override
+autoload -Uz promptinit && promptinit
+prompt arrows
+
+
+### unset imports
+unfunction check-busybox
+
+# vim: set et sts=4 sw=4 ts=8 tw=79 :
This page took 0.038276 seconds and 4 git commands to generate.