diff options
author | Ulrich Drepper <drepper@redhat.com> | 2001-03-28 06:25:09 +0000 |
---|---|---|
committer | Ulrich Drepper <drepper@redhat.com> | 2001-03-28 06:25:09 +0000 |
commit | 228293b5906774f8d5dffde32251863d045a354e (patch) | |
tree | 72d24b6e2e10251bea2175544236ea79b9d0860c /posix | |
parent | 325a39c51197c480891d83b742abc01e61c7786f (diff) | |
download | glibc-228293b5906774f8d5dffde32251863d045a354e.zip glibc-228293b5906774f8d5dffde32251863d045a354e.tar.gz glibc-228293b5906774f8d5dffde32251863d045a354e.tar.bz2 |
Update.
* posix/fnmatch_loop.c (FCT): Handle !() after * special like @()
and +().
* posix/tst-fnmatch.input: Add test cases for matching empty strings.
Diffstat (limited to 'posix')
-rw-r--r-- | posix/fnmatch_loop.c | 4 | ||||
-rw-r--r-- | posix/tst-fnmatch.input | 6 |
2 files changed, 7 insertions, 3 deletions
diff --git a/posix/fnmatch_loop.c b/posix/fnmatch_loop.c index 20ae0e3..fd25853 100644 --- a/posix/fnmatch_loop.c +++ b/posix/fnmatch_loop.c @@ -164,8 +164,8 @@ FCT (pattern, string, string_end, no_leading_period, flags) if (c == L('[') || (__builtin_expect (flags & FNM_EXTMATCH, 0) != 0 - /* XXX Do we have to add '!'? */ - && (c == L('@') || c == L('+')) && *p == L('('))) + && (c == L('@') || c == L('+') || c == L('!')) + && *p == L('('))) { int flags2 = ((flags & FNM_FILE_NAME) ? flags : (flags & ~FNM_PERIOD)); diff --git a/posix/tst-fnmatch.input b/posix/tst-fnmatch.input index 2191245..e448576 100644 --- a/posix/tst-fnmatch.input +++ b/posix/tst-fnmatch.input @@ -713,5 +713,9 @@ C "[" "!([!]a[])" 0 EXTMATCH C "]" "!([!]a[])" 0 EXTMATCH C ")" "*([)])" 0 EXTMATCH C "*" "*([*(])" 0 EXTMATCH -C "abcd" "*!(|a)cd" NOMATCH EXTMATCH +C "abcd" "*!(|a)cd" 0 EXTMATCH C "ab/.a" "+([abc])/*" NOMATCH EXTMATCH|PATHNAME|PERIOD +C "" "" 0 +C "" "" 0 EXTMATCH +C "" "*([abc])" 0 EXTMATCH +C "" "?([abc])" 0 EXTMATCH |