Provided by: manpages-fr-dev_4.21.0-2_all bug

NOM

       getopt,  getopt_long, getopt_long_only, optarg, optind, opterr, optopt — Analyser les options de la ligne
       de commande

BIBLIOTHÈQUE

       Bibliothèque C standard (libc, -lc)

SYNOPSIS

       #include <unistd.h>

       int getopt(int argc, char *const argv[],
                  const char *chaine_options);

       extern char *optarg;
       extern int optind, opterr, optopt;

       #include <getopt.h>

       int getopt_long(int argc, char *const argv[],
                  const char *chaine_options,
                  const struct option *longopts, int *longindex);
       int getopt_long_only(int argc, char *const argv[],
                  const char *chaine_options,
                  const struct option *longopts, int *longindex);

   Exigences de macros de test de fonctionnalités pour la glibc (consulter feature_test_macros(7)) :

       getopt() :
           _POSIX_C_SOURCE >= 2 || _XOPEN_SOURCE

       getopt_long(), getopt_long_only() :
           _GNU_SOURCE

DESCRIPTION

       La fonction getopt() analyse les  arguments  de  la  ligne  de  commande.  Ses  arguments  argc  et  argv
       correspondent au nombre et à la table d'éléments qui sont transmis à la fonction main() lors du lancement
       du programme. Un élément de argv qui commence par « - » (et qui n'est pas uniquement « -- » ou « - ») est
       considéré  comme  une  option.  Les caractères à la suite du ou des « - » initiaux sont les caractères de
       l'option. Si getopt() est appelée à plusieurs reprises, elle renverra successivement chaque caractère  de
       chaque option.

       La  variable  optind  est  l'index de l'élément suivant à analyser dans argv. Le système initialise cette
       valeur à 1. L'appelant peut la remettre à 1 pour recommencer l'analyse du même tableau de paramètres argv
       ou pour en analyser un nouveau.

       Si getopt() trouve un autre caractère d'option, elle renvoie ce caractère en mettant à jour  la  variable
       externe  optind  et  la  variable  statique nextchar, de façon à ce que l'appel suivant à getopt() puisse
       continuer l'analyse avec le caractère d'option suivant ou l'élément suivant de argv.

       S'il n'y a plus de caractères d'option, getopt() renvoie -1. Alors, optind  devient  l'index  du  premier
       élément de argv qui n'est pas une option.

       chaine_options  est  une  chaîne  contenant  l'ensemble  des  caractères d'option autorisés. Un caractère
       d'option autorisé est un caractère ascii(7) imprimable sur 1 octet (pour lequel isgraph(3) renverrait une
       valeur différente de zéro) autre que « - », « : » ou « ; ». Si un de ces  caractères  est  suivi  par  un
       deux-points (« : »), l'option nécessite un argument, donc getopt() placera dans optarg un pointeur sur le
       texte  suivant  dans  le  même  élément  de  argv ou sur le texte de l'élément de argv suivant. Un double
       deux-points (« :: ») signifie qu'une option prend un argument facultatif. S'il existe un  texte  dans  le
       même élément de argv (c'est-à-dire dans le même mot que le nom de l'option elle-même comme « -oarg »), il
       est renvoyé dans optarg, sinon optarg est défini à zéro. Il s'agit d'une extension GNU. Si chaine_options
       contient  W  suivi  d'un  point-virgule,  -W  foo est traité comme l'option longue --foo (l'option -W est
       réservée par POSIX.2 pour des extensions spécifiques à l'implémentation). Ce comportement,  spécifique  à
       la version GNU, est pris en charge à partir de la version 2 de la bibliothèque glibc.

       Par  défaut, getopt() permute les éléments de argv au fur et à mesure de son analyse, de façon à ce qu'en
       fin de compte, les arguments ne constituant pas des options se trouvent  à  la  fin.  Deux  autres  modes
       d'analyse  sont  également  implémentés :  si  le premier caractère de chaine_options vaut « + » ou si la
       variable  d'environnement  POSIXLY_CORRECT  est  définie,  l'analyse  s'arrête  dès  qu'un  argument   ne
       constituant  pas une option est rencontré. Si le premier caractère de chaine_options est autre que « + »,
       il est traité comme une option normale. Si le comportement induit par la  définition  de  POSIXLY_CORRECT
       est requis, chaine_options contiendra deux symboles « + ». Si le premier caractère de chaine_options vaut
       « - »,  les  arguments ne correspondant pas à une option sont manipulés comme s'ils étaient des arguments
       d'une option avec le code de caractère 1 (cela est utilisé par les programmes conçus  pour  recevoir  des
       options et d'autres éléments de argv dans n'importe quel ordre mais qui prennent en compte l'ordre de ces
       deux  types  d'élément).  L'argument  spécial  « -- » arrête l'analyse des options, quel que soit le mode
       d'analyse en cours.

       getopt() peut détecter deux types d'erreur lors du traitement de la liste  d'options :  (1) un  caractère
       d'option  non  spécifié dans chaine_options et (2) un argument d'option manquant (c'est-à-dire une option
       sans son argument attendu à la fin de la ligne de commande). Les erreurs de  ce  type  sont  traitées  et
       signalées comme suit :

       -  Par  défaut,  getopt() affiche un message d'erreur sur la sortie d'erreur standard, place le caractère
          d'option erroné dans optopt et renvoie « ? » comme résultat.

       -  Si l'appelant a défini la variable globale opterr à zéro, getopt() n'affiche pas de message  d'erreur.
          L'appelant  peut  détecter  la  présence d'une erreur en vérifiant si la fonction a renvoyé « ? » (par
          défaut, opterr possède une valeur différente de zéro).

       -  Si le premier caractère de chaine_options (suivant  un  des  caractères  facultatifs  « + »  ou  « - »
          décrits  ci-dessus)  est  un « : », là non plus, getopt() n'affiche pas de message d'erreur. En outre,
          elle renvoie « : » au lieu de « ? » pour indiquer un argument  d'option  manquant,  ce  qui  permet  à
          l'appelant de distinguer les deux types d'erreur.

   getopt_long() et getopt_long_only()
       La  fonction  getopt_long()  fonctionne  comme  getopt()  sauf  qu'elle  accepte également des noms longs
       d'option,  commençant  par  deux  tirets  (si  le  programme  accepte  seulement  les  options   longues,
       chaine_options  doit être indiquée avec une chaîne vide « "" » et non avec NULL). Les noms longs d'option
       peuvent être abrégés si l'abréviation est unique ou si elle correspond exactement à une  option  définie.
       Une option longue peut prendre un argument, de la forme --arg=param ou --arg param.

       longopts  est  un pointeur sur le premier élément d'un tableau de structures struct option déclarées dans
       <getopt.h> ainsi :

           struct option {
               const char *name;
               int         has_arg;
               int        *flag;
               int         val;
           };

       La signification des différents champs est la suivante :

       nom    est le nom de l'option longue.

       has_arg
              vaut : aucun_argument (ou 0), si l'option ne  prend  pas  d'argument,  argument_requis  (ou 1)  si
              l'option prend un argument, ou argument_facultatif (ou 2) si l'option prend un argument optionnel.

       flag   indique  la  manière  de  renvoyer  les  résultats  pour  une  option  longue.  Si flag vaut NULL,
              getopt_long() renvoie val (par exemple, le programme appelant peut remplir val avec  le  caractère
              de  l'option  courte  correspondante).  Sinon,  getopt_long()  renvoie 0,  et  flag pointe sur une
              variable définie à val si l'option est trouvée, mais reste inchangé si l'option est absente.

       val    est la valeur à renvoyer ou à affecter à la variable pointée par flag.

       Le dernier élément de la table doit être rempli avec des zéros.

       Si longindex est différent de NULL, il pointe sur une variable qui est définie avec l'index  de  l'option
       longue correspondant à longopts.

       getopt_long_only()  fonctionne comme getopt_long(), mais « - » tout comme « -- » peut indiquer une option
       longue. Si une option commençant par « - » (et non « -- ») ne correspond pas à une  option  longue,  mais
       correspond à une option courte, elle est analysée en tant qu'option courte.

VALEUR RENVOYÉE

       Si une option a été trouvée, getopt() renvoie le caractère de l'option. Si toutes les options de la ligne
       de  commande ont été lues, getopt() renvoie -1. Si getopt() rencontre un caractère d'option qui n'est pas
       dans chaine_options, « ? » est renvoyé. Si getopt() rencontre une option avec un  argument  manquant,  la
       valeur renvoyée dépend du premier caractère de chaine_options : si c'est « : », ce caractère est renvoyé,
       sinon « ? » est renvoyé.

       getopt_long() et getopt_long_only() renvoient également le caractère d'option courte si elles en trouvent
       une.  Pour  les options longues, elles renvoient val si flag vaut NULL, et 0 sinon. Les erreurs et la fin
       des options sont gérées comme avec getopt(), en renvoyant  de  surcroît  « ? »  pour  une  correspondance
       ambiguë ou un paramètre en trop.

ENVIRONNEMENT

       POSIXLY_CORRECT
              Si cette variable est définie, l'analyse s'arrête dès qu'un argument ne constituant pas une option
              est rencontré.

       _<PID>_GNU_nonoption_argv_flags_
              Cette variable est utilisée par bash(1) 2.0 pour communiquer à la glibc les arguments résultant de
              l'expansion  des caractères génériques et ne devant donc pas être considérés comme des options. Ce
              comportement a été supprimé de bash(1) 2.01, mais il est toujours pris en charge par la glibc.

ATTRIBUTS

       Pour une explication des termes utilisés dans cette section, consulter attributes(7).
       ┌──────────────────────────┬──────────────────────┬─────────────────────────────────────────────────────┐
       │ InterfaceAttributValeur                                              │
       ├──────────────────────────┼──────────────────────┼─────────────────────────────────────────────────────┤
       │ getopt(), getopt_long(), │ Sécurité des threads │ MT-Unsafe race:getopt env                           │
       │ getopt_long_only()       │                      │                                                     │
       └──────────────────────────┴──────────────────────┴─────────────────────────────────────────────────────┘

STANDARDS

       getopt() :
              POSIX.1-2001, POSIX.1-2008 et POSIX.2, à condition que la variable d'environnement POSIXLY_CORRECT
              soit définie. Sinon, les éléments de argv ne sont pas vraiment  qualifiés  de  const  puisque  ces
              fonctions  les permutent. On les déclare tout de même « const » dans le prototype pour être compa‐
              tible avec les autres systèmes.

              L'utilisation de « + » et « - » dans chaine_options est une extension GNU.

              Sur certaines anciennes implémentations, getopt() était déclarée dans <stdio.h>. SUSv1  permettait
              que la déclaration apparaisse soit dans <unistd.h>, soit dans <stdio.h>. POSIX.1-1996 considère la
              déclaration  dans <stdio.h> comme « LEGACY » (obsolète), et POSIX.1-2001 n'exige pas que la décla‐
              ration soit dans <stdio.h>.

       getopt_long() et getopt_long_only() :
              Ces fonctions sont des extensions GNU.

NOTES

       Un programme qui analyse plusieurs tableaux de paramètres ou analyse plusieurs fois le  même  tableau  et
       qui  veut utiliser les extensions GNU telles que « + » et « - » au début de chaine_options, ou changer la
       valeur de POSIXLY_CORRECT entre les analyses, doit réinitialiser getopt() en remettant optind à 0, plutôt
       qu'à la valeur traditionnelle de 1. La remise à 0 force l'appel d'une  routine  d'initialisation  interne
       qui revérifie la définition de POSIXLY_CORRECT et recherche les extensions GNU dans chaine_options.

       Les  arguments  de la ligne de commande sont analysés selon leur ordre strict, ce qui signifie qu'une op‐
       tion nécessitant un argument va consommer l'argument suivant, qu'il s'agisse de son argument correctement
       spécifié ou de l'option suivante (auquel cas l'utilisateur aura mal rédigé la  ligne  de  commande).  Par
       exemple,  si chaine_options contient « 1n: » et si l'utilisateur fournit une ligne de commande incorrecte
       en spécifiant prog -n -1, l'option -n se verra affecter la valeur de optarg « -1 », et l'option  -1  sera
       considérée comme non spécifiée.

