X-Git-Url: https://git.friedersdorff.com/?a=blobdiff_plain;f=bash%2F.bashrc;h=6349cc8a2f1a5ca163681db2e9746bb4534608d9;hb=fe723d4352968207b76f0d23a3d633df69946854;hp=9413671004c9a1aa828f881871507dfc42e58853;hpb=6064692c3e68554e4aa791befac2bf8b496e4aee;p=max%2Fdotfiles.git diff --git a/bash/.bashrc b/bash/.bashrc index 9413671..6349cc8 100644 --- a/bash/.bashrc +++ b/bash/.bashrc @@ -24,7 +24,11 @@ HISTFILESIZE=2000 shopt -s checkwinsize # make less more friendly for non-text input files, see lesspipe(1) -[ -x /usr/bin/lesspipe ] && eval "$(SHELL=/bin/sh lesspipe)" +if [ -x /usr/bin/lesspipe ]; then + export LESSOPEN="|lesspipe %s" +elif [ -x /usr/bin/lesspipe.sh ]; then + export LESSOPEN="|lesspipe %s" +fi # set variable identifying the chroot you work in (used in the prompt below) if [ -z "${debian_chroot:-}" ] && [ -r /etc/debian_chroot ]; then @@ -64,6 +68,12 @@ GRAY=$(tput setaf 7) BOLD=$(tput bold) RESET=$(tput sgr0) +function __virtualenv_prompt() { + if [ -n "$VIRTUAL_ENV" ]; then + echo "(${VIRTUAL_ENV##*/}) " + fi +} + # set up command prompt function __prompt_command() { @@ -71,6 +81,30 @@ function __prompt_command() EXIT="$?" PS1="" + # check if inside git repo + local git_status="`git status -unormal 2>&1`" + if git rev-parse --git-dir > /dev/null 2>&1; then + git_status=$(git status --porcelain) + # parse the porcelain output of git status + if [[ ! $git_status = *[![:space:]]* ]]; then + local Color_On=$GREEN + elif [[ $git_status =~ ^\?\? ]]; then + local Color_On=$CYAN + else + local Color_On=$RED + fi + + branch=$(git symbolic-ref -q HEAD) + branch=${branch##refs/heads/} + branch=${branch:-HEAD} + + # add the result to prompt + PS1+="\n\[$Color_On\][$branch]\[$RESET\]\n" + fi + + + PS1+="$(__virtualenv_prompt)" + if [ $EXIT -eq 0 ]; then PS1+="\[$GREEN\][\!]\[$RESET\] "; else PS1+="\[$RED\][\!]\[$RESET\] "; fi # if logged in via ssh shows the ip of the client @@ -85,41 +119,20 @@ function __prompt_command() # basic information (user@host:path) PS1+="\[$RED$BOLD\]\u\[$RESET\]@\[$RED$BOLD\]\h\[$RESET\]:\[$BLUE\]\w\[$RESET\] " - # check if inside git repo - local git_status="`git status -unormal 2>&1`" - if ! [[ "$git_status" =~ Not\ a\ git\ repo ]]; then - # parse the porcelain output of git status - if [[ "$git_status" =~ nothing\ to\ commit ]]; then - local Color_On=$GREEN - elif [[ "$git_status" =~ nothing\ added\ to\ commit\ but\ untracked\ files\ present ]]; then - local Color_On=$CYAN - else - local Color_On=$RED - fi - - if [[ "$git_status" =~ On\ branch\ ([^[:space:]]+) ]]; then - branch=${BASH_REMATCH[1]} - else - # Detached HEAD. (branch=HEAD is a faster alternative.) - branch="(`git describe --all --contains --abbrev=4 HEAD 2> /dev/null || echo HEAD`)" - fi - - # add the result to prompt - PS1+="\[$Color_On\][$branch]\[$RESET\] " - fi - + # prompt $ or # for root PS1+="\$ " } PROMPT_COMMAND=__prompt_command - -if [ -f "${HOME}/.gpg-agent-info" ]; then - . "${HOME}/.gpg-agent-info" - export GPG_AGENT_INFO - export SSH_AUTH_SOCK +if ! pgrep -x -u "${USER}" gpg-agent >/dev/null 2>&1; then + gpg-connect-agent /bye >/dev/null 2>&1 fi +unset SSH_AGENT_PID +if [ "${gnupg_SSH_AUTH_SOCK_by:-0}" -ne $$ ]; then + export SSH_AUTH_SOCK=~/.gnupg/S.gpg-agent.ssh +fi -# Set GPG TTY -export GPG_TTY=$(tty) +export GPG_TTY=($tty) +gpg-connect-agent updatestartuptty /bye > /dev/null