autoconf/autoheader.m4
Akim Demaille 00f447ee06 * acspecific.m4 (AC_C_INLINE): Proceed as for AC_C_CONST:
condition out the test case if __cpluscplus.
Don't document the autoheader template twice, one is enough.
* autoheader.m4 (AC_CONFIG_HEADER): don't hook on this guy, but
on...
(AC_CONFIG_HEADERS), since the former is defined on the latter.
2000-02-07 15:39:16 +00:00

270 lines
8.0 KiB
Plaintext

dnl This file is part of Autoconf. -*- Autoconf -*-
dnl Driver and redefinitions of some Autoconf macros for autoheader.
dnl Copyright (C) 1994, 1995, 1999 Free Software Foundation, Inc.
dnl
dnl This program is free software; you can redistribute it and/or modify
dnl it under the terms of the GNU General Public License as published by
dnl the Free Software Foundation; either version 2, or (at your option)
dnl any later version.
dnl
dnl This program is distributed in the hope that it will be useful,
dnl but WITHOUT ANY WARRANTY; without even the implied warranty of
dnl MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
dnl GNU General Public License for more details.
dnl
dnl You should have received a copy of the GNU General Public License
dnl along with this program; if not, write to the Free Software
dnl Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
dnl 02111-1307, USA.
dnl
dnl Written by Roland McGrath.
dnl
include(acgeneral.m4)dnl
m4_include(acspecific.m4)dnl
m4_include(acoldnames.m4)dnl
dnl AH_HOOK(AUTOCONF-NAME, AUTOHEADER-NAME)
dnl ---------------------------------------
dnl Install a new hook for AH_ macros. Specify that the macro
dnl AUTOCONF-NAME will later be defined as the concatenation of
dnl both its former definition, and that of AUTOHEADER-NAME.
dnl
dnl There are several motivations for not just defining to be equivalent to
dnl AUTOHEADER-NAME.
dnl
dnl Let AC_FOO be
dnl | AC_DEFINE(FOO, 1)
dnl | AC_DEFINE(BAR, 1)
dnl | AC_DEFINE(BAZ, 1, The value of BAZ.)
dnl Let AH_FOO be
dnl | AH_TEMPLATE(FOO, The value of FOO.)
dnl
dnl If we hook AC_FOO to be AH_FOO only, then only FOO will be templated.
dnl If we hook AC_FOO to expand in both the former AC_FOO and AH_FOO, then
dnl both FOO and BAZ are templated.
dnl
dnl Additionaly, if AC_FOO is hooked to AH_FOO only, then we loose track
dnl of the other AC_DEFINE, and the autoheader machinery (see the use of
dnl the shell variable SYMS in AC_TEMPLATE) won't be able to see that BAR
dnl is not templated at all. Hooking AC_FOO on both its AC_ and AH_ faces
dnl makes sure we keep track of non templated DEFINEs.
dnl
dnl The two last end of lines make AH_HOOKS more readable.
define(AH_HOOK,
[m4_append([AH_HOOKS],
[define([$1],
defn([$1])
defn([$2])
)
])])
dnl AH_DEFUN(MACRO, CONTENT)
dnl ------------------------
dnl Define the macro AH_MACRO (i.e., with AH_ prepended) as CONTENT. Also
dnl install an AH_HOOK from MACRO to AH_MACRO. This hook is run by
dnl autoheader to substitutes the selected AC_FOO macros by AH_AC_FOO.
define(AH_DEFUN,
[define([AH_$1], [$2])
AH_HOOK([$1], [AH_$1])])
dnl These are alternate definitions of some macros, which produce
dnl strings in the output marked with "@@@" so we can easily extract
dnl the information we want. The `#' at the end of the first line of
dnl each definition seems to be necessary to prevent m4 from eating
dnl the newline, which makes the @@@ not always be at the beginning of
dnl a line.
dnl Autoheader is not the right program to complain about cross-compiling.
AH_DEFUN([AC_TRY_RUN],
[$2
$3
$4])
dnl AH_DEFINE(VARIABLE, [VALUE], [DESCRIPTION])
dnl -------------------------------------------
dnl When running autoheader, this macro replaces AC_DEFINE and
dnl AC_DEFINE_UNQUOTED.
dnl
dnl If DESCRIPTION is not given, then there is a risk that VARIABLE will
dnl not be properly templated. To control later that it has been
dnl templated elsewhere, store VARIABLE in a shell growing string, SYMS.
define([AH_DEFINE],
[ifval([$3],
[AH_TEMPLATE([$1], [$3])],
[#
dnl Ignore CPP macro arguments.
@@@syms="$syms patsubst($1, [(.*$])"@@@
])])
AH_DEFUN([AC_DEFINE], [AH_DEFINE($@)])
AH_DEFUN([AC_DEFINE_UNQUOTED], [AH_DEFINE($@)])
dnl AH_TEMPLATE(KEY, DESCRIPTION)
dnl -----------------------------
dnl Issue an autoheader template for KEY, i.e., a comment composed
dnl of DESCRIPTION (properly wrapped), and then #undef KEY.
define([AH_TEMPLATE],
[AH_VERBATIM([$1],
AC_WRAP([$2 */], [ ], [/* ])[
#undef $1])])
dnl AH_VERBATIM(KEY, TEMPLATE)
dnl --------------------------
dnl If KEY is direct (i.e., no indirection such as in KEY=$my_func which may
dnl occur if there is AC_CHECK_FUNCS($my_func)), issue an autoheader TEMPLATE
dnl associated to the KEY. Otherwise, do nothing.
dnl TEMPLATE is output as is, with no formating.
define([AH_VERBATIM],
[AC_VAR_IF_INDIR([$1],,
[#
@@@
ac_verbatim_$1="\
_AC_SH_QUOTE([$2])"
@@@
])])
dnl FIXME: To be rigorous, this should not be systematic: depending
dnl upon the arguments of AC_CHECK_LIB, we might not AC_DEFINE.
AH_DEFUN([AC_CHECK_LIB],
[AH_TEMPLATE(AC_TR_CPP(HAVE_LIB$1),
[Define if you have the `]$1[' library (-l]$1[).])
# Success
$3
# Failure
$4])
define([AH_CHECK_HEADERS],
[AC_FOREACH([AC_Header], [$1],
[AH_TEMPLATE(AC_TR_CPP(HAVE_[]AC_Header),
[Define if you have the <]AC_Header[> header file.])
# Success
$2
# Failure
$3])])
AH_DEFUN([AC_CHECK_HEADERS], [AH_CHECK_HEADERS($@)])
AH_DEFUN([AC_CHECK_HEADERS_DIRENT], [AH_CHECK_HEADERS($@)])
AH_DEFUN([AC_CHECK_DECLS],
[m4_foreach([AC_Symbol], [$1],
[AH_TEMPLATE(AC_TR_CPP([NEED_]AC_Symbol[_DECL]),
[Define if you need the declaration of `]AC_Symbol['.])
# Success
$2
# Failure
$3])])
AH_DEFUN([AC_CHECK_FUNCS],
[AC_FOREACH([AC_Func], [$1],
[AH_TEMPLATE(AC_TR_CPP(HAVE_[]AC_Func),
[Define if you have the `]AC_Func[' function.])
# Success
$2
# Failure
$3])
])
AH_DEFUN([AC_CHECK_SIZEOF],
[AH_TEMPLATE(AC_TR_CPP(SIZEOF_$1),
[The number of bytes in a `]$1['.])])
AH_DEFUN([AC_PROG_LEX],
[AC_CHECK_LIB(fl)
AC_CHECK_LIB(l)])
AH_DEFUN([AC_CHECK_MEMBERS],
[m4_foreach([AC_Member], [$1],
[pushdef(AC_Member_Aggregate, [patsubst(AC_Member, [\.[^.]*])])
pushdef(AC_Member_Member, [patsubst(AC_Member, [.*\.])])
AH_TEMPLATE(AC_TR_CPP(HAVE_[]AC_Member),
[Define if `]AC_Member_Member[' is member of]
[`]AC_Member_Aggregate['.])
popdef([AC_Member_Member])
popdef([AC_Member_Aggregate])
# Success
$2
# Failure
$3])
])
dnl AC_CHECK_TYPE(TYPE, SUBTITUTE)
dnl ------------------------------
AH_DEFUN([AC_CHECK_TYPE],
[AH_TEMPLATE([$1], [Define to `$2' if <sys/types.h> does not define.])])
AH_DEFUN([AC_FUNC_ALLOCA],
[AH_VERBATIM([STACK_DIRECTION],
[/* If using the C implementation of alloca, define if you know the
direction of stack growth for your system; otherwise it will be
automatically deduced at run-time.
STACK_DIRECTION > 0 => grows toward higher addresses
STACK_DIRECTION < 0 => grows toward lower addresses
STACK_DIRECTION = 0 => direction of growth unknown */
#undef STACK_DIRECTION
])])dnl AH_FUNC_ALLOCA
dnl AH_CHECK_TYPES((TYPES, ...))
dnl ----------------------------
AH_DEFUN([AC_CHECK_TYPES],
[m4_foreach([AC_Type], [$1],
[AH_TEMPLATE(AC_TR_CPP(HAVE_[]AC_Type),
[Define if the system has the type `]AC_Type['.])
# Success
$2
# Failure
$3])
])
AH_DEFUN([AC_C_CHAR_UNSIGNED],
[AH_VERBATIM([__CHAR_UNSIGNED__],
[/* Define if type `char' is unsigned and you are not using gcc. */
#ifndef __CHAR_UNSIGNED__
# undef __CHAR_UNSIGNED__
#endif
])])
AH_DEFUN([AC_AIX],
[AH_VERBATIM([_ALL_SOURCE],
[/* Define if on AIX 3.
System headers sometimes define this.
We just want to avoid a redefinition error message. */
#ifndef _ALL_SOURCE
# undef _ALL_SOURCE
#endif
])])
AH_DEFUN([AC_F77_WRAPPERS],
[AH_TEMPLATE([F77_FUNC],
[Define to a macro that performs the appropriate name
mangling on its argument to make the C identifier, which
*does not* contain underscores, match the name mangling
scheme of the Fortran 77 compiler.])
AH_TEMPLATE([F77_FUNC_],
[Define to a macro that performs the appropriate name
mangling on its argument to make the C identifier, which
*does* contain underscores, match the name mangling
scheme of the Fortran 77 compiler.])])
AH_DEFUN([AC_CONFIG_HEADERS],
[@@@config_h=patsubst($1, [ .*$], [])@@@
])
dnl Install the AH_HOOKS
AH_HOOKS