X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=m4%2Fcheck-decl.m4;h=e301e44f1a950a1d65209c07cf1f8376a73d64e6;hb=0362299f47367789e16450f7fc87f3d1fe0f424a;hp=0596ce018a9a72f1ce67e958905d12db34a102d5;hpb=d22fdbb6446143a78b3257ff3877958e37d8c121;p=gnulib.git diff --git a/m4/check-decl.m4 b/m4/check-decl.m4 index 0596ce018..e301e44f1 100644 --- a/m4/check-decl.m4 +++ b/m4/check-decl.m4 @@ -1,16 +1,72 @@ +#serial 11 + dnl This is just a wrapper function to encapsulate this kludge. dnl Putting it in a separate file like this helps share it between dnl different packages. AC_DEFUN(jm_CHECK_DECLS, [ - if test x = y; then - dnl This code is deliberately never run via ./configure. - dnl FIXME: this is a gross hack to make autoheader put entries - dnl for each of these symbols in the config.h.in. - dnl Otherwise, I'd have to update acconfig.h every time I change - dnl this list of functions. - AC_CHECK_FUNCS(DECLARATION_FREE DECLARATION_MALLOC DECLARATION_REALLOC \ - DECLARATION_STPCPY DECLARATION_STRSTR) - fi - jm_CHECK_DECLARATIONS(free malloc realloc stpcpy strstr) + AC_REQUIRE([_jm_DECL_HEADERS]) + AC_REQUIRE([AC_HEADER_TIME]) + headers=' +#include +#if HAVE_STRING_H +# if !STDC_HEADERS && HAVE_MEMORY_H +# include +# endif +# include +#else +# if HAVE_STRINGS_H +# include +# endif +#endif +#if HAVE_STDLIB_H +# include +#endif +#if HAVE_UNISTD_H +# include +#endif + +#include +#if TIME_WITH_SYS_TIME +# include +# include +#else +# if HAVE_SYS_TIME_H +# include +# else +# include +# endif +#endif + +#if !HAVE_UTMPX_H +# include +#endif +' + + AC_CHECK_DECLS(( + free, + getenv, + geteuid, + getlogin, + getutent, + lseek, + malloc, + memchr, + nanosleep, + realloc, + stpcpy, + strndup, + strstr, + strtoul, + strtoull, + ttyname), , , $headers) +]) + +dnl FIXME: when autoconf has support for it. +dnl This is a little helper so we can require these header checks. +AC_DEFUN(_jm_DECL_HEADERS, +[ + AC_REQUIRE([AC_HEADER_STDC]) + AC_CHECK_HEADERS(memory.h string.h strings.h stdlib.h unistd.h sys/time.h \ + utmpx.h) ])