LBRANCH=$(eval "${BRANCH[$DIR]}")
LTYPE="${TYPE[$DIR]}"
if [ "$color_prompt" = yes ]; then
- VCS_info="${nocolor}${vcs_symbols_color}(${vcs_type_color}$LTYPE${vcs_symbols_color})-${vcs_symbols_color}[${vcs_branch_color}$LBRANCH${vcs_symbols_color}]${nocolor}"
+ VCS_info="${nocolor_prompt}${vcs_symbols_color}(${vcs_type_color}$LTYPE${vcs_symbols_color})-${vcs_symbols_color}[${vcs_branch_color}$LBRANCH${vcs_symbols_color}]${nocolor_prompt}"
else
VCS_info="($LTYPE)-[$LBRANCH]"
fi
# Rien de spécial n'arrivera si vous n'avez pas le fichier .umaskrc
function cd {
builtin cd "$@"
+ ret=$?
if [ -f ~/.umaskrc ]; then
- umask $(/usr/bin/awk 'BEGIN {pwd=ENVIRON["PWD"]; a=length(pwd); cmax=0} {if($1==pwd) {MASK=$2;exit}; c=length($1); if(c>a) {next}; if(substr(pwd,0,c)==$1 && c > cmax) {cmax=c; MASK=$2}} END {print MASK}' ~/.umaskrc) >/dev/null
- else
- return 0
+ umask $(/usr/bin/awk 'BEGIN {pwd=ENVIRON["PWD"]"/"; a=length(pwd); cmax=0} {if($1==pwd) {MASK=$2;exit}; c=length($1); if(c>a) {next}; if(substr(pwd,0,c+1)==$1 && c > cmax) {cmax=c; MASK=$2}} END {print MASK}' ~/.umaskrc) >/dev/null
fi
+ return $ret
}
### Attention à ce que vous éditez dans cette section ###
# les couleurs doivent être entourés de \[ et \] pour délimiter les caractères
# invisibles
cyan='\e[1;36m'
+cyan_thin='\e[0;36m'
violet='\e[1;35m'
violet_thin='\e[0;35m'
jaune='\e[1;33m'
jaune_thin='\e[0;33m'
rouge='\e[1;31m'
+rouge_thin='\e[0;31m'
vert='\e[1;32m'
vert_thin='\e[0;32m'
bleu='\e[1;34m'
+bleu_thin='\e[0;34m'
blanc='\e[1;37m'
+blanc_thin='\e[0;37m'
nocolor='\e[0m'
cyan_prompt="\[${cyan}\]"
+cyan_thin_prompt="\[${cyan_thin}\]"
violet_prompt="\[${violet}\]"
violet_thin_prompt="\[${violet_thin}\]"
jaune_prompt="\[${jaune}\]"
jaune_thin_prompt="\[${jaune_thin}\]"
rouge_prompt="\[${rouge}\]"
+rouge_thin_prompt="\[${rouge_thin}\]"
vert_prompt="\[${vert}\]"
vert_thin_prompt="\[${vert_thin}\]"
bleu_prompt="\[${bleu}\]"
+bleu_thin_prompt="\[${bleu_thin}\]"
+blanc_prompt="\[${blanc}\]"
+blanc_thin_prompt="\[${blanc_thin}\]"
nocolor_prompt="\[${nocolor}\]"
if [ -x /usr/bin/tput ] && tput setaf 1 >&/dev/null; then
color_prompt=no
fi
+# Est-ce qu'on veut que le prompt affiche les information sur l'éventuel dépôt
+# versionné dans lequel on se trouve
+#~# # Changez cette variable en "yes" pour l'afficher
+display_vcs_info=no
+
# Génération de la ligne de "-"
function gen_minus_line
local i
MINUS_LINE=""
+ # Pas la peine de refaire le travail tant qu'on ne change
+ # pas le nombre de colonnes.
SAVE_COLUMNS=$COLUMNS
for ((i = COLUMNS-23; i>0; i--)); do
# Génération du prompt après chaque commande
function prompt_command
{
- # Attention aux hacks pour que la couleur (et sa taille)
- # soient évaluées au moment de l'affichage du prompt
local pwd ERR DATE PROMPT DIR POST_DIR
+ # Cette fonction génère un prompt sur deux lignes
+ # ayant cette allure :
+ # ─( 12:59:05 )─< ~ >───────────────────────────────────────────────────────[ 0 ]─
+ # user@host $
+
+ # Attention aux hacks (échappement, interprétation des variables)
+ # pour que les couleurs (et leurs tailles)
+ # soient évaluées au moment de l'affichage du prompt
+ # Si le terminal a été redimensionné, on régénère la ligne de tirets
(( SAVE_COLUMNS == COLUMNS )) || gen_minus_line
-
- # À décommenter si on veut des infos
+
+ # À décommenter si on veut afficher des infos
# quand on se trouve dans un dépôt versionné
- get_vcs_info
+ if [ "$display_vcs_info" = yes ]; then
+ get_vcs_info
+ fi
+ # Chemin courant, en faisant attention à la largeur de la fenêtre
pwd=${PWD/#$HOME/'~'}
if (( ${#pwd} + ${VCS_size} + 27 > COLUMNS )); then
if (( COLUMNS >= 33 )); then
DIR=$pwd
POST_DIR='${MINUS_LINE:'${#pwd}+${VCS_size}+1'+${#?}}'
fi
+
+ # Génération des différents morceaux du prompt, avec ou sans la couleur
if [ "$color_prompt" = yes ]; then
DIR="< ${pwd_color}"$DIR"${line_color_prompt} >"
# On affiche le code de retour en "no color" si c'est 0, en rouge sinon
# Ceci n'est pas customizable à coup de variable,
# il faut changer $((31+($?==0)*6)) si vous y tenez vraiment et que vous comprenez ce que vous faites
ERR='[ \[\e[1;$((31+($?==0)*6))m\]$?'${line_color_prompt}' ]'$MINUS_CHAR
+ # Affichage de l'heure courante
+ # pratique pour savoir quand on a tapé la commande précédente
DATE="( ${date_color}\D{%H:%M:%S}${line_color_prompt} )"
- PROMPT="${username_color}\u${symbols_color}@${host_color}\h ${symbols_color}\$ ${nocolor}"
+ # Deuxième ligne du prompt "user@host $"
+ # Attention "\\\$" devient \$, c'est-à-dire # pour root, $ pour les autres
+ PROMPT="${username_color}\u${symbols_color}@${host_color}\h ${symbols_color}\\\$ ${nocolor_prompt}"
+ # On fusionne tout ça
PS1=$TITLE${line_color_prompt}$MINUS_CHAR$DATE$MINUS_CHAR$DIR$MINUS_CHAR$VCS_info${line_color_prompt}$POST_DIR$ERR'\n'$PROMPT
else
DIR="< "$DIR" >"
ERR='[ $? ]'$MINUS_CHAR
DATE="( \D{%H:%M:%S} )"
- PROMPT="\u@\h \$ "
+ PROMPT="\u@\h \\\$ "
PS1=$TITLE$MINUS_CHAR$DATE$MINUS_CHAR$DIR$MINUS_CHAR$VCS_info$POST_DIR$ERR'\n'$PROMPT
fi
}
TITLE=''
fi
-# On regénére le prompt après chaque commande
+# On régénère le prompt après chaque commande
PROMPT_COMMAND=prompt_command
# +-------------------+
# | Messages au début |
# +-------------------+
-if [[ $(uname) == Linux && ( $(locale charmap) == UTF-8 && $TERM != screen ) ]]; then
- MINUS_CHAR=─
- gen_minus_line
- date=$(/bin/date +"%R, %A %d %B %Y")
- redate=${date//é/e}
- redate=${redate//û/u}
- if [ "$color_prompt" = yes ]; then
- echo -e "${line_color}┬─${redate//?/─}─┬${MINUS_LINE:${#date}-18}\n\
-│ ${announce_date_color}$date ${line_color}│\n\
-└─${redate//?/─}─┘\e[0m\n"
+function welcome_message ()
+{
+ # Si on supporte l'utf-8 et qu'on n'est pas dans un screen,
+ # on affiche un joli cadre avec la date.
+ # On utilise aussi un caractère plus sympa pour faire les lignes de tirets
+ if [[ $(uname) == Linux && ( $(locale charmap) == UTF-8 && $TERM != screen ) ]]; then
+ MINUS_CHAR=─
+ gen_minus_line
+ date=$(/bin/date +"%R, %A %d %B %Y")
+ # ${redate} sert à connaître la taille de la chaine $date,
+ # mais sans se planter sur le nombre d'octet/nombre de caractères
+ redate=${date//é/e}
+ redate=${redate//û/u}
+ if [ "$color_prompt" = yes ]; then
+ echo -e "${line_color}┬─${redate//?/─}─┬${MINUS_LINE:${#date}-19}\n│ ${announce_date_color}$date ${line_color}│\n└─${redate//?/─}─┘\e[0m\n"
+ else
+ echo -e "┬─${redate//?/─}──┬${MINUS_LINE:${#date}-18}\n│ $date │\n└─${redate//?/─}──┘\n"
+ fi
+ unset date
+ # Sinon, on se contente d'une ligne de tirets
else
- echo -e "┬─${redate//?/─}──┬${MINUS_LINE:${#date}-18}\n\
-│ $date │\n\
-└─${redate//?/─}──┘\n"
+ MINUS_CHAR=-
+ gen_minus_line
fi
- unset date
-else
- MINUS_CHAR=-
- gen_minus_line
-fi
+}
### ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ###
### Attention à ce que vous avez édité dans cette section ###
. ~/.bash_aliases_local
fi
+# On n'exécute le welcome_message que à ce moment, parce que la customisation
+# locale a pu changer des couleurs
+welcome_message