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.

114 lines
3.7 KiB

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