X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=m4%2Fregex.m4;h=d80eafb2ce5ccdbdba7fa785d5920e7522ea3182;hb=096169d9b94db45ad690d93b3a680eaa72b95f35;hp=a79f03bcd73e2cad20a4deecd738efc518ab2a7b;hpb=f2aaef059b81506453205d7efc4b7e66b4876254;p=gnulib.git diff --git a/m4/regex.m4 b/m4/regex.m4 index a79f03bcd..d80eafb2c 100644 --- a/m4/regex.m4 +++ b/m4/regex.m4 @@ -1,11 +1,16 @@ -#serial 10 +#serial 13 dnl Initially derived from code in GNU grep. dnl Mostly written by Jim Meyering. +AC_DEFUN([gl_REGEX], +[ + jm_INCLUDED_REGEX([lib/regex.c]) +]) + dnl Usage: jm_INCLUDED_REGEX([lib/regex.c]) dnl -AC_DEFUN(jm_INCLUDED_REGEX, +AC_DEFUN([jm_INCLUDED_REGEX], [ dnl Even packages that don't use regex.c can use this macro. dnl Of course, for them it doesn't do anything. @@ -30,10 +35,7 @@ AC_DEFUN(jm_INCLUDED_REGEX, const char *s; struct re_registers regs; re_set_syntax (RE_SYNTAX_POSIX_EGREP); - /* These two brackets, '[[' and the one in the comment below serve - to quote the brackets (unbalanced) in the following line. */ - s = re_compile_pattern ("a[[:]:]]b\n", 9, ®ex); - /* This bracket ']' helps quote the unbalanced expression above. */ + [s = re_compile_pattern ("a[[:@:>@:]]b\n", 9, ®ex);] /* This should fail with _Invalid character class name_ error. */ if (!s) exit (1); @@ -77,8 +79,26 @@ AC_DEFUN(jm_INCLUDED_REGEX, jm_with_regex=$ac_use_included_regex) if test "$jm_with_regex" = yes; then AC_LIBOBJ(regex) + jm_PREREQ_REGEX fi ], ) ] ) + +# Prerequisites of lib/regex.c. +AC_DEFUN([jm_PREREQ_REGEX], +[ + dnl FIXME: Maybe provide a btowc replacement someday: solaris-2.5.1 lacks it. + dnl FIXME: Check for wctype and iswctype, and and add -lw if necessary + dnl to get them. + + dnl Persuade glibc to declare mempcpy(). + AC_REQUIRE([AC_GNU_SOURCE]) + + AC_REQUIRE([AC_FUNC_ALLOCA]) + AC_REQUIRE([AC_HEADER_STDC]) + AC_CHECK_HEADERS_ONCE(limits.h string.h wchar.h wctype.h) + AC_CHECK_FUNCS_ONCE(isascii mempcpy) + AC_CHECK_FUNCS(btowc) +])