X-Git-Url: https://git.sev.monster/~sev/dotfiles.git/blobdiff_plain/d50f11d1b1c215bfc135949c0bd5d6faea6a4199..54a85d6c6744df54af2c092234ba84baacdc5ebc:/base/.zshenv diff --git a/base/.zshenv b/base/.zshenv index 3a577ad..f6f0646 100644 --- a/base/.zshenv +++ b/base/.zshenv @@ -1,17 +1,31 @@ -export EDITOR=vim -export XDG_CONFIG_HOME=~/etc -export XDG_CONFIG_DIRS=~/.config:/etc/xdg -export XDG_DATA_HOME=~/share -export XDG_DATA_DIRS=~/.local/share:/usr/local/share/:/usr/share/ -export XDG_CACHE_HOME=~/tmp +[[ -v _sev_home ]] || export _sev_home=$HOME -export DVTM_TERM=rxvt-unicode -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 -if [[ -f ~/.zshenv.local ]]; then - source ~/.zshenv.local -fi +### 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= 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 +}