EXEMPLES

   getopt()
       Le programme d'exemple trivial suivant utilise getopt() avec deux options : -n sans valeur associée et -t
       val qui nécessite une valeur.

       #include <stdio.h>
       #include <stdlib.h>
       #include <unistd.h>

       int
       main(int argc, char *argv[])
       {
           int flags, opt;
           int nsecs, tfnd;

           nsecs = 0;
           tfnd = 0;
           flags = 0;
           while ((opt = getopt(argc, argv, "nt:")) != -1) {
               switch (opt) {
               case 'n':
                   flags = 1;
                   break;
               case 't':
                   nsecs = atoi(optarg);
                   tfnd = 1;
                   break;
               default: /* '?' */
                   fprintf(stderr, "Usage: %s [-t nsecs] [-n] name\n",
                           argv[0]);
                   exit(EXIT_FAILURE);
               }
           }

           printf("flags=%d; tfnd=%d; nsecs=%d; optind=%d\n",
                  flags, tfnd, nsecs, optind);

           if (optind >= argc) {
               fprintf(stderr, "Argument attendu après les options\n");
               exit(EXIT_FAILURE);
           }

           printf("argument nom = %s\n", argv[optind]);

           /* Autre code omis */

           exit(EXIT_SUCCESS);
       }

   getopt_long()
       Le  programme suivant montre l'utilisation de getopt_long() en illustrant la plupart de ses fonctionnali‐
       tés.

       #include <getopt.h>
       #include <stdio.h>     /* pour printf */
       #include <stdlib.h>    /* pour exit */

       int
       main(int argc, char *argv[])
       {
           int c;
           int digit_optind = 0;

           while (1) {
               int this_option_optind = optind ? optind : 1;
               int option_index = 0;
               static struct option long_options[] = {
                   {"add",     argument_requis, 0,  0 },
                   {"append",  aucun_argument,       0,  0 },
                   {"delete",  argument_requis, 0,  0 },
                   {"verbose", aucun_argument,       0,  0 },
                   {"create",  argument_requis, 0, 'c'},
                   {"file",    argument_requis, 0,  0 },
                   {0,         0,                 0,  0 }
               };

               c = getopt_long(argc, argv, "abc:d:012",
                               long_options, &option_index);
               if (c == -1)
                   break;

               switch (c) {
               case 0:
                   printf("option %s", long_options[option_index].name);
                   if (optarg)
                       printf(" avec l'argument %s", optarg);
                   printf("\n");
                   break;

               case '0':
               case '1':
               case '2':
                   if (digit_optind != 0 && digit_optind != this_option_optind)
                     printf("les chiffres apparaissent dans deux éléments de argv.\n");
                   digit_optind = this_option_optind;
                   printf("option %c\n", c);
                   break;

               case 'a':
                   printf("option a\n");
                   break;

               case 'b':
                   printf("option b\n");
                   break;

               case 'c':
                   printf("option c avec la valeur '%s'\n", optarg);
                   break;

               case 'd':
                   printf("option d avec la valeur '%s'\n", optarg);
                   break;

               case '?':
                   break;

               default:
                   printf("?? getopt a renvoyé le caractère de code 0%o ??\n", c);
               }
           }

           if (optind < argc) {
               printf("éléments de ARGV autres que des options : ");
               while (optind < argc)
                   printf("%s ", argv[optind++]);
               printf("\n");
           }

           exit(EXIT_SUCCESS);
       }

