NFTW(3P) POSIX Programmer's Manual NFTW(3P)
PROLOG
This manual page is part of the POSIX Programmer's Manual. The Linux
implementation of this interface may differ (consult the corresponding
Linux manual page for details of Linux behavior), or the interface may
not be implemented on Linux.
NAME
nftw -- walk a file tree
SYNOPSIS
#include <ftw.h>
int nftw(const char *path, int (*fn)(const char *,
const struct stat *, int, struct FTW *), int fd_limit, int flags);
DESCRIPTION
The nftw() function shall recursively descend the directory hierarchy
rooted in path. The nftw() function has a similar effect to ftw()
except that it takes an additional argument flags, which is a bitwise-
inclusive OR of zero or more of the following flags:
FTW_CHDIR If set, nftw() shall change the current working directory
to each directory as it reports files in that directory. If
clear, nftw() shall not change the current working direc-
tory.
FTW_DEPTH If set, nftw() shall report all files in a directory before
reporting the directory itself. If clear, nftw() shall
report any directory before reporting the files in that
directory.
FTW_MOUNT If set, nftw() shall only report files in the same file
system as path. If clear, nftw() shall report all files
encountered during the walk.
FTW_PHYS If set, nftw() shall perform a physical walk and shall not
follow symbolic links.
If FTW_PHYS is clear and FTW_DEPTH is set, nftw() shall follow links
instead of reporting them, but shall not report any directory that
would be a descendant of itself. If FTW_PHYS is clear and FTW_DEPTH is
clear, nftw() shall follow links instead of reporting them, but shall
not report the contents of any directory that would be a descendant of
itself.
At each file it encounters, nftw() shall call the user-supplied func-
tion fn with four arguments:
* The first argument is the pathname of the object.
* The second argument is a pointer to the stat buffer containing
information on the object, filled in as if fstatat(), stat(), or
lstat() had been called to retrieve the information.
* The third argument is an integer giving additional information. Its
value is one of the following:
FTW_D The object is a directory.
FTW_DNR The object is a directory that cannot be read. The fn
function shall not be called for any of its descendants.
FTW_DP The object is a directory and subdirectories have been
visited. (This condition shall only occur if the
FTW_DEPTH flag is included in flags.)
FTW_F The object is a non-directory file.
FTW_NS The stat() function failed on the object because of lack
of appropriate permission. The stat buffer passed to fn
is undefined. Failure of stat() for any other reason is
considered an error and nftw() shall return -1.
FTW_SL The object is a symbolic link. (This condition shall only
occur if the FTW_PHYS flag is included in flags.)
FTW_SLN The object is a symbolic link that does not name an
existing file. (This condition shall only occur if the
FTW_PHYS flag is not included in flags.)
* The fourth argument is a pointer to an FTW structure. The value of
base is the offset of the object's filename in the pathname passed
as the first argument to fn. The value of level indicates depth
relative to the root of the walk, where the root level is 0.
The results are unspecified if the application-supplied fn function
does not preserve the current working directory.
The argument fd_limit sets the maximum number of file descriptors that
shall be used by nftw() while traversing the file tree. At most one
file descriptor shall be used for each directory level.
The nftw() function need not be thread-safe.
RETURN VALUE
The nftw() function shall continue until the first of the following
conditions occurs:
* An invocation of fn shall return a non-zero value, in which case
nftw() shall return that value.
* The nftw() function detects an error other than [EACCES] (see
FTW_DNR and FTW_NS above), in which case nftw() shall return -1 and
set errno to indicate the error.
* The tree is exhausted, in which case nftw() shall return 0.
ERRORS
The nftw() function shall fail if:
EACCES Search permission is denied for any component of path or read
permission is denied for path, or fn returns -1 and does not
reset errno.
ELOOP A loop exists in symbolic links encountered during resolution of
the path argument.
ENAMETOOLONG
The length of a component of a pathname is longer than
{NAME_MAX}.
ENOENT A component of path does not name an existing file or path is an
empty string.
ENOTDIR
A component of path names an existing file that is neither a
directory nor a symbolic link to a directory.
EOVERFLOW
A field in the stat structure cannot be represented correctly in
the current programming environment for one or more files found
in the file hierarchy.
The nftw() function may fail if:
ELOOP More than {SYMLOOP_MAX} symbolic links were encountered during
resolution of the path argument.
EMFILE All file descriptors available to the process are currently
open.
ENAMETOOLONG
The length of a pathname exceeds {PATH_MAX}, or pathname resolu-
tion of a symbolic link produced an intermediate result with a
length that exceeds {PATH_MAX}.
ENFILE Too many files are currently open in the system.
In addition, errno may be set if the function pointed to by fn causes
errno to be set.
The following sections are informative.
EXAMPLES
The following program traverses the directory tree under the path named
in its first command-line argument, or under the current directory if
no argument is supplied. It displays various information about each
file. The second command-line argument can be used to specify charac-
ters that control the value assigned to the flags argument when calling
nftw().
#include <ftw.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stdint.h>
static int
display_info(const char *fpath, const struct stat *sb,
int tflag, struct FTW *ftwbuf)
{
printf("%-3s %2d %7jd %-40s %d %s\n",
(tflag == FTW_D) ? "d" : (tflag == FTW_DNR) ? "dnr" :
(tflag == FTW_DP) ? "dp" : (tflag == FTW_F) ?
(S_ISBLK(sb->st_mode) ? "f b" :
S_ISCHR(sb->st_mode) ? "f c" :
S_ISFIFO(sb->st_mode) ? "f p" :
S_ISREG(sb->st_mode) ? "f r" :
S_ISSOCK(sb->st_mode) ? "f s" : "f ?") :
(tflag == FTW_NS) ? "ns" : (tflag == FTW_SL) ? "sl" :
(tflag == FTW_SLN) ? "sln" : "?",
ftwbuf->level, (intmax_t) sb->st_size,
fpath, ftwbuf->base, fpath + ftwbuf->base);
return 0; /* To tell nftw() to continue */
}
int
main(int argc, char *argv[])
{
int flags = 0;
if (argc > 2 && strchr(argv[2], 'd') != NULL)
flags |= FTW_DEPTH;
if (argc > 2 && strchr(argv[2], 'p') != NULL)
flags |= FTW_PHYS;
if (nftw((argc < 2) ? "." : argv[1], display_info, 20, flags) == -1)
{
perror("nftw");
exit(EXIT_FAILURE);
}
exit(EXIT_SUCCESS);
}
APPLICATION USAGE
The nftw() function may allocate dynamic storage during its operation.
If nftw() is forcibly terminated, such as by longjmp() or siglongjmp()
being executed by the function pointed to by fn or an interrupt rou-
tine, nftw() does not have a chance to free that storage, so it remains
permanently allocated. A safe way to handle interrupts is to store the
fact that an interrupt has occurred, and arrange to have the function
pointed to by fn return a non-zero value at its next invocation.
RATIONALE
None.
FUTURE DIRECTIONS
None.
SEE ALSO
fdopendir(), fstatat(), readdir()
The Base Definitions volume of POSIX.1-2008, <ftw.h>
COPYRIGHT
Portions of this text are reprinted and reproduced in electronic form
from IEEE Std 1003.1, 2013 Edition, Standard for Information Technology
-- Portable Operating System Interface (POSIX), The Open Group Base
Specifications Issue 7, Copyright (C) 2013 by the Institute of Electri-
cal and Electronics Engineers, Inc and The Open Group. (This is
POSIX.1-2008 with the 2013 Technical Corrigendum 1 applied.) In the
event of any discrepancy between this version and the original IEEE and
The Open Group Standard, the original IEEE and The Open Group Standard
is the referee document. The original Standard can be obtained online
at http://www.unix.org/online.html .
Any typographical or formatting errors that appear in this page are
most likely to have been introduced during the conversion of the source
files to man page format. To report such errors, see https://www.ker-
nel.org/doc/man-pages/reporting_bugs.html .
IEEE/The Open Group 2013 NFTW(3P)