Formerly ../posix/glob.h.~8~
[kopensolaris-gnu/glibc.git] / posix / glob.h
1 /* Copyright (C) 1991, 1992 Free Software Foundation, Inc.
2 This file is part of the GNU C Library.
3
4 The GNU C Library is free software; you can redistribute it and/or
5 modify it under the terms of the GNU Library General Public License as
6 published by the Free Software Foundation; either version 2 of the
7 License, or (at your option) any later version.
8
9 The GNU C Library is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12 Library General Public License for more details.
13
14 You should have received a copy of the GNU Library General Public
15 License along with the GNU C Library; see the file COPYING.LIB.  If
16 not, write to the Free Software Foundation, Inc., 675 Mass Ave,
17 Cambridge, MA 02139, USA.  */
18
19 #ifndef _GLOB_H
20
21 #define _GLOB_H 1
22
23 #ifdef  __cplusplus
24 extern "C" {
25 #endif
26
27 /* Bits set in the FLAGS argument to `glob'.  */
28 #define GLOB_ERR        (1 << 0)/* Return on read errors.  */
29 #define GLOB_MARK       (1 << 1)/* Append a slash to each name.  */
30 #define GLOB_NOSORT     (1 << 2)/* Don't sort the names.  */
31 #define GLOB_DOOFFS     (1 << 3)/* Insert PGLOB->gl_offs NULLs.  */
32 #define GLOB_NOCHECK    (1 << 4)/* If nothing matches, return the pattern.  */
33 #define GLOB_APPEND     (1 << 5)/* Append to results of a previous call.  */
34 #define GLOB_NOESCAPE   (1 << 6)/* Backslashes don't quote metacharacters.  */
35 #define GLOB_PERIOD     (1 << 7)/* Leading `.' can be matched by metachars.  */
36 #define __GLOB_FLAGS    (GLOB_ERR|GLOB_MARK|GLOB_NOSORT|GLOB_DOOFFS| \
37                          GLOB_NOESCAPE|GLOB_NOCHECK|GLOB_APPEND|GLOB_PERIOD)
38
39 /* Error returns from `glob'.  */
40 #define GLOB_NOSPACE    1       /* Ran out of memory.  */
41 #define GLOB_ABEND      2       /* Read error.  */
42 #define GLOB_NOMATCH    3       /* No matches found.  */
43
44 /* Structure describing a globbing run.  */
45 typedef struct
46   {
47     int gl_pathc;       /* Count of paths matched by the pattern.  */
48     char **gl_pathv;    /* List of matched pathnames.  */
49     int gl_offs;        /* Slots to reserve in `gl_pathv'.  */
50   } glob_t;
51
52 /* Do glob searching for PATTERN, placing results in PGLOB.
53    The bits defined above may be set in FLAGS.
54    If a directory cannot be opened or read and ERRFUNC is not nil,
55    it is called with the pathname that caused the error, and the
56    `errno' value from the failing call; if it returns non-zero
57    `glob' returns GLOB_ABEND; if it returns zero, the error is ignored.
58    If memory cannot be allocated for PGLOB, GLOB_NOSPACE is returned.
59    Otherwise, `glob' returns zero.  */
60 extern int EXFUN(glob, (CONST char *__pattern, int __flags,
61                         int EXFUN((*__errfunc), (CONST char *, int)),
62                         glob_t *__pglob));
63
64 /* Free storage allocated in PGLOB by a previous `glob' call.  */
65 extern void EXFUN(globfree, (glob_t *__pglob));
66
67 #ifdef  __cplusplus
68 }
69 #endif
70
71 #endif  /* glob.h  */