diff --git a/configure.in b/configure.in index 252525d..0b7a836 100644 --- a/configure.in +++ b/configure.in @@ -2894,6 +2894,42 @@ if test "${universal_binary-no}" = yes ; then ])]) fi +AC_CHECK_FUNC(memmem, [ + AC_CACHE_CHECK(for broken memmem, rb_cv_broken_memmem, [ + AC_TRY_RUN([ +#include + +int +main() +{ + char *str = "hogefugafoobar"; + char *rs = "foo"; + char *empty = ""; + char *p; + + p = memmem(str, strlen(str), rs, strlen(rs)); + if (p == str+8) { + p = memmem(str, strlen(str), empty, strlen(empty)); + if (p == str) + return 0; + else + return 1; + } + else { + return 1; + } +} + ], + rb_cv_broken_memmem=no, + rb_cv_broken_memmem=yes, + rb_cv_broken_memmem=yes) + ]) + if test "$rb_cv_broken_memmem" = no; then + AC_DEFINE(HAVE_MEMMEM, 1) + fi +]) + + CPPFLAGS="$CPPFLAGS "'$(DEFS)' test -z "$CPPFLAGS" || CPPFLAGS="$CPPFLAGS "; CPPFLAGS="$CPPFLAGS"'${cppflags}' if test -n "${cflags+set}"; then diff --git a/re.c b/re.c index ea11f1c..97803d4 100644 --- a/re.c +++ b/re.c @@ -97,6 +97,18 @@ rb_memcmp(const void *p1, const void *p2, long len) return memcmp(p1, p2, len); } +#ifdef HAVE_MEMMEM +static inline long +rb_memsearch_ss(const unsigned char *xs, long m, const unsigned char *ys, long n) +{ + const unsigned char *y; + + if (y = memmem(ys, n, xs, m)) + return y - ys; + else + return -1; +} +#else static inline long rb_memsearch_ss(const unsigned char *xs, long m, const unsigned char *ys, long n) { @@ -132,6 +144,7 @@ rb_memsearch_ss(const unsigned char *xs, long m, const unsigned char *ys, long n } return y - ys - m; } +#endif static inline long rb_memsearch_qs(const unsigned char *xs, long m, const unsigned char *ys, long n)