]> git.sev.monster Git - dotfiles.git/blobdiff - base/.zshenv
fix term error msg in .zshenv
[dotfiles.git] / base / .zshenv
index 7ef4681c0ee61e0aa54fca7d8bc6beff2ed74c3a..5142322e8549e8f04338de0dc7575ddd4bad9794 100644 (file)
@@ -1,12 +1,33 @@
-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"
+### load site-specific
+[[ -f ~/.zshenv.local ]] && source ~/.zshenv.local
 
-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
+### 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 PYTHONSTARTUP=~/.pythonrc
+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 PUUSH_API_KEY=159C54A56C88394136BA1ACB6A9D8F80
+# vim: et sts=4 sw=4 ts=8 tw=79
This page took 0.031312 seconds and 4 git commands to generate.