]> git.sev.monster Git - dotfiles.git/blobdiff - base/.zshenv
update zsh, X, gpg config; add ssh config, gpg bin
[dotfiles.git] / base / .zshenv
index 46b0e662703896389e5ad0116e72992a6b9dff16..819eb70e00260a893cca9baaaa95478d7a74d681 100644 (file)
@@ -1,44 +1,57 @@
-### path
-# /usr/{pkg,local,games} are unix/bsdisms
-typeset -U path
-path=({~/,/,/usr/}sbin {~/,/,/usr/}bin /usr/pkg/{s,}bin /usr/X11R{7,6}/bin
-      /usr/local/{s,}bin /usr/games $path)
+### exports for new non-interactive shell
+if [[ $SHLVL == 1 ]] {
+    ## lang
+    export CHARSET=UTF-8
+    export LANG="en_US.UTF-8"
+    export LC_CTYPE="$LANG"
 
-### posix
-export EDITOR=vim
-export PAGER=less
-export GREP_OPTIONS=--color=auto
-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
+    ## 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
 
-### applications
-export PYTHONSTARTUP=~/.pythonrc
-## perl
-(( ${+commands[perl]} )) && eval $(perl -I $XDG_DATA_HOME/perl5/lib/perl5 -Mlocal::lib=$XDG_DATA_HOME/perl5)
-## gpg
-export GPG_TTY=$(tty)
-if [[ ! -v SSH_AUTH_SOCK ]] {
-       # set up SSH auth socket and start GPG agent
-       export SSH_AUTH_SOCK=$(gpgconf --list-dirs agent-ssh-socket)
+    # 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
 }
-gpg-connect-agent updatestartuptty /bye >/dev/null
 
-### freebsd
-if [[ "$OSTYPE" =~ "^freebsd" ]] {
-       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'
+### 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
 }
 
 ### load site-specific
-if [[ -f ~/.zshenv.local ]] && [[ ! -v _ZSHENV_LOADED ]] {
-       export _ZSHENV_LOADED=
-       source ~/.zshenv.local
-}
+if [[ -f ~/.zshenv.local ]] { source ~/.zshenv.local }
+
+# vim: set et sts=4 sw=4 ts=8 tw=79 :
This page took 0.034296 seconds and 4 git commands to generate.