enum
{
DT_UNKNOWN = 0,
+# define DT_UNKNOWN DT_UNKNOWN
DT_FIFO = 1,
+# define DT_FIFO DT_FIFO
DT_CHR = 2,
+# define DT_CHR DT_CHR
DT_DIR = 4,
+# define DT_DIR DT_DIR
DT_BLK = 6,
+# define DT_BLK DT_BLK
DT_REG = 8,
+# define DT_REG DT_REG
DT_LNK = 10,
+# define DT_LNK DT_LNK
DT_SOCK = 12
+# define DT_SOCK DT_SOCK
};
/* Convert between stat structure types and directory types. */
extern int __closedir __P ((DIR *__dirp));
extern int closedir __P ((DIR *__dirp));
-/* Read a directory entry from DIRP.
- Return a pointer to a `struct dirent' describing the entry,
- or NULL for EOF or error. The storage returned may be overwritten
- by a later readdir call on the same DIR stream. */
+/* Read a directory entry from DIRP. Return a pointer to a `struct
+ dirent' describing the entry, or NULL for EOF or error. The
+ storage returned may be overwritten by a later readdir call on the
+ same DIR stream.
+
+ If the Large File Support API is selected we have to use the
+ appropriate interface. */
extern struct dirent *__readdir __P ((DIR *__dirp));
+#ifndef __USE_FILE_OFFSET64
extern struct dirent *readdir __P ((DIR *__dirp));
+#else
+extern struct dirent *readdir __P ((DIR *__dirp)) __asm__ ("readdir64");
+#endif
+
+#ifdef __USE_LARGEFILE64
+extern struct dirent64 *readdir64 __P ((DIR *__dirp));
+#endif
#if defined __USE_POSIX || defined __USE_MISC
/* Reentrant version of `readdir'. Return in RESULT a pointer to the
next entry. */
extern int __readdir_r __P ((DIR *__dirp, struct dirent *__entry,
struct dirent **__result));
+# ifndef __USE_FILE_OFFSET64
extern int readdir_r __P ((DIR *__dirp, struct dirent *__entry,
struct dirent **__result));
+# else
+extern int readdir_r __P ((DIR *__dirp, struct dirent *__entry,
+ struct dirent **__result))
+ __asm__ ("readdir64_r");
+# endif
+
+# ifdef __USE_LARGEFILE64
+extern int readdir64_r __P ((DIR *__dirp, struct dirent64 *__entry,
+ struct dirent64 **__result));
+# endif
#endif /* POSIX or misc */
/* Rewind DIRP to the beginning of the directory. */