getline(3) Library Functions Manual getline(3) NOM getline, getdelim - Saisie de chaine delimitee BIBLIOTHEQUE Bibliotheque C standard (libc, -lc) SYNOPSIS #include ssize_t getline(char **restrict lineptr, size_t *restrict n, FILE *restrict flux); ssize_t getdelim(char **restrict lineptr, size_t *restrict n, int delim, FILE *restrict flux); Exigences de macros de test de fonctionnalites pour la glibc (consulter feature_test_macros(7)) : getline(), getdelim() : Depuis la glibc 2.10 : _POSIX_C_SOURCE >= 200809L Avant la glibc 2.10 : _GNU_SOURCE DESCRIPTION getline() lit une ligne entiere dans flux et stocke l'adresse du tampon contenant le texte dans *lineptr. Le tampon se termine par un octet NULL et inclut le caractere saut de ligne, si un tel separateur a ete trouve. Si *lineptr est positionne a NULL avant l'appel, la routine getline() allouera un tampon pour stocker la ligne. Ce tampon devra etre libere par le programme utilisateur meme si getline() echoue. Alternativement, avant d'appeler getline(), *lineptr peut contenir un pointeur vers un tampon de *n octets alloue par malloc(3). Si le tampon n'est pas suffisant pour stocker la ligne saisie, getline() le redimensionnera avec realloc(3), mettant a jour *lineptr et *n comme il se doit. Quoi qu'il en soit, en cas de succes, *lineptr et *n seront mis a jour afin de rendre compte respectivement de l'adresse et de la taille du tampon. getdelim() fonctionne comme getline(), si ce n'est qu'un separateur different du saut de ligne peut etre specifie en tant qu'argument delimiter. Tout comme avec getline(), aucun separateur n'est ajoute s'il n'y en avait pas dans l'entree avant que la fin du fichier ne soit atteinte. VALEUR RENVOYEE En cas de succes, getline() et getdelim() renvoient le nombre de caracteres lus, separateur inclus, mais sans compter l'octet NULL final ('\0'). Cette valeur peut etre utilisee afin de traiter les octets NULL inseres dans la ligne lue. Les deux fonctions renvoient -1 en cas d'echec de lecture de la ligne (condition de fin de fichier incluse). En cas d'erreur, errno est defini pour indiquer l'erreur. Si *lineptr a ete positionne a NULL avant l'appel, le tampon doit etre libere par le programme utilisateur meme en cas d'echec. ERREURS EINVAL Parametres errones (n ou lineptr valent NULL, ou bien flux n'est pas valable). ENOMEM Echec de l'allocation ou de la reallocation du tampon de ligne. ATTRIBUTS Pour une explication des termes utilises dans cette section, consulter attributes(7). +---------------------------------+--------------------------+---------+ |Interface | Attribut | Valeur | +---------------------------------+--------------------------+---------+ |getline(), getdelim() | Securite des threads | MT-Safe | +---------------------------------+--------------------------+---------+ STANDARDS POSIX.1-2008. HISTORIQUE GNU, POSIX.1-2008. EXEMPLES #define _GNU_SOURCE #include #include int main(int argc, char *argv[]) { FILE *stream; char *line = NULL; size_t len = 0; ssize_t nread; if (argc != 2) { fprintf(stderr, "Utilisation : %s \n", argv[0]); exit(EXIT_FAILURE); } stream = fopen(argv[1], "r"); if (stream == NULL) { perror("fopen"); exit(EXIT_FAILURE); } while ((nread = getline(&line, &len, stream)) != -1) { printf("Reception d'une ligne de longueur %zd:\n", nread); fwrite(line, nread, 1, stdout); } free(line); fclose(stream); exit(EXIT_SUCCESS); } VOIR AUSSI read(2), fgets(3), fopen(3), fread(3), scanf(3) TRADUCTION La traduction francaise de cette page de manuel a ete creee par Christophe Blaess , Stephan Rafin , Thierry Vignaud , Francois Micaux, Alain Portal , Jean-Philippe Guerard , Jean-Luc Coulon (f5ibh) , Julien Cristau , Thomas Huriaux , Nicolas Francois , Florentin Duneau , Simon Paillard , Denis Barbier , David Prevot , Frederic Hantrais et Gregoire Scano Cette traduction est une documentation libre ; veuillez vous reporter a la GNU General Public License version 3 concernant les conditions de copie et de distribution. Il n'y a aucune RESPONSABILITE LEGALE. Si vous decouvrez un bogue dans la traduction de cette page de manuel, veuillez envoyer un message a . Pages du manuel de Linux 6.06 31 octobre 2023 getline(3)