]> gitweb.pimeys.fr Git - config-20-100.git/blob - .bashrc
On ne hardcode plus les couleurs. Ça permet de les changer dans le .bashrc.local
[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 #~# path="$1"
49 #~# shift 1
50 #~# while [[ "`readlink -f -- \"$path\"`" != "/" ]];
51 #~# do
52 #~# find "$path" -maxdepth 1 -mindepth 1 "$@"
53 #~# path=${path}/..
54 #~# done
55 #~# }
56 #~#
57 #~# get_vcs_info () {
58 #~# # Donne les infos sur le dépôt VCS courant.
59 #~# local LBRANCH LTYPE BRANCH TYPE DIR
60 #~# declare -a DIR
61 #~# declare -A TYPE
62 #~# declare -A BRANCH
63 #~# DIR[0]=".git"
64 #~# DIR[1]=".hg"
65 #~# DIR[2]="_darcs"
66 #~# DIR[3]=".svn"
67 #~# TYPE[.git]="git"
68 #~# TYPE[.hg]="mercurial"
69 #~# TYPE[_darcs]="darcs"
70 #~# TYPE[.svn]="svn"
71 #~# BRANCH[.git]='git branch 2>/dev/null | sed -r "s/^[^*].*$//" | paste -s -d "" | sed -r "s/^[*] //"'
72 #~# BRANCH[.hg]='hg branch 2>/dev/null'
73 #~# BRANCH[_darcs]="darcs show repo 2>/dev/null| egrep '^ *Cache' | sed 's@.*/\([^/]*\),.*@\1@'"
74 #~# BRANCH[.svn]="svn info 2>/dev/null | head -n 6 | tail -n 1"
75 #~#
76 #~# DIR=$(eval "find_up \"$PWD\" -name \"\"$(printf -- ' -o -name "%s"' "${DIR[@]}") | head -n 1")
77 #~# if [ -n "$DIR" ]; then
78 #~# DIR=$(basename "$DIR")
79 #~# LBRANCH=$(eval "${BRANCH[$DIR]}")
80 #~# LTYPE="${TYPE[$DIR]}"
81 #~# if [ "$color_prompt" = yes ]; then
82 #~# VCS_info="${nocolor}${vcs_symbols_color}(${nocolor}$LTYPE${vcs_symbols_color})-${vcs_symbols_color}[${vcs_branch_color}$LBRANCH${vcs_symbols_color}]${nocolor}"
83 #~# else
84 #~# VCS_info="($LTYPE)-[$LBRANCH]"
85 #~# fi
86 #~# VCS_size=$((${#LTYPE}+${#LBRANCH}+5))
87 #~# else
88 #~# VCS_info=""
89 #~# VCS_size=0
90 #~# fi
91 #~# }
92
93
94 # Pour avoir le bon umask en fonction du dossier où on se trouve
95 # L'umask définit avec quel droits un fichier est créé.
96 # Quand on écrit dans un dossier et qu'on veut que, par défaut,
97 # d'autres personnes puissent modifier les fichiers, il faut changer l'umask.
98 # Rien de spécial n'arrivera si vous n'avez pas le fichier .umaskrc
99 function cd {
100 builtin cd "$@"
101 if [ -f ~/.umaskrc ]; then
102 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
103 else
104 return 0
105 fi
106 }
107
108 ### Attention à ce que vous éditez dans cette section ###
109 ### v v v v v v v v v v ###
110 # +----------------------+
111 # | Génération du prompt |
112 # +----------------------+
113
114 cyan='\[\e[1;36m\]'
115 violet='\[\e[1;35m\]'
116 violet_thin='\[\e[0;35m\]'
117 jaune='\[\e[1;33m\]'
118 rouge='\[\e[1;31m\]'
119 vert='\[\e[1;32m\]'
120 vert_thin='\[\e[0;32m\]'
121 bleu='\[\e[1;34m\]'
122 nocolor='\[\e[0m\]'
123
124 if [ -x /usr/bin/tput ] && tput setaf 1 >&/dev/null; then
125 # support de la couleur
126 color_prompt=yes
127 # Couleurs dans "user@host $"
128 username_color=$rouge
129 host_color=$bleu
130 symbols_color=$vert
131 # Couleur de la ligne séparatrice de prompt
132 line_color=$cyan
133 # Couleur du path actuel
134 pwd_color=$jaune
135 # Couleur de la date
136 date_color=$violet
137 # Couleur d'affichage de vcs_info
138 vcs_symbols_color=$violet_thin
139 vcs_type_color=
140 vcs_branch_color=$vert_thin
141 else
142 # pas de support de la couleur
143 color_prompt=no
144 fi
145
146
147 # Génération de la ligne de "-"
148 function gen_minus_line
149 {
150 local i
151
152 MINUS_LINE=""
153 SAVE_COLUMNS=$COLUMNS
154
155 for ((i = COLUMNS-23; i>0; i--)); do
156 MINUS_LINE=$MINUS_CHAR$MINUS_LINE
157 done
158 }
159
160 # Génération du prompt après chaque commande
161 function prompt_command
162 {
163 # Attention aux hacks pour que la couleur (et sa taille)
164 # soient évaluées au moment de l'affichage du prompt
165 local pwd ERR DATE PROMPT DIR POST_DIR
166 (( SAVE_COLUMNS == COLUMNS )) || gen_minus_line
167
168 #~# #dépend de la section VCS
169 #~# get_vcs_info
170
171 pwd=${PWD/#$HOME/'~'}
172 if (( ${#pwd} + ${VCS_size} + 27 > COLUMNS )); then
173 if (( COLUMNS >= 33 )); then
174 DIR='..'${pwd:${#pwd}+${VCS_size}+30-COLUMNS}
175 POST_DIR='${MINUS_LINE:0:4-${#?}}'
176 else
177 DIR=$pwd
178 POST_DIR=$MINUS_CHAR
179 fi
180 else
181 DIR=$pwd
182 POST_DIR='${MINUS_LINE:'${#pwd}+${VCS_size}+1'+${#?}}'
183 fi
184 if [ "$color_prompt" = yes ]; then
185 DIR="< ${pwd_color}"$DIR"${line_color} >"
186 # On affiche le code de retour en "no color" si c'est 0, en rouge sinon
187 # Ceci n'est pas customizable à coup de variable,
188 # il faut changer $((31+($?==0)*6)) si vous y tenez vraiment et que vous comprenez ce que vous faites
189 ERR='[ \[\e[1;$((31+($?==0)*6))m\]$?'${line_color}' ]'$MINUS_CHAR
190 DATE="( ${date_color}\D{%H:%M:%S}${line_color} )"
191 PROMPT="${username_color}\u${symbols_color}@${host_color}\h ${symbols_color}\$ ${nocolor}"
192 PS1=$TITLE${line_color}$MINUS_CHAR$DATE$MINUS_CHAR$DIR$MINUS_CHAR$VCS_info${line_color}$POST_DIR$ERR'\n'$PROMPT
193 else
194 DIR="< "$DIR" >"
195 ERR='[ $? ]'$MINUS_CHAR
196 DATE="( \D{%H:%M:%S} )"
197 PROMPT="\u@\h \$ "
198 PS1=$TITLE$MINUS_CHAR$DATE$MINUS_CHAR$DIR$MINUS_CHAR$VCS_info$POST_DIR$ERR'\n'$PROMPT
199 fi
200 }
201
202 # On change le titre de la fenêtre dynamiquement si on est sous X
203 if [[ $TERM = "xterm" ]]; then
204 TITLE='\[\e];\u@\h:\w\a\]'
205 else
206 TITLE=''
207 fi
208
209 # On regénére le prompt après chaque commande
210 PROMPT_COMMAND=prompt_command
211
212 # +-------------------+
213 # | Messages au début |
214 # +-------------------+
215
216 if [[ $(uname) == Linux && ( $(locale charmap) == UTF-8 && $TERM != screen ) ]]; then
217 MINUS_CHAR=─
218 gen_minus_line
219 date=$(/bin/date +"%R, %A %d %B %Y")
220 redate=${date//é/e}
221 redate=${redate//û/u}
222 if [ "$color_prompt" = yes ]; then
223 echo -e "\e[1;36m┬─${redate//?/─}──┬${MINUS_LINE:${#date}-18}\n\
224 │ \e[1;37m$date\e[1;31m \e[1;36m │\n\
225 └─${redate//?/─}──┘\e[0m\n"
226 else
227 echo -e "┬─${redate//?/─}──┬${MINUS_LINE:${#date}-18}\n\
228 │ $date │\n\
229 └─${redate//?/─}──┘\n"
230 fi
231 unset date
232 else
233 MINUS_CHAR=-
234 gen_minus_line
235 fi
236 ### ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ###
237 ### Attention à ce que vous avez édité dans cette section ###
238
239
240 # +---------------------------------------+
241 # | Gestion de l'historique des commandes |
242 # +---------------------------------------+
243
244 # On ne sauve pas les lignes dupliquées qui se suivent dans l'historique
245 # ainsi que les commandes qui commencent par une espace
246 export HISTCONTROL=ignoreboth
247
248 # Nombre de lignes d'historique à garder
249 export HISTSIZE=5000
250
251 # la même chose dans le fichier d'historique
252 export HISTFILESIZE=5000
253
254 # Mémoriser le timestamp d'exécution de la commande
255 export HISTTIMEFORMAT='%F %T - '
256
257 # pour sauvegarder les commandes de plusieurs lignes (\ ) en une seule
258 shopt -s cmdhist
259 # pour enregistrer tout de suite les commandes dans l'historique
260 # et non pas à la fermeture du shell
261 shopt -s histappend
262
263
264 # +---------------+
265 # | Environnement |
266 # +---------------+
267
268 # Pour éviter un troll, aucune ligne de cette section n'est décommentée.
269 # Choisissez la vôtre.
270 #~# export EDITOR='/usr/bin/nano'
271 #~# export EDITOR='/usr/bin/vim'
272 #~# export EDITOR='/usr/bin/emacs'
273 #~# export EDITOR='/usr/bin/jed'
274
275 # Ajouter ~/bin, /sbin et /usr/sbin à son PATH
276 PATH=~/bin:$PATH:/sbin:/usr/sbin
277
278 # Chargement des alias
279 if [ -f ~/.bash_aliases ]; then
280 . ~/.bash_aliases
281 fi
282
283 # Fichier locaux (utile quand on clone sa config sur plusieurs machines)
284 [[ -f ~/.bashrc.local ]] && . ~/.bashrc.local
285
286 if [ -f ~/.bash_aliases_local ]; then
287 . ~/.bash_aliases_local
288 fi
289