/**
* 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