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