Source code pulled from OpenBSD for OpenNTPD. The place to contribute to this code is via the OpenBSD CVS tree.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

117 lines
3.9 KiB

  1. /* $OpenBSD: dirent.h,v 1.9 2002/10/25 21:55:28 millert Exp $ */
  2. /* $NetBSD: dirent.h,v 1.9 1995/03/26 20:13:37 jtc Exp $ */
  3. /*-
  4. * Copyright (c) 1989, 1993
  5. * The Regents of the University of California. All rights reserved.
  6. *
  7. * Redistribution and use in source and binary forms, with or without
  8. * modification, are permitted provided that the following conditions
  9. * are met:
  10. * 1. Redistributions of source code must retain the above copyright
  11. * notice, this list of conditions and the following disclaimer.
  12. * 2. Redistributions in binary form must reproduce the above copyright
  13. * notice, this list of conditions and the following disclaimer in the
  14. * documentation and/or other materials provided with the distribution.
  15. * 3. All advertising materials mentioning features or use of this software
  16. * must display the following acknowledgement:
  17. * This product includes software developed by the University of
  18. * California, Berkeley and its contributors.
  19. * 4. Neither the name of the University nor the names of its contributors
  20. * may be used to endorse or promote products derived from this software
  21. * without specific prior written permission.
  22. *
  23. * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  24. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  25. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  26. * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  27. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  28. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  29. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  30. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  31. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  32. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  33. * SUCH DAMAGE.
  34. *
  35. * @(#)dirent.h 8.2 (Berkeley) 7/28/94
  36. */
  37. #ifndef _DIRENT_H_
  38. #define _DIRENT_H_
  39. /*
  40. * POSIX doesn't mandate this, but X/Open XPG 4.2 does.
  41. */
  42. #ifndef _POSIX_SOURCE
  43. #include <sys/types.h>
  44. #endif
  45. /*
  46. * The kernel defines the format of directory entries returned by
  47. * the getdirentries(2) system call.
  48. */
  49. #include <sys/dirent.h>
  50. #ifdef _POSIX_SOURCE
  51. typedef void * DIR;
  52. #else
  53. #define d_ino d_fileno /* backward compatibility */
  54. /* definitions for library routines operating on directories. */
  55. #define DIRBLKSIZ 1024
  56. /* structure describing an open directory. */
  57. typedef struct _dirdesc {
  58. int dd_fd; /* file descriptor associated with directory */
  59. long dd_loc; /* offset in current buffer */
  60. long dd_size; /* amount of data returned by getdirentries */
  61. char *dd_buf; /* data buffer */
  62. int dd_len; /* size of data buffer */
  63. long dd_seek; /* magic cookie returned by getdirentries */
  64. long dd_rewind; /* magic cookie for rewinding */
  65. int dd_flags; /* flags for readdir */
  66. } DIR;
  67. #define dirfd(dirp) ((dirp)->dd_fd)
  68. /* flags for opendir2 */
  69. #define DTF_HIDEW 0x0001 /* hide whiteout entries */
  70. #define DTF_NODUP 0x0002 /* don't return duplicate names */
  71. #define DTF_REWIND 0x0004 /* rewind after reading union stack */
  72. #define __DTF_READALL 0x0008 /* everything has been read */
  73. #ifndef NULL
  74. #ifdef __GNUG__
  75. #define NULL __null
  76. #else
  77. #define NULL 0L
  78. #endif
  79. #endif
  80. #endif /* _POSIX_SOURCE */
  81. #ifndef _KERNEL
  82. #include <sys/cdefs.h>
  83. __BEGIN_DECLS
  84. DIR *opendir(const char *);
  85. struct dirent *readdir(DIR *);
  86. void rewinddir(DIR *);
  87. int closedir(DIR *);
  88. #ifndef _POSIX_SOURCE
  89. DIR *__opendir2(const char *, int);
  90. long telldir(const DIR *);
  91. void seekdir(DIR *, long);
  92. int scandir(const char *, struct dirent ***,
  93. int (*)(struct dirent *), int (*)(const void *, const void *));
  94. int alphasort(const void *, const void *);
  95. int getdirentries(int, char *, int, long *);
  96. #endif /* not POSIX */
  97. int readdir_r(DIR *, struct dirent *, struct dirent **);
  98. __END_DECLS
  99. #endif /* !_KERNEL */
  100. #endif /* !_DIRENT_H_ */