.\" Copyright (C) 1995 Andries Brouwer (aeb@cwi.nl) .\" .\" Permission is granted to make and distribute verbatim copies of this .\" manual provided the copyright notice and this permission notice are .\" preserved on all copies. .\" .\" Permission is granted to copy and distribute modified versions of this .\" manual under the conditions for verbatim copying, provided that the .\" entire resulting derived work is distributed under the terms of a .\" permission notice identical to this one .\" .\" Since the Linux kernel and libraries are constantly changing, this .\" manual page may be incorrect or out-of-date. The author(s) assume no .\" responsibility for errors or omissions, or for damages resulting from .\" the use of the information contained herein. The author(s) may not .\" have taken the same level of care in the production of this manual, .\" which is licensed free of charge, as they might when working .\" professionally. .\" .\" Formatted or processed versions of this manual, if unaccompanied by .\" the source, must acknowledge the copyright and authors of this work. .\" .\" Written 11 June 1995 by Andries Brouwer .\" Modified 22 July 1995 by Michael Chastain : .\" In 1.3.X, returns only one entry each time; return value is different. .\" Translated 23 Jan 1998 by Vicente Pastor Gómez .\" .TH READDIR 2 "22 julio 1995" "Linux 1.3.6" "Manual del Programador de Linux" .SH NOMBRE readdir \- lee una entrada de un directorio .SH SINOPSIS .nf .B #include .B #include .B #include .sp .B _syscall3(int, readdir, uint, fd, struct dirent *, dirp, uint, count); .sp .BI "int readdir(unsigned int " fd ", struct dirent *" dirp ", unsigned int " count ); .fi .SH DESCRIPCIÓN Esta no es la función que buscaba. Mire .BR readdir (3) para ver la interfaz de la biblioteca C conforme con POSIX. Esta página documenta la interfaz desnuda con la llamada al sistema del núcleo, que puede cambiar, y que es reemplazada por .BR getdents (2). .PP .B readdir lee una estructura .I dirent del directorio al que apunta .I fd y la almacena en el área de memoria apuntada por .IR dirp . El parámetro .I count es ignorado; como mucho se lee una estructura dirent. .PP La estructura .I dirent se declara como sigue: .PP .RS .nf struct dirent { long d_ino; /* número de nodo-í */ off_t d_off; /* desplazamiento hasta el \fIdirent\fP */ unsigned short d_reclen; /* longitud del \fId_name\fP */ char d_name [NAME_MAX+1]; /* nombre de fichero (acabado en nulo) */ } .fi .RE .PP .I d_ino es un número de nodo-í. .I d_off es la distancia desde el principio del directorio hasta este .IR dirent . .I d_reclen es el tamaño de .IR d_name, sin contar el carácter nulo del final. .I d_name es un nombre de fichero, una cadena de caracteres terminada en nulo. .PP .SH "VALOR DEVUELTO" En caso de éxito se devuelve 1. Si se alcanzó el final del directorio se devuelve 0. Si hubo un error se devuelve \-1 y la variable .I errno se modifica apropiadamente. .SH "ERRORES" .TP .B EBADF Descriptor de fichero .IR fd inválido. .TP .B EFAULT El argumento señala fuera del espacio de direcciones del proceso que realiza la llamada. .TP .B EINVAL El buffer para el resultado es demasiado pequeño. .TP .B ENOENT No existe el directorio. .TP .B ENOTDIR El descriptor de fichero no se refiere a un directorio. .SH "CONFORME A" Esta llamada al sistema es específica de Linux. .SH "VÉASE TAMBIÉN" .BR getdents (2), .BR readdir (3)