X-Git-Url: https://git.sev.monster/~sev/dotfiles.git/blobdiff_plain/b133dc9212c5d15d32757135d46d28481bffac4f..4fec01cb66f5553ac7f11ac0b8c77d6078c8210c:/base/.zshenv diff --git a/base/.zshenv b/base/.zshenv index 819eb70..7e8dee7 100644 --- a/base/.zshenv +++ b/base/.zshenv @@ -1,57 +1,33 @@ -### exports for new non-interactive shell -if [[ $SHLVL == 1 ]] { - ## lang - export CHARSET=UTF-8 - export LANG="en_US.UTF-8" - export LC_CTYPE="$LANG" - - ## path - # /usr/{pkg,local,games} are unix/bsdisms - typeset -U PATH path - path=({~/,/,/usr/}sbin {~/,/,/usr/}bin /usr/pkg/{s,}bin /usr/X11R{7,6}/bin - /usr/local/{s,}bin /usr/games "${path[@]}") - export PATH - typeset -U _sev_backup_path - _sev_backup_path=("${path[@]}") - typeset -U FPATH fpath - fpath=(${ZDOTDIR:-$HOME/.zsh}/functions/{*,Completions/*}(N) "${fpath[@]}") - export FPATH - - ## xdg - export XDG_CONFIG_HOME=~/etc - export XDG_CONFIG_DIRS=~/.config:/usr/pkg/etc/xdg:/usr/local/etc/xdg:/etc/xdg - export XDG_DATA_HOME=~/share - export XDG_DATA_DIRS=~/.local/share:/usr/pkg/share:/usr/local/share:/usr/share - export XDG_CACHE_HOME=~/tmp - export XDG_RUNTIME_DIR=~/tmp +### load site-specific +[[ -f ~/.zshenv.local ]] && source ~/.zshenv.local - # create tmp link - t="${TMPDIR:-/tmp}/home-$LOGNAME" - h="$HOME/tmp" - if [[ ! -e "$t" ]] { - mkdir -m 700 "$t" > /dev/null 2>&1 - # TODO: check if dir exists after mkdir - } - # allow opaque entries to override link creation - if [[ ! -e "$h" ]] { - ln -sf "$t" "$h" > /dev/null 2>&1 - } - unset t h +### 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 } -### gpg ssh forwarding -# these env vars are used as arguments to RemoteForward in ~/.ssh/config -if [[ -v commands[gpgconf] && ! ( -v _GNUPG_SOCK_SRC && -v _GNUPG_SOCK_DEST ) ]] { - # if already connected over SSH, reuse forwarded socket for future - # connections; else use extra socket - sock=${SSH_CLIENT:+agent-socket} - export _GNUPG_SOCK_SRC=$(gpgconf --list-dirs ${sock:-agent-extra-socket}) - # XXX: chance of race condition - export _GNUPG_SOCK_DEST=/tmp/.gpg-agent-forward - unset sock +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 + } } -### load site-specific -if [[ -f ~/.zshenv.local ]] { source ~/.zshenv.local } - -# vim: set et sts=4 sw=4 ts=8 tw=79 : +# vim: et sts=4 sw=4 ts=8 tw=79