X-Git-Url: http://gitweb.pimeys.fr/?a=blobdiff_plain;f=.bashrc;h=aa33f36183c4c0c696fed7613e63a1fb749bcff7;hb=fd090c83e9d578fe1736b4e3ce6d168bc46ef063;hp=679c3a6e1749ce5697a43d4998fa90af39d647f9;hpb=883402061ad8d78d96defdc7088c5ee9e8e5affe;p=config-20-100.git diff --git a/.bashrc b/.bashrc index 679c3a6..aa33f36 100644 --- 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 += "" +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