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