summaryrefslogtreecommitdiff
path: root/m4/regex.m4
diff options
context:
space:
mode:
authorJim Meyering <jim@meyering.net>1999-03-20 23:23:14 +0000
committerJim Meyering <jim@meyering.net>1999-03-20 23:23:14 +0000
commitdf3d9f68128c4e8edcf06405c70c107cfbd2b27b (patch)
tree3ddf841dd640dc610b120a09de32637022b6125a /m4/regex.m4
parentdf570c09ee24b0a0fbfb70e7e07a86ff3052a5bf (diff)
downloadcoreutils-df3d9f68128c4e8edcf06405c70c107cfbd2b27b.tar.xz
(jm_INCLUDED_REGEX): Rename from jm_WITH_REGEX.
Don't depend on AM_GLIBC. Suggestions from Alain Magloire.
Diffstat (limited to 'm4/regex.m4')
-rw-r--r--m4/regex.m473
1 files changed, 35 insertions, 38 deletions
diff --git a/m4/regex.m4 b/m4/regex.m4
index bb201ed2f..3047d4d49 100644
--- a/m4/regex.m4
+++ b/m4/regex.m4
@@ -1,54 +1,51 @@
-#serial 4
+#serial 5
dnl Initially derived from code in GNU grep.
dnl Mostly written by Jim Meyering.
-AC_DEFUN(jm_WITH_REGEX,
+dnl Usage: jm_INCLUDED_REGEX([lib/regex.c])
+dnl
+AC_DEFUN(jm_INCLUDED_REGEX,
[
- AC_REQUIRE([AM_GLIBC])
-
dnl Even packages that don't use regex.c can use this macro.
dnl Of course, for them it doesn't do anything.
- # By default, don't use the included regex.c on systems with a version
- # of glibc 2 that's new enough to pass the following run test.
- # If cross compiling, assume the test would fail and use the included
- # regex.c. The failing regular expression is from `Spencer ere test
- # #75' in grep-2.2f.
+ # Assume we'll default to using the included regex.c.
ac_use_included_regex=yes
- if test "$ac_cv_glibc" = yes; then
- # Without this run-test, on older glibc2 systems we'd end up
- # using the buggy system regex.
- AC_CACHE_CHECK([for working re_compile_pattern],
- jm_cv_func_working_re_compile_pattern,
- AC_TRY_RUN(
- changequote(<<, >>)dnl
- <<
+ # However, if the system regex support is good enough that it passes the
+ # the following run test, then default to *not* using the included regex.c.
+ # If cross compiling, assume the test would fail and use the included
+ # regex.c. The failing regular expression is from `Spencer ere test #75'
+ # in grep-2.3.
+ AC_CACHE_CHECK([for working re_compile_pattern],
+ jm_cv_func_working_re_compile_pattern,
+ AC_TRY_RUN(
+ changequote(<<, >>)dnl
+ <<
#include <stdio.h>
#include <regex.h>
- int
- main ()
- {
- static struct re_pattern_buffer regex;
- const char *s;
- re_set_syntax (RE_SYNTAX_POSIX_EGREP);
- /* Add this third left square bracket, [, to balance the
- three right ones below. Otherwise autoconf-2.14 chokes. */
- s = re_compile_pattern ("a[[:]:]]b\n", 9, &regex);
- /* This should fail with _Invalid character class name_ error. */
- exit (s ? 0 : 1);
- }
- >>,
- changequote([, ])dnl
+ int
+ main ()
+ {
+ static struct re_pattern_buffer regex;
+ const char *s;
+ re_set_syntax (RE_SYNTAX_POSIX_EGREP);
+ /* Add this third left square bracket, [, to balance the
+ three right ones below. Otherwise autoconf-2.14 chokes. */
+ s = re_compile_pattern ("a[[:]:]]b\n", 9, &regex);
+ /* This should fail with _Invalid character class name_ error. */
+ exit (s ? 0 : 1);
+ }
+ >>,
+ changequote([, ])dnl
- jm_cv_func_working_re_compile_pattern=yes,
- jm_cv_func_working_re_compile_pattern=no,
- dnl When crosscompiling, assume it's broken.
- jm_cv_func_working_re_compile_pattern=no))
- if test $jm_cv_func_working_re_compile_pattern = yes; then
- ac_use_included_regex=no
- fi
+ jm_cv_func_working_re_compile_pattern=yes,
+ jm_cv_func_working_re_compile_pattern=no,
+ dnl When crosscompiling, assume it's broken.
+ jm_cv_func_working_re_compile_pattern=no))
+ if test $jm_cv_func_working_re_compile_pattern = yes; then
+ ac_use_included_regex=no
fi
test -n "$1" || AC_MSG_ERROR([missing argument])