xref: /aosp_15_r20/bionic/libc/include/ftw.h (revision 8d67ca893c1523eb926b9080dbe4e2ffd2a27ba1)
1*8d67ca89SAndroid Build Coastguard Worker /* $NetBSD: ftw.h,v 1.1 2005/12/30 23:07:33 agc Exp $ */
2*8d67ca89SAndroid Build Coastguard Worker 
3*8d67ca89SAndroid Build Coastguard Worker /*	From OpenBSD: ftw.h,v 1.1 2003/07/21 21:13:18 millert Exp 	*/
4*8d67ca89SAndroid Build Coastguard Worker 
5*8d67ca89SAndroid Build Coastguard Worker /*
6*8d67ca89SAndroid Build Coastguard Worker  * Copyright (c) 2003 Todd C. Miller <[email protected]>
7*8d67ca89SAndroid Build Coastguard Worker  *
8*8d67ca89SAndroid Build Coastguard Worker  * Permission to use, copy, modify, and distribute this software for any
9*8d67ca89SAndroid Build Coastguard Worker  * purpose with or without fee is hereby granted, provided that the above
10*8d67ca89SAndroid Build Coastguard Worker  * copyright notice and this permission notice appear in all copies.
11*8d67ca89SAndroid Build Coastguard Worker  *
12*8d67ca89SAndroid Build Coastguard Worker  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
13*8d67ca89SAndroid Build Coastguard Worker  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
14*8d67ca89SAndroid Build Coastguard Worker  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
15*8d67ca89SAndroid Build Coastguard Worker  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
16*8d67ca89SAndroid Build Coastguard Worker  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
17*8d67ca89SAndroid Build Coastguard Worker  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
18*8d67ca89SAndroid Build Coastguard Worker  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
19*8d67ca89SAndroid Build Coastguard Worker  *
20*8d67ca89SAndroid Build Coastguard Worker  * Sponsored in part by the Defense Advanced Research Projects
21*8d67ca89SAndroid Build Coastguard Worker  * Agency (DARPA) and Air Force Research Laboratory, Air Force
22*8d67ca89SAndroid Build Coastguard Worker  * Materiel Command, USAF, under agreement number F39502-99-1-0512.
23*8d67ca89SAndroid Build Coastguard Worker  */
24*8d67ca89SAndroid Build Coastguard Worker 
25*8d67ca89SAndroid Build Coastguard Worker #ifndef	_FTW_H
26*8d67ca89SAndroid Build Coastguard Worker #define	_FTW_H
27*8d67ca89SAndroid Build Coastguard Worker 
28*8d67ca89SAndroid Build Coastguard Worker #include <sys/cdefs.h>
29*8d67ca89SAndroid Build Coastguard Worker #include <sys/stat.h>
30*8d67ca89SAndroid Build Coastguard Worker #include <sys/types.h>
31*8d67ca89SAndroid Build Coastguard Worker 
32*8d67ca89SAndroid Build Coastguard Worker /*
33*8d67ca89SAndroid Build Coastguard Worker  * Valid flags for the 3rd argument to the function that is passed as the
34*8d67ca89SAndroid Build Coastguard Worker  * second argument to ftw(3) and nftw(3).  Say it three times fast!
35*8d67ca89SAndroid Build Coastguard Worker  */
36*8d67ca89SAndroid Build Coastguard Worker #define	FTW_F		0	/* File.  */
37*8d67ca89SAndroid Build Coastguard Worker #define	FTW_D		1	/* Directory.  */
38*8d67ca89SAndroid Build Coastguard Worker #define	FTW_DNR		2	/* Directory without read permission.  */
39*8d67ca89SAndroid Build Coastguard Worker #define	FTW_DP		3	/* Directory with subdirectories visited.  */
40*8d67ca89SAndroid Build Coastguard Worker #define	FTW_NS		4	/* Unknown type; stat() failed.  */
41*8d67ca89SAndroid Build Coastguard Worker #define	FTW_SL		5	/* Symbolic link.  */
42*8d67ca89SAndroid Build Coastguard Worker #define	FTW_SLN		6	/* Sym link that names a nonexistent file.  */
43*8d67ca89SAndroid Build Coastguard Worker 
44*8d67ca89SAndroid Build Coastguard Worker /*
45*8d67ca89SAndroid Build Coastguard Worker  * Flags for use as the 4th argument to nftw(3).  These may be ORed together.
46*8d67ca89SAndroid Build Coastguard Worker  */
47*8d67ca89SAndroid Build Coastguard Worker #define	FTW_PHYS	0x01	/* Physical walk, don't follow sym links.  */
48*8d67ca89SAndroid Build Coastguard Worker #define	FTW_MOUNT	0x02	/* The walk does not cross a mount point.  */
49*8d67ca89SAndroid Build Coastguard Worker #define	FTW_DEPTH	0x04	/* Subdirs visited before the dir itself. */
50*8d67ca89SAndroid Build Coastguard Worker #define	FTW_CHDIR	0x08	/* Change to a directory before reading it. */
51*8d67ca89SAndroid Build Coastguard Worker 
52*8d67ca89SAndroid Build Coastguard Worker struct FTW {
53*8d67ca89SAndroid Build Coastguard Worker 	int base;
54*8d67ca89SAndroid Build Coastguard Worker 	int level;
55*8d67ca89SAndroid Build Coastguard Worker };
56*8d67ca89SAndroid Build Coastguard Worker 
57*8d67ca89SAndroid Build Coastguard Worker __BEGIN_DECLS
58*8d67ca89SAndroid Build Coastguard Worker int ftw(const char* _Nonnull __dir_path, int (* _Nonnull __callback)(const char* _Nonnull, const struct stat* _Nonnull, int), int __max_fd_count);
59*8d67ca89SAndroid Build Coastguard Worker int nftw(const char* _Nonnull __dir_path, int (* _Nonnull __callback)(const char* _Nonnull, const struct stat* _Nonnull, int, struct FTW* _Nonnull), int __max_fd_count, int __flags);
60*8d67ca89SAndroid Build Coastguard Worker int ftw64(const char* _Nonnull __dir_path, int (* _Nonnull __callback)(const char* _Nonnull, const struct stat64* _Nonnull, int), int __max_fd_count);
61*8d67ca89SAndroid Build Coastguard Worker int nftw64(const char* _Nonnull __dir_path, int (* _Nonnull __callback)(const char* _Nonnull, const struct stat64* _Nonnull, int, struct FTW* _Nonnull), int __max_fd_count, int __flags);
62*8d67ca89SAndroid Build Coastguard Worker __END_DECLS
63*8d67ca89SAndroid Build Coastguard Worker 
64*8d67ca89SAndroid Build Coastguard Worker #endif
65