getdents   Début   Suivant   Sommaire   Préc.page.lue   Accueil
Section: Manuel du programmeur Linux (2)
Updated: 1er juin 2007
Sommaire  



NOM   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
getdents - Obtenir les points d'entrée d'un répertoire  



SYNOPSIS   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
#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);
 



DESCRIPTION   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
Ce n'est pas la fonction qui vous intéresse. Veuillez regarder readdir(3) pour l'interface de la fonction de même nom de la glibc conforme à la spécification POSIX. Cette page documente l'interface de l'appel système du noyau.

L'appel système getdents() lit plusieurs structures dirent depuis un répertoire pointé par le descripteur de fichier 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 dirent {
    long d_ino;                 /* numéro d'i-noeud            */
    off_t d_off;                /* distance au prochain dirent */
    unsigned short d_reclen;    /* longueur de ce dirent       */
    char d_name [NAME_MAX+1];   /* nom de fichier (fini par 0) */
}

d_ino est un numéro d'i-noeud. 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.

Cette fonction remplace readdir(2).  




VALEUR RENVOYÉE   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
getdents() renvoie le nombre d'octets lus s'il réussit (0 en fin de répertoire), ou -1 s'il échoue, auquel cas errno contient le code d'erreur.  



ERREURS   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
EBADF
fd n'est pas un descripteur de fichier valide.
EFAULT
L'argument pointe en dehors de l'espace d'adressage disponible.
EINVAL
Le tampon de résultat est trop petit.
ENOENT
Répertoire inexistant.
ENOTDIR
Le descripteur de fichier ne pointe pas sur un répertoire.
 



CONFORMITÉ   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
SVr4.  



NOTES   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
La glibc ne fournit pas d'enveloppe pour cet appel système ; appelez-le avec syscall(2).  



VOIR AUSSI   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
readdir(2), readdir(3)  



TRADUCTION   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil

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 14 janvier 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.


 



Sommaire   Début   Suivant   Sommaire   Préc.page.lue   Accueil
NOM
SYNOPSIS
DESCRIPTION
VALEUR RENVOYÉE
ERREURS
CONFORMITÉ
NOTES
VOIR AUSSI
TRADUCTION

Table des mots clés   Début   Suivant   Sommaire   Préc.page.lue   Accueil
EBADFERREURS
EFAULTERREURS
EINVALERREURS
ENOENTERREURS
ENOTDIRERREURS



Ce document a été créé par man2html suivi de man2html.pl, le 17/10/2008 17:50:14, en utilisant les pages de 'man'.
 

Valid HTML 4.01 Transitional