X-Git-Url: https://git.sev.monster/~sev/dotfiles.git/blobdiff_plain/8b88e2ab3168f489e96295fbbb7e015ccac12a13..975ad64b1891b5653db9816fd95550896ae2a7a8:/base/.zshenv diff --git a/base/.zshenv b/base/.zshenv index 09faa1d..5142322 100644 --- a/base/.zshenv +++ b/base/.zshenv @@ -1,17 +1,33 @@ -if [ -f ~/.zshenv.local ]; then - source ~/.zshenv.local -fi +### load site-specific +[[ -f ~/.zshenv.local ]] && source ~/.zshenv.local -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 +### fix broken term +if [[ -o interactive && $#terminfo -eq 0 ]] { + _oldterm=$TERM + TERM=xterm-256color >/dev/null 2>&1 + print -P "%F{red}!!! Can't find terminfo for $_oldterm, using $TERM%f" + unset _oldterm +} -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 +if [[ -o login ]] { + ### cd on login shell for convenience + cd ~ +} else { + if [[ ! -v _sev_first_display && ( -v DISPLAY || -v WAYLAND_DISPLAY ) ]] { + # this is to allow gpg and pinentry env to be updated + # XXX: will be sourced by every new child shell if zsh is not used to + # start the graphical session, but since .zprofile is light that + # shouldn't cause a noticeable performance impact + # NOTE: above happens with sway without a display manager or launcher + export _sev_first_display= + source ${ZDOTDIR:-~}/.zprofile + export _sev_first_display=0 + } elif [[ $SHLVL == 1 ]] { + ### early zprofile sourcing for first shell + # NOTE: ensure profile is loaded for toplevel shells; should hopefully be 1 + # under some Xorg or cron implementations, which is where this would be most useful + source ${ZDOTDIR:-~}/.zprofile + } +} -export PYTHONSTARTUP=~/.pythonrc +# vim: et sts=4 sw=4 ts=8 tw=79