X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=m4%2Fcheck-decl.m4;h=d70e1c90f8dc393327200f7f90d884c89aa78951;hb=2183c2199b61a0738ff5712257ad503223669fe2;hp=eb8faa277861b616bcc605879d638288265ba8cd;hpb=ea35b88657b1d2fe5c053549f20dd6173913c0d8;p=gnulib.git diff --git a/m4/check-decl.m4 b/m4/check-decl.m4 index eb8faa277..d70e1c90f 100644 --- a/m4/check-decl.m4 +++ b/m4/check-decl.m4 @@ -1,18 +1,75 @@ -#serial 2 +#serial 20 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, +AC_DEFUN([gl_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(DECL_FREE DECL_LSEEK DECL_MALLOC DECL_MEMCHR DECL_REALLOC \ - DECL_STPCPY DECL_STRSTR) - fi - jm_CHECK_DECLARATIONS(free lseek malloc memchr realloc stpcpy strstr) + AC_REQUIRE([_gl_DECL_HEADERS]) + AC_REQUIRE([AC_HEADER_TIME]) + headers=' +#include +#include +#include + +#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_UTMP_H +# include +#endif + +#if HAVE_GRP_H +# include +#endif + +#if HAVE_PWD_H +# include +#endif +' + + AC_CHECK_DECLS([ + free, + getenv, + geteuid, + getgrgid, + getlogin, + getpwuid, + getuid, + getutent, + lseek, + malloc, + memchr, + memrchr, + nanosleep, + realloc, + stpcpy, + strndup, + strnlen, + 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([_gl_DECL_HEADERS], +[ + AC_REQUIRE([AC_HEADER_STDC]) + AC_CHECK_HEADERS(grp.h memory.h pwd.h string.h strings.h stdlib.h \ + unistd.h sys/time.h utmp.h utmpx.h) ])