C++程序  |  67行  |  1.93 KB

/**
 * This file is part of the mingw-w64 runtime package.
 * No warranty is given; refer to the file DISCLAIMER within this package.
 */

#ifndef _FTW_HXX
#define	_FTW_HXX

#include <sys/types.h>
#include <sys/stat.h>

#ifdef __cplusplus
extern "C" {
#endif

  struct FTW {
    int base;
    int level;
  };

  /* A regular file.  */
#define FTW_F 0
  /* A directory.  */
#define FTW_D 1
  /* An unreadable directory.  */
#define FTW_DNR	2
  /* An unstatable file.  */
#define FTW_NS 3
  /* A symbolic link (not supported).  */
#define FTW_SL 4
  /* A directory (all subdirs are visited). */
#define FTW_DP 5
  /* A symbolic link naming non-existing file (not supported).  */
#define FTW_SLN 6

  /* Do a physical walk (ignore symlinks).  */
#define FTW_PHYS 1
  /* Do report only files on same device as the argument (partial supported).  */
#define FTW_MOUNT 2
  /* Change to current directory while processing (unsupported).  */
#define FTW_CHDIR 4
  /* Do report files in directory before the directory itself.*/
#define FTW_DEPTH 8
  /* Tell callback to return FTW_* values instead of zero to continue and non-zero to terminate.  */
#define FTW_ACTIONRETVAL 16

  /* Continue with next sibling or with the first child-directory.  */
#define FTW_CONTINUE 0
  /* Return from ftw or nftw with FTW_STOP as return value.  */
#define FTW_STOP 1
  /* Valid only for FTW_D: Don't walk through the subtree. */
#define FTW_SKIP_SUBTREE 2
  /* Continue with FTW_DP callback for current directory (if FTW_DEPTH) and then its siblings.  */
#define FTW_SKIP_SIBLINGS 3

  int ftw (const char *, int (*) (const char *, const struct stat *, int), int);
  int ftw64 (const char *, int (*) (const char *, const struct stat64 *, int), int);

  int nftw (const char *, int (*) (const char *, const struct stat *, int , struct FTW *), int, int);
  int nftw64 (const char *, int (*) (const char *, const struct stat64 *, int , struct FTW *), int, int);

#ifdef __cplusplus
}
#endif

#endif