]> git.sev.monster Git - dotfiles.git/blobdiff - base/.zshenv
replace modeline with editorconfig; small fixes
[dotfiles.git] / base / .zshenv
index a709ce6efaf9b1520cce80985efc1160e6cc0953..90ec4cab246508429982add5421f6fad65538b6a 100644 (file)
@@ -1,29 +1,31 @@
+[[ -v _sev_home ]] || export _sev_home=$HOME
+
+export ZDOTDIR=${XDG_CONFIG_HOME:-~/.config}/zsh
+
 ### load site-specific
-[[ -f ~/.zshenv.local ]] && source ~/.zshenv.local
+[[ -f ${ZDOTDIR:-~}/.zshenv.local ]] && source ${ZDOTDIR:-~}/.zshenv.local
 
 ### fix broken term
-if (( $#terminfo == 0 )) {
-    [[ -o interactive ]] &&
-      print -P "%F{red}!!! Can't find terminfo for $TERM, using xterm%f"
-    TERM=xterm
+if [[ ! -v TERM ]] {
+    TERM=xterm-256color >/dev/null 2>&1
 }
-
-### early zprofile sourcing
-# NOTE: see comments in .zprofile for additional rationale for this
-if [[ ! -o login ]] {
-    if [[ -v _sev_olduser && $_sev_olduser != $USERNAME ]] {
-        # set up some user-dependent stuff since we switched users
-        # XXX: _sev_switched_users is no longer implemented
-        _sev_switched_users= source ${ZDOTDIR:-~}/.zprofile
-    } elif [[ $SHLVL == 1 ]] {
-        # ensure profile is loaded for toplevel shells; should hopefully be 1
-        # under Xorg or cron, which is where this would be most useful
-        source ${ZDOTDIR:-~}/.zprofile
-    }
-} else {
-    # for convenience
-    cd ~
+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
 }
-export _sev_olduser=$USERNAME
 
-# vim: et sts=4 sw=4 ts=8 tw=79
+# 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= source ${ZDOTDIR:-~}/.zprofile
+} elif [[ ! -o login && $SHLVL == 1 ]] {
+    ### early zprofile sourcing for first shell even if not a login shell
+    source ${ZDOTDIR:-~}/.zprofile
+}
This page took 0.038255 seconds and 4 git commands to generate.