Voici ma PS1 actuelle:
export PS1='[\u@\h \W$(__git_ps1 " (%s)")]\$ '
Comment afficher la branche actuelle dans une couleur différente?
Vous pouvez envelopper la pièce que vous souhaitez en couleur avec les éléments suivants:
\e[0;32m
- définit la couleur (dans ce cas, le vert)
\e[m
- redéfinit la couleur par défaut
Par exemple, cela définit l'invite sur le dernier jeton du chemin actuel, en vert, suivi de $
dans la couleur par défaut:
export PS1='\e[0;32m\w\e[m $'
D'autres couleurs sont également disponibles. Jetez un oeil à cet article sous colorisation pour une liste complète des alternatives.
Voici, partie par partie (et pas de 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
Ressemble à ceci (avec ma propre palette de terminaux):
Voici ma ligne 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$
function pc {
[ -d .git ] && git name-rev --name-only @
}
PS1='\e];\s\a\n\e[33m\w \e[36m$(pc)\e[m\n$ '
Ceci est ma solution PS1.
Il a fière allure sur un Mac avec le thème Novel. Désolé, mais mon indentation a été un peu collée. Hack jusqu'à ce que vous l'aimiez.
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"
Si vous êtes extrait d'une succursale, vous obtenez le nom de la succursale.
Si vous êtes dans un projet Git qui vient de commencer, vous obtenez simplement '@'.
Si vous êtes sans tête, vous obtenez un nom humain agréable par rapport à une branche ou une balise, avec un "@" devant le nom.
Si vous êtes sans tête et que vous n'êtes pas l'ancêtre d'une branche ou d'une étiquette, vous obtenez simplement le SHA1 court.
De plus, un "-" rouge signifie un répertoire de travail et un index propres, et un "+" rouge signifie le contraire.
Mettez-le dans votre .bashrc ou mieux: enregistrez-le dans/etc/bash-Prompt et sourcez-le à partir de votre .bashrc.
L'utilisation de tput est censée être la bonne façon de faire des couleurs.
#!/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'
Pour mon Mac avec le thème Homebrew, cela fonctionne très bien. Entièrement débogué et très rapide, et complètement autonome. BONUS: assez intelligent pour afficher UNIQUEMENT une branche git dans le cadre de l'invite lorsque vous êtes réellement dans un dépôt 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 "
Voici à quoi cela ressemble: Mac + Homebrew + Color Git Prompt
Si vous voulez avoir le chemin complet (ou supprimer le ... /), changez simplement -W en -w (et supprimez le ... /).
Appelez simplement tput
avec les paramètres appropriés. Reportez-vous aux pages de manuel tput(1)
et terminfo(5)
.
Version modifiée de l'invite @ cmcginty qui ajoute la fonction d'analyse git
et utilise un espacement légèrement différent:
# 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\$ '
Cela utilise également \$
dans l'invite au lieu de $
, ce qui signifie que vous obtiendrez #
lorsque vous êtes root.
Jetez un œil à liquidprompt:
https://github.com/nojhan/liquidprompt
Peut-être un peu trop lourd pour vos besoins, mais vous pouvez désactiver les fonctionnalités en définissant
LP_ENABLE_...=0
Voir la documentation sur la page ci-dessus.
Voici une solution Windows/Cygwin/Bash.
Ajoutez ce qui suit à votre ~/.bashrc
fichier.
xxx est l'emplacement de votre référentiel Git local.
GetBranch()
{
cat /cygdrive/c/xxx/.git/HEAD | sed 's+^ref: refs/heads/++'
}
export PS1="\[\e]0;\w\a\]\n\[\e[32m\]\u@\h \[\e[36m\]\$(GetBranch) \[\e[33m\]\w \[\e[0m\] \n\$ "
Voilà le mien
export PS1="\n\[\033[1;30m\][$$:$PPID - \j:\!\[\033[1;30m\]]\[\033[0;36m\] \T \
\[\033[1;30m\][\[\033[1;34m\]\u@\H\[\033[1;30m\]:\[\033[0;37m\]${SSH_TTY:-o} \
\[\033[0;32m\]+${SHLVL}\[\033[1;30m\]] \[\033[1;37m\]\w\[\033[0;37m\]\[\033[1;34m\]\$(__git_ps1 \" (%s)\") \[\033[0;37m\] \n\$ "
Pour un état plus compliqué de Git, vous pouvez utiliser n script plus grand .