#include <unistd.h> #include <linux/types.h> #include <linux/dirent.h> #include <linux/unistd.h> #include <errno.h> int getdents(unsigned int fd, struct dirent *dirp, unsigned int count);
L'appel système getdents() lit plusieurs structures dirent depuis un répertoire référencé par le descripteur de fichier ouvert fd et les place dans la zone de mémoire pointée par dirp. Le paramètre count est la taille de la zone mémoire.
La structure dirent est déclarée ainsi :
struct linux_dirent { unsigned long d_ino; /* Numéro d'inœud */ unsigned long d_off; /* Distance au prochain dirent */ unsigned short d_reclen; /* Longueur de ce dirent */ char d_name []; /* Nom de fichier (fini par 0) */ /* La longueur est en fait (d_reclen - 2 - offsetof(struct linux_dirent, d_name) */ char pad; /* Octet nul de remplissage */ char d_type; /* Type de fichier (seulement depuis Linux 2.6.4 ; sa position est (d_reclen - 1)) */ }
d_ino est un numéro d'inœud. d_off est la distance entre le début du répertoire et le début de la prochaine structure dirent. d_reclen est la taille complète de dirent. d_name est le nom de fichier terminé par un octet nul.
d_type est un octet placé à la fin de la structure qui indique le type du fichier. Il contient l'une des valeurs suivantes :
Cet appel système remplace readdir(2).
Ce document est une traduction réalisée par Christophe Blaess <http://www.blaess.fr/christophe/> le 11 octobre 1996 et révisée le 17 juillet 2008.
L'équipe de traduction a fait le maximum pour réaliser une adaptation française de qualité. La version anglaise la plus à jour de ce document est toujours consultable via la commande : « LANG=C man 2 getdents ». N'hésitez pas à signaler à l'auteur ou au traducteur, selon le cas, toute erreur dans cette page de manuel.
Dernière mise à jour : 17 juillet 2008