Provided by: manpages-fr-dev_3.65d1p1-1_all bug

NOM

       pipe, pipe2 - Créer un tube

SYNOPSIS

       #include <unistd.h>

       int pipe(int pipefd[2]);

       #define _GNU_SOURCE             /* Consultez feature_test_macros(7) */
       #include <fcntl.h>              /* Obtenir les définition de constante O_* */
       #include <unistd.h>

       int pipe2(int pipefd[2], int flags);

DESCRIPTION

       pipe()  crée  un  tube,  un canal unidirectionnel de données qui peut être utilisé pour la
       communication  entre  processus.  Le  tableau  pipefd  est  utilisé  pour  renvoyer   deux
       descripteurs de fichier faisant référence aux extrémités du tube. pipefd[0] fait référence
       à l'extrémité de lecture du tube. pipefd[1] fait référence  à  l'extrémité  d'écriture  du
       tube.  Les données écrites sur l'extrémité d'écriture du tube sont mises en mémoire tampon
       par le noyau jusqu'à ce qu'elles soient lues sur l'extrémité de lecture du tube. Pour plus
       de détails, consultez pipe(7).

       Si flags est nul, alors pipe2() est identique à pipe(). Les valeurs suivantes peuvent être
       incluses à l'aide d'un OU binaire dans flags pour obtenir différents comportements :

       O_CLOEXEC
              Placer l'attribut « close-on-exec » (FD_CLOEXEC) sur les deux nouveaux descripteurs
              de  fichiers.  Consultez  la  description  de cet attribut dans open(2) pour savoir
              pourquoi ça peut être utile.

       O_DIRECT (depuis Linux 3.4)
              Créer un tube qui assure les E/S en mode « packet ». Chaque opération write(2) vers
              le  tube est exécutée avec un paquet distinct, and les opérations read(2) depuis le
              tube lisent un seul paquet à la fois. Notez les précisions suivantes :

              *  Les opérations d'écriture dont la taille dépasse PIPE_BUF octets (voir  pipe(7))
                 seront fractionnées en plusieurs paquets.

              *  Si  une  opération  read(2)  indique  une taille du tampon inférieure à celle du
                 paquet à venir, alors seul le nombre d'octets demandé sera  lu,  et  les  octets
                 supplémentaires  du  paquet  seront écartés. Si l'on souhaite s'assurer que même
                 les paquets les plus longs seront lus, il suffit de définir la taille du  tampon
                 à PIPE_BUF(voir le point précédent).

              *  Les  paquets  de  longueur nulle ne sont pas acceptés (une opération read(2) qui
                 indique une taille de tampon de longueur zéro est sans effet et renvoie 0).

              Les anciens noyaux qui n'acceptent pas cet attribut renvoient une erreur EINVAL.

       O_NONBLOCK
              Placer l'attribut d'état de fichier O_NONBLOCK sur les deux  nouveaux  descripteurs
              de  fichiers  ouverts. Utiliser cet attribut économise des appels supplémentaires à
              fcntl(2) pour obtenir le même résultat.

VALEUR RENVOYÉE

       S'il réussit, cet appel système renvoie 0. S'il échoue, il renvoie -1 et remplit errno  en
       conséquence.

ERREURS

       EFAULT pipefd est invalide.

       EINVAL (pipe2()) Valeur incorrecte dans flags.

       EMFILE Trop de descripteurs de fichier sont utilisés par le processus.

       ENFILE La limite du nombre total de fichiers ouverts sur le système a été atteinte.

VERSIONS

       pipe2()  a été ajouté à Linux dans la version 2.6.27 ; sa prise en charge par la glibc est
       disponible depuis la version 2.9.

CONFORMITÉ

       pipe() : POSIX.1-2001.

       pipe2() est spécifique à Linux.

EXEMPLE

       Le programme suivant crée un tube, puis invoque fork(2) pour créer un processus fils ;  le
       fils  hérite  d'un jeu de descripteurs de fichier qui se rapportent au même tube. Après le
       fork(2), chaque processus ferme les descripteurs dont il  n'a  pas  besoin  pour  le  tube
       (consultez  pipe(7)).  Le  père écrit alors la chaîne contenue dans l'argument de ligne de
       commande du programme dans le tube, et le fils lit cette chaîne un octet à la fois dans le
       tube, et l'affiche sur la sortie standard.

   Source du programme
       #include <sys/types.h>
       #include <sys/wait.h>
       #include <stdio.h>
       #include <stdlib.h>
       #include <unistd.h>
       #include <string.h>

       int
       main(int argc, char *argv[])
       {
           int pipefd[2];
           pid_t cpid;
           char buf;

           if (argc != 2) {
               fprintf(stderr, "Utilisation : %s <chaîne>\n", argv[0]);
               exit(EXIT_FAILURE);
           }

           if (pipe(pipefd) == -1) {
               perror("pipe");
               exit(EXIT_FAILURE);
           }

           cpid = fork();
           if (cpid == -1) {
               perror("fork");
               exit(EXIT_FAILURE);
           }

           if (cpid == 0) {    /* Le fils lit dans le tube */
               close(pipefd[1]);          /* Fermeture du descripteur en écriture inutilisé */

               while (read(pipefd[0], &buf, 1) > 0)
                   write(STDOUT_FILENO, &buf, 1);

               write(STDOUT_FILENO, "\n", 1);
               close(pipefd[0]);
               _exit(EXIT_SUCCESS);

           } else {            /* Le père écrit argv[1] dans le tube */
               close(pipefd[0]);          /* Fermeture du descripteur en lecture inutilisé*/
               write(pipefd[1], argv[1], strlen(argv[1]));
               close(pipefd[1]);          /* Le lecteur verra EOF */
               wait(NULL);                /* Attente du fils */
               exit(EXIT_SUCCESS);
           }
       }

VOIR AUSSI

       fork(2), read(2), socketpair(2), write(2), popen(3), pipe(7)

COLOPHON

       Cette  page  fait partie de la publication 3.65 du projet man-pages Linux. Une description
       du projet et des  instructions  pour  signaler  des  anomalies  peuvent  être  trouvées  à
       l'adresse http://www.kernel.org/doc/man-pages/.

TRADUCTION

       Depuis    2010,    cette   traduction   est   maintenue   à   l'aide   de   l'outil   po4a
       <http://po4a.alioth.debian.org/> par l'équipe de traduction francophone au sein du  projet
       perkamon <http://perkamon.alioth.debian.org/>.

       Christophe    Blaess    <http://www.blaess.fr/christophe/>   (1996-2003),   Alain   Portal
       <http://manpagesfr.free.fr/>  (2003-2006).  Julien  Cristau  et  l'équipe  francophone  de
       traduction de Debian (2006-2009).

       Veuillez     signaler     toute     erreur     de     traduction     en     écrivant     à
       <debian-l10n-french@lists.debian.org>  ou  par  un  rapport  de  bogue   sur   le   paquet
       manpages-fr.

       Vous  pouvez  toujours  avoir  accès  à la version anglaise de ce document en utilisant la
       commande « man -L C <section> <page_de_man> ».