X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=m4%2Fstrsignal.m4;h=f5c70ef1c9e2440f94a3d59181de68931edcc32e;hb=7d7ec7650cd840f005ddd6dd886dd1036802fd63;hp=d71f0963fb6d99802f04df88eb17044360601f48;hpb=829d0e0cfc21f3eb72ff83d70b7aabc5c9854a17;p=gnulib.git diff --git a/m4/strsignal.m4 b/m4/strsignal.m4 index d71f0963f..f5c70ef1c 100644 --- a/m4/strsignal.m4 +++ b/m4/strsignal.m4 @@ -1,5 +1,5 @@ -# strsignal.m4 serial 3 -dnl Copyright (C) 2008 Free Software Foundation, Inc. +# strsignal.m4 serial 6 +dnl Copyright (C) 2008-2011 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. @@ -19,32 +19,35 @@ AC_DEFUN([gl_FUNC_STRSIGNAL], AC_CHECK_FUNCS([strsignal]) if test $ac_cv_func_strsignal = yes; then + HAVE_STRSIGNAL=1 dnl Check if strsignal behaves reasonably for out-of-range signal numbers. dnl On Solaris it returns NULL; on AIX 5.1 it returns (char *) -1. AC_CACHE_CHECK([whether strsignal always returns a string], [gl_cv_func_working_strsignal], [AC_RUN_IFELSE( - [AC_LANG_PROGRAM( - [[#include - ]], - [[char *s = strsignal (-1); - return !(s != (char *) 0 && s != (char *) -1);]])], - [gl_cv_func_working_strsignal=yes], - [gl_cv_func_working_strsignal=no], - [case "$host_os" in - solaris* | aix*) gl_cv_func_working_strsignal=no;; - *) gl_cv_func_working_strsignal="guessing yes";; - esac])]) - else - gl_cv_func_working_strsignal=no - fi - - if test "$gl_cv_func_working_strsignal" = no; then - if test $ac_cv_func_strsignal = yes; then + [AC_LANG_PROGRAM( + [[#include +#include /* NetBSD 5.0 declares it in wrong header. */ + ]], + [[int result = 0; + char *s = strsignal (-1); + if (s == (char *) 0) + result |= 1; + if (s == (char *) -1) + result |= 2; + return result; + ]])], + [gl_cv_func_working_strsignal=yes], + [gl_cv_func_working_strsignal=no], + [case "$host_os" in + solaris* | aix*) gl_cv_func_working_strsignal=no;; + *) gl_cv_func_working_strsignal="guessing yes";; + esac])]) + if test "$gl_cv_func_working_strsignal" = no; then REPLACE_STRSIGNAL=1 fi - AC_LIBOBJ([strsignal]) - gl_PREREQ_STRSIGNAL + else + HAVE_STRSIGNAL=0 fi ])