X-Git-Url: http://gitweb.pimeys.fr/?a=blobdiff_plain;f=.bashrc;h=409278c8378370500c078d1c8eb69966878f908d;hb=029ce53a3b3d96a1991eb2913a96ae3aa14838f6;hp=a29feec29fb3bc8777d5c63854ea0a4c2ad4699c;hpb=8f36d01580c5bd91b5a33d39a74139a922938361;p=config-20-100.git diff --git a/.bashrc b/.bashrc index a29feec..409278c 100644 --- a/.bashrc +++ b/.bashrc @@ -1,6 +1,6 @@ # .bashrc générique mis à votre disposition # par les gentils membres actifs du Cr@ns -# Vous pouvez l'utilisez, le redistribuer, le modifier à votre convenance. +# Vous pouvez l'utiliser, le redistribuer, le modifier à votre convenance. # Des questions, des suggestions : {nounou,ca}@lists.crans.org # Licence : WTFPL @@ -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=-