5 * Header file supporting a MinGW implementation of an (approximately)
6 * POSIX conforming glob() and globfree() API.
10 * Written by Keith Marshall <keithmarshall@users.sourceforge.net>
11 * Copyright (C) 2011, 2012, 2014, 2016, 2017, MinGW.org Project.
14 * Permission is hereby granted, free of charge, to any person obtaining a
15 * copy of this software and associated documentation files (the "Software"),
16 * to deal in the Software without restriction, including without limitation
17 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
18 * and/or sell copies of the Software, and to permit persons to whom the
19 * Software is furnished to do so, subject to the following conditions:
21 * The above copyright notice, this permission notice, and the following
22 * disclaimer shall be included in all copies or substantial portions of
25 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
26 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
27 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
28 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
29 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
30 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OF OR OTHER
31 * DEALINGS IN THE SOFTWARE.
35 #pragma GCC system_header
37 /* All MinGW.org system headers are required to include <_mingw.h>.
42 /* POSIX requires glob.h to define the size_t type; we need to
43 * get this from GCC's <stddef.h>, just as <sys/types.h> does.
50 { /* The structure, in which glob() returns the list of file system
51 * entities which it has matched.
53 void * gl_magic; /* reserved field; pointer to a glob signature */
54 size_t gl_pathc; /* counter for paths matched */
55 char ** gl_pathv; /* list of matching path names */
56 size_t gl_offs; /* number of initial unused slots in gl_pathv */
59 /* A macro to facilitate definition of the flags which are used to
60 * control the operation of glob().
62 #define __GLOB_FLAG__(NAME) (1 << __GLOB_##NAME##_OFFSET)
64 /* Identify the zero-based offset values which are used to specify
65 * the individual bit positions for each __GLOB_FLAG; the initial
66 * list specifies the standard set of flags required by POSIX.
68 __GLOB_APPEND_OFFSET = 0,
72 __GLOB_NOCHECK_OFFSET,
73 __GLOB_NOESCAPE_OFFSET,
76 * GNU's implementation of glob() supports a supplementary set of
77 * options, none of which are required by POSIX. We include these
78 * for reference, and to reserve the flag identities for a possible
79 * future implementation; of these extensions, the current MinGW
80 * implementation supports only GLOB_BRACE.
83 __GLOB_TILDE_CHECK_OFFSET,
86 __GLOB_ONLYDIR_OFFSET,
87 __GLOB_ALTDIRFUNC_OFFSET,
88 __GLOB_NOMAGIC_OFFSET,
90 * This MinGW implementation DOES add support for the following
91 * custom options, which offer improved handling of MS-Windows
92 * specific peculiarities:--
94 * GLOB_CASEMATCH makes glob() respect case sensitivity
95 * in path name matches; this is similar
96 * to default behaviour on POSIX systems,
97 * but to better support the MS-Windows
98 * file system, the MinGW implementation
99 * of glob() performs a CASE INSENSITIVE
100 * character match by default.
102 __GLOB_CASEMATCH_OFFSET,
104 * The following is a convenience, to mark the end of the enumeration;
105 * it is NEVER used to locate any user visible __GLOB_FLAG__, but it
106 * MUST remain as the final entry in the enumerated list.
108 __GLOB_FLAG_OFFSET_HIGH_WATER_MARK
111 /* Definitions of the mandatory flags, as specified by POSIX.
113 #define GLOB_APPEND __GLOB_FLAG__(APPEND)
114 #define GLOB_DOOFFS __GLOB_FLAG__(DOOFFS)
115 #define GLOB_ERR __GLOB_FLAG__(ERR)
116 #define GLOB_MARK __GLOB_FLAG__(MARK)
117 #define GLOB_NOCHECK __GLOB_FLAG__(NOCHECK)
118 #define GLOB_NOESCAPE __GLOB_FLAG__(NOESCAPE)
119 #define GLOB_NOSORT __GLOB_FLAG__(NOSORT)
121 /* Flag definitions for those GNU extensions, as listed above, for which
122 * we provide support; (i.e. GLOB_BRACE only, at present).
124 #define GLOB_BRACE __GLOB_FLAG__(BRACE)
126 /* Additional flags definitions, for MinGW specific extensions.
128 #define GLOB_CASEMATCH __GLOB_FLAG__(CASEMATCH)
132 * Function prototypes. Formally POSIX mandates:
134 * int glob( const char *, int, int (*)( const char *, int ), glob_t * );
135 * void globfree( glob_t * );
137 * However, our actual function implementations are provided via this
138 * pair of reserved function names...
140 int __mingw_glob (const char *, int, int (*)(const char *, int), glob_t *);
141 void __mingw_globfree (glob_t *);
143 /* ...to which the standard names are then mapped as aliases,
144 * via __CRT_ALIAS inline function expansion.
146 __CRT_ALIAS __JMPSTUB__(( FUNCTION = glob ))
147 # define __ERRFUNC_P (*__errfunc) (const char *, int)
148 int glob (const char *__pattern, int __flags, int __ERRFUNC_P, glob_t *__data)
149 { return __mingw_glob (__pattern, __flags, __errfunc, __data); }
152 __CRT_ALIAS __JMPSTUB__(( FUNCTION = globfree ))
153 void globfree (glob_t *__data){ return __mingw_globfree (__data); }
157 /* Manifest definitions for the possible status values
158 * which glob() may return.
160 #define GLOB_SUCCESS (0)
161 #define GLOB_ABORTED (1)
162 #define GLOB_NOMATCH (2)
163 #define GLOB_NOSPACE (3)
165 #endif /* ! RC_INVOKED */
166 #endif /* !_GLOB_H: $RCSfile$: end of file */