Beside the flags described in the last section, the GNU implementation of
glob allows a few more flags which are also defined in the
`glob.h' file.  Some of the extensions implement functionality
which is available in modern shell implementations.
GLOB_PERIOD
. character (period) is treated special.  It cannot be
matched by wildcards.  See section Wildcard Matching, FNM_PERIOD.
GLOB_MAGCHAR
GLOB_MAGCHAR value is not to be given to glob in the
flags parameter.  Instead, glob sets this bit in the
gl_flags element of the glob_t structure provided as the
result if the pattern used for matching contains any wildcard character.
GLOB_ALTDIRFUNC
glob implementation uses the user-supplied
functions specified in the structure pointed to by pglob
parameter.  For more information about the functions refer to the
sections about directory handling see section Accessing Directories, and
section Reading the Attributes of a File.
GLOB_BRACE
, (comma) characters.  The commas
themself are discarded.  Please note what we said above about recursive
brace expressions.  The commas used to separate the subexpressions must
be at the same level.  Commas in brace subexpressions are not matched.
They are used during expansion of the brace expression of the deeper
level.  The example below shows this
glob ("{foo/{,bar,biz},baz}", GLOB_BRACE, NULL, &result)
is equivalent to the sequence
glob ("foo/", GLOB_BRACE, NULL, &result)
glob ("foo/bar", GLOB_BRACE|GLOB_APPEND, NULL, &result)
glob ("foo/biz", GLOB_BRACE|GLOB_APPEND, NULL, &result)
glob ("baz", GLOB_BRACE|GLOB_APPEND, NULL, &result)
if we leave aside error handling.
GLOB_NOMAGIC
GLOB_TILDE
~ (tilde) is handled special
if it appears at the beginning of the pattern.  Instead of being taken
verbatim it is used to represent the home directory of a known user.
If ~ is the only character in pattern or it is followed by a
/ (slash), the home directory of the process owner is
substituted.  Using getlogin and getpwnam the information
is read from the system databases.  As an example take user bart
with his home directory at `/home/bart'.  For him a call like
glob ("~/bin/*", GLOB_TILDE, NULL, &result)
would return the contents of the directory `/home/bart/bin'.
Instead of referring to the own home directory it is also possible to
name the home directory of other users.  To do so one has to append the
user name after the tilde character.  So the contents of user
homer's `bin' directory can be retrieved by
glob ("~homer/bin/*", GLOB_TILDE, NULL, &result)
If the user name is not valid or the home directory cannot be determined
for some reason the pattern is left untouched and itself used as the
result.  I.e., if in the last example home is not available the
tilde expansion yields to "~homer/bin/*" and glob is not
looking for a directory named ~homer.
This functionality is equivalent to what is available in C-shells if the
nonomatch flag is set.
GLOB_TILDE_CHECK
glob behaves like as if GLOB_TILDE is
given.  The only difference is that if the user name is not available or
the home directory cannot be determined for other reasons this leads to
an error.  glob will return GLOB_NOMATCH instead of using
the pattern itself as the name.
This functionality is equivalent to what is available in C-shells if
nonomatch flag is not set.
GLOB_ONLYDIR
glob
implementation.  It is mainly used internally to increase the
performance but might be useful for a user as well and therefore is
documented here.
Calling glob will in most cases allocate resources which are used
to represent the result of the function call.  If the same object of
type glob_t is used in multiple call to glob the resources
are freed or reused so that no leaks appear.  But this does not include
the time when all glob calls are done.
globfree function frees all resources allocated by previous
calls to glob associated with the object pointed to by
pglob.  This function should be called whenever the currently used
glob_t typed object isn't used anymore.
globfree but it frees records of
type glob64_t which were allocated by glob64.
Go to the first, previous, next, last section, table of contents.