]> 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 679c3a6e1749ce5697a43d4998fa90af39d647f9..aa33f36183c4c0c696fed7613e63a1fb749bcff7 100644 (file)
--- a/.bashrc
+++ b/.bashrc
@@ -45,12 +45,17 @@ fi
 # des infos quand on est dans un dépôt versionné
 
 find_up () {
+    local path normalized_path normalized_ret
     path="$1"
     shift 1
-    while [[ "`readlink -f -- \"$path\"`" != "/" ]];
+    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
 }
 
@@ -100,7 +105,7 @@ 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
+            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
 }
@@ -183,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
@@ -193,17 +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écommenter si on veut des infos
+    
+    # À 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
@@ -217,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_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_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
 }
@@ -242,7 +264,7 @@ 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
 
 # +-------------------+
@@ -251,10 +273,15 @@ PROMPT_COMMAND=prompt_command
 
 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
@@ -263,6 +290,7 @@ function welcome_message ()
             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
         MINUS_CHAR=-
         gen_minus_line
@@ -271,6 +299,7 @@ function welcome_message ()
 ### ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ###
 ### Attention à ce que vous avez édité dans cette section ###
 
+
 # +---------------------------------------+
 # | Gestion de l'historique des commandes |
 # +---------------------------------------+
@@ -280,10 +309,10 @@ function welcome_message ()
 export HISTCONTROL=ignoreboth
 
 # Nombre de lignes d'historique à garder
-export HISTSIZE=
+export HISTSIZE=""
 
 # la même chose dans le fichier d'historique
-export HISTFILESIZE=
+export HISTFILESIZE=""
 
 # Mémoriser le timestamp d'exécution de la commande
 export HISTTIMEFORMAT='%F %T - '
@@ -309,6 +338,17 @@ export EDITOR='/usr/bin/nano'
 # 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
@@ -321,6 +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
-# local a pu changer des couleurs
+# locale a pu changer des couleurs
 welcome_message