Index: gdb/gnulib/import/m4/fnmatch.m4 |
diff --git a/gdb/gnulib/import/m4/fnmatch.m4 b/gdb/gnulib/import/m4/fnmatch.m4 |
new file mode 100644 |
index 0000000000000000000000000000000000000000..e46b6e521cfa103ee1e135e8a023434c0620cb4b |
--- /dev/null |
+++ b/gdb/gnulib/import/m4/fnmatch.m4 |
@@ -0,0 +1,156 @@ |
+# Check for fnmatch - serial 9. |
+ |
+# Copyright (C) 2000-2007, 2009-2012 Free Software Foundation, Inc. |
+# This file is free software; the Free Software Foundation |
+# gives unlimited permission to copy and/or distribute it, |
+# with or without modifications, as long as this notice is preserved. |
+ |
+# Autoconf defines AC_FUNC_FNMATCH, but that is obsolescent. |
+# New applications should use the macros below instead. |
+ |
+# Request a POSIX compliant fnmatch function. |
+AC_DEFUN([gl_FUNC_FNMATCH_POSIX], |
+[ |
+ m4_divert_text([DEFAULTS], [gl_fnmatch_required=POSIX]) |
+ |
+ dnl Persuade glibc <fnmatch.h> to declare FNM_CASEFOLD etc. |
+ dnl This is only needed if gl_fnmatch_required = GNU. It would be possible |
+ dnl to avoid this dependency for gl_FUNC_FNMATCH_POSIX by putting |
+ dnl gl_FUNC_FNMATCH_GNU into a separate .m4 file. |
+ AC_REQUIRE([AC_USE_SYSTEM_EXTENSIONS]) |
+ |
+ FNMATCH_H= |
+ gl_fnmatch_required_lowercase=` |
+ echo $gl_fnmatch_required | LC_ALL=C tr '[[A-Z]]' '[[a-z]]' |
+ ` |
+ gl_fnmatch_cache_var="gl_cv_func_fnmatch_${gl_fnmatch_required_lowercase}" |
+ AC_CACHE_CHECK([for working $gl_fnmatch_required fnmatch], |
+ [$gl_fnmatch_cache_var], |
+ [dnl Some versions of Solaris, SCO, and the GNU C Library |
+ dnl have a broken or incompatible fnmatch. |
+ dnl So we run a test program. If we are cross-compiling, take no chance. |
+ dnl Thanks to John Oleynick, François Pinard, and Paul Eggert for this |
+ dnl test. |
+ if test $gl_fnmatch_required = GNU; then |
+ gl_fnmatch_gnu_start= |
+ gl_fnmatch_gnu_end= |
+ else |
+ gl_fnmatch_gnu_start='#if 0' |
+ gl_fnmatch_gnu_end='#endif' |
+ fi |
+ AC_RUN_IFELSE( |
+ [AC_LANG_PROGRAM( |
+ [[#include <fnmatch.h> |
+ static int |
+ y (char const *pattern, char const *string, int flags) |
+ { |
+ return fnmatch (pattern, string, flags) == 0; |
+ } |
+ static int |
+ n (char const *pattern, char const *string, int flags) |
+ { |
+ return fnmatch (pattern, string, flags) == FNM_NOMATCH; |
+ } |
+ ]], |
+ [[char const *Apat = 'A' < '\\\\' ? "[A-\\\\\\\\]" : "[\\\\\\\\-A]"; |
+ char const *apat = 'a' < '\\\\' ? "[a-\\\\\\\\]" : "[\\\\\\\\-a]"; |
+ static char const A_1[] = { 'A' - 1, 0 }; |
+ static char const A01[] = { 'A' + 1, 0 }; |
+ static char const a_1[] = { 'a' - 1, 0 }; |
+ static char const a01[] = { 'a' + 1, 0 }; |
+ static char const bs_1[] = { '\\\\' - 1, 0 }; |
+ static char const bs01[] = { '\\\\' + 1, 0 }; |
+ int result = 0; |
+ if (!n ("a*", "", 0)) |
+ return 1; |
+ if (!y ("a*", "abc", 0)) |
+ return 1; |
+ if (!y ("[/b", "[/b", 0)) /*"]]"*/ /* glibc Bugzilla bug 12378 */ |
+ return 1; |
+ if (!n ("d*/*1", "d/s/1", FNM_PATHNAME)) |
+ return 2; |
+ if (!y ("a\\\\bc", "abc", 0)) |
+ return 3; |
+ if (!n ("a\\\\bc", "abc", FNM_NOESCAPE)) |
+ return 3; |
+ if (!y ("*x", ".x", 0)) |
+ return 4; |
+ if (!n ("*x", ".x", FNM_PERIOD)) |
+ return 4; |
+ if (!y (Apat, "\\\\", 0)) |
+ return 5; |
+ if (!y (Apat, "A", 0)) |
+ return 5; |
+ if (!y (apat, "\\\\", 0)) |
+ return 5; |
+ if (!y (apat, "a", 0)) |
+ return 5; |
+ if (!(n (Apat, A_1, 0) == ('A' < '\\\\'))) |
+ return 5; |
+ if (!(n (apat, a_1, 0) == ('a' < '\\\\'))) |
+ return 5; |
+ if (!(y (Apat, A01, 0) == ('A' < '\\\\'))) |
+ return 5; |
+ if (!(y (apat, a01, 0) == ('a' < '\\\\'))) |
+ return 5; |
+ if (!(y (Apat, bs_1, 0) == ('A' < '\\\\'))) |
+ return 5; |
+ if (!(y (apat, bs_1, 0) == ('a' < '\\\\'))) |
+ return 5; |
+ if (!(n (Apat, bs01, 0) == ('A' < '\\\\'))) |
+ return 5; |
+ if (!(n (apat, bs01, 0) == ('a' < '\\\\'))) |
+ return 5; |
+ $gl_fnmatch_gnu_start |
+ if (!y ("xxXX", "xXxX", FNM_CASEFOLD)) |
+ result |= 8; |
+ if (!y ("a++(x|yy)b", "a+xyyyyxb", FNM_EXTMATCH)) |
+ result |= 16; |
+ if (!n ("d*/*1", "d/s/1", FNM_FILE_NAME)) |
+ result |= 32; |
+ if (!y ("*", "x", FNM_FILE_NAME | FNM_LEADING_DIR)) |
+ result |= 64; |
+ if (!y ("x*", "x/y/z", FNM_FILE_NAME | FNM_LEADING_DIR)) |
+ result |= 64; |
+ if (!y ("*c*", "c/x", FNM_FILE_NAME | FNM_LEADING_DIR)) |
+ result |= 64; |
+ $gl_fnmatch_gnu_end |
+ return result; |
+ ]])], |
+ [eval "$gl_fnmatch_cache_var=yes"], |
+ [eval "$gl_fnmatch_cache_var=no"], |
+ [eval "$gl_fnmatch_cache_var=\"guessing no\""]) |
+ ]) |
+ eval "gl_fnmatch_result=\"\$$gl_fnmatch_cache_var\"" |
+ if test "$gl_fnmatch_result" = yes; then |
+ dnl Not strictly necessary. Only to avoid spurious leftover files if people |
+ dnl don't do "make distclean". |
+ rm -f "$gl_source_base/fnmatch.h" |
+ else |
+ FNMATCH_H=fnmatch.h |
+ fi |
+ AC_SUBST([FNMATCH_H]) |
+ AM_CONDITIONAL([GL_GENERATE_FNMATCH_H], [test -n "$FNMATCH_H"]) |
+]) |
+ |
+# Request a POSIX compliant fnmatch function with GNU extensions. |
+AC_DEFUN([gl_FUNC_FNMATCH_GNU], |
+[ |
+ m4_divert_text([INIT_PREPARE], [gl_fnmatch_required=GNU]) |
+ |
+ AC_REQUIRE([gl_FUNC_FNMATCH_POSIX]) |
+]) |
+ |
+AC_DEFUN([gl_PREREQ_FNMATCH], |
+[ |
+ dnl We must choose a different name for our function, since on ELF systems |
+ dnl a broken fnmatch() in libc.so would override our fnmatch() if it is |
+ dnl compiled into a shared library. |
+ AC_DEFINE_UNQUOTED([fnmatch], [${gl_fnmatch_required_lowercase}_fnmatch], |
+ [Define to a replacement function name for fnmatch().]) |
+ dnl Prerequisites of lib/fnmatch.c. |
+ AC_REQUIRE([AC_TYPE_MBSTATE_T]) |
+ AC_CHECK_DECLS([isblank], [], [], [[#include <ctype.h>]]) |
+ AC_CHECK_FUNCS_ONCE([btowc isblank iswctype mbsrtowcs mempcpy wmemchr wmemcpy wmempcpy]) |
+ AC_CHECK_HEADERS_ONCE([wctype.h]) |
+]) |