VOIR AUSSI

       getopt(1), getsubopt(3)

TRADUCTION

       La  traduction  française   de   cette   page   de   manuel   a   été   créée   par   Christophe   Blaess
       <https://www.blaess.fr/christophe/>,  Stéphan  Rafin  <stephan.rafin@laposte.net>,  Thierry Vignaud <tvi‐
       gnaud@mandriva.com>, François Micaux, Alain Portal <aportal@univ-montp2.fr>, Jean-Philippe  Guérard  <fe‐
       vrier@tigreraye.org>,  Jean-Luc Coulon (f5ibh) <jean-luc.coulon@wanadoo.fr>, Julien Cristau <jcristau@de‐
       bian.org>,  Thomas  Huriaux  <thomas.huriaux@gmail.com>,   Nicolas   François   <nicolas.francois@centra‐
       liens.net>, Florentin Duneau <fduneau@gmail.com>, Simon Paillard <simon.paillard@resel.enst-bretagne.fr>,
       Denis Barbier <barbier@debian.org>, David Prévot <david@tilapin.org> et Lucien Gentis <lucien.gentis@wai‐
       ka9.com>

       Cette  traduction  est  une  documentation libre ; veuillez vous reporter à la GNU General Public License
       version 3 concernant les conditions de copie et de distribution. Il n'y a aucune RESPONSABILITÉ LÉGALE.

       Si vous découvrez un bogue dans la traduction de cette page de manuel, veuillez envoyer un message à  de‐
       bian-l10n-french@lists.debian.org.

Pages du manuel de Linux 6.03                    5 février 2023                                        getopt(3)