NOM
stdarg, va_start, va_arg, va_end, va_copy - Liste variable d’arguments
SYNOPSIS
#include <stdarg.h>
void
va_start(va_list ap, last);
type va_arg(va_list ap,
type);
void va_end(va_list ap);
void va_copy(va_list dest, va_list
src);
DESCRIPTION
Une fonction peut être appelée avec un nombre variable d’arguments, eux-mêmes de types variables. Une telle fonction est dite « variadique ». Le fichier d’en-tête <stdarg.h> déclare un type va_list et définit trois macros permettant de parcourir la liste d’arguments dont le nombre et les types ne sont pas connus par la fonction appelée.
La fonction appelée doit déclarer un objet de type va_list utilisé par les macros va_start(), va_arg() et va_end().
va_start()
La macro va_start() initialise ap pour les
utilisations ultérieures de va_arg() et
va_end(), et doit donc être appelée en
premier.
Le paramètre last est le nom du dernier paramètre avant la liste variable de paramètres, c’est-à-dire le dernier paramètre dont la fonction connaisse le type.
Comme l’adresse de ce paramètre est utilisée dans la macro va_start(), il ne doit pas être déclaré comme une variable en registre, ni comme un type fonction ou tableau.
va_arg()
La macro va_arg() se développe en une
expression qui a le type et la valeur de l’argument
suivant de l’appel. Le paramètre ap est
la va_list ap initialisée par
va_start(). Chaque appel de va_arg() modifie
ap pour que l’appel suivant renvoie le
paramètre suivant. Le paramètre type
est le nom du type, indiqué de telle manière
qu’un pointeur sur un objet de ce type puisse
être déclaré simplement en ajoutant un
astérisque à type.
La première utilisation de la macro va_arg() après celle de va_start() renvoie l’argument suivant last. Les invocations successives renvoient les valeurs des arguments restants.
S’il n’y a pas d’argument suivant, ou si type n’est pas compatible avec le type réel du prochain argument, des erreurs imprévisibles se produiront.
Si ap est passé à une fonction qui utilise va_arg(ap,type) alors la valeur de ap est indéfinie après le retour de cette fonction.
va_end()
À chaque invocation de va_start() doit
correspondre une invocation de va_end() dans la
même fonction. Après l’appel
va_end(ap) la variable ap est
indéfinie. Plusieurs traversées de la liste
sont possibles, à condition que chacune soit
encadrée par va_start() et va_end().
va_end() peut être une macro ou une
fonction.
va_copy()
La macro va_copy() copie la liste d’arguments
variables (précédemment initialisés)
src vers dest. Le comportement serait
similaire si va_start() était appliqué
à dest avec le même argument
last, suivi du même nombre d’invocations
de va_arg() qui ont été
utilisées pour atteindre l’état actuel
de src.
Une implémentation évidente est de représenter va_list par un pointeur dans la pile de la fonction variadique. Dans une telle situation (de loin la plus courante), rien ne semble s’opposer à une affectation
va_list aq = ap;
Malheureusement, il y a aussi des systèmes qui créent une table de pointeurs (de longueur 1), et on devrait écrire
va_list aq; *aq = *ap;
De plus, sur les systèmes où les paramètres sont passés dans des registres, il peut être nécessaire pour va_start() d’allouer de la mémoire, d’y enregistrer les paramètres ainsi que l’indication du paramètre suivant, afin que va_arg() puisse balayer la liste. Ainsi va_end() pourra libérer la mémoire allouée. Pour gérer ces situations, C99 ajoute une macro va_copy(), afin que les affectations ci-dessus soient remplacées par
va_list aq; va_copy(aq, ap); ... va_end(aq);
À chaque invocation de va_copy() doit correspondre une invocation de va_end() dans la même fonction. Certains systèmes qui ne disposent pas de va_copy() ont une macro __va_copy() à la place, puisque c’était le nom proposé auparavant.
ATTRIBUTS
Pour une explication des termes utilisés dans cette section, consulter attributes(7).
CONFORMITÉ
Les macros va_start(), va_arg() et va_end() sont conformes à C89. C99 définit la macro va_copy().
BOGUES
Unlike the historical varargs macros, the stdarg macros do not permit programmers to code a function with no fixed arguments. This problem generates work mainly when converting varargs code to stdarg code, but it also creates difficulties for variadic functions that wish to pass all of their arguments on to a function that takes a va_list argument, such as vfprintf(3).
EXEMPLES
La fonction foo() prend une chaîne de caractères de mise en forme, et affiche les arguments associés avec chaque format correspondant au type indiqué.
#include <stdio.h> #include <stdarg.h> void foo(char *fmt, ...) /* ’...’ is C syntax for a variadic function */ { va_list ap; int d; char c, *s; va_start(ap, fmt); while (*fmt) switch (*fmt ++) { case 's': /* chaîne */ s = va_arg (ap, char *); printf("chaîne %s\n", s); break; case 'd': /* entier */ d = va_arg (ap, int); printf("int %d\n", d); break; case 'c': /* caractère */ c = va_arg (ap, char); printf("char %c\n", c); break; } va_end(ap); }
VOIR AUSSI
vprintf(3), vscanf(3), vsyslog(3)
COLOPHON
Cette page fait partie de la publication 5.07 du projet man-pages Linux. Une description du projet et des instructions pour signaler des anomalies et la dernière version de cette page, peuvent être trouvées à l’adresse https://www.kernel.org/doc/man-pages/.
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 [AT] laposte.net>, Thierry Vignaud <tvignaud [AT] mandriva.com>, François Micaux, Alain Portal <aportal [AT] univ-montp2.fr>, Jean-Philippe Guérard <fevrier [AT] tigreraye.org>, Jean-Luc Coulon (f5ibh) <jean-luc.coulon [AT] wanadoo.fr>, Julien Cristau <jcristau [AT] debian.org>, Thomas Huriaux <thomas.huriaux [AT] gmail.com>, Nicolas François <nicolas.francois [AT] centraliens.net>, Florentin Duneau <fduneau [AT] gmail.com>, Simon Paillard <simon.paillard [AT] resel.fr>, Denis Barbier <barbier [AT] debian.org>, David Prévot <david [AT] tilapin.org>, Cédric Boutillier <cedric.boutillier [AT] gmail.com> et Frédéric Hantrais <fhantrais [AT] gmail.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 à <debian-l10n-french [AT] lists.org>.