In commentary, do not use ` to quote.
[gnulib.git] / lib / fnmatch.in.h
1 /* Copyright (C) 1991-1993, 1996-1999, 2001-2003, 2005, 2007, 2009-2012 Free
2    Software Foundation, Inc.
3
4    This file is part of the GNU C Library.
5
6    This program is free software; you can redistribute it and/or modify
7    it under the terms of the GNU General Public License as published by
8    the Free Software Foundation; either version 2, or (at your option)
9    any later version.
10
11    This program is distributed in the hope that it will be useful,
12    but WITHOUT ANY WARRANTY; without even the implied warranty of
13    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14    GNU General Public License for more details.
15
16    You should have received a copy of the GNU General Public License
17    along with this program; if not, write to the Free Software Foundation,
18    Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.  */
19
20 #ifndef _FNMATCH_H
21 #define _FNMATCH_H      1
22
23 /* The definition of _GL_ARG_NONNULL is copied here.  */
24
25 #ifdef __cplusplus
26 extern "C" {
27 #endif
28
29 /* We #undef these before defining them because some losing systems
30    (HP-UX A.08.07 for example) define these in <unistd.h>.  */
31 #undef  FNM_PATHNAME
32 #undef  FNM_NOESCAPE
33 #undef  FNM_PERIOD
34
35 /* Bits set in the FLAGS argument to 'fnmatch'.  */
36 #define FNM_PATHNAME    (1 << 0) /* No wildcard can ever match '/'.  */
37 #define FNM_NOESCAPE    (1 << 1) /* Backslashes don't quote special chars.  */
38 #define FNM_PERIOD      (1 << 2) /* Leading '.' is matched only explicitly.  */
39
40 #if !defined _POSIX_C_SOURCE || _POSIX_C_SOURCE < 2 || defined _GNU_SOURCE
41 # define FNM_FILE_NAME   FNM_PATHNAME   /* Preferred GNU name.  */
42 # define FNM_LEADING_DIR (1 << 3)       /* Ignore '/...' after a match.  */
43 # define FNM_CASEFOLD    (1 << 4)       /* Compare without regard to case.  */
44 # define FNM_EXTMATCH    (1 << 5)       /* Use ksh-like extended matching. */
45 #endif
46
47 /* Value returned by 'fnmatch' if STRING does not match PATTERN.  */
48 #define FNM_NOMATCH     1
49
50 /* This value is returned if the implementation does not support
51    'fnmatch'.  Since this is not the case here it will never be
52    returned but the conformance test suites still require the symbol
53    to be defined.  */
54 #ifdef _XOPEN_SOURCE
55 # define FNM_NOSYS      (-1)
56 #endif
57
58 /* Match NAME against the file name pattern PATTERN,
59    returning zero if it matches, FNM_NOMATCH if not.  */
60 extern int fnmatch (const char *__pattern, const char *__name,
61                     int __flags)
62      _GL_ARG_NONNULL ((1, 2));
63
64 #ifdef __cplusplus
65 }
66 #endif
67
68 #endif /* fnmatch.h */