aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog4
-rw-r--r--posix/fnmatch.c21
2 files changed, 24 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index d80bc68..1772ea9 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+1998-07-22 23:47 Ulrich Drepper <drepper@cygnus.com>
+
+ * posix/fnmatch.c: Fix completely broken range matching.
+
1998-07-22 23:19 Ulrich Drepper <drepper@cygnus.com>
* sysdeps/unix/sysv/linux/bits/siginfo.h: Fix typo.
diff --git a/posix/fnmatch.c b/posix/fnmatch.c
index 4f5c667..e4677cb 100644
--- a/posix/fnmatch.c
+++ b/posix/fnmatch.c
@@ -35,7 +35,7 @@
# include <strings.h>
#endif
-#ifdef STDC_HEADERS
+#if defined STDC_HEADERS || defined _LIBC
# include <stdlib.h>
#endif
@@ -216,6 +216,7 @@ fnmatch (pattern, string, flags)
/* 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;
@@ -245,6 +246,9 @@ fnmatch (pattern, string, flags)
if (c == fn)
goto matched;
}
+ else if ((flags & FNM_FILE_NAME) && c == '/')
+ /* [/] can never match. */
+ return FNM_NOMATCH;
else if (c == '[' && *p == ':')
{
/* Leave room for the null. */
@@ -301,8 +305,23 @@ fnmatch (pattern, string, flags)
else if (FOLD (c) == fn)
goto matched;
+ cold = c;
c = *p++;
+ if (c == '-' && *p != ']')
+ {
+ /* It is a range. */
+ 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;
}