yann@1201: Original patch from: gentoo/src/patchsets/glibc/2.9/5021_all_2.9-fnmatch.patch yann@1201: yann@1201: -= BEGIN original header =- yann@1201: http://sourceware.org/ml/libc-hacker/2002-11/msg00071.html yann@1201: yann@1201: When fnmatch detects an invalid multibyte character it should fall back to yann@1201: single byte matching, so that "*" has a chance to match such a string. yann@1201: yann@1201: Andreas. yann@1201: yann@1201: 2005-04-12 Andreas Schwab yann@1201: yann@1201: * posix/fnmatch.c (fnmatch): If conversion to wide character yann@1201: fails fall back to single byte matching. yann@1201: yann@1201: -= END original header =- yann@1201: yann@1201: diff -durN glibc-2_9.orig/posix/fnmatch.c glibc-2_9/posix/fnmatch.c yann@1201: --- glibc-2_9.orig/posix/fnmatch.c 2007-07-28 22:35:00.000000000 +0200 yann@1201: +++ glibc-2_9/posix/fnmatch.c 2009-02-02 22:01:25.000000000 +0100 yann@1201: @@ -327,6 +327,7 @@ yann@1201: # if HANDLE_MULTIBYTE yann@1201: if (__builtin_expect (MB_CUR_MAX, 1) != 1) yann@1201: { yann@1201: + const char *orig_pattern = pattern; yann@1201: mbstate_t ps; yann@1201: size_t n; yann@1201: const char *p; yann@1201: @@ -382,10 +383,8 @@ yann@1201: wstring = (wchar_t *) alloca ((n + 1) * sizeof (wchar_t)); yann@1201: n = mbsrtowcs (wstring, &p, n + 1, &ps); yann@1201: if (__builtin_expect (n == (size_t) -1, 0)) yann@1201: - /* Something wrong. yann@1201: - XXX Do we have to set `errno' to something which mbsrtows hasn't yann@1201: - already done? */ yann@1201: - return -1; yann@1201: + /* Something wrong. Fall back to single byte matching. */ yann@1201: + goto try_singlebyte; yann@1201: if (p) yann@1201: { yann@1201: memset (&ps, '\0', sizeof (ps)); yann@1201: @@ -397,10 +396,8 @@ yann@1201: prepare_wstring: yann@1201: n = mbsrtowcs (NULL, &string, 0, &ps); yann@1201: if (__builtin_expect (n == (size_t) -1, 0)) yann@1201: - /* Something wrong. yann@1201: - XXX Do we have to set `errno' to something which mbsrtows hasn't yann@1201: - already done? */ yann@1201: - return -1; yann@1201: + /* Something wrong. Fall back to single byte matching. */ yann@1201: + goto try_singlebyte; yann@1201: wstring = (wchar_t *) alloca ((n + 1) * sizeof (wchar_t)); yann@1201: assert (mbsinit (&ps)); yann@1201: (void) mbsrtowcs (wstring, &string, n + 1, &ps); yann@1201: @@ -408,6 +405,9 @@ yann@1201: yann@1201: return internal_fnwmatch (wpattern, wstring, wstring + n, yann@1201: flags & FNM_PERIOD, flags, NULL); yann@1201: + yann@1201: + try_singlebyte: yann@1201: + pattern = orig_pattern; yann@1201: } yann@1201: # endif /* mbstate_t and mbsrtowcs or _LIBC. */ yann@1201: