summaryrefslogtreecommitdiff
path: root/ACE/ace/Dirent.h
blob: 02551013d07ab1e5818a35aff0d62990727f2d2b (plain)
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
// -*- C++ -*-

//=============================================================================
/**
 *  @file    Dirent.h
 *
 *  Define a portable C++ interface to ACE_OS_Dirent directory-entry
 *  manipulation.
 *
 *  @author Douglas C. Schmidt <d.schmidt@vanderbilt.edu>
 */
//=============================================================================

#ifndef ACE_DIRENT_H
#define ACE_DIRENT_H
#include /**/ "ace/pre.h"

#include /**/ "ace/ACE_export.h"

#if !defined (ACE_LACKS_PRAGMA_ONCE)
# pragma once
#endif /* ACE_LACKS_PRAGMA_ONCE */

#include "ace/OS_NS_dirent.h"

ACE_BEGIN_VERSIONED_NAMESPACE_DECL

/**
 * @class ACE_Dirent
 *
 * @brief Define a portable C++ directory-entry iterator based on the POSIX API.
 */
class ACE_Export ACE_Dirent
{
public:
  /// Default constructor.
  ACE_Dirent ();

  /// Constructor calls @c opendir()
  explicit ACE_Dirent (const ACE_TCHAR *dirname);

  /// Opens the directory named by filename and associates a directory
  /// stream with it.
  int open (const ACE_TCHAR *filename);

  /// Destructor calls @c closedir().
  ~ACE_Dirent ();

  /// Closes the directory stream and frees the ACE_DIR structure.
  void close ();

  // = Iterator methods.
  /**
   * Returns a pointer to a structure representing the directory entry
   * at the current position in the directory stream to which dirp
   * refers, and positions the directory stream at the next entry,
   * except on read-only filesystems.  It returns a NULL pointer upon
   * reaching the end of the directory stream, or upon detecting an
   * invalid location in the directory.  @c read() shall not return
   * directory entries containing empty names.  It is unspecified
   * whether entries are returned for dot or dot-dot.  The pointer
   * returned by @c read() points to data that may be overwritten by
   * another call to @c read() on the same directory stream.  This
   * data shall not be overwritten by another call to @c read() on a
   * different directory stream.  @c read() may buffer several
   * directory entries per actual read operation; @c read() marks for
   * update the st_atime field of the directory each time the
   * directory is actually read.
   */
  ACE_DIRENT *read ();

  // = Manipulators.
  /// Returns the current location associated with the directory
  /// stream.
  long tell ();

  /**
   * Sets the position of the next @c read() operation on the
   * directory stream.  The new position reverts to the position
   * associated with the directory stream at the time the @c tell()
   * operation that provides loc was performed.  Values returned by
   * @c tell() are good only for the lifetime of the ACE_DIR pointer from
   * which they are derived.  If the directory is closed and then
   * reopened, the @c telldir() value may be invalidated due to
   * undetected directory compaction.  It is safe to use a previous
   * @c telldir() value immediately after a call to @c opendir() and before
   * any calls to readdir.
   */
  void seek (long loc);

  /**
   * Resets the position of the directory stream to the beginning of
   * the directory.  It also causes the directory stream to refer to
   * the current state of the corresponding directory, as a call to
   * @c opendir() would.
   */
  void rewind ();

private:
  /// Pointer to the directory stream.
  ACE_DIR *dirp_;
};

ACE_END_VERSIONED_NAMESPACE_DECL

#if defined (__ACE_INLINE__)
#include "ace/Dirent.inl"
#endif /* __ACE_INLINE__ */

#include /**/ "ace/post.h"
#endif /* ACE_DIRENT_H */