# .bashrc générique mis à votre disposition # par les gentils membres actifs du Cr@ns # Vous pouvez l'utiliser, le redistribuer, le modifier à votre convenance. # Des questions, des suggestions : {nounou,ca}@lists.crans.org # Licence : WTFPL # Les sections commentées par #~# sont des features qui ne sont pas activées # par défaut. Sentez-vous libre de les décommenter pour les utiliser. #------------------------------------------------------------------------------ # Pour les shells non interactif (sous emacs, avec rcp, ...) # on ne charge pas le .bashrc [ -z "$PS1" -o "$TERM" = dumb ] && return # Hack pour que $COLUMNS contienne le nombre de colonne du terminal # Sinon, le prompt kikoo risque de déborder/être trop court COLUMNS=$(tput cols) shopt -s checkwinsize # +-------------------------+ # | Customizations diverses | # +-------------------------+ # Utilisation de lesspipe comme PAGER si il est présent [[ -x /usr/bin/lesspipe ]] && eval "$(lesspipe)" # Couleur pour certaines commandes (ls, …) if [ -x /usr/bin/dircolors ]; then test -r ~/.dircolors && eval "$(dircolors -b ~/.dircolors)" || eval "$(dircolors -b)" fi # Bash-complétion [ -f /etc/bash_completion ] && . /etc/bash_completion # Placez vos fichiers de bash-complétion custom dans ~/.bash_completion.d/ # ils seront chargés par la ligne suivante [ -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. #~# # priorité à git, puis darcs #~# local LBRANCH LTYPE BRANCH TYPE DIR violet orange vert #~# violet="\[\e[35m\]" #~# orange="\[\e[33m\]" #~# vert="\[\e[32m\]" #~# nocolor="\[\e[0m\]" #~# 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 #~# 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, # d'autres personnes puissent modifier les fichiers, il faut changer l'umask. # Rien de spécial n'arrivera si vous n'avez pas le fichier .umaskrc function cd { builtin cd "$@" 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 ### ### v v v v v v v v v v ### # +----------------------+ # | Génération du prompt | # +----------------------+ # Génération de la ligne de "-" function gen_minus_line { local i MINUS_LINE="" SAVE_COLUMNS=$COLUMNS for ((i = COLUMNS-23; i>0; i--)); do MINUS_LINE=$MINUS_CHAR$MINUS_LINE done } # 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 cyan violet jaune rouge vert bleu ERR DATE PROMPT DIR POST_DIR (( SAVE_COLUMNS == COLUMNS )) || gen_minus_line #~# #dépend de la section VCS #~# get_vcs_info cyan='\[\e[1;36m\]' violet='\[\e[1;35m\]' jaune='\[\e[1;33m\]' rouge='\[\e[1;31m\]' vert='\[\e[1;32m\]' bleu='\[\e[1;34m\]' nocolor='\[\e[0m\]' pwd=${PWD/#$HOME/'~'} if (( ${#pwd} + ${VCS_size} + 27 > COLUMNS )); then if (( COLUMNS >= 33 )); then DIR='..'${pwd:${#pwd}+${VCS_size}+30-COLUMNS} POST_DIR='${MINUS_LINE:0:4-${#?}}' else DIR=$pwd POST_DIR=$MINUS_CHAR fi else DIR=$pwd POST_DIR='${MINUS_LINE:'${#pwd}+${VCS_size}+1'+${#?}}' fi 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\]' else TITLE='' fi # On regé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" else echo -e "┬─${redate//?/─}──┬${MINUS_LINE:${#date}-18}\n\ │ $date │\n\ └─${redate//?/─}──┘\n" fi unset date else MINUS_CHAR=- gen_minus_line fi ### ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ### ### Attention à ce que vous avez édité dans cette section ### # +---------------------------------------+ # | Gestion de l'historique des commandes | # +---------------------------------------+ # On ne sauve pas les lignes dupliquées qui se suivent dans l'historique # ainsi que les commandes qui commencent par une espace export HISTCONTROL=ignoreboth # Nombre de lignes d'historique à garder export HISTSIZE=5000 # la même chose dans le fichier d'historique export HISTFILESIZE=5000 # Mémoriser le timestamp d'exécution de la commande export HISTTIMEFORMAT='%F %T - ' # pour sauvegarder les commandes de plusieurs lignes (\ ) en une seule shopt -s cmdhist # pour enregistrer tout de suite les commandes dans l'historique # et non pas à la fermeture du shell shopt -s histappend # +---------------+ # | Environnement | # +---------------+ # 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/vim' #~# export EDITOR='/usr/bin/emacs' #~# export EDITOR='/usr/bin/jed' # Ajouter ~/bin, /sbin et /usr/sbin à son PATH PATH=~/bin:$PATH:/sbin:/usr/sbin # Chargement des alias if [ -f ~/.bash_aliases ]; then . ~/.bash_aliases fi # Fichier locaux (utile quand on clone sa config sur plusieurs machines) [[ -f ~/.bashrc.local ]] && . ~/.bashrc.local if [ -f ~/.bash_aliases_local ]; then . ~/.bash_aliases_local fi