|  | /* Copyright (C) 1991-2016 Free Software Foundation, Inc. | 
|  | This file is part of the GNU C Library. | 
|  |  | 
|  | The GNU C Library is free software; you can redistribute it and/or | 
|  | modify it under the terms of the GNU Lesser General Public | 
|  | License as published by the Free Software Foundation; either | 
|  | version 2.1 of the License, or (at your option) any later version. | 
|  |  | 
|  | The GNU C Library is distributed in the hope that it will be useful, | 
|  | but WITHOUT ANY WARRANTY; without even the implied warranty of | 
|  | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | 
|  | Lesser General Public License for more details. | 
|  |  | 
|  | You should have received a copy of the GNU Lesser General Public | 
|  | License along with the GNU C Library; if not, see | 
|  | <http://www.gnu.org/licenses/>.  */ | 
|  |  | 
|  | #ifndef	_GLOB_H | 
|  | #define	_GLOB_H	1 | 
|  |  | 
|  | #include <sys/cdefs.h> | 
|  |  | 
|  | __BEGIN_DECLS | 
|  |  | 
|  | /* We need `size_t' for the following definitions.  */ | 
|  | #ifndef __size_t | 
|  | typedef __SIZE_TYPE__ __size_t; | 
|  | # if defined __USE_XOPEN || __USE_XOPEN2K8 | 
|  | typedef __SIZE_TYPE__ size_t; | 
|  | # endif | 
|  | #else | 
|  | /* The GNU CC stddef.h version defines __size_t as empty.  We need a real | 
|  | definition.  */ | 
|  | # undef __size_t | 
|  | # define __size_t size_t | 
|  | #endif | 
|  |  | 
|  | /* Bits set in the FLAGS argument to `glob'.  */ | 
|  | #define	GLOB_ERR	(1 << 0)/* Return on read errors.  */ | 
|  | #define	GLOB_MARK	(1 << 1)/* Append a slash to each name.  */ | 
|  | #define	GLOB_NOSORT	(1 << 2)/* Don't sort the names.  */ | 
|  | #define	GLOB_DOOFFS	(1 << 3)/* Insert PGLOB->gl_offs NULLs.  */ | 
|  | #define	GLOB_NOCHECK	(1 << 4)/* If nothing matches, return the pattern.  */ | 
|  | #define	GLOB_APPEND	(1 << 5)/* Append to results of a previous call.  */ | 
|  | #define	GLOB_NOESCAPE	(1 << 6)/* Backslashes don't quote metacharacters.  */ | 
|  | #define	GLOB_PERIOD	(1 << 7)/* Leading `.' can be matched by metachars.  */ | 
|  |  | 
|  | #if !defined __USE_POSIX2 || defined __USE_MISC | 
|  | # define GLOB_MAGCHAR	 (1 << 8)/* Set in gl_flags if any metachars seen.  */ | 
|  | # define GLOB_ALTDIRFUNC (1 << 9)/* Use gl_opendir et al functions.  */ | 
|  | # define GLOB_BRACE	 (1 << 10)/* Expand "{a,b}" to "a" "b".  */ | 
|  | # define GLOB_NOMAGIC	 (1 << 11)/* If no magic chars, return the pattern.  */ | 
|  | # define GLOB_TILDE	 (1 << 12)/* Expand ~user and ~ to home directories. */ | 
|  | # define GLOB_ONLYDIR	 (1 << 13)/* Match only directories.  */ | 
|  | # define GLOB_TILDE_CHECK (1 << 14)/* Like GLOB_TILDE but return an error | 
|  | if the user name is not available.  */ | 
|  | # define __GLOB_FLAGS	(GLOB_ERR|GLOB_MARK|GLOB_NOSORT|GLOB_DOOFFS| \ | 
|  | GLOB_NOESCAPE|GLOB_NOCHECK|GLOB_APPEND|     \ | 
|  | GLOB_PERIOD|GLOB_ALTDIRFUNC|GLOB_BRACE|     \ | 
|  | GLOB_NOMAGIC|GLOB_TILDE|GLOB_ONLYDIR|GLOB_TILDE_CHECK) | 
|  | #else | 
|  | # define __GLOB_FLAGS	(GLOB_ERR|GLOB_MARK|GLOB_NOSORT|GLOB_DOOFFS| \ | 
|  | GLOB_NOESCAPE|GLOB_NOCHECK|GLOB_APPEND|     \ | 
|  | GLOB_PERIOD) | 
|  | #endif | 
|  |  | 
|  | /* Error returns from `glob'.  */ | 
|  | #define	GLOB_NOSPACE	1	/* Ran out of memory.  */ | 
|  | #define	GLOB_ABORTED	2	/* Read error.  */ | 
|  | #define	GLOB_NOMATCH	3	/* No matches found.  */ | 
|  | #define GLOB_NOSYS	4	/* Not implemented.  */ | 
|  | #ifdef __USE_GNU | 
|  | /* Previous versions of this file defined GLOB_ABEND instead of | 
|  | GLOB_ABORTED.  Provide a compatibility definition here.  */ | 
|  | # define GLOB_ABEND GLOB_ABORTED | 
|  | #endif | 
|  |  | 
|  | /* Structure describing a globbing run.  */ | 
|  | #ifdef __USE_GNU | 
|  | struct stat; | 
|  | #endif | 
|  | typedef struct | 
|  | { | 
|  | __size_t gl_pathc;		/* Count of paths matched by the pattern.  */ | 
|  | char **gl_pathv;		/* List of matched pathnames.  */ | 
|  | __size_t gl_offs;		/* Slots to reserve in `gl_pathv'.  */ | 
|  | int gl_flags;		/* Set to FLAGS, maybe | GLOB_MAGCHAR.  */ | 
|  |  | 
|  | /* If the GLOB_ALTDIRFUNC flag is set, the following functions | 
|  | are used instead of the normal file access functions.  */ | 
|  | void (*gl_closedir) (void *); | 
|  | #ifdef __USE_GNU | 
|  | struct dirent *(*gl_readdir) (void *); | 
|  | #else | 
|  | void *(*gl_readdir) (void *); | 
|  | #endif | 
|  | void *(*gl_opendir) (const char *); | 
|  | #ifdef __USE_GNU | 
|  | int (*gl_lstat) (const char *__restrict, struct stat *__restrict); | 
|  | int (*gl_stat) (const char *__restrict, struct stat *__restrict); | 
|  | #else | 
|  | int (*gl_lstat) (const char *__restrict, void *__restrict); | 
|  | int (*gl_stat) (const char *__restrict, void *__restrict); | 
|  | #endif | 
|  | } glob_t; | 
|  |  | 
|  | #ifdef __USE_LARGEFILE64 | 
|  | # ifdef __USE_GNU | 
|  | struct stat64; | 
|  | # endif | 
|  | typedef struct | 
|  | { | 
|  | __size_t gl_pathc; | 
|  | char **gl_pathv; | 
|  | __size_t gl_offs; | 
|  | int gl_flags; | 
|  |  | 
|  | /* If the GLOB_ALTDIRFUNC flag is set, the following functions | 
|  | are used instead of the normal file access functions.  */ | 
|  | void (*gl_closedir) (void *); | 
|  | # ifdef __USE_GNU | 
|  | struct dirent64 *(*gl_readdir) (void *); | 
|  | # else | 
|  | void *(*gl_readdir) (void *); | 
|  | # endif | 
|  | void *(*gl_opendir) (const char *); | 
|  | # ifdef __USE_GNU | 
|  | int (*gl_lstat) (const char *__restrict, struct stat64 *__restrict); | 
|  | int (*gl_stat) (const char *__restrict, struct stat64 *__restrict); | 
|  | # else | 
|  | int (*gl_lstat) (const char *__restrict, void *__restrict); | 
|  | int (*gl_stat) (const char *__restrict, void *__restrict); | 
|  | # endif | 
|  | } glob64_t; | 
|  | #endif | 
|  |  | 
|  | /* Do glob searching for PATTERN, placing results in PGLOB. | 
|  | The bits defined above may be set in FLAGS. | 
|  | If a directory cannot be opened or read and ERRFUNC is not nil, | 
|  | it is called with the pathname that caused the error, and the | 
|  | `errno' value from the failing call; if it returns non-zero | 
|  | `glob' returns GLOB_ABEND; if it returns zero, the error is ignored. | 
|  | If memory cannot be allocated for PGLOB, GLOB_NOSPACE is returned. | 
|  | Otherwise, `glob' returns zero.  */ | 
|  | #if !defined __USE_FILE_OFFSET64 | 
|  | extern int glob (const char *__restrict __pattern, int __flags, | 
|  | int (*__errfunc) (const char *, int), | 
|  | glob_t *__restrict __pglob) __THROW; | 
|  |  | 
|  | /* Free storage allocated in PGLOB by a previous `glob' call.  */ | 
|  | extern void globfree (glob_t *__pglob) __THROW; | 
|  | #else | 
|  | extern int __REDIRECT_NTH (glob, (const char *__restrict __pattern, | 
|  | int __flags, | 
|  | int (*__errfunc) (const char *, int), | 
|  | glob_t *__restrict __pglob), glob64); | 
|  |  | 
|  | extern void __REDIRECT_NTH (globfree, (glob_t *__pglob), globfree64); | 
|  | #endif | 
|  |  | 
|  | #ifdef __USE_LARGEFILE64 | 
|  | extern int glob64 (const char *__restrict __pattern, int __flags, | 
|  | int (*__errfunc) (const char *, int), | 
|  | glob64_t *__restrict __pglob) __THROW; | 
|  |  | 
|  | extern void globfree64 (glob64_t *__pglob) __THROW; | 
|  | #endif | 
|  |  | 
|  |  | 
|  | #ifdef __USE_GNU | 
|  | /* Return nonzero if PATTERN contains any metacharacters. | 
|  | Metacharacters can be quoted with backslashes if QUOTE is nonzero. | 
|  |  | 
|  | This function is not part of the interface specified by POSIX.2 | 
|  | but several programs want to use it.  */ | 
|  | extern int glob_pattern_p (const char *__pattern, int __quote) __THROW; | 
|  | #endif | 
|  |  | 
|  | __END_DECLS | 
|  |  | 
|  | #endif /* glob.h  */ |