X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=m4%2Ftsearch.m4;h=50a9aabe8ff9f5ae066d2a8fdf2fb220825d0b52;hb=82b0be34b85e7169e869e0503b607c990c524da2;hp=e279fc049f64661cfb6513cbbb265e8bc3611713;hpb=a2a1879395ffb102d4cd97510bb6b6386cecbe3d;p=gnulib.git diff --git a/m4/tsearch.m4 b/m4/tsearch.m4 index e279fc049..50a9aabe8 100644 --- a/m4/tsearch.m4 +++ b/m4/tsearch.m4 @@ -1,13 +1,54 @@ -# tsearch.m4 serial 1 -dnl Copyright (C) 2006 Free Software Foundation, Inc. +# tsearch.m4 serial 4 +dnl Copyright (C) 2006-2010 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. AC_DEFUN([gl_FUNC_TSEARCH], [ - AC_REPLACE_FUNCS(tsearch) - if test $ac_cv_func_tsearch = no; then + AC_REQUIRE([gl_SEARCH_H_DEFAULTS]) + AC_CHECK_FUNCS([tsearch]) + if test $ac_cv_func_tsearch = yes; then + dnl On OpenBSD 4.0, the return value of tdelete() is incorrect. + AC_REQUIRE([AC_PROG_CC]) + AC_REQUIRE([AC_CANONICAL_HOST]) dnl for cross-compiles + AC_CACHE_CHECK([whether tdelete works], [gl_cv_func_tdelete_works], + [ + AC_RUN_IFELSE([AC_LANG_SOURCE([[ +#include +#include +static int +cmp_fn (const void *a, const void *b) +{ + return *(const int *) a - *(const int *) b; +} +int +main () +{ + int x = 0; + void *root = NULL; + if (!(tfind (&x, &root, cmp_fn) == NULL)) return 1; + tsearch (&x, &root, cmp_fn); + if (!(tfind (&x, &root, cmp_fn) != NULL)) return 1; + if (!(tdelete (&x, &root, cmp_fn) != NULL)) return 1; + return 0; +}]])], [gl_cv_func_tdelete_works=yes], [gl_cv_func_tdelete_works=no], + [case "$host_os" in + openbsd*) gl_cv_func_tdelete_works="guessing no";; + *) gl_cv_func_tdelete_works="guessing yes";; + esac + ]) + ]) + case "$gl_cv_func_tdelete_works" in + *no) + REPLACE_TSEARCH=1 + AC_LIBOBJ([tsearch]) + gl_PREREQ_TSEARCH + ;; + esac + else + HAVE_TSEARCH=0 + AC_LIBOBJ([tsearch]) gl_PREREQ_TSEARCH fi ])