Man page - readdir(3)

Packages contains this manual

Available languages:

en fr ja ru ro de

Manual

readdir

NOM
BIBLIOTHÈQUE
SYNOPSIS
DESCRIPTION
VALEUR RENVOYÉE
ERREURS
ATTRIBUTS
VERSIONS
Le champ d_name
STANDARDS
HISTORIQUE
NOTES
VOIR AUSSI
TRADUCTION

NOM

readdir - Consulter un répertoire

BIBLIOTHÈQUE

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

SYNOPSIS

#include <dirent.h>

struct dirent *readdir(DIR * dirp );

DESCRIPTION

La fonction readdir () renvoie un pointeur sur une structure dirent reprĂ©sentant l’entrĂ©e suivante du flux rĂ©pertoire pointĂ© par dirp . Elle renvoie NULL Ă  la fin du rĂ©pertoire ou en cas d’erreur.

Dans l’implĂ©mentation de la glibc, la structure dirent est dĂ©finie comme suit :

struct dirent {
ino_t d_ino; /* numĂ©ro d’inƓud */
off_t d_off; /* pas une position ; consultez NOTES */
unsigned short d_reclen; /* longueur de cet enregistrement */
unsigned char d_type; /* type du fichier ; pas pris en
charge par tous les types de
systĂšme de fichiers */
char d_name[256]; /* nom du fichier terminĂ© par l’octet NULL */
};

Les seuls champs exigés par POSIX.1 pour la structure dirent sont d_name et d_ino . Les autres champs ne sont pas normalisés et ne sont pas présents sur tous les systÚmes ; consultez les VERSIONS ci-dessous pour plus de détails.

Les champs de la structure dirent sont les suivants :

d_ino

Le numĂ©ro d’inƓud du fichier.

d_off

La valeur renvoyée dans d_off est celle qui serait renvoyée en appelant telldir (3) à la position actuelle dans le flux répertoire. Soyez conscient que, malgré son type et son nom, le champ d_off ne représente que rarement une sorte de position de répertoire sur les systÚmes de fichiers modernes. Les applications devraient traiter ce champ comme une valeur opaque, sans faire de supposition sur son contenu. Consultez aussi telldir (3).

d_reclen

La taille (en octets) de l’enregistrement renvoyĂ©. Elle peut ne pas correspondre Ă  la taille de la dĂ©finition de la structure montrĂ©e plus haut ; voir VERSIONS.

d_type

Ce champ contient une valeur indiquant le type du fichier, permettant d’éviter le coĂ»t d’un appel Ă  lstat (2) si d’autres actions dĂ©pendent du type du fichier.

Lorsqu’une macro de test de fonctionnalitĂ© est dĂ©finie ( _DEFAULT_SOURCE depuis la glibc 2.19, ou _BSD_SOURCE pour la glibc 2.19 ou antĂ©rieure), la glibc dĂ©finit les constantes de macro suivantes pour les valeurs renvoyĂ©es dans d_type :

DT_BLK

Il s’agit d’un pĂ©riphĂ©rique bloc.

DT_CHR

Il s’agit d’un pĂ©riphĂ©rique caractĂšre.

DT_DIR

Il s’agit d’un rĂ©pertoire

DT_FIFO

Il s’agit d’un tube nommĂ© (FIFO).

DT_LNK

Il s’agit d’un lien symbolique.

DT_REG

Il s’agit d’un fichier ordinaire.

DT_SOCK

Il s’agit d’un socket de domaine UNIX.

DT_UNKNOWN

Le type du fichier n’a pu ĂȘtre dĂ©terminĂ©.

Actuellement, seuls certains systÚmes de fichiers (parmi lesquels Btrfs, ext2, ext3 et ext4) prennent complÚtement en charge le renvoi du type de fichier dans d_type . Toutes les applications doivent gérer correctement une valeur de retour valant DT_UNKNOWN .

d_name

Ce champ contient le nom de fichier terminĂ© par l’octet NULL. Voir VERSIONS .

Les donnes renvoyĂ©es par readdir () sont Ă©crasĂ©es lors de l’appel suivant Ă  readdir () sur le mĂȘme flux rĂ©pertoire.

VALEUR RENVOYÉE

En cas de succĂšs, readdir () renvoie un pointeur sur une structure dirent (cette structure peut avoir Ă©tĂ© allouĂ©e statiquement ; n’essayez pas de la dĂ©sallouer avec free (3)).

