]> gitweb.pimeys.fr Git - config-20-100.git/blobdiff - .bashrc
[ssh] pimeys est passé chez online
[config-20-100.git] / .bashrc
diff --git a/.bashrc b/.bashrc
index 041f2f9dd4e2009c77c3c90cd10d253f5bd8ad11..aa33f36183c4c0c696fed7613e63a1fb749bcff7 100644 (file)
--- 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 ###
 
@@ -246,10 +309,10 @@ fi
 export HISTCONTROL=ignoreboth
 
 # Nombre de lignes d'historique à garder
-export HISTSIZE=5000
+export HISTSIZE=""
 
 # la même chose dans le fichier d'historique
-export HISTFILESIZE=5000
+export HISTFILESIZE=""
 
 # Mémoriser le timestamp d'exécution de la commande
 export HISTTIMEFORMAT='%F %T - '
@@ -267,7 +330,7 @@ shopt -s histappend
 
 # Pour éviter un troll, aucune ligne de cette section n'est décommentée.
 # Choisissez la vôtre.
-#~# export EDITOR='/usr/bin/nano'
+export EDITOR='/usr/bin/nano'
 #~# export EDITOR='/usr/bin/vim'
 #~# export EDITOR='/usr/bin/emacs'
 #~# export EDITOR='/usr/bin/jed'
@@ -275,6 +338,17 @@ shopt -s histappend
 # Ajouter ~/bin, /sbin et /usr/sbin à son PATH
 PATH=~/bin:$PATH:/sbin:/usr/sbin
 
+# Décommentez les lignes suivantes et peuplez-les correctement si
+# vous avez besoin de commiter en tant que root *et* que votre
+# /etc/sudoers contient bien la directive
+# Defaults env_keep += "<les variables en question>"
+export GIT_AUTHOR_NAME="$(git config user.name)"
+export GIT_AUTHOR_EMAIL="$(git config user.email)"
+
+# +----------+
+# | Sourcing |
+# +----------+
+
 # Chargement des alias
 if [ -f ~/.bash_aliases ]; then
     . ~/.bash_aliases
@@ -287,3 +361,11 @@ if [ -f ~/.bash_aliases_local ]; then
     . ~/.bash_aliases_local
 fi
 
+
+# +-----+
+# | End |
+# +-----+
+
+# On n'exécute le welcome_message que à ce moment, parce que la customisation
+# locale a pu changer des couleurs
+welcome_message