1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119
|
.\" 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 <aeb@cwi.nl>
.\" Modified 22 July 1995 by Michael Chastain <mec@duracef.shout.net>:
.\" In 1.3.X, returns only one entry each time; return value is different.
.\" Translated 23 Jan 1998 by Vicente Pastor Gómez <VPASTORG@santandersupernet.com , vicpastor@hotmail.com>
.\"
.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 <unistd.h>
.B #include <linux/dirent.h>
.B #include <linux/unistd.h>
.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)
|