### This configuration makes zsh fully "XDG compliant". One change is needed to ### /etc/zsh/zshenv (or equivalent upstream profile): ### `export ZDOTDIR="$HOME"/.config/zsh` # # Lines configured by zsh-newuser-install export HISTFILE="$XDG_STATE_HOME"/zsh/history mkdir -p "$(dirname "$HISTFILE")" HISTSIZE=100000 SAVEHIST=100000 setopt autocd unsetopt beep bindkey -v # End of lines configured by zsh-newuser-install # The following lines were added by compinstall zstyle :compinstall filename "$ZDOTDIR/.zshrc" autoload -Uz compinit compinit -d "$XDG_CACHE_HOME"/zsh/zcompdump-"$ZSH_VERSION" # End of lines added by compinstall ### User configuration # for shell integration precmd() { print -Pn "\e]133;A\e\\" } # prompt configuration autoload -Uz vcs_info precmd_vcs_info () { vcs_info } precmd_functions+=( precmd_vcs_info ) setopt prompt_subst zstyle ':vcs_info:*' formats ' %F{green}%b' PROMPT='%F{yellow}%n@%m %F{white}%1~%(?.. %?) $ ' RPROMPT='%f$vcs_info_msg_0_ ' alias boinctui='boinctui --boinchost=localhost' alias bt='bluetoothctl' alias c='clear' alias daybreak='mosh daybreak -p 60101' alias epoch='mosh epoch -p 60104' alias grc='gridcoinresearchd' alias l='eza -lh --all --octal-permissions' alias less='less -r' alias ls='eza' alias lsa='eza -a' alias lss='eza -a' alias vim='nvim' alias wake_circadian='ssh epoch wol a8:a1:59:11:06:f1' alias xrm='sudo xbps-remove' if [[ -n "$WSL_DISTRO_NAME" ]]; then alias adb='adb.exe' alias choco='choco.exe' alias fastboot='fastboot.exe' alias gsudo='gsudo.exe' alias pwsh='pwsh.exe' alias usbipd='usbipd.exe' fi # GPG setup (and SSH) # SSH setup # I finally figured out how to export my id_rsa from GPG using # https://superuser.com/a/1681454 (copied/summarized here to avoid link rot): # 0. Run `gpg -K --with-keygrip` and note the desired keygrip (probably the one # with [A] for auth). # 1. Run `gpgsm --gen-key -o tempcert`: # a. Select "Existing Key". # b. Enter the keygrip from step 0. # c. Select "(1) sign, encrypt". This and following steps don't really apply # for our use case, but we need to do it to make the tool happy. # d. Enter some valid X.509 subject, e.g. "C=US". # e. Press enter for rest of fields. # f. "y" to create self-signed certificate. # g. "y" to proceed with creation. # 2. `gpgsm --import tempcert` and `gpgsm -K` to get the (new) keyid. # 3. `gpgsm --export-secret-key-p8 -a -o id_rsa $keyid` # 4. (optional) `rm tempcert`, probably don't want that sitting around. # 5. (optional) Trim the phony metadata we gave to gpgsm that is prepended to # the exported PEM cert (id_rsa). if command -v keychain >/dev/null; then alias keychain="keychain --nolock --absolute --dir $XDG_RUNTIME_DIR" eval "$(keychain --quick --eval)" rbw unlock SSH_ASKPASS=get_id_rsa_pass SSH_ASKPASS_REQUIRE=force ssh-add ~/.ssh/id_rsa fi ### End user configuration ### hooks/includes for plugin in zsh-syntax-highlighting zsh-history-substring-search \ zsh-autosuggestions; do if [ -f /usr/share/zsh/plugins/$plugin/${plugin}.zsh ]; then source /usr/share/zsh/plugins/$plugin/${plugin}.zsh fi done bindkey '^[[A' history-substring-search-up bindkey '^[[B' history-substring-search-down bindkey -M vicmd 'k' history-substring-search-up bindkey -M vicmd 'j' history-substring-search-down if command -v pazi &>/dev/null; then eval "$(pazi init zsh)" # or 'bash' fi