2016-12-29 11:25:39 +01:00
|
|
|
**Cette page a été importée automatiquement de notre ancien wiki mais n'a pas encore été révisée.**
|
|
|
|
|
|
|
|
# Astuces Bash
|
|
|
|
|
|
|
|
~~~
|
|
|
|
function hello { echo Hello; echo $1; }
|
|
|
|
~~~
|
|
|
|
|
|
|
|
## Raccourcis
|
|
|
|
|
|
|
|
~~~
|
|
|
|
Ctrl+d : quitte le terminal courant
|
|
|
|
Ctrl+a : aller en début de ligne
|
|
|
|
Ctrl+e : aller en fin de ligne
|
|
|
|
Ctrl+k : effacer (coupe) du curseur à la fin de la ligne
|
|
|
|
Ctrl+u : effacer (coupe) du début de ligne au curseur
|
|
|
|
Ctrl+y : colle la partie précédemment coupée
|
|
|
|
Ctrl+r : rechercher parmi l'historique
|
|
|
|
Ctrl+s : freeze l'affichage de l'output
|
|
|
|
Ctrl+q : défreeze l'affichage de l'affichage de l'output
|
|
|
|
Ctrl+t : inverse les caractères autour du curseur
|
|
|
|
Ctrl+c : annule la ligne en cours et passer sur une nouvelle ligne vide
|
|
|
|
Ctrl+z : suspend la tâche en cours
|
|
|
|
ctrl+l : efface/rafraichit l'écran
|
2017-04-12 09:35:53 +02:00
|
|
|
ctrl+w : efface les mots qui précède le curseur
|
2016-12-29 11:25:39 +01:00
|
|
|
ctrl+x ctrl+e : édite la ligne dans $EDITOR
|
|
|
|
alt+effacer : Efface un mot à gauche du curseur
|
|
|
|
alt+d : Efface un mot à droite du curseur
|
2017-03-15 11:01:46 +01:00
|
|
|
~~~
|
|
|
|
|
|
|
|
# Script
|
|
|
|
|
2017-03-15 11:10:09 +01:00
|
|
|
## Variables
|
|
|
|
|
2017-03-15 11:29:27 +01:00
|
|
|
### Environnement
|
|
|
|
|
|
|
|
~~~{.bash}
|
|
|
|
$PPID
|
|
|
|
$BASHPID
|
|
|
|
$!
|
|
|
|
$$
|
2017-03-15 18:00:21 +01:00
|
|
|
$PIPESTATUS
|
2017-03-15 11:29:27 +01:00
|
|
|
~~~
|
|
|
|
|
2017-03-15 11:10:09 +01:00
|
|
|
### Initialiser
|
|
|
|
|
|
|
|
~~~{.bash}
|
|
|
|
var=
|
|
|
|
~~~
|
|
|
|
|
|
|
|
En readonly <=> constante
|
|
|
|
|
|
|
|
~~~{.bash}
|
|
|
|
readonly var="pas touche"
|
|
|
|
~~~
|
|
|
|
|
|
|
|
### Protéger
|
|
|
|
|
|
|
|
~~~{.bash}
|
|
|
|
[ -n "${var}" ] && true
|
|
|
|
#et surtout pas
|
|
|
|
[ -n $var ] && false
|
|
|
|
#car si var est vide, l'expression sera équivalente à [ -n ] => erreur de syntaxe
|
|
|
|
~~~
|
|
|
|
|
|
|
|
~~~{.bash}
|
2017-04-12 09:35:53 +02:00
|
|
|
echo $var "joue au ${foot}"
|
2017-03-15 11:10:09 +01:00
|
|
|
#et surtout pas
|
|
|
|
echo $var "joue au $foot"
|
|
|
|
#car sinon c'est bien le contenu de la variable $foot qui sera remplacé et non $foo
|
|
|
|
~~~
|
|
|
|
|
2017-03-15 11:29:27 +01:00
|
|
|
## Conditions
|
|
|
|
|
|
|
|
~~~{.bash}
|
|
|
|
true && echo "C'est toujours vrai"
|
|
|
|
false || echo "Ça sera toujours vraiment faux"
|
|
|
|
[ $? -eq 0 ] && { echo "tâche"; sleep 1; echo -e "\e'a plus!!" }
|
|
|
|
~~~
|
|
|
|
|
2017-03-15 11:38:32 +01:00
|
|
|
### test
|
|
|
|
|
2017-03-15 16:54:37 +01:00
|
|
|
## Boucles
|
|
|
|
|
2017-03-15 17:43:44 +01:00
|
|
|
«Liste» :
|
|
|
|
|
2017-03-15 16:54:37 +01:00
|
|
|
~~~{.bash}
|
|
|
|
for i in "valeur1 valeur2prisavec1" valeur3 valeurn; do echo $i; done
|
|
|
|
~~~
|
|
|
|
|
|
|
|
«Incrémentale» :
|
|
|
|
|
|
|
|
~~~{.bash}
|
|
|
|
for ((i=0; i<10; i++)); do echo $i; done
|
|
|
|
#ou
|
|
|
|
for i in $(seq 1 10); do echo $i; done
|
2017-03-15 17:35:47 +01:00
|
|
|
#ou
|
|
|
|
for i in {1..10}; do echo $i; done
|
2017-03-15 16:54:37 +01:00
|
|
|
~~~
|
|
|
|
|
|
|
|
«Conditionnelle» :
|
|
|
|
|
|
|
|
~~~{.bash}
|
|
|
|
file=; while [ -f "$file" ]; do sleep 10; touch $file; done
|
|
|
|
~~~
|
|
|
|
|
2017-03-15 11:29:27 +01:00
|
|
|
## Processus
|
|
|
|
|
|
|
|
~~~{.bash}
|
2017-03-15 16:58:37 +01:00
|
|
|
( echo "Je suis un fils du script principal, mais on attend que je meurs."; exit 0; )
|
2017-03-15 11:29:27 +01:00
|
|
|
( echo "Libreee !"; yes "Libre je dis !"; ) &
|
|
|
|
sleep 10 && kill $! #on tue le dernier fils créé
|
|
|
|
~~~
|
|
|
|
|
|
|
|
> Note: Dans une boucle, ne pas créer de process via *(* *)* sinon un usage comme **break** ou **continue**, ... ne fonctionnera pas :
|
2017-03-15 11:29:46 +01:00
|
|
|
>
|
2017-03-15 11:29:27 +01:00
|
|
|
> ~~~{.bash}
|
|
|
|
> while :
|
|
|
|
> do
|
|
|
|
> : && { echo "Stop !"; break; }
|
|
|
|
> done
|
|
|
|
> # ( echo "Stop !"; break; ) dans cet exemple ne quittera pas la boucle -car break dans un process fils-, et donc restera infini
|
|
|
|
> ~~~
|
|
|
|
|
|
|
|
## Astuces [concrètes]
|
|
|
|
|
|
|
|
### Récupérer tout stdin dans une variable
|
2017-03-15 11:01:46 +01:00
|
|
|
|
2017-03-15 11:29:27 +01:00
|
|
|
#### Complet
|
2017-03-15 11:01:46 +01:00
|
|
|
|
|
|
|
~~~{.bash}
|
|
|
|
var="$(cat <&0)"
|
|
|
|
#ou
|
|
|
|
var="$(cat -)"
|
|
|
|
~~~
|
|
|
|
|
2017-03-15 11:29:27 +01:00
|
|
|
#### Ligne par ligne
|
2017-03-15 11:01:46 +01:00
|
|
|
|
|
|
|
~~~{.bash}
|
|
|
|
var=
|
|
|
|
while read ligne
|
|
|
|
do
|
2017-03-15 11:10:09 +01:00
|
|
|
var="${var}${ligne}"
|
2017-03-15 11:01:46 +01:00
|
|
|
done <&0
|
2017-03-15 11:29:27 +01:00
|
|
|
~~~
|
|
|
|
|
|
|
|
autrement :
|
|
|
|
|
|
|
|
~~~{.bash}
|
|
|
|
cat <&0 | (while read ligne; do ... done)
|
2017-03-15 13:13:15 +01:00
|
|
|
~~~
|
|
|
|
|
|
|
|
### Écrire un fichier temporaire [unique]
|
|
|
|
|
|
|
|
~~~{.bash}
|
|
|
|
nomfichier=$(mktemp)
|
|
|
|
#pour un répertoire
|
|
|
|
nomrep=$(mktemp -d)
|
|
|
|
~~~
|
|
|
|
|
|
|
|
> Note: La création d'un fichier temporaire n'implique pas côté système une suppression automatique de ce dernier.
|