Linux

CentOS 4.8

readdir(2)


READDIR

NOM

readdir − Lire une entrée de répertoire.

SYNOPSIS

#include <unistd.h>
#include <linux/dirent.h>
#include <linux/unistd.h>

_syscall3(int, readdir, uint, fd, struct dirent *, dirp, uint, count);

int readdir(unsigned int fd, struct dirent *dirp, unsigned int count);

DESCRIPTION

Cette fonction n’est normalement pas intéressante pour les programmeurs. Utiliser readdir(3) pour les fonctionnalités conformes POSIX. Cette page documente l’interface de l’appel système bas-niveau, qui peut changer, et qui est remplacée par getdents(2).

readdir lit une structure dirent depuis le répertoire pointé par fd et la place en mémoire dans la zone pointée par dirp.

Le paramètre count est ignoré, au plus une structure dirent est lue.

La structure dirent est déclarée comme suit :

struct dirent
{
    long d_ino;                 /* inode number */
    off_t d_off;                /* offset to this dirent */
    unsigned short d_reclen;    /* length of this d_name */
    char d_name [NAME_MAX+1];   /* file name (null-terminated) */
}

d_ino est un numéro d’i-node.

d_off est la distance entre le début du répertoire et cette structure dirent.

d_reclen est la longueur d_name, sans compter le caractère nul final.

d_name est le nom de fichier terminé par un caractère nul.

VALEUR RENVOYÃE

readdir renvoie 1 s’il réussit, 0 en fin de répertoire, ou −1 s’il échoue, auquel cas errno contient le code d’erreur.

ERREURS

EBADF

fd est invalide.

EFAULT

L’argument pointe en dehors de l’espace d’adressage.

EINVAL

Le buffer de résultat est trop petit.

ENONENT

Répertoire inexistant.

ENOTDIR

Le descripteur est associé à un fichier, pas à un répertoire.

CONFORMITÃ

Cet appel-système est spécifique à Linux.

VOIR AUSSI

getdents(2), readdir(3)

TRADUCTION

Christophe Blaess, 1997.


readdir(2)