X-Git-Url: https://git.phdru.name/?a=blobdiff_plain;f=admin%2Fprog%2Fbash_prompt;h=070390260d94f449b9893ce817ad2cb13a8222fd;hb=306434444eaa399f8d56087d015435b5a98015d3;hp=e04e6e86e83bc30556d3d6631b872e1b21280ada;hpb=a1df7fa8cc5301684ae8eb8bc2852a05531b7816;p=dotfiles.git diff --git a/admin/prog/bash_prompt b/admin/prog/bash_prompt index e04e6e8..0703902 100644 --- a/admin/prog/bash_prompt +++ b/admin/prog/bash_prompt @@ -2,10 +2,15 @@ cgmem_which_prompt() { local _cgmem_which _cgmem_which="`cgmem_which 2>/dev/null`" if [ -n "$_cgmem_which" ]; then - echo "[$_cgmem_which] " + _cgmem_which=" $_cgmem_which" fi + echo "$_cgmem_which" } +# Cut directories to 20% of the terminal width; add space for 3 dots +_DIR_LENGTH=`awk "END { print int(0.2 * ${COLUMNS:-80}) }" /dev/null || \ printf "(unknown)")" - [ -n "$s" ] && s=" [$s]" + up=`git rev-parse --abbrev-ref @{u} 2>/dev/null` + if [ -n "$up" -a "$up" != "@{u}" ]; then + local left right + set -- `git rev-list --count --left-right @{u}...HEAD` + left=$1 + right=$2 + if [ "$left" -gt 0 ]; then + s="$s-$left" + fi + if [ "$right" -gt 0 ]; then + s="$s+$right" + fi + fi + + [ -n "$s" ] && s=" $s" printf " (%s)" "$branchName$s" fi } -if test -x /usr/bin/git >/dev/null 2>&1; then - if [ "`type -t __git_ps1`" != function ]; then - git_sh_prompt=`git --exec-path`/git-sh-prompt - test -r $git_sh_prompt && . $git_sh_prompt || : - fi - if [ "`type -t __git_ps1`" = function ]; then - GIT_PS1_SHOWDIRTYSTATE=true - GIT_PS1_SHOWSTASHSTATE=true - GIT_PS1_SHOWUNTRACKEDFILES=true - GIT_PS1_SHOWUPSTREAM=verbose - fi -fi +#if test -x /usr/bin/git >/dev/null 2>&1; then +# if [ "`type -t __git_ps1`" != function ]; then +# git_sh_prompt=`git --exec-path`/git-sh-prompt +# test -r $git_sh_prompt && . $git_sh_prompt || : +# fi +# if [ "`type -t __git_ps1`" = function ]; then +# GIT_PS1_SHOWDIRTYSTATE=true +# GIT_PS1_SHOWSTASHSTATE=true +# GIT_PS1_SHOWUNTRACKEDFILES=true +# GIT_PS1_SHOWUPSTREAM=verbose +# fi +#fi set_prompts() { - OPS1='' + PS1='' + local _COMMON_PROMPT='${debian_chroot:+($debian_chroot)}\u@\h:\w' # display the user, host and current working directory # in the terminal title case "$TERM" in *rxvt*|screen*|*term*|vt100) - OPS1+="\[\033]0;${debian_chroot:+($debian_chroot)}\u@\h:\w\007\]" + PS1="\033]0;${_COMMON_PROMPT}\007" # Set xterm title/icon case "$TERM" in screen*) - OPS1+="\[\033k${debian_chroot:+($debian_chroot)}" - OPS1+="\u@\h:\w\033\\\\\]" # Set screen/tmux caption + PS1="\033P${PS1}\033\\\\" # Set xterm title/icon under screen/tmux + if [ -z "$MC_SID" ]; then + PS1+="\033k${_COMMON_PROMPT}\033\\\\" # Set screen/tmux caption + fi ;; esac ;; *) - OPS1="" + PS1="" ;; esac - OPS1+="${debian_chroot:+($debian_chroot)}" - OPS1+="\`cgmem_which_prompt\`\u@\${HOSTNAME::5}:\`short_curdir\`" + # This is for .screenrc: shelltitle "\$ |$SHELL" + #PS1+='\033k\033\\' + + PS1="\[$PS1\]" + PS1+='${debian_chroot:+($debian_chroot)}' + PS1+='[\A`cgmem_which_prompt`] \u@${HOSTNAME::5}:`short_curdir`' if test -x /usr/bin/git >/dev/null 2>&1; then - if [ "`type -t __git_ps1`" = function ]; then - OPS1+="\$(__git_ps1)" - else - OPS1+="\$(prompt_git)" - fi + #if [ "`type -t __git_ps1`" = function ]; then + # PS1+='$(__git_ps1)' + #else + PS1+='$(prompt_git)' + #fi fi - # This is for .screenrc: shelltitle "\$ |$SHELL" - #OPS1+="\[\033k\033\\\\\]" - OPS1+=" \$SHLVL\\$ " - export OPS1 + PS1+=' $SHLVL\$ ' }