X-Git-Url: http://gitweb.pimeys.fr/?a=blobdiff_plain;f=.bashrc;h=50f4f8b128af1de598c998cce3a270f7663701b9;hb=dc49a3c4e5f31d57c3a7835401b68840e3bcafec;hp=041f2f9dd4e2009c77c3c90cd10d253f5bd8ad11;hpb=ccbce1e7f54c6708d524b5bd55b38217a9a95000;p=config-20-100.git diff --git a/.bashrc b/.bashrc index 041f2f9..50f4f8b 100644 --- a/.bashrc +++ b/.bashrc @@ -37,58 +37,63 @@ fi [ -d ~/.bash_completion.d/ ] && for f in ~/.bash_completion.d/*; do source $f; done -#~# # +-----+ -#~# # | VCS | -#~# # +-----+ -#~# -#~# # Définition de fonction pour pouvoir afficher dans le prompt -#~# # des infos quand on est dans un dépôt versionné -#~# -#~# find_up () { -#~# path="$1" -#~# shift 1 -#~# while [[ "`readlink -f -- \"$path\"`" != "/" ]]; -#~# do -#~# find "$path" -maxdepth 1 -mindepth 1 "$@" -#~# path=${path}/.. -#~# done -#~# } -#~# -#~# get_vcs_info () { -#~# # Donne les infos sur le dépôt VCS courant. -#~# local LBRANCH LTYPE BRANCH TYPE DIR -#~# declare -a DIR -#~# declare -A TYPE -#~# declare -A BRANCH -#~# DIR[0]=".git" -#~# DIR[1]=".hg" -#~# DIR[2]="_darcs" -#~# DIR[3]=".svn" -#~# TYPE[.git]="git" -#~# TYPE[.hg]="mercurial" -#~# TYPE[_darcs]="darcs" -#~# TYPE[.svn]="svn" -#~# BRANCH[.git]='git branch 2>/dev/null | sed -r "s/^[^*].*$//" | paste -s -d "" | sed -r "s/^[*] //"' -#~# BRANCH[.hg]='hg branch 2>/dev/null' -#~# BRANCH[_darcs]="darcs show repo 2>/dev/null| egrep '^ *Cache' | sed 's@.*/\([^/]*\),.*@\1@'" -#~# BRANCH[.svn]="svn info 2>/dev/null | head -n 6 | tail -n 1" -#~# -#~# DIR=$(eval "find_up \"$PWD\" -name \"\"$(printf -- ' -o -name "%s"' "${DIR[@]}") | head -n 1") -#~# if [ -n "$DIR" ]; then -#~# DIR=$(basename "$DIR") -#~# LBRANCH=$(eval "${BRANCH[$DIR]}") -#~# LTYPE="${TYPE[$DIR]}" -#~# if [ "$color_prompt" = yes ]; then -#~# VCS_info="${nocolor}${vcs_symbols_color}(${nocolor}$LTYPE${vcs_symbols_color})-${vcs_symbols_color}[${vcs_branch_color}$LBRANCH${vcs_symbols_color}]${nocolor}" -#~# else -#~# VCS_info="($LTYPE)-[$LBRANCH]" -#~# fi -#~# VCS_size=$((${#LTYPE}+${#LBRANCH}+5)) -#~# else -#~# VCS_info="" -#~# VCS_size=0 -#~# fi -#~# } +# +-----+ +# | VCS | +# +-----+ + +# Définition de fonction pour pouvoir afficher dans le prompt +# des infos quand on est dans un dépôt versionné + +find_up () { + local path normalized_path normalized_ret + path="$1" + shift 1 + normalized_path=`readlink -f -- "$path"` + normalized_ret=$? + while [[ "$normalized_path" != "/" ]] && [ $normalized_ret -eq 0 ]; + do + find "$path" -maxdepth 1 -mindepth 1 "$@" + path=${path}/.. + normalized_path=`readlink -f -- "$path"` + normalized_ret=$? + done +} + +get_vcs_info () { + # Donne les infos sur le dépôt VCS courant. + local LBRANCH LTYPE BRANCH TYPE DIR + declare -a DIR + declare -A TYPE + declare -A BRANCH + DIR[0]=".git" + DIR[1]=".hg" + DIR[2]="_darcs" + DIR[3]=".svn" + TYPE[.git]="git" + TYPE[.hg]="mercurial" + TYPE[_darcs]="darcs" + TYPE[.svn]="svn" + BRANCH[.git]='git branch 2>/dev/null | sed -r "s/^[^*].*$//" | paste -s -d "" | sed -r "s/^[*] //"' + BRANCH[.hg]='hg branch 2>/dev/null' + BRANCH[_darcs]="darcs show repo 2>/dev/null| egrep '^ *Cache' | sed 's@.*/\([^/]*\),.*@\1@'" + BRANCH[.svn]="svn info 2>/dev/null | head -n 6 | tail -n 1" + + DIR=$(eval "find_up \"$PWD\" -name \"\"$(printf -- ' -o -name "%s"' "${DIR[@]}") | head -n 1") + if [ -n "$DIR" ]; then + DIR=$(basename "$DIR") + LBRANCH=$(eval "${BRANCH[$DIR]}") + LTYPE="${TYPE[$DIR]}" + if [ "$color_prompt" = yes ]; then + 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 + VCS_size=$((${#LTYPE}+${#LBRANCH}+5)) + else + VCS_info="" + VCS_size=0 + fi +} # Pour avoir le bon umask en fonction du dossier où on se trouve @@ -98,11 +103,11 @@ 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 ### @@ -111,38 +116,71 @@ function cd { # | Génération du prompt | # +----------------------+ -cyan='\[\e[1;36m\]' -violet='\[\e[1;35m\]' -violet_thin='\[\e[0;35m\]' -jaune='\[\e[1;33m\]' -rouge='\[\e[1;31m\]' -vert='\[\e[1;32m\]' -vert_thin='\[\e[0;32m\]' -bleu='\[\e[1;34m\]' -nocolor='\[\e[0m\]' +# Définition des couleurs +# Pour les utiliser dans le prompt, +# 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 # support de la couleur color_prompt=yes # Couleurs dans "user@host $" - username_color=$rouge - host_color=$bleu - symbols_color=$vert + username_color=${rouge_prompt} + host_color=${bleu_prompt} + symbols_color=${vert_prompt} # Couleur de la ligne séparatrice de prompt - line_color=$cyan + line_color=${cyan} + line_color_prompt=${cyan_prompt} # Couleur du path actuel - pwd_color=$jaune - # Couleur de la date - date_color=$violet + pwd_color=${jaune_prompt} + # Couleur de la date (à chaque affichage du prompt) + date_color=${violet_prompt} + # Couleur de la date au premier affichage (à l'ouverture du terminal) + announce_date_color=${blanc} # Couleur d'affichage de vcs_info - vcs_symbols_color=$violet_thin - vcs_type_color= - vcs_branch_color=$vert_thin + vcs_symbols_color=${violet_thin_prompt} + vcs_type_color=${jaune_thin_prompt} + vcs_branch_color=${vert_thin_prompt} else # pas de support de la couleur 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 @@ -150,6 +188,8 @@ 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 @@ -160,14 +200,25 @@ function gen_minus_line # 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épend de la section VCS - #~# get_vcs_info + # À décommenter si on veut afficher des infos + # quand on se trouve dans un dépôt versionné + 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 @@ -181,20 +232,27 @@ function prompt_command 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} >" + 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}' ]'$MINUS_CHAR - DATE="( ${date_color}\D{%H:%M:%S}${line_color} )" - PROMPT="${username_color}\u${symbols_color}@${host_color}\h ${symbols_color}\$ ${nocolor}" - PS1=$TITLE${line_color}$MINUS_CHAR$DATE$MINUS_CHAR$DIR$MINUS_CHAR$VCS_info${line_color}$POST_DIR$ERR'\n'$PROMPT + 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} )" + # 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 } @@ -206,33 +264,38 @@ else 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 "\e[1;36m┬─${redate//?/─}──┬${MINUS_LINE:${#date}-18}\n\ -│ \e[1;37m$date\e[1;31m \e[1;36m │\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 ### @@ -287,3 +350,6 @@ if [ -f ~/.bash_aliases_local ]; then . ~/.bash_aliases_local fi +# On n'exécute le welcome_message que à ce moment, parce que la customisation +# local a pu changer des couleurs +welcome_message