Линия PS1 с текущей веткой Git и цветами - PullRequest
54 голосов
/ 09 ноября 2010

Вот мой текущий PS1:

export PS1='[\u@\h \W$(__git_ps1 " (%s)")]\$ '

Как отобразить текущую ветку другим цветом?

Ответы [ 13 ]

113 голосов
/ 22 мая 2011

Вот, часть за частью (и без Ruby):

function color_my_prompt {
    local __user_and_host="\[\033[01;32m\]\u@\h"
    local __cur_location="\[\033[01;34m\]\w"
    local __git_branch_color="\[\033[31m\]"
    #local __git_branch="\`ruby -e \"print (%x{git branch 2> /dev/null}.grep(/^\*/).first || '').gsub(/^\* (.+)$/, '(\1) ')\"\`"
    local __git_branch='`git branch 2> /dev/null | grep -e ^* | sed -E  s/^\\\\\*\ \(.+\)$/\(\\\\\1\)\ /`'
    local __prompt_tail="\[\033[35m\]$"
    local __last_color="\[\033[00m\]"
    export PS1="$__user_and_host $__cur_location $__git_branch_color$__git_branch$__prompt_tail$__last_color "
}
color_my_prompt

Выглядит так (с моей собственной палитрой терминала):

Colored prompt

Также см. эту и эту статью.

33 голосов
/ 09 ноября 2010

Вы можете обернуть нужную деталь цветом следующим образом:

\e[0;32m - устанавливает цвет (в данном случае зеленый)

\e[m - устанавливает цвет по умолчанию

Например, это устанавливает приглашение для последнего токена текущего пути, зеленого цвета, за которым следует $ цветом по умолчанию:

export PS1='\e[0;32m\w\e[m $'

Также доступны другие цвета. Взгляните на эту статью в разделе раскраски для полного списка альтернатив.

22 голосов
/ 09 ноября 2010

Вот моя строка PS1:

\n\[\e[1;37m\]|-- \[\e[1;32m\]\u\[\e[0;39m\]@\[\e[1;36m\]\h\[\e[0;39m\]:\[\e[1;33m\]\w\[\e[0;39m\]\[\e[1;35m\]$(__git_ps1 " (%s)")\[\e[0;39m\] \[\e[1;37m\]--|\[\e[0;39m\]\n$

alt text

17 голосов
/ 05 мая 2012
function pc {
  [ -d .git ] && git name-rev --name-only @
}
PS1='\e];\s\a\n\e[33m\w \e[36m$(pc)\e[m\n$ '

ps1

Источник

11 голосов
/ 15 августа 2012

Это мое решение для PS1.

Отлично смотрится на Mac с темой Novel.Извините, но мои отступы немного напутали.Взламывайте его, пока он вам не понравится.

function we_are_in_git_work_tree {
    git rev-parse --is-inside-work-tree &> /dev/null
}

function parse_git_branch {
    if we_are_in_git_work_tree
    then
    local BR=$(git rev-parse --symbolic-full-name --abbrev-ref HEAD 2> /dev/null)
    if [ "$BR" == HEAD ]
    then
        local NM=$(git name-rev --name-only HEAD 2> /dev/null)
        if [ "$NM" != undefined ]
        then echo -n "@$NM"
        else git rev-parse --short HEAD 2> /dev/null
        fi
    else
        echo -n $BR
       fi
    fi
}

function parse_git_status {
    if we_are_in_git_work_tree
    then
    local ST=$(git status --short 2> /dev/null)
    if [ -n "$ST" ]
    then echo -n " + "
    else echo -n " - "
    fi
    fi
}

function pwd_depth_limit_2 {
    if [ "$PWD" = "$HOME" ]
    then echo -n "~"
    else pwd | sed -e "s|.*/\(.*/.*\)|\1|"
    fi
}

COLBROWN="\[\033[1;33m\]"
COLRED="\[\033[1;31m\]"
COLCLEAR="\[\033[0m\]"

# Export all these for subshells
export -f parse_git_branch parse_git_status we_are_in_git_work_tree pwd_depth_limit_2
export PS1="$COLRED<$COLBROWN \$(pwd_depth_limit_2)$COLRED\$(parse_git_status)$COLBROWN\$(parse_git_branch) $COLRED>$COLCLEAR "
export TERM="xterm-color"

Если вы зарегестрированы в ветке, вы получите имя ветки.просто получите'@'.

Если вы без головы, вы получите хорошее человеческое имя относительно какой-либо ветви или тега, с символом «@» перед именем.

Если вы без головы ине являясь предком какой-либо ветви или тэга, вы просто получаете короткий SHA1.

Кроме того, красный «-» обозначает чистый рабочий каталог и индекс, а красный «+» означает противоположное.

8 голосов
/ 21 июня 2015

Моя сверхмощная многострочная Linux-подсказка!

Поместите его в ваш .bashrc или лучше: сохраните его в / etc / bash-prompt и получите его из вашего .bashrc.
Предполагается, что использование tput является правильным способом создания цветов.

#!/bin/bash

set_prompt()
{
   local last_cmd=$?
   local txtreset='$(tput sgr0)'
   local txtbold='$(tput bold)'
   local txtblack='$(tput setaf 0)'
   local txtred='$(tput setaf 1)'
   local txtgreen='$(tput setaf 2)'
   local txtyellow='$(tput setaf 3)'
   local txtblue='$(tput setaf 4)'
   local txtpurple='$(tput setaf 5)'
   local txtcyan='$(tput setaf 6)'
   local txtwhite='$(tput setaf 7)'
   # unicode "✗"
   local fancyx='\342\234\227'
   # unicode "✓"
   local checkmark='\342\234\223'
   # Line 1: Full date + full time (24h)
   # Line 2: current path
   PS1="\[$txtbold\]\[$txtwhite\]\n\D{%A %d %B %Y %H:%M:%S}\n\[$txtgreen\]\w\n"
   # User color: red for root, yellow for others
   if [[ $EUID == 0 ]]; then
       PS1+="\[$txtred\]"
   else
       PS1+="\[$txtyellow\]"   
   fi
   # Line 3: user@host
   PS1+="\u\[$txtwhite\]@\h\n"
   # Line 4: a red "✗" or a green "✓" and the error number
   if [[ $last_cmd == 0 ]]; then
      PS1+="\[$txtgreen\]$checkmark \[$txtwhite\](0)"
   else
      PS1+="\[$txtred\]$fancyx \[$txtwhite\]($last_cmd)"
   fi
   # Line 4: green git branch
   PS1+="\[$txtgreen\]$(__git_ps1 ' (%s)')\[$txtwhite\]"
   # Line 4: good old prompt, $ for user, # for root
   PS1+=" \\$ "
}
PROMPT_COMMAND='set_prompt'
3 голосов
/ 09 февраля 2016

Для моего Mac с темой Homebrew это работает очень хорошо.Полностью отлаженный, очень быстрый и полностью автономный.БОНУС: достаточно умный, чтобы ТОЛЬКО показывать ветку git как часть приглашения, когда вы на самом деле в репозитории git!:)

# Color prompt for git
reset=$(tput sgr0)
boldgreen=$(tput setaf 2)$(tput bold)
cyan=$(tput sgr0)$(tput setaf 6)
boldred=$(tput setaf 1)$(tput bold)
boldwhite=$(tput setaf 7)$(tput bold)
boldyellow=$(tput setaf 3)$(tput bold)

PARENCLR=$'\001\e[0;36m\002'
BRANCHCLR=$'\001\e[1;33m\002'

alias branchname="git branch 2>/dev/null | sed -ne 's/^* \(.*\)/ ${PARENCLR}(${BRANCHCLR}\1${PARENCLR}\)/p'"

GIT_STATUS='$(branchname)'

PROMPT_CHAR="\$"
PS1="\[$boldgreen\]\u\[$cyan\]::\[$boldred\]\h \[$cyan\]{\[$boldwhite\].../\W\[$cyan\]}\[$reset\]$GIT_STATUS\[$reset\]$PROMPT_CHAR "

Вот как это выглядит: Mac + Homebrew + Color Git Prompt

Если вы хотите указать полный путь (или удалить .../), затем просто измените -W на -w (и удалите ... /).

2 голосов
/ 09 ноября 2018

Модифицированная версия подсказки @ cmcginty, которая добавляет в функцию синтаксического анализа git и использует немного другой интервал:

# So I know where I am in repos:
parse_git_branch() {
    git branch 2> /dev/null | sed -e '/^[^*]/d' -e 's/* \(.*\)/ (\1)/'
}

# Modified from:
# https://stackoverflow.com/a/4138531/2662028
export PS1='\n\[\e[1;37m\]|-- \[\e[1;32m\]\u\[\e[0;39m\]@\[\e[1;36m\]\h\[\e[0;39m\]:\[\e[1;33m\]\w\[\e[0;39m\]\[\e[1;35m\]$(parse_git_branch " (%s)")\[\e[0;39m\] \[\e[1;37m\]--|\[\e[0;39m\]\n\$ '

В приглашении также используется \$ вместо $, что означаетвы получите # когда вы root.

2 голосов
/ 07 марта 2014

Взгляните на liquidprompt:

https://github.com/nojhan/liquidprompt

Возможно, он слишком тяжел для ваших требований, но вы можете отключить функции, установив

LP_ENABLE_...=0

См. Документацию на странице выше.

2 голосов
/ 09 ноября 2010

Просто вызовите tput с соответствующими параметрами. См. Справочные страницы tput(1) и terminfo(5).

...