When fnmatch detects an invalid multibyte character it should fall back to single byte matching, so that "*" has a chance to match such a string. Andreas. 2005-04-12 Andreas Schwab * posix/fnmatch.c (fnmatch): If conversion to wide character fails fall back to single byte matching. --- glibc-2.3.90.orig/posix/fnmatch.c 30 Mar 2005 04:17:47 -0000 1.51 +++ glibc-2.3.90/posix/fnmatch.c 12 Apr 2005 11:35:51 -0000 @@ -325,6 +325,7 @@ fnmatch (pattern, string, flags) # if HANDLE_MULTIBYTE if (__builtin_expect (MB_CUR_MAX, 1) != 1) { + const char *orig_pattern = pattern; mbstate_t ps; size_t n; const char *p; @@ -376,10 +377,8 @@ fnmatch (pattern, string, flags) wstring = (wchar_t *) alloca ((n + 1) * sizeof (wchar_t)); n = mbsrtowcs (wstring, &p, n + 1, &ps); if (__builtin_expect (n == (size_t) -1, 0)) - /* Something wrong. - XXX Do we have to set `errno' to something which mbsrtows hasn't - already done? */ - return -1; + /* Something wrong. Fall back to single byte matching. */ + goto try_singlebyte; if (p) memset (&ps, '\0', sizeof (ps)); } @@ -387,10 +386,8 @@ fnmatch (pattern, string, flags) { n = mbsrtowcs (NULL, &string, 0, &ps); if (__builtin_expect (n == (size_t) -1, 0)) - /* Something wrong. - XXX Do we have to set `errno' to something which mbsrtows hasn't - already done? */ - return -1; + /* Something wrong. Fall back to single byte matching. */ + goto try_singlebyte; wstring = (wchar_t *) alloca ((n + 1) * sizeof (wchar_t)); assert (mbsinit (&ps)); (void) mbsrtowcs (wstring, &string, n + 1, &ps); @@ -398,6 +395,9 @@ fnmatch (pattern, string, flags) return internal_fnwmatch (wpattern, wstring, wstring + n, flags & FNM_PERIOD, flags); + + try_singlebyte: + pattern = orig_pattern; } # endif /* mbstate_t and mbsrtowcs or _LIBC. */