]> git.sev.monster Git - dotfiles.git/blobdiff - base/.zshenv
zsh: compact path glob, avoid double source
[dotfiles.git] / base / .zshenv
index 7ef4681c0ee61e0aa54fca7d8bc6beff2ed74c3a..45ea3392b6130062cb6a8b789d38dcf4aee6099d 100644 (file)
@@ -1,12 +1,32 @@
-export EDITOR=vim
-export XDG_DATA_HOME="$HOME/share"
-export XDG_DATA_DIRS="$HOME/.local/share:/usr/local/share/:/usr/share/"
-export XDG_CACHE_HOME="$HOME/tmp"
+[[ -v _sev_home ]] || export _sev_home=$HOME
 
-export CLICOLOR=
-export LS_COLORS='di=34:ln=35:so=32:pi=33:ex=31:bd=46;34:cd=43;34:su=41;30:sg=46;30:tw=42;30:ow=43;30'
-export GREP_OPTIONS=--color=auto
+export ZDOTDIR=${XDG_CONFIG_HOME:-~/.config}/zsh
 
-export PYTHONSTARTUP=~/.pythonrc
+### load site-specific
+[[ -f ${ZDOTDIR:-~}/.zshenv.local ]] && source ${ZDOTDIR:-~}/.zshenv.local
 
-export PUUSH_API_KEY=159C54A56C88394136BA1ACB6A9D8F80
+### fix broken term
+if [[ ! -v TERM ]] {
+    TERM=xterm-256color >/dev/null 2>&1
+}
+if [[ -o interactive && $#terminfo -eq 0 ]] {
+    _oldterm=$TERM
+    export TERM=xterm >/dev/null 2>&1
+    print -P "%F{red}!!! Can't find terminfo for $_oldterm, using $TERM%f"
+    unset _oldterm
+}
+
+# NOTE: see .zprofile comment for rationale on sourcing
+if [[ ! -v _sev_first_display && ( -v DISPLAY || -v WAYLAND_DISPLAY ) ]] {
+    ### update gpgagent to use graphical pinentry
+    # XXX: will be sourced by every new child shell if zsh is not used to
+    #      start the graphical session and the _sev_first_display var isn't
+    #      exported; for example, this previously happened with sway without a
+    #      display manager or launcher in front of it
+    export _sev_first_display=
+    _sev_refresh_gpgagent=
+    [[ ! -o login ]] && source ${ZDOTDIR:-~}/.zprofile
+} elif [[ ! -o login && $SHLVL -eq 1 && ${+TERMUX_VERSION} -eq 0 ]] {
+    ### early zprofile sourcing for first shell even if not a login shell
+    source ${ZDOTDIR:-~}/.zprofile
+}
This page took 0.033847 seconds and 4 git commands to generate.