Next: Programming in M4sh, Up: Other Autoconf macros [Contents][Index]
AM_INIT_AUTOMAKE([OPTIONS])Runs many macros required for proper operation of the generated Makefiles.
AM_INIT_AUTOMAKE is called with a single argument: a
space-separated list of Automake options that should be applied to
every Makefile.am in the tree. The effect is as if
each option were listed in AUTOMAKE_OPTIONS (see Automake options).
By default this macro AC_DEFINE’s PACKAGE and
VERSION. This can be avoided by passing the no-define
option (see List of Automake options):
AM_INIT_AUTOMAKE([no-define ...])
AM_INIT_AUTOMAKE can also be called in another, deprecated
form:
AM_INIT_AUTOMAKE(PACKAGE, VERSION, [NO-DEFINE]). In this form,
there are two required arguments: the package and the version number.
This usage is mostly obsolete because the package and version
can be obtained from Autoconf’s AC_INIT macro. However,
differently from what happens for AC_INIT invocations, this
AM_INIT_AUTOMAKE invocation supports shell variables’ expansions
in the PACKAGE and VERSION arguments (which otherwise
defaults, respectively, to the PACKAGE_TARNAME and
PACKAGE_VERSION defined via the AC_INIT invocation;
see AC_INIT);
and this can be still be useful in some selected situations.
Our hope is that future Autoconf versions will improve their support
for package versions defined dynamically at configure runtime; when
(and if) this happens, support for the two-args AM_INIT_AUTOMAKE
invocation will likely be removed from Automake.
If your configure.ac has:
AC_INIT([src/foo.c]) AM_INIT_AUTOMAKE([mumble], [1.5])
you should modernize it as follows:
AC_INIT([mumble], [1.5]) AC_CONFIG_SRCDIR([src/foo.c]) AM_INIT_AUTOMAKE
Note that if you’re upgrading your configure.ac from an earlier
version of Automake, it is not always correct to simply move the
package and version arguments from AM_INIT_AUTOMAKE directly to
AC_INIT, as in the example above. The first argument to
AC_INIT should be the name of your package (e.g., ‘GNU
Automake’), not the tarball name (e.g., ‘automake’) that you used
to pass to AM_INIT_AUTOMAKE. Autoconf tries to derive a
tarball name from the package name, which should work for most but not
all package names. (If it doesn’t work for yours, you can use the
four-argument form of AC_INIT to provide the tarball name
explicitly).
AM_PATH_LISPDIRSearches for the program emacs, and, if found, sets the
output variable lispdir to the full path to Emacs’ site-lisp
directory.
Note that this test assumes the emacs found to be a version
that supports Emacs Lisp (such as GNU Emacs or XEmacs). Other
emacsen can cause this test to hang (some, like old versions of
MicroEmacs, start up in interactive mode, requiring C-x C-c to
exit, which is hardly obvious for a non-emacs user). In most cases,
however, you should be able to use C-c to kill the test. In
order to avoid problems, you can set EMACS to “no” in the
environment, or use the --with-lispdir option to
configure to explicitly set the correct path (if you’re sure
you have an emacs that supports Emacs Lisp).
AM_PROG_AR([act-if-fail])You must use this macro when you use the archiver in your project, if
you want support for unusual archivers such as Microsoft lib.
The content of the optional argument is executed if the archiver
interface is not recognized; the default action is to abort configure
with an error message.
AM_PROG_ASUse this macro when you have assembly code in your project. This will
choose the assembler for you (by default the C compiler) and set
CCAS, and will also set CCASFLAGS if required.
AM_PROG_CC_C_OThis is an obsolescent macro that checks that the C compiler supports
the -c and -o options together. Note that, since
Automake 1.14, the AC_PROG_CC is rewritten to implement such
checks itself, and thus the explicit use of AM_PROG_CC_C_O
should no longer be required.
AM_PROG_LEXLike AC_PROG_LEX (see Particular Programs),
but uses the
missing script on systems that do not have lex.
HP-UX 10 is one such system.
AM_PROG_GCJThis macro finds the gcj program or causes an error. It sets
GCJ and GCJFLAGS. gcj is the Java front-end to the
GNU Compiler Collection.
AM_PROG_UPC([compiler-search-list])Find a compiler for Unified Parallel C and define the UPC
variable. The default compiler-search-list is ‘upcc upc’.
This macro will abort configure if no Unified Parallel C
compiler is found.
AM_MISSING_PROG(name, program)Find a maintainer tool program and define the name
environment variable with its location. If program is not
detected, then name will instead invoke the missing
script, in order to give useful advice to the user about the missing
maintainer tool. See maintainer-mode for more information on when
the missing script is appropriate.
AM_SILENT_RULESControl the machinery for less verbose build output (see Automake Silent Rules).
AM_WITH_DMALLOCAdd support for the Dmalloc package. If
the user runs configure with --with-dmalloc, then
define WITH_DMALLOC and add -ldmalloc to LIBS.
You should not use the next macro in new code, as it will be removed in some future Automake version, so you should consider updating your configure.ac to avoid problems in the future.
AM_PROG_MKDIR_PFrom Automake 1.8 to 1.9.6 this macro used to define the output
variable mkdir_p to one of mkdir -p, install-sh
-d, or mkinstalldirs.
Nowadays Autoconf provides a similar functionality with
AC_PROG_MKDIR_P (see Particular Programs),
however this defines
the output variable MKDIR_P instead. In case you are still
using the AM_PROG_MKDIR_P macro in your configure.ac,
or its provided variable $(mkdir_p) in your Makefile.am,
you are advised to switch ASAP to the more modern Autoconf-provided
interface instead; both the macro and the variable might be removed
in a future major Automake release.
Next: Programming in M4sh, Up: Other Autoconf macros [Contents][Index]