X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=m4%2Fprereq.m4;h=d1f8a1d4e882765cca81b4ac6103ffa274d18657;hb=02e3bf2a532498c860f248a9bd81869dbf514404;hp=407ee18ba57c321fc9e23426f7f22f87820c19e7;hpb=ea5404e9b914fd10489ef1851876f0c5d2b4f3e9;p=gnulib.git diff --git a/m4/prereq.m4 b/m4/prereq.m4 index 407ee18ba..d1f8a1d4e 100644 --- a/m4/prereq.m4 +++ b/m4/prereq.m4 @@ -1,21 +1,27 @@ -#serial 10 +#serial 21 dnl These are the prerequisite macros for files in the lib/ dnl directories of the fileutils, sh-utils, and textutils packages. -AC_DEFUN(jm_PREREQ, +AC_DEFUN([jm_PREREQ], [ jm_PREREQ_ADDEXT jm_PREREQ_CANON_HOST + jm_PREREQ_DIRNAME jm_PREREQ_ERROR + jm_PREREQ_EXCLUDE jm_PREREQ_GETPAGESIZE + jm_PREREQ_HASH jm_PREREQ_HUMAN + jm_PREREQ_MBSWIDTH + jm_PREREQ_MEMCHR jm_PREREQ_QUOTEARG jm_PREREQ_READUTMP jm_PREREQ_REGEX + jm_PREREQ_TEMPNAME # called by mkstemp ]) -AC_DEFUN(jm_PREREQ_ADDEXT, +AC_DEFUN([jm_PREREQ_ADDEXT], [ dnl For addext.c. AC_SYS_LONG_FILE_NAMES @@ -23,7 +29,7 @@ AC_DEFUN(jm_PREREQ_ADDEXT, AC_CHECK_HEADERS(limits.h string.h unistd.h) ]) -AC_DEFUN(jm_PREREQ_CANON_HOST, +AC_DEFUN([jm_PREREQ_CANON_HOST], [ dnl Add any libraries as early as possible. dnl In particular, inet_ntoa needs -lnsl at least on Solaris5.5.1, @@ -38,33 +44,56 @@ AC_DEFUN(jm_PREREQ_CANON_HOST, netinet/in.h arpa/inet.h) ]) +AC_DEFUN([jm_PREREQ_DIRNAME], +[ + AC_HEADER_STDC + AC_CHECK_HEADERS(string.h) +]) + +AC_DEFUN([jm_PREREQ_EXCLUDE], +[ + jm_FUNC_FNMATCH + AC_CHECK_HEADERS(stdbool.h) +]) + +AC_DEFUN([jm_PREREQ_GETPAGESIZE], +[ + AC_CHECK_FUNCS(getpagesize) + AC_CHECK_HEADERS(OS.h unistd.h) +]) + +AC_DEFUN([jm_PREREQ_HASH], +[ + AC_CHECK_HEADERS(stdlib.h stdbool.h) + AC_REQUIRE([jm_CHECK_DECLS]) +]) + # If you use human.c, you need the following files: -# uintmax_t.m4 inttypes_h.m4 ulonglong.m4 -AC_DEFUN(jm_PREREQ_HUMAN, +# inttypes.m4 ulonglong.m4 +AC_DEFUN([jm_PREREQ_HUMAN], [ AC_CHECK_HEADERS(limits.h stdlib.h string.h) AC_CHECK_DECLS([getenv]) - AC_REQUIRE([jm_AC_HEADER_INTTYPES_H]) AC_REQUIRE([jm_AC_TYPE_UINTMAX_T]) ]) -AC_DEFUN(jm_PREREQ_GETPAGESIZE, +AC_DEFUN([jm_PREREQ_MEMCHR], [ - AC_CHECK_FUNCS(getpagesize) - AC_CHECK_HEADERS(OS.h unistd.h) + AC_CHECK_HEADERS(limits.h stdlib.h bp-sym.h) ]) -AC_DEFUN(jm_PREREQ_QUOTEARG, +AC_DEFUN([jm_PREREQ_QUOTEARG], [ - AC_CHECK_FUNCS(isascii iswprint mbrtowc) - AC_CHECK_HEADERS(limits.h stdlib.h string.h wchar.h wctype.h) + AC_CHECK_FUNCS(isascii iswprint) + jm_FUNC_MBRTOWC + AC_CHECK_HEADERS(limits.h stddef.h stdlib.h string.h wchar.h wctype.h) AC_HEADER_STDC AC_C_BACKSLASH_A - AC_MBSTATE_T_OBJECT + AC_MBSTATE_T AM_C_PROTOTYPES ]) -AC_DEFUN(jm_PREREQ_READUTMP, +AC_DEFUN([jm_PREREQ_READUTMP], [ AC_HEADER_STDC AC_CHECK_HEADERS(string.h utmp.h utmpx.h sys/param.h) @@ -77,7 +106,8 @@ AC_DEFUN(jm_PREREQ_READUTMP, $ac_includes_default #ifdef HAVE_UTMPX_H # include -#else +#endif +#ifdef HAVE_UTMP_H # include #endif " @@ -85,11 +115,13 @@ $ac_includes_default AC_CHECK_MEMBERS([struct utmp.ut_user],,,[$utmp_includes]) AC_CHECK_MEMBERS([struct utmpx.ut_name],,,[$utmp_includes]) AC_CHECK_MEMBERS([struct utmp.ut_name],,,[$utmp_includes]) + AC_CHECK_MEMBERS([struct utmpx.ut_type],,,[$utmp_includes]) + AC_CHECK_MEMBERS([struct utmp.ut_type],,,[$utmp_includes]) AC_LIBOBJ(readutmp) fi ]) -AC_DEFUN(jm_PREREQ_REGEX, +AC_DEFUN([jm_PREREQ_REGEX], [ dnl FIXME: Maybe provide a btowc replacement someday: solaris-2.5.1 lacks it. dnl FIXME: Check for wctype and iswctype, and and add -lw if necessary @@ -99,3 +131,11 @@ AC_DEFUN(jm_PREREQ_REGEX, AC_HEADER_STDC AC_FUNC_ALLOCA ]) + +AC_DEFUN([jm_PREREQ_TEMPNAME], +[ + AC_HEADER_STDC + AC_HEADER_STAT + AC_CHECK_HEADERS(fcntl.h sys/time.h stdint.h unistd.h) + AC_CHECK_FUNCS(__secure_getenv gettimeofday) +])