
{ suite_cmds ; }
Insérée entre une paire d’accolades, la suite de commandes est exécutée dans le shell courant. Cela a pour effet de préserver les modifications apportées par la suite de commandes sur l’environnement du processus courant.
Exemple :
$ pwd
/home/tony => répertoire initial
$
$ { cd /bin ; pwd ; } => changement du répertoire courant
/bin
$
$ pwd
/bin => répertoire final (le changement a été préservé !)
$
S’exécutant dans le shell courant, les modifications apportées aux variables sont également conservées :
Exemple :
$ a=bonjour
$
$ { a=coucou ; echo $a ;}
coucou
$
$ echo $a
coucou
$
Les accolades { et } sont deux mots-clé de bash ; chacune d’elles doit donc être le premier mot d’une commande. Pour cela, chaque accolade doit être le premier mot de la ligne de commande ou bien être précédée d’un caractère ;. De plus, suite_cmds ne doit pas « coller » l’accolade ouvrante {.
Par contre, la présence ou absence d’un caractère espace entre le caractère ; et le mot-clé } n’a aucune importance.
Exemple :
$ { cd /bin } => l’accolade } n’est pas le premier mot d’une commande
> => le shell ne détecte pas la fin du groupement
> ^C => control-C
$
$ {cd /bin ;} => il manque un espace ou une tabulation entre { et cd
-bash: syntax error near unexpected token `}'
$
Toutefois, lancée en arrière-plan, la suite de commandes n’est plus exécutée par le shell courant mais par un sous-shell.
Exemple :
$ pwd
/home/tony => répertoire initial
$
$ { echo processus : ; cd / ; ps ;} &
processus :
[1] 27963
$ PID TTY TIME CMD
27942 pts/14 00:00:00 bash
27947 pts/14 00:00:00 bash
27963 pts/14 00:00:00 ps
[1] + Done { echo processus :; cd /; ps; }
$
$ pwd
/home/tony => répertoire final
$ &ot; lig2 </dev/tty
> read lig3
> } < fich
Entrez votre ligne : bonjour tout le monde
$
$ echo $lig1
premiere ligne
$ echo $lig2
bonjour tout le monde
$ echo $lig3
deuxieme ligne
$
Les commandes read lig1 et read lig3 lisent le contenu du fichier fich mais la commande read -p "Entrez votre ligne : " lig2 lit son entrée standard (/dev/tty).
Insertion entre parenthèses
(suite_cmds)
&lrsquo;entrée standard des deux commandes read ligne1 et read ligne2 est globalement redirigée : elles liront séquentiellement le contenu du fichier fich.
Si les commandes de lecture n’avaient pas été groupées, seule la première ligne de fich aurait été lue.
Exemple :
$ read ligne1 < fich ; read ligne2 < fich
$
$ echo $ligne1
premiere ligne
$
$ echo $ligne2
premiere ligne
$
Comme pour toutes commandes composées, lorsque plusieurs redirections de même type sont appliquées à la même suite de commandes, seule la redirection la plus proche est effective.
Exemple :
$ { read lig1 ; read -p "Entrez votre ligne : " lig2 </dev/tty
> read lig3
> } < fich
Entrez votre ligne : bonjour tout le monde
$
$ echo $lig1
premiere ligne
$ echo $lig2
bonjour tout le monde
$ echo $lig3
deuxieme ligne
$
Les commandes read lig1 et read lig3 lisent le contenu du fichier fich mais la commande read -p "Entrez votre ligne : " lig2 lit son entrée standard (/dev/tty).
Insertion entre parenthèses
(suite_cmds)
Insérée entre une paire de parenthèses, la suite de commandes est exécutée dans un sous-shell. L’environnement du processus n’est pas modifié après exécution de la suite de commandes. Les parenthèses sont des opérateurs (et non des mots clé) : suite_cmds peut par conséquent coller une ou deux parenthèses sans provoquer une erreur de syntaxe.
Exemple :
$ pwd
/home/tony => répertoire initial
$
$ (cd /bin ; pwd)
/bin
$
$ pwd
/home/tony => le répertoire initial n’a pas été modifié
$
$ b=bonjour
$
$ ( b=coucou ; echo $b )
coucou
$
$ echo $b
bonjour => la valeur de la variable b n’a pas été modifiée
$
Ce type de groupement de commandes peut être aussi utilisé pour effectuer une redirection globale.
Exemple :
$ ( pwd ; date ; echo FIN ) > fin
$
$ cat fin
/home/tony
lundi 26 octobre 2015, 15:47:45 (UTC+0100)
FIN
$