X-Git-Url: https://git.sev.monster/~sev/dotfiles.git/blobdiff_plain/7ddca96da6e30ad4b5a05c4804bf11911bd671eb..c7e3e126ca2bfe463d344260b73b8c044e203ea0:/base/.zlogout diff --git a/base/.zlogout b/base/.zlogout index 1e50611..6e7b474 100644 --- a/base/.zlogout +++ b/base/.zlogout @@ -1,5 +1,11 @@ -# gpg forward cleanup -if [[ $SHLVL == 1 && $GNUPGHOME =~ '.ssh_forward/\d+$' ]] { +# NOTE: for the cleanups below, even if our shell is not the one that spawned +# the directory, SHLVL == 1 means that it should be safe to clean it up. +# since .zlogout isn't guaranteed to have been run in the same shell as +# our .zprofile was (since we source it in .zshenv) it has to be done +# like this. + +### gpg forward cleanup +if [[ $SHLVL == 1 && $GNUPGHOME =~ '/.ssh_forward/\d+/*$' ]] { x=$GNUPGHOME # reset GNUPGHOME [[ -o GLOB_ASSIGN ]]; y=$? @@ -17,11 +23,15 @@ if [[ $SHLVL == 1 && $GNUPGHOME =~ '.ssh_forward/\d+$' ]] { rm -f $_GNUPG_SOCK_DEST_BASE*(N=) } -# remove xdg runtime -rm -rf $XDG_RUNTIME_DIR 2>/dev/null +### remove tmp runtime if our shell spawned it +if [[ $SHLVL == 1 && $TMPDIR =~ '/.session.\d+/*$' ]] { + rm -rf $TMPDIR 2>/dev/null +} -[[ -o interactive ]] && echo logout -clear +if [[ -o interactive ]] { + echo logout + clear +} ### load site-specific if [[ -f ~/.zlogout.local ]] { source ~/.zlogout.local }