nftw man page on Manjaro

Man page or keyword search:  
man Server   11224 pages
apropos Keyword Search (all sections)
Output format
Manjaro logo
[printable version]

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)
[top]

List of man pages available for Manjaro

Copyright (c) for man pages and the logo by the respective OS vendor.

For those who want to learn more, the polarhome community provides shell access and support.

[legal] [privacy] [GNU] [policy] [cookies] [netiquette] [sponsors] [FAQ]
Tweet
Polarhome, production since 1999.
Member of Polarhome portal.
Based on Fawad Halim's script.
....................................................................
Vote for polarhome
Free Shell Accounts :: the biggest list on the net