]> gitweb.pimeys.fr Git - config-20-100.git/blob - .bashrc
Merge branch 'master' into perso
[config-20-100.git] / .bashrc
1 # .bashrc générique mis à votre disposition
2 # par les gentils membres actifs du Cr@ns
3 # Vous pouvez l'utiliser, le redistribuer, le modifier à votre convenance.
4 # Des questions, des suggestions : {nounou,ca}@lists.crans.org
5 # Licence : WTFPL
6
7 # Les sections commentées par #~# sont des features qui ne sont pas activées
8 # par défaut. Sentez-vous libre de les décommenter pour les utiliser.
9
10 #------------------------------------------------------------------------------
11
12 # Pour les shells non interactif (sous emacs, avec rcp, ...)
13 # on ne charge pas le .bashrc
14 [ -z "$PS1" -o "$TERM" = dumb ] && return
15
16 # Hack pour que $COLUMNS contienne le nombre de colonne du terminal
17 # Sinon, le prompt kikoo risque de déborder/être trop court
18 COLUMNS=$(tput cols)
19 shopt -s checkwinsize
20
21 # +-------------------------+
22 # | Customizations diverses |
23 # +-------------------------+
24
25 # Utilisation de lesspipe comme PAGER si il est présent
26 [[ -x /usr/bin/lesspipe ]] && eval "$(lesspipe)"
27
28 # Couleur pour certaines commandes (ls, …)
29 if [ -x /usr/bin/dircolors ]; then
30 test -r ~/.dircolors && eval "$(dircolors -b ~/.dircolors)" || eval "$(dircolors -b)"
31 fi
32
33 # Bash-complétion
34 [ -f /etc/bash_completion ] && . /etc/bash_completion
35 # Placez vos fichiers de bash-complétion custom dans ~/.bash_completion.d/
36 # ils seront chargés par la ligne suivante
37 [ -d ~/.bash_completion.d/ ] && for f in ~/.bash_completion.d/*; do source $f; done
38
39
40 # +-----+
41 # | VCS |
42 # +-----+
43
44 # Définition de fonction pour pouvoir afficher dans le prompt
45 # des infos quand on est dans un dépôt versionné
46
47 find_up () {
48 local path normalized_path normalized_ret
49 path="$1"
50 shift 1
51 normalized_path=`readlink -f -- "$path"`
52 normalized_ret=$?
53 while [[ "$normalized_path" != "/" ]] && [ $normalized_ret -eq 0 ];
54 do
55 find "$path" -maxdepth 1 -mindepth 1 "$@"
56 path=${path}/..
57 normalized_path=`readlink -f -- "$path"`
58 normalized_ret=$?
59 done
60 }
61
62 get_vcs_info () {
63 # Donne les infos sur le dépôt VCS courant.
64 local LBRANCH LTYPE BRANCH TYPE DIR
65 declare -a DIR
66 declare -A TYPE
67 declare -A BRANCH
68 DIR[0]=".git"
69 DIR[1]=".hg"
70 DIR[2]="_darcs"
71 DIR[3]=".svn"
72 TYPE[.git]="git"
73 TYPE[.hg]="mercurial"
74 TYPE[_darcs]="darcs"
75 TYPE[.svn]="svn"
76 BRANCH[.git]='git branch 2>/dev/null | sed -r "s/^[^*].*$//" | paste -s -d "" | sed -r "s/^[*] //"'
77 BRANCH[.hg]='hg branch 2>/dev/null'
78 BRANCH[_darcs]="darcs show repo 2>/dev/null| egrep '^ *Cache' | sed 's@.*/\([^/]*\),.*@\1@'"
79 BRANCH[.svn]="svn info 2>/dev/null | head -n 6 | tail -n 1"
80
81 DIR=$(eval "find_up \"$PWD\" -name \"\"$(printf -- ' -o -name "%s"' "${DIR[@]}") | head -n 1")
82 if [ -n "$DIR" ]; then
83 DIR=$(basename "$DIR")
84 LBRANCH=$(eval "${BRANCH[$DIR]}")
85 LTYPE="${TYPE[$DIR]}"
86 if [ "$color_prompt" = yes ]; then
87 VCS_info="${nocolor_prompt}${vcs_symbols_color}(${vcs_type_color}$LTYPE${vcs_symbols_color})-${vcs_symbols_color}[${vcs_branch_color}$LBRANCH${vcs_symbols_color}]${nocolor_prompt}"
88 else
89 VCS_info="($LTYPE)-[$LBRANCH]"
90 fi
91 VCS_size=$((${#LTYPE}+${#LBRANCH}+5))
92 else
93 VCS_info=""
94 VCS_size=0
95 fi
96 }
97
98
99 # Pour avoir le bon umask en fonction du dossier où on se trouve
100 # L'umask définit avec quel droits un fichier est créé.
101 # Quand on écrit dans un dossier et qu'on veut que, par défaut,
102 # d'autres personnes puissent modifier les fichiers, il faut changer l'umask.
103 # Rien de spécial n'arrivera si vous n'avez pas le fichier .umaskrc
104 function cd {
105 builtin cd "$@"
106 ret=$?
107 if [ -f ~/.umaskrc ]; then
108 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
109 fi
110 return $ret
111 }
112
113 ### Attention à ce que vous éditez dans cette section ###
114 ### v v v v v v v v v v ###
115 # +----------------------+
116 # | Génération du prompt |
117 # +----------------------+
118
119 # Définition des couleurs
120 # Pour les utiliser dans le prompt,
121 # les couleurs doivent être entourés de \[ et \] pour délimiter les caractères
122 # invisibles
123 cyan='\e[1;36m'
124 cyan_thin='\e[0;36m'
125 violet='\e[1;35m'
126 violet_thin='\e[0;35m'
127 jaune='\e[1;33m'
128 jaune_thin='\e[0;33m'
129 rouge='\e[1;31m'
130 rouge_thin='\e[0;31m'
131 vert='\e[1;32m'
132 vert_thin='\e[0;32m'
133 bleu='\e[1;34m'
134 bleu_thin='\e[0;34m'
135 blanc='\e[1;37m'
136 blanc_thin='\e[0;37m'
137 nocolor='\e[0m'
138 cyan_prompt="\[${cyan}\]"
139 cyan_thin_prompt="\[${cyan_thin}\]"
140 violet_prompt="\[${violet}\]"
141 violet_thin_prompt="\[${violet_thin}\]"
142 jaune_prompt="\[${jaune}\]"
143 jaune_thin_prompt="\[${jaune_thin}\]"
144 rouge_prompt="\[${rouge}\]"
145 rouge_thin_prompt="\[${rouge_thin}\]"
146 vert_prompt="\[${vert}\]"
147 vert_thin_prompt="\[${vert_thin}\]"
148 bleu_prompt="\[${bleu}\]"
149 bleu_thin_prompt="\[${bleu_thin}\]"
150 blanc_prompt="\[${blanc}\]"
151 blanc_thin_prompt="\[${blanc_thin}\]"
152 nocolor_prompt="\[${nocolor}\]"
153
154 if [ -x /usr/bin/tput ] && tput setaf 1 >&/dev/null; then
155 # support de la couleur
156 color_prompt=yes
157 # Couleurs dans "user@host $"
158 username_color=${rouge_prompt}
159 host_color=${bleu_prompt}
160 symbols_color=${vert_prompt}
161 # Couleur de la ligne séparatrice de prompt
162 line_color=${cyan}
163 line_color_prompt=${cyan_prompt}
164 # Couleur du path actuel
165 pwd_color=${jaune_prompt}
166 # Couleur de la date (à chaque affichage du prompt)
167 date_color=${violet_prompt}
168 # Couleur de la date au premier affichage (à l'ouverture du terminal)
169 announce_date_color=${blanc}
170 # Couleur d'affichage de vcs_info
171 vcs_symbols_color=${violet_thin_prompt}
172 vcs_type_color=${jaune_thin_prompt}
173 vcs_branch_color=${vert_thin_prompt}
174 else
175 # pas de support de la couleur
176 color_prompt=no
177 fi
178
179 # Est-ce qu'on veut que le prompt affiche les information sur l'éventuel dépôt
180 # versionné dans lequel on se trouve
181 #~# # Changez cette variable en "yes" pour l'afficher
182 display_vcs_info=no
183
184
185 # Génération de la ligne de "-"
186 function gen_minus_line
187 {
188 local i
189
190 MINUS_LINE=""
191 # Pas la peine de refaire le travail tant qu'on ne change
192 # pas le nombre de colonnes.
193 SAVE_COLUMNS=$COLUMNS
194
195 for ((i = COLUMNS-23; i>0; i--)); do
196 MINUS_LINE=$MINUS_CHAR$MINUS_LINE
197 done
198 }
199
200 # Génération du prompt après chaque commande
201 function prompt_command
202 {
203 local pwd ERR DATE PROMPT DIR POST_DIR
204 # Cette fonction génère un prompt sur deux lignes
205 # ayant cette allure :
206 # ─( 12:59:05 )─< ~ >───────────────────────────────────────────────────────[ 0 ]─
207 # user@host $
208
209 # Attention aux hacks (échappement, interprétation des variables)
210 # pour que les couleurs (et leurs tailles)
211 # soient évaluées au moment de l'affichage du prompt
212 # Si le terminal a été redimensionné, on régénère la ligne de tirets
213 (( SAVE_COLUMNS == COLUMNS )) || gen_minus_line
214
215 # À décommenter si on veut afficher des infos
216 # quand on se trouve dans un dépôt versionné
217 if [ "$display_vcs_info" = yes ]; then
218 get_vcs_info
219 fi
220
221 # Chemin courant, en faisant attention à la largeur de la fenêtre
222 pwd=${PWD/#$HOME/'~'}
223 if (( ${#pwd} + ${VCS_size} + 27 > COLUMNS )); then
224 if (( COLUMNS >= 33 )); then
225 DIR='..'${pwd:${#pwd}+${VCS_size}+30-COLUMNS}
226 POST_DIR='${MINUS_LINE:0:4-${#?}}'
227 else
228 DIR=$pwd
229 POST_DIR=$MINUS_CHAR
230 fi
231 else
232 DIR=$pwd
233 POST_DIR='${MINUS_LINE:'${#pwd}+${VCS_size}+1'+${#?}}'
234 fi
235
236 # Génération des différents morceaux du prompt, avec ou sans la couleur
237 if [ "$color_prompt" = yes ]; then
238 DIR="< ${pwd_color}"$DIR"${line_color_prompt} >"
239 # On affiche le code de retour en "no color" si c'est 0, en rouge sinon
240 # Ceci n'est pas customizable à coup de variable,
241 # il faut changer $((31+($?==0)*6)) si vous y tenez vraiment et que vous comprenez ce que vous faites
242 ERR='[ \[\e[1;$((31+($?==0)*6))m\]$?'${line_color_prompt}' ]'$MINUS_CHAR
243 # Affichage de l'heure courante
244 # pratique pour savoir quand on a tapé la commande précédente
245 DATE="( ${date_color}\D{%H:%M:%S}${line_color_prompt} )"
246 # Deuxième ligne du prompt "user@host $"
247 # Attention "\\\$" devient \$, c'est-à-dire # pour root, $ pour les autres
248 PROMPT="${username_color}\u${symbols_color}@${host_color}\h ${symbols_color}\\\$ ${nocolor_prompt}"
249 # On fusionne tout ça
250 PS1=$TITLE${line_color_prompt}$MINUS_CHAR$DATE$MINUS_CHAR$DIR$MINUS_CHAR$VCS_info${line_color_prompt}$POST_DIR$ERR'\n'$PROMPT
251 else
252 DIR="< "$DIR" >"
253 ERR='[ $? ]'$MINUS_CHAR
254 DATE="( \D{%H:%M:%S} )"
255 PROMPT="\u@\h \\\$ "
256 PS1=$TITLE$MINUS_CHAR$DATE$MINUS_CHAR$DIR$MINUS_CHAR$VCS_info$POST_DIR$ERR'\n'$PROMPT
257 fi
258 }
259
260 # On change le titre de la fenêtre dynamiquement si on est sous X
261 if [[ $TERM = "xterm" ]]; then
262 TITLE='\[\e];\u@\h:\w\a\]'
263 else
264 TITLE=''
265 fi
266
267 # On régénère le prompt après chaque commande
268 PROMPT_COMMAND=prompt_command
269
270 # +-------------------+
271 # | Messages au début |
272 # +-------------------+
273
274 function welcome_message ()
275 {
276 # Si on supporte l'utf-8 et qu'on n'est pas dans un screen,
277 # on affiche un joli cadre avec la date.
278 # On utilise aussi un caractère plus sympa pour faire les lignes de tirets
279 if [[ $(uname) == Linux && ( $(locale charmap) == UTF-8 && $TERM != screen ) ]]; then
280 MINUS_CHAR=─
281 gen_minus_line
282 date=$(/bin/date +"%R, %A %d %B %Y")
283 # ${redate} sert à connaître la taille de la chaine $date,
284 # mais sans se planter sur le nombre d'octet/nombre de caractères
285 redate=${date//é/e}
286 redate=${redate//û/u}
287 if [ "$color_prompt" = yes ]; then
288 echo -e "${line_color}┬─${redate//?/─}─┬${MINUS_LINE:${#date}-19}\n│ ${announce_date_color}$date ${line_color}│\n└─${redate//?/─}─┘\e[0m\n"
289 else
290 echo -e "┬─${redate//?/─}──┬${MINUS_LINE:${#date}-18}\n│ $date │\n└─${redate//?/─}──┘\n"
291 fi
292 unset date
293 # Sinon, on se contente d'une ligne de tirets
294 else
295 MINUS_CHAR=-
296 gen_minus_line
297 fi
298 }
299 ### ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ###
300 ### Attention à ce que vous avez édité dans cette section ###
301
302 # +---------------------------------------+
303 # | Gestion de l'historique des commandes |
304 # +---------------------------------------+
305
306 # On ne sauve pas les lignes dupliquées qui se suivent dans l'historique
307 # ainsi que les commandes qui commencent par une espace
308 export HISTCONTROL=ignoreboth
309
310 # Nombre de lignes d'historique à garder
311 export HISTSIZE=
312
313 # la même chose dans le fichier d'historique
314 export HISTFILESIZE=
315
316 # Mémoriser le timestamp d'exécution de la commande
317 export HISTTIMEFORMAT='%F %T - '
318
319 # pour sauvegarder les commandes de plusieurs lignes (\ ) en une seule
320 shopt -s cmdhist
321 # pour enregistrer tout de suite les commandes dans l'historique
322 # et non pas à la fermeture du shell
323 shopt -s histappend
324
325
326 # +---------------+
327 # | Environnement |
328 # +---------------+
329
330 # Pour éviter un troll, aucune ligne de cette section n'est décommentée.
331 # Choisissez la vôtre.
332 export EDITOR='/usr/bin/nano'
333 #~# export EDITOR='/usr/bin/vim'
334 #~# export EDITOR='/usr/bin/emacs'
335 #~# export EDITOR='/usr/bin/jed'
336
337 # Ajouter ~/bin, /sbin et /usr/sbin à son PATH
338 PATH=~/bin:$PATH:/sbin:/usr/sbin
339
340 # Chargement des alias
341 if [ -f ~/.bash_aliases ]; then
342 . ~/.bash_aliases
343 fi
344
345 # Fichier locaux (utile quand on clone sa config sur plusieurs machines)
346 [[ -f ~/.bashrc.local ]] && . ~/.bashrc.local
347
348 if [ -f ~/.bash_aliases_local ]; then
349 . ~/.bash_aliases_local
350 fi
351
352 # On n'exécute le welcome_message que à ce moment, parce que la customisation
353 # locale a pu changer des couleurs
354 welcome_message