]> gitweb.pimeys.fr Git - config-20-100.git/blobdiff - .bashrc
[.ssh/config] Commentaire constructif
[config-20-100.git] / .bashrc
diff --git a/.bashrc b/.bashrc
index 9017ff476323940fb0a918145df1461ba28a706e..409278c8378370500c078d1c8eb69966878f908d 100644 (file)
--- a/.bashrc
+++ b/.bashrc
@@ -44,35 +44,58 @@ fi
 #~# # 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.
 #~#     # priorité à git, puis darcs
-#~#     local BRANCH TYPE violet orange vert
+#~#     local LBRANCH LTYPE BRANCH TYPE DIR violet orange vert
 #~#     violet="\[\e[35m\]"
 #~#     orange="\[\e[33m\]"
 #~#     vert="\[\e[32m\]"
 #~#     nocolor="\[\e[0m\]"
-#~#     BRANCH=$(git branch 2>/dev/null | sed -r "s/^[^*].*$//" | paste -s -d '' | sed -r "s/^[*] //")
-#~#     if [ -n "$BRANCH" ];
-#~#     then
-#~#         TYPE="git"
-#~#     else
-#~#         BRANCH=$(darcs show repo 2>/dev/null| egrep '^ *Cache' | sed 's@.*/\([^/]*\),.*@\1@')
-#~#         if [ -n "$BRANCH" ];
-#~#         then
-#~#             TYPE="darcs"
+#~#     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}${violet}(${nocolor}$LTYPE${violet})-${violet}[${vert}$LBRANCH${violet}]${nocolor}"
+#~#         else
+#~#             VCS_info="($LTYPE)-[$LBRANCH]"
 #~#         fi
-#~#     fi
-#~#     if [ -n "$TYPE" ];
-#~#     then
-#~#         VCS_info="${nocolor}${violet}(${nocolor}$TYPE${violet})-${violet}[${vert}$BRANCH${violet}]${nocolor}"
-#~#         VCS_size=$((${#TYPE}+${#BRANCH}+5))
+#~#         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
 # L'umask définit avec quel droits un fichier est créé.
 # Quand on écrit dans un dossier et qu'on veut que, par défaut,
@@ -80,7 +103,11 @@ fi
 # Rien de spécial n'arrivera si vous n'avez pas le fichier .umaskrc
 function cd {
         builtin cd "$@"
-        [ -f ~/.umaskrc ] &&  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
+        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
+        fi
 }
 
 ### Attention à ce que vous éditez dans cette section ###
@@ -135,13 +162,29 @@ function prompt_command
            DIR=$pwd
         POST_DIR='${MINUS_LINE:'${#pwd}+${VCS_size}+1'+${#?}}'
     fi
-    DIR="< ${jaune}"$DIR"${cyan} >"
-    ERR='[ \[\e[1;$((31+($?==0)*6))m\]$?'${cyan}' ]'$MINUS_CHAR
-    DATE="( ${violet}\D{%H:%M:%S}${cyan} )"
-    PROMPT="${rouge}\u${vert}@${bleu}\h ${vert}\$ ${nocolor}"
-    PS1=$TITLE${cyan}$MINUS_CHAR$DATE$MINUS_CHAR$DIR$MINUS_CHAR$VCS_info${cyan}$POST_DIR$ERR'\n'$PROMPT
+    if [ "$color_prompt" = yes ]; then
+        DIR="< ${jaune}"$DIR"${cyan} >"
+        ERR='[ \[\e[1;$((31+($?==0)*6))m\]$?'${cyan}' ]'$MINUS_CHAR
+        DATE="( ${violet}\D{%H:%M:%S}${cyan} )"
+        PROMPT="${rouge}\u${vert}@${bleu}\h ${vert}\$ ${nocolor}"
+        PS1=$TITLE${cyan}$MINUS_CHAR$DATE$MINUS_CHAR$DIR$MINUS_CHAR$VCS_info${cyan}$POST_DIR$ERR'\n'$PROMPT
+    else
+        DIR="< "$DIR" >"
+        ERR='[ $? ]'$MINUS_CHAR
+        DATE="( \D{%H:%M:%S} )"
+        PROMPT="\u@\h \$ "
+        PS1=$TITLE$MINUS_CHAR$DATE$MINUS_CHAR$DIR$MINUS_CHAR$VCS_info$POST_DIR$ERR'\n'$PROMPT
+    fi
 }
 
+if [ -x /usr/bin/tput ] && tput setaf 1 >&/dev/null; then
+    # support de la couleur
+    color_prompt=yes
+else
+    # pas de support de la couleur
+    color_prompt=no
+fi
+
 # On change le titre de la fenêtre dynamiquement si on est sous X
 if [[ $TERM = "xterm" ]]; then
     TITLE='\[\e];\u@\h:\w\a\]'
@@ -162,9 +205,15 @@ if [[ $(uname) == Linux && ( $(locale charmap) == UTF-8 && $TERM != screen ) ]];
     date=$(/bin/date +"%R, %A %d %B %Y")
     redate=${date//é/e}
     redate=${redate//û/u}
-    echo -e "\e[1;36m┬─${redate//?/─}──┬${MINUS_LINE:${#date}-18}\n\
+    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"
+    else
+        echo -e "┬─${redate//?/─}──┬${MINUS_LINE:${#date}-18}\n\
+│ $date  │\n\
+└─${redate//?/─}──┘\n"
+    fi
     unset date
 else
     MINUS_CHAR=-