X-Git-Url: https://git.phdru.name/?a=blobdiff_plain;f=admin%2Fprog%2Fbash_prompt;h=e04e6e86e83bc30556d3d6631b872e1b21280ada;hb=a1df7fa8cc5301684ae8eb8bc2852a05531b7816;hp=7c6117ce49aee8e58262d395b2b85ac2e61c15f0;hpb=d6d0947f637535c4b2156aa8c32534f376e73526;p=dotfiles.git diff --git a/admin/prog/bash_prompt b/admin/prog/bash_prompt index 7c6117c..e04e6e8 100644 --- a/admin/prog/bash_prompt +++ b/admin/prog/bash_prompt @@ -25,7 +25,7 @@ short_curdir() { # bash_prompt; adapted from # https://github.com/necolas/dotfiles/blob/master/shell/bash_prompt and -# http://vitus-wagner.livejournal.com/1176589.html?thread=40146189#t40146189 +# https://github.com/git/git/blob/master/contrib/completion/git-prompt.sh prompt_git() { local s="" @@ -40,19 +40,14 @@ prompt_git() { # ensure index is up to date #git update-index --really-refresh -q &>/dev/null - # check for uncommitted changes in the index - if ! $(git diff --quiet --ignore-submodules --cached); then - s="$s+"; - fi - # check for unstaged changes if [ -n "$(git ls-files --modified)" ]; then - s="$s!"; + s="$s*"; fi - # check for untracked files - if [ -n "$(git ls-files --others --exclude-standard)" ]; then - s="$s?"; + # check for uncommitted changes in the index + if ! $(git diff --quiet --ignore-submodules --cached); then + s="$s+"; fi # check for stashed files @@ -60,6 +55,11 @@ prompt_git() { s="$s$"; fi + # check for untracked files + if [ -n "$(git ls-files --others --exclude-standard)" ]; then + s="$s%"; + fi + fi # get the short symbolic ref @@ -70,10 +70,23 @@ prompt_git() { printf "(unknown)")" [ -n "$s" ] && s=" [$s]" - printf "%s" "$branchName$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 + set_prompts() { OPS1='' # display the user, host and current working directory @@ -95,8 +108,16 @@ set_prompts() { esac OPS1+="${debian_chroot:+($debian_chroot)}" - OPS1+="\`cgmem_which_prompt\`\u@\${HOSTNAME::5}:\`short_curdir\` " - OPS1+="\$(prompt_git)" - OPS1+="\\$\$SHLVL " + OPS1+="\`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 + fi + # This is for .screenrc: shelltitle "\$ |$SHELL" + #OPS1+="\[\033k\033\\\\\]" + OPS1+=" \$SHLVL\\$ " export OPS1 }