Lorsque la fin du flux rĂ©pertoire est atteinte, NULL est renvoyĂ© et errno n’est pas modifiĂ©e. En cas d’erreur, NULL est renvoyĂ© et errno contient le code d’erreur. Pour distinguer la fin du flux d’une erreur, il faut assigner errno Ă  zĂ©ro avant d’appeler readdir() puis ensuite tester la valeur de errno si NULL est renvoyĂ©.

ERREURS

EBADF

Le descripteur de flux rĂ©pertoire dirp n’est pas valable.

ATTRIBUTS

Pour une explication des termes utilisés dans cette section, consulter attributes (7).

Image grohtml-3895368-1.png

Dans la spĂ©cification POSIX.1 actuelle (POSIX.1-2008), il n’est pas requis que readdir (3) soit sĂ»r vis-Ă -vis des threads. Cependant, dans les implĂ©mentations modernes, incluant la glibc, des appels concurrents Ă  readdir (3) pour des flux rĂ©pertoire diffĂ©rents sont sĂ»rs vis-Ă -vis des threads. Dans le cas oĂč de multiples threads doivent lire depuis un flux de rĂ©pertoire identique, l’utilisation de readdir (3) avec une synchronisation externe est toujours prĂ©fĂ©rable Ă  l’utilisation de readdir_r (3). Il est attendu qu’une future version de POSIX.1 demande que readdir () soit sĂ»r vis-Ă -vis des threads lorsqu’il est employĂ© simultanĂ©ment sur des flux rĂ©pertoire diffĂ©rents.

VERSIONS

Seuls les champs d_name et (comme extension XSI) d_ino sont spécifiés dans POSIX.1. Ailleurs que sur Linux, le champ d_type est principalement disponible sur les systÚmes BSD. Les autres champs sont disponibles sur beaucoup de systÚmes, mais pas sur tous. Avec la glibc, les programmes peuvent vérifier la disponibilité des champs non définis dans POSIX.1 en testant si les macros _DIRENT_HAVE_D_NAMLEN , _DIRENT_HAVE_D_RECLEN , _DIRENT_HAVE_D_OFF ou _DIRENT_HAVE_D_TYPE sont définies.

Le champ d_name

La dĂ©finition de la structure dirent donne ci-dessus est reprise des en-tĂȘtes de la glibc et montre le champ d_name avec une taille fixe.

Avertissement : les applications devraient Ă©viter tout dĂ©pendance sur la taille du champ d_name . POSIX la dĂ©finit comme char d_name[] , un tableau de caractĂšres de taille non spĂ©cifiĂ©e, avec au plus NAME_MAX caractĂšres avant l’octet NULL final ('\0').

POSIX.1 est explicite sur le fait que ce champ ne doit pas ĂȘtre utilisĂ© comme une lvalue. La norme ajoute que l’utilisation de sizeof(d_name) est incorrecte ; utilisez strlen(d_name) Ă  la place. Sur certains systĂšmes, ce champ est dĂ©fini comme char d_name[1] ! Cela implique que l’utilisation de sizeof(struct dirent) pour dĂ©terminer la taille de l’enregistrement, y compris du champ d_name , est Ă©galement incorrecte.

Notez que bien que l’appel

fpathconf(fd, _PC_NAME_MAX)

renvoie la valeur 255 pour la plupart des systĂšmes de fichiers, le nom de fichier terminĂ© par l’octet NULL qui est (correctement) renvoyĂ© dans d_name peut en fait dĂ©passer cette taille sur certains systĂšmes de fichiers (CIFS ou les serveurs Windows SMB par exemple). Dans de tels cas, le champ d_reclen contiendra une valeur qui dĂ©passe la taille de la structure dirent de la glibc montrĂ©e plus haut.

STANDARDS

POSIX.1-2008.

HISTORIQUE

POSIX.1-2001, SVr4, 4.3BSD.

NOTES

Un flux répertoire est ouvert avec opendir (3).

L’ordre dans lequel les noms de fichier sont lus par des appels successifs Ă  readdir () dĂ©pend de l’implĂ©mentation du systĂšme de fichiers ; il est peu probable que les noms soient triĂ©s d’une quelconque façon.

VOIR AUSSI

getdents (2), read (2), closedir (3), dirfd (3), ftw (3), offsetof (3), opendir (3), readdir_r (3), rewinddir (3), scandir (3), seekdir (3), telldir (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>, 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 .