Man page - va_copy(3)

Packages contains this manual

Available languages:

en fr pl ja ru ro de

Manual

stdarg

NOM
BIBLIOTHÈQUE
SYNOPSIS
DESCRIPTION
va_start()
va_arg()
va_end()
va_copy()
ATTRIBUTS
STANDARDS
HISTORIQUE
AVERTISSEMENTS
EXEMPLES
VOIR AUSSI
TRADUCTION

NOM

stdarg, va_start, va_arg, va_end, va_copy - Liste variable d’arguments

BIBLIOTHÈQUE

BibliothĂšque C standard ( libc , -lc )

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 dernier 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 dernier . 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 du prochain argument effectif, 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 dernier , suivi du mĂȘme nombre d’invocations de va_arg () qui seraient 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).

Image grohtml-3872974-1.png

STANDARDS

C11, POSIX.1-2008.

HISTORIQUE

va_start ()
va_arg
()
va_end
()

C89, POSIX.1-2001.

va_copy ()

C99, POSIX.1-2001.

AVERTISSEMENTS

Contrairement aux macros varargs () historiques, les macros stdarg () ne permettent pas aux programmeurs de coder une fonction sans aucun argument fixe. Ce problÚme se pose principalement en convertissant directement du code utilisant varargs () en code utilisant stdarg (), mais il se pose également pour les fonctions qui désirent passer tous leurs arguments à une fonction utilisant un argument va_list telle que 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, ...) /* '...' est la syntaxe C des fonctions variadiques */
{
va_list ap;
int d;
char c;
char *s;
va_start(ap, fmt);
while (*fmt)
switch (*fmt++) {
case 's': /* chaĂźne */
s = va_arg(ap, char *);
printf("string %s\n", s);
break;
case 'd': /* entier */
d = va_arg(ap, int);
printf("int %d\n", d);
break;
case 'c': /* caractĂšre */
/* il faut une conversion de type ici
puisque va_arg ne prend que des
types entiĂšrement promus */
c = (char) va_arg(ap, int);
printf("char %c\n", c);
break;
}
va_end(ap);
}

VOIR AUSSI

vprintf (3), vscanf (3), vsyslog (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 <tvignaud@mandriva.com>, François Micaux, Alain Portal <aportal@univ-montp2.fr>, Jean-Philippe Guérard <fevrier@tigreraye.org>, Jean-Luc Coulon (f5ibh) <jean-luc.coulon@wanadoo.fr>, Julien Cristau <jcristau@debian.org>, Thomas Huriaux <thomas.huriaux@gmail.com>, Nicolas François <nicolas.francois@centraliens.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>, Cédric Boutillier <cedric.boutillier@gmail.com>, Frédéric Hantrais <fhantrais@gmail.com> et Grégoire Scano <gregoire.scano@malloc.fr>

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@lists.debian.org .