Browse Source
Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>maint


2 changed files with 0 additions and 578 deletions
@ -1,494 +0,0 @@
@@ -1,494 +0,0 @@
|
||||
/* Copyright (C) 1991, 92, 93, 96, 97, 98, 99 Free Software Foundation, Inc. |
||||
This file is part of the GNU C Library. |
||||
|
||||
This library is free software; you can redistribute it and/or |
||||
modify it under the terms of the GNU Library General Public License as |
||||
published by the Free Software Foundation; either version 2 of the |
||||
License, or (at your option) any later version. |
||||
|
||||
This 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 |
||||
Library General Public License for more details. |
||||
|
||||
You should have received a copy of the GNU Library General Public |
||||
License along with this library; see the file COPYING.LIB. If not, |
||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, |
||||
Boston, MA 02111-1307, USA. */ |
||||
|
||||
#if HAVE_CONFIG_H |
||||
# include <config.h> |
||||
#endif |
||||
|
||||
/* Enable GNU extensions in fnmatch.h. */ |
||||
#ifndef _GNU_SOURCE |
||||
# define _GNU_SOURCE 1 |
||||
#endif |
||||
|
||||
#include <stddef.h> |
||||
#include <errno.h> |
||||
#include <fnmatch.h> |
||||
#include <ctype.h> |
||||
|
||||
#if HAVE_STRING_H || defined _LIBC |
||||
# include <string.h> |
||||
#else |
||||
# include <strings.h> |
||||
#endif |
||||
|
||||
#if defined STDC_HEADERS || defined _LIBC |
||||
# include <stdlib.h> |
||||
#endif |
||||
|
||||
/* For platforms which support the ISO C amendment 1 functionality we |
||||
support user defined character classes. */ |
||||
#if defined _LIBC || (defined HAVE_WCTYPE_H && defined HAVE_WCHAR_H) |
||||
/* Solaris 2.5 has a bug: <wchar.h> must be included before <wctype.h>. */ |
||||
# include <wchar.h> |
||||
# include <wctype.h> |
||||
#endif |
||||
|
||||
/* Comment out all this code if we are using the GNU C Library, and are not |
||||
actually compiling the library itself. This code is part of the GNU C |
||||
Library, but also included in many other GNU distributions. Compiling |
||||
and linking in this code is a waste when using the GNU C library |
||||
(especially if it is a shared library). Rather than having every GNU |
||||
program understand `configure --with-gnu-libc' and omit the object files, |
||||
it is simpler to just do this in the source for each such file. */ |
||||
|
||||
#if defined NO_FNMATCH || defined NO_FNMATCH_CASEFOLD || \ |
||||
defined _LIBC || !defined __GNU_LIBRARY__ |
||||
|
||||
|
||||
# if defined STDC_HEADERS || !defined isascii |
||||
# define ISASCII(c) 1 |
||||
# else |
||||
# define ISASCII(c) isascii(c) |
||||
# endif |
||||
|
||||
# ifdef isblank |
||||
# define ISBLANK(c) (ISASCII (c) && isblank (c)) |
||||
# else |
||||
# define ISBLANK(c) ((c) == ' ' || (c) == '\t') |
||||
# endif |
||||
# ifdef isgraph |
||||
# define ISGRAPH(c) (ISASCII (c) && isgraph (c)) |
||||
# else |
||||
# define ISGRAPH(c) (ISASCII (c) && isprint (c) && !isspace (c)) |
||||
# endif |
||||
|
||||
# define ISPRINT(c) (ISASCII (c) && isprint (c)) |
||||
# define ISDIGIT(c) (ISASCII (c) && isdigit (c)) |
||||
# define ISALNUM(c) (ISASCII (c) && isalnum (c)) |
||||
# define ISALPHA(c) (ISASCII (c) && isalpha (c)) |
||||
# define ISCNTRL(c) (ISASCII (c) && iscntrl (c)) |
||||
# define ISLOWER(c) (ISASCII (c) && islower (c)) |
||||
# define ISPUNCT(c) (ISASCII (c) && ispunct (c)) |
||||
# define ISSPACE(c) (ISASCII (c) && isspace (c)) |
||||
# define ISUPPER(c) (ISASCII (c) && isupper (c)) |
||||
# define ISXDIGIT(c) (ISASCII (c) && isxdigit (c)) |
||||
|
||||
# define STREQ(s1, s2) ((strcmp (s1, s2) == 0)) |
||||
|
||||
# if defined _LIBC || (defined HAVE_WCTYPE_H && defined HAVE_WCHAR_H) |
||||
/* The GNU C library provides support for user-defined character classes |
||||
and the functions from ISO C amendment 1. */ |
||||
# ifdef CHARCLASS_NAME_MAX |
||||
# define CHAR_CLASS_MAX_LENGTH CHARCLASS_NAME_MAX |
||||
# else |
||||
/* This shouldn't happen but some implementation might still have this |
||||
problem. Use a reasonable default value. */ |
||||
# define CHAR_CLASS_MAX_LENGTH 256 |
||||
# endif |
||||
|
||||
# ifdef _LIBC |
||||
# define IS_CHAR_CLASS(string) __wctype (string) |
||||
# else |
||||
# define IS_CHAR_CLASS(string) wctype (string) |
||||
# endif |
||||
# else |
||||
# define CHAR_CLASS_MAX_LENGTH 6 /* Namely, `xdigit'. */ |
||||
|
||||
# define IS_CHAR_CLASS(string) \ |
||||
(STREQ (string, "alpha") || STREQ (string, "upper") \ |
||||
|| STREQ (string, "lower") || STREQ (string, "digit") \ |
||||
|| STREQ (string, "alnum") || STREQ (string, "xdigit") \ |
||||
|| STREQ (string, "space") || STREQ (string, "print") \ |
||||
|| STREQ (string, "punct") || STREQ (string, "graph") \ |
||||
|| STREQ (string, "cntrl") || STREQ (string, "blank")) |
||||
# endif |
||||
|
||||
/* Avoid depending on library functions or files |
||||
whose names are inconsistent. */ |
||||
|
||||
# if !defined _LIBC && !defined getenv |
||||
extern char *getenv (const char *name); |
||||
# endif |
||||
|
||||
# ifndef errno |
||||
extern int errno; |
||||
# endif |
||||
|
||||
# ifndef NULL |
||||
# define NULL 0 |
||||
# endif |
||||
|
||||
/* This function doesn't exist on most systems. */ |
||||
|
||||
# if !defined HAVE___STRCHRNUL && !defined _LIBC |
||||
static char * |
||||
__strchrnul (const char *s, int c) |
||||
|
||||
|
||||
{ |
||||
char *result = strchr (s, c); |
||||
if (result == NULL) |
||||
result = strchr (s, '\0'); |
||||
return result; |
||||
} |
||||
# endif |
||||
|
||||
# ifndef internal_function |
||||
/* Inside GNU libc we mark some function in a special way. In other |
||||
environments simply ignore the marking. */ |
||||
# define internal_function |
||||
# endif |
||||
|
||||
/* Match STRING against the filename pattern PATTERN, returning zero if |
||||
it matches, nonzero if not. */ |
||||
static int internal_fnmatch __P ((const char *pattern, const char *string, |
||||
int no_leading_period, int flags)) |
||||
internal_function; |
||||
static int |
||||
internal_function |
||||
internal_fnmatch (const char *pattern, const char *string, int no_leading_period, int flags) |
||||
|
||||
|
||||
|
||||
|
||||
{ |
||||
register const char *p = pattern, *n = string; |
||||
register unsigned char c; |
||||
|
||||
/* Note that this evaluates C many times. */ |
||||
# ifdef _LIBC |
||||
# define FOLD(c) ((flags & FNM_CASEFOLD) ? tolower (c) : (c)) |
||||
# else |
||||
# define FOLD(c) ((flags & FNM_CASEFOLD) && ISUPPER (c) ? tolower (c) : (c)) |
||||
# endif |
||||
|
||||
while ((c = *p++) != '\0') |
||||
{ |
||||
c = FOLD (c); |
||||
|
||||
switch (c) |
||||
{ |
||||
case '?': |
||||
if (*n == '\0') |
||||
return FNM_NOMATCH; |
||||
else if (*n == '/' && (flags & FNM_FILE_NAME)) |
||||
return FNM_NOMATCH; |
||||
else if (*n == '.' && no_leading_period |
||||
&& (n == string |
||||
|| (n[-1] == '/' && (flags & FNM_FILE_NAME)))) |
||||
return FNM_NOMATCH; |
||||
break; |
||||
|
||||
case '\\': |
||||
if (!(flags & FNM_NOESCAPE)) |
||||
{ |
||||
c = *p++; |
||||
if (c == '\0') |
||||
/* Trailing \ loses. */ |
||||
return FNM_NOMATCH; |
||||
c = FOLD (c); |
||||
} |
||||
if (FOLD ((unsigned char) *n) != c) |
||||
return FNM_NOMATCH; |
||||
break; |
||||
|
||||
case '*': |
||||
if (*n == '.' && no_leading_period |
||||
&& (n == string |
||||
|| (n[-1] == '/' && (flags & FNM_FILE_NAME)))) |
||||
return FNM_NOMATCH; |
||||
|
||||
for (c = *p++; c == '?' || c == '*'; c = *p++) |
||||
{ |
||||
if (*n == '/' && (flags & FNM_FILE_NAME)) |
||||
/* A slash does not match a wildcard under FNM_FILE_NAME. */ |
||||
return FNM_NOMATCH; |
||||
else if (c == '?') |
||||
{ |
||||
/* A ? needs to match one character. */ |
||||
if (*n == '\0') |
||||
/* There isn't another character; no match. */ |
||||
return FNM_NOMATCH; |
||||
else |
||||
/* One character of the string is consumed in matching |
||||
this ? wildcard, so *??? won't match if there are |
||||
less than three characters. */ |
||||
++n; |
||||
} |
||||
} |
||||
|
||||
if (c == '\0') |
||||
/* The wildcard(s) is/are the last element of the pattern. |
||||
If the name is a file name and contains another slash |
||||
this does mean it cannot match. */ |
||||
return ((flags & FNM_FILE_NAME) && strchr (n, '/') != NULL |
||||
? FNM_NOMATCH : 0); |
||||
else |
||||
{ |
||||
const char *endp; |
||||
|
||||
endp = __strchrnul (n, (flags & FNM_FILE_NAME) ? '/' : '\0'); |
||||
|
||||
if (c == '[') |
||||
{ |
||||
int flags2 = ((flags & FNM_FILE_NAME) |
||||
? flags : (flags & ~FNM_PERIOD)); |
||||
|
||||
for (--p; n < endp; ++n) |
||||
if (internal_fnmatch (p, n, |
||||
(no_leading_period |
||||
&& (n == string |
||||
|| (n[-1] == '/' |
||||
&& (flags |
||||
& FNM_FILE_NAME)))), |
||||
flags2) |
||||
== 0) |
||||
return 0; |
||||
} |
||||
else if (c == '/' && (flags & FNM_FILE_NAME)) |
||||
{ |
||||
while (*n != '\0' && *n != '/') |
||||
++n; |
||||
if (*n == '/' |
||||
&& (internal_fnmatch (p, n + 1, flags & FNM_PERIOD, |
||||
flags) == 0)) |
||||
return 0; |
||||
} |
||||
else |
||||
{ |
||||
int flags2 = ((flags & FNM_FILE_NAME) |
||||
? flags : (flags & ~FNM_PERIOD)); |
||||
|
||||
if (c == '\\' && !(flags & FNM_NOESCAPE)) |
||||
c = *p; |
||||
c = FOLD (c); |
||||
for (--p; n < endp; ++n) |
||||
if (FOLD ((unsigned char) *n) == c |
||||
&& (internal_fnmatch (p, n, |
||||
(no_leading_period |
||||
&& (n == string |
||||
|| (n[-1] == '/' |
||||
&& (flags |
||||
& FNM_FILE_NAME)))), |
||||
flags2) == 0)) |
||||
return 0; |
||||
} |
||||
} |
||||
|
||||
/* If we come here no match is possible with the wildcard. */ |
||||
return FNM_NOMATCH; |
||||
|
||||
case '[': |
||||
{ |
||||
/* Nonzero if the sense of the character class is inverted. */ |
||||
static int posixly_correct; |
||||
register int not; |
||||
char cold; |
||||
|
||||
if (posixly_correct == 0) |
||||
posixly_correct = getenv ("POSIXLY_CORRECT") != NULL ? 1 : -1; |
||||
|
||||
if (*n == '\0') |
||||
return FNM_NOMATCH; |
||||
|
||||
if (*n == '.' && no_leading_period && (n == string |
||||
|| (n[-1] == '/' |
||||
&& (flags |
||||
& FNM_FILE_NAME)))) |
||||
return FNM_NOMATCH; |
||||
|
||||
if (*n == '/' && (flags & FNM_FILE_NAME)) |
||||
/* `/' cannot be matched. */ |
||||
return FNM_NOMATCH; |
||||
|
||||
not = (*p == '!' || (posixly_correct < 0 && *p == '^')); |
||||
if (not) |
||||
++p; |
||||
|
||||
c = *p++; |
||||
for (;;) |
||||
{ |
||||
unsigned char fn = FOLD ((unsigned char) *n); |
||||
|
||||
if (!(flags & FNM_NOESCAPE) && c == '\\') |
||||
{ |
||||
if (*p == '\0') |
||||
return FNM_NOMATCH; |
||||
c = FOLD ((unsigned char) *p); |
||||
++p; |
||||
|
||||
if (c == fn) |
||||
goto matched; |
||||
} |
||||
else if (c == '[' && *p == ':') |
||||
{ |
||||
/* Leave room for the null. */ |
||||
char str[CHAR_CLASS_MAX_LENGTH + 1]; |
||||
size_t c1 = 0; |
||||
# if defined _LIBC || (defined HAVE_WCTYPE_H && defined HAVE_WCHAR_H) |
||||
wctype_t wt; |
||||
# endif |
||||
const char *startp = p; |
||||
|
||||
for (;;) |
||||
{ |
||||
if (c1 > CHAR_CLASS_MAX_LENGTH) |
||||
/* The name is too long and therefore the pattern |
||||
is ill-formed. */ |
||||
return FNM_NOMATCH; |
||||
|
||||
c = *++p; |
||||
if (c == ':' && p[1] == ']') |
||||
{ |
||||
p += 2; |
||||
break; |
||||
} |
||||
if (c < 'a' || c >= 'z') |
||||
{ |
||||
/* This cannot possibly be a character class name. |
||||
Match it as a normal range. */ |
||||
p = startp; |
||||
c = '['; |
||||
goto normal_bracket; |
||||
} |
||||
str[c1++] = c; |
||||
} |
||||
str[c1] = '\0'; |
||||
|
||||
# if defined _LIBC || (defined HAVE_WCTYPE_H && defined HAVE_WCHAR_H) |
||||
wt = IS_CHAR_CLASS (str); |
||||
if (wt == 0) |
||||
/* Invalid character class name. */ |
||||
return FNM_NOMATCH; |
||||
|
||||
if (__iswctype (__btowc ((unsigned char) *n), wt)) |
||||
goto matched; |
||||
# else |
||||
if ((STREQ (str, "alnum") && ISALNUM ((unsigned char) *n)) |
||||
|| (STREQ (str, "alpha") && ISALPHA ((unsigned char) *n)) |
||||
|| (STREQ (str, "blank") && ISBLANK ((unsigned char) *n)) |
||||
|| (STREQ (str, "cntrl") && ISCNTRL ((unsigned char) *n)) |
||||
|| (STREQ (str, "digit") && ISDIGIT ((unsigned char) *n)) |
||||
|| (STREQ (str, "graph") && ISGRAPH ((unsigned char) *n)) |
||||
|| (STREQ (str, "lower") && ISLOWER ((unsigned char) *n)) |
||||
|| (STREQ (str, "print") && ISPRINT ((unsigned char) *n)) |
||||
|| (STREQ (str, "punct") && ISPUNCT ((unsigned char) *n)) |
||||
|| (STREQ (str, "space") && ISSPACE ((unsigned char) *n)) |
||||
|| (STREQ (str, "upper") && ISUPPER ((unsigned char) *n)) |
||||
|| (STREQ (str, "xdigit") && ISXDIGIT ((unsigned char) *n))) |
||||
goto matched; |
||||
# endif |
||||
} |
||||
else if (c == '\0') |
||||
/* [ (unterminated) loses. */ |
||||
return FNM_NOMATCH; |
||||
else |
||||
{ |
||||
normal_bracket: |
||||
if (FOLD (c) == fn) |
||||
goto matched; |
||||
|
||||
cold = c; |
||||
c = *p++; |
||||
|
||||
if (c == '-' && *p != ']') |
||||
{ |
||||
/* It is a range. */ |
||||
unsigned char cend = *p++; |
||||
if (!(flags & FNM_NOESCAPE) && cend == '\\') |
||||
cend = *p++; |
||||
if (cend == '\0') |
||||
return FNM_NOMATCH; |
||||
|
||||
if (cold <= fn && fn <= FOLD (cend)) |
||||
goto matched; |
||||
|
||||
c = *p++; |
||||
} |
||||
} |
||||
|
||||
if (c == ']') |
||||
break; |
||||
} |
||||
|
||||
if (!not) |
||||
return FNM_NOMATCH; |
||||
break; |
||||
|
||||
matched: |
||||
/* Skip the rest of the [...] that already matched. */ |
||||
while (c != ']') |
||||
{ |
||||
if (c == '\0') |
||||
/* [... (unterminated) loses. */ |
||||
return FNM_NOMATCH; |
||||
|
||||
c = *p++; |
||||
if (!(flags & FNM_NOESCAPE) && c == '\\') |
||||
{ |
||||
if (*p == '\0') |
||||
return FNM_NOMATCH; |
||||
/* XXX 1003.2d11 is unclear if this is right. */ |
||||
++p; |
||||
} |
||||
else if (c == '[' && *p == ':') |
||||
{ |
||||
do |
||||
if (*++p == '\0') |
||||
return FNM_NOMATCH; |
||||
while (*p != ':' || p[1] == ']'); |
||||
p += 2; |
||||
c = *p; |
||||
} |
||||
} |
||||
if (not) |
||||
return FNM_NOMATCH; |
||||
} |
||||
break; |
||||
|
||||
default: |
||||
if (c != FOLD ((unsigned char) *n)) |
||||
return FNM_NOMATCH; |
||||
} |
||||
|
||||
++n; |
||||
} |
||||
|
||||
if (*n == '\0') |
||||
return 0; |
||||
|
||||
if ((flags & FNM_LEADING_DIR) && *n == '/') |
||||
/* The FNM_LEADING_DIR flag says that "foo*" matches "foobar/frobozz". */ |
||||
return 0; |
||||
|
||||
return FNM_NOMATCH; |
||||
|
||||
# undef FOLD |
||||
} |
||||
|
||||
|
||||
int |
||||
fnmatch (const char *pattern, const char *string, int flags) |
||||
|
||||
|
||||
|
||||
{ |
||||
return internal_fnmatch (pattern, string, flags & FNM_PERIOD, flags); |
||||
} |
||||
|
||||
#endif /* _LIBC or not __GNU_LIBRARY__. */ |
@ -1,84 +0,0 @@
@@ -1,84 +0,0 @@
|
||||
/* Copyright (C) 1991, 92, 93, 96, 97, 98, 99 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 Library General Public License as |
||||
published by the Free Software Foundation; either version 2 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 |
||||
Library General Public License for more details. |
||||
|
||||
You should have received a copy of the GNU Library General Public |
||||
License along with the GNU C Library; see the file COPYING.LIB. If not, |
||||
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, |
||||
Boston, MA 02111-1307, USA. */ |
||||
|
||||
#ifndef _FNMATCH_H |
||||
#define _FNMATCH_H 1 |
||||
|
||||
#ifdef __cplusplus |
||||
extern "C" { |
||||
#endif |
||||
|
||||
#if defined __cplusplus || (defined __STDC__ && __STDC__) || defined WINDOWS32 |
||||
# if !defined __GLIBC__ || !defined __P |
||||
# undef __P |
||||
# define __P(protos) protos |
||||
# endif |
||||
#else /* Not C++ or ANSI C. */ |
||||
# undef __P |
||||
# define __P(protos) () |
||||
/* We can get away without defining `const' here only because in this file |
||||
it is used only inside the prototype for `fnmatch', which is elided in |
||||
non-ANSI C where `const' is problematical. */ |
||||
#endif /* C++ or ANSI C. */ |
||||
|
||||
#ifndef const |
||||
# if (defined __STDC__ && __STDC__) || defined __cplusplus |
||||
# define __const const |
||||
# else |
||||
# define __const |
||||
# endif |
||||
#endif |
||||
|
||||
/* We #undef these before defining them because some losing systems |
||||
(HP-UX A.08.07 for example) define these in <unistd.h>. */ |
||||
#undef FNM_PATHNAME |
||||
#undef FNM_NOESCAPE |
||||
#undef FNM_PERIOD |
||||
|
||||
/* Bits set in the FLAGS argument to `fnmatch'. */ |
||||
#define FNM_PATHNAME (1 << 0) /* No wildcard can ever match `/'. */ |
||||
#define FNM_NOESCAPE (1 << 1) /* Backslashes don't quote special chars. */ |
||||
#define FNM_PERIOD (1 << 2) /* Leading `.' is matched only explicitly. */ |
||||
|
||||
#if !defined _POSIX_C_SOURCE || _POSIX_C_SOURCE < 2 || defined _GNU_SOURCE |
||||
# define FNM_FILE_NAME FNM_PATHNAME /* Preferred GNU name. */ |
||||
# define FNM_LEADING_DIR (1 << 3) /* Ignore `/...' after a match. */ |
||||
# define FNM_CASEFOLD (1 << 4) /* Compare without regard to case. */ |
||||
#endif |
||||
|
||||
/* Value returned by `fnmatch' if STRING does not match PATTERN. */ |
||||
#define FNM_NOMATCH 1 |
||||
|
||||
/* This value is returned if the implementation does not support |
||||
`fnmatch'. Since this is not the case here it will never be |
||||
returned but the conformance test suites still require the symbol |
||||
to be defined. */ |
||||
#ifdef _XOPEN_SOURCE |
||||
# define FNM_NOSYS (-1) |
||||
#endif |
||||
|
||||
/* Match NAME against the filename pattern PATTERN, |
||||
returning zero if it matches, FNM_NOMATCH if not. */ |
||||
extern int fnmatch __P ((__const char *__pattern, __const char *__name, |
||||
int __flags)); |
||||
|
||||
#ifdef __cplusplus |
||||
} |
||||
#endif |
||||
|
||||
#endif /* fnmatch.h */ |
Loading…
Reference in new issue