X-Git-Url: https://git.shemshak.org/~bandali/configs/blobdiff_plain/16ff2912b50296e533a40e149cad944bfaf30391..ccbb71911874084108954d62c689ea6ebba53958:/.bashrc diff --git a/.bashrc b/.bashrc index daa4d00..4bc8787 100644 --- a/.bashrc +++ b/.bashrc @@ -21,24 +21,41 @@ if [ -n "$IS_GUIX_SYSTEM" ]; then source /etc/bashrc fi -# from https://unix.stackexchange.com/a/55935 -a_prompt() { - cwd=$(sed -e "s:$HOME:~:" -e "s:\(\.\?[^/]\)[^/]*/:\1/:g" <<<$PWD) - printf $cwd +# prompt +# ------ + +b_prompt() { + case $TERM in + xterm*) + local TITLEBAR='\[\033]0;\h:\w\007\]' + ;; + *) + local TITLEBAR='' + ;; + esac + + PS1="${TITLEBAR}\ +$([ $(id -u) = "0" ] && printf "\[\e[1;31m\]")\ +: \h:\w\ +$([ -n "$GUIX_ENVIRONMENT" ] && printf " [env]")\ + ;\ +$([ $(id -u) = "0" ] && printf "\[\e[00m\]")\ + " } -# Adjust the prompt depending on whether we're in 'guix environment'. -if [ -n "$GUIX_ENVIRONMENT" ] -then - PS1="\u@\h [env] \$(a_prompt)> " -else - PS1="\u@\h \$(a_prompt)> " -fi +b_prompt + +# cursor +# ------ -# i-beam cursor -# echo -e "\033[5 q" # blinking -# echo -e "\033[6 q" # non-blinking +# i-beam cursor (uncomment one of the two): +# echo -e "\033[5 q" # blinking +# echo -e "\033[6 q" # non-blinking -# various bash tweaks +# general configuration and completions +# ------------------------------------- + +# disallow overwriting existing file using redirection +set -o noclobber # append to the history file, don't overwrite it shopt -s histappend shopt -s cmdhist @@ -55,11 +72,41 @@ HISTFILESIZE= # history. HISTCONTROL=ignoreboth # ignore a few very common commands and don't add them to history -HISTIGNORE='ls:l:s:g:[bf]g:history' +#HISTIGNORE='ls:l:ll:s:g:[bf]g:history:da:li' HISTTIMEFORMAT='%F %T ' stty stop "" -# aliases +# enable programmable completion features (not needed if already +# enabled in /etc/bash.bashrc and if /etc/profile sources +# /etc/bash.bashrc). +if ! shopt -oq posix; then + if [ -f /usr/share/bash-completion/bash_completion ]; then + . /usr/share/bash-completion/bash_completion + elif [ -f /etc/bash_completion ]; then + . /etc/bash_completion + fi +fi + +# source Guix shell config dirs, for vte.sh and bash completions +GUIX_PROFILES=("${HOME}/.guix-profile" + "${HOME}/.config/guix/current") +for profile in "${GUIX_PROFILES[@]}"; do + for dir in "${profile}/etc/bash_completion.d" "${profile}/etc/profile.d"; do + if [ -d "${dir}" ]; then + for f in "${dir}"/*; do + . $f + done + fi + done +done + +# aliases and functions +# --------------------- + +if [ -f ~/.bash_aliases ]; then + . ~/.bash_aliases +fi + alias ls='ls -p --color=auto' alias l='ls -lh' # long format and human-readable sizes alias ll='l -A' # long format, all files @@ -68,7 +115,7 @@ alias vdir='vdir --color=auto' alias grep='grep --color=auto' alias fgrep='fgrep --color=auto' alias egrep='egrep --color=auto' -alias mpv="mpv --ytdl-format mp4" +alias mpv="mpv --ytdl-format=mp4" alias mv="mv -iv" alias cp="cp -iv" alias mbsync='mbsync -c "$XDG_CONFIG_HOME"/isync/mbsyncrc' @@ -77,34 +124,15 @@ alias m="mbsync csclub; mbsync uwaterloo; mbsync shemshak; mbsync gnub" alias best="youtube-dl -f best" alias e="$EDITOR" alias se="SUDO_EDITOR=\"emacsclient\" sudo -e" +alias s="startx" -aur() { - cd ~/usr/builds - [ -d ${1} ] || git clone https://aur.archlinux.org/${1}.git - cd ${1} -} - -# separate alias definitions file, if exists -if [ -f ~/.bash_aliases ]; then - . ~/.bash_aliases -fi +alias da='change-theme dark' +alias li='change-theme light' -# enable programmable completion features (not needed if already -# enabled in /etc/bash.bashrc and if /etc/profile sources -# /etc/bash.bashrc). -if ! shopt -oq posix; then - if [ -f /usr/share/bash-completion/bash_completion ]; then - . /usr/share/bash-completion/bash_completion - elif [ -f /etc/bash_completion ]; then - . /etc/bash_completion - fi -fi +alias dquilt="quilt --quiltrc=${XDG_CONFIG_HOME}/quilt/quiltrc-dpkg" +. /usr/share/bash-completion/completions/quilt +complete -F _quilt_completion -o filenames dquilt -if [ -z "$IS_GUIX_SYSTEM" ]; then - if ! pgrep -u "$USER" ssh-agent > /dev/null; then - ssh-agent > ~/.ssh-agent-thing - fi - if [[ ! "$SSH_AUTH_SOCK" ]]; then - eval "$(<~/.ssh-agent-thing)" - fi -fi +function t { + cd $(mktemp -d /tmp/$1.XXXX) +}