manpagez: man pages & more
info autoconf
Home | html | info | man

File: autoconf.info,  Node: Introduction,  Next: The GNU Build System,  Prev: Top.php">Top,  Up: Top.php">Top

1 Introduction
**************

 A physicist, an engineer, and a computer scientist were discussing the
     nature of God.  "Surely a Physicist," said the physicist, "because
         early in the Creation, God made Light; and you know, Maxwell's
  equations, the dual nature of electromagnetic waves, the relativistic
          consequences..."  "An Engineer!," said the engineer, "because
 before making Light, God split the Chaos into Land and Water; it takes
    a hell of an engineer to handle that big amount of mud, and orderly
          separation of solids from liquids..."  The computer scientist
  shouted: "And the Chaos, where do you think it was coming from, hmm?"

                                                            --Anonymous

   Autoconf is a tool for producing shell scripts that automatically
configure software source code packages to adapt to many kinds of
Posix-like systems.  The configuration scripts produced by Autoconf are
independent of Autoconf when they are run, so their users do not need to
have Autoconf.

   The configuration scripts produced by Autoconf require no manual user
intervention when run; they do not normally even need an argument
specifying the system type.  Instead, they individually test for the
presence of each feature that the software package they are for might
need.  (Before each check, they print a one-line message stating what
they are checking for, so the user doesn't get too bored while waiting
for the script to finish.)  As a result, they deal well with systems
that are hybrids or customized from the more common Posix variants.
There is no need to maintain files that list the features supported by
each release of each variant of Posix.

   For each software package that Autoconf is used with, it creates a
configuration script from a template file that lists the system features
that the package needs or can use.  After the shell code to recognize
and respond to a system feature has been written, Autoconf allows it to
be shared by many software packages that can use (or need) that feature.
If it later turns out that the shell code needs adjustment for some
reason, it needs to be changed in only one place; all of the
configuration scripts can be regenerated automatically to take advantage
of the updated code.

   Those who do not understand Autoconf are condemned to reinvent it,
poorly.  The primary goal of Autoconf is making the _user's_ life
easier; making the _maintainer's_ life easier is only a secondary goal.
Put another way, the primary goal is not to make the generation of
‘configure’ automatic for package maintainers (although patches along
that front are welcome, since package maintainers form the user base of
Autoconf); rather, the goal is to make ‘configure’ painless, portable,
and predictable for the end user of each “autoconfiscated” package.  And
to this degree, Autoconf is highly successful at its goal--most
complaints to the Autoconf list are about difficulties in writing
Autoconf input, and not in the behavior of the resulting ‘configure’.
Even packages that don't use Autoconf will generally provide a
‘configure’ script, and the most common complaint about these
alternative home-grown scripts is that they fail to meet one or more of
the GNU Coding Standards (*note (standards)Configuration::) that users
have come to expect from Autoconf-generated ‘configure’ scripts.

   The Metaconfig package is similar in purpose to Autoconf, but the
scripts it produces require manual user intervention, which is quite
inconvenient when configuring large source trees.  Unlike Metaconfig
scripts, Autoconf scripts can support cross-compiling, if some care is
taken in writing them.

   Autoconf does not solve all problems related to making portable
software packages--for a more complete solution, it should be used in
concert with other GNU build tools like Automake and Libtool.  These
other tools take on jobs like the creation of a portable, recursive
makefile with all of the standard targets, linking of shared libraries,
and so on.  *Note The GNU Build System::, for more information.

   Autoconf imposes some restrictions on the names of macros used with
‘#if’ in C programs (*note Preprocessor Symbol Index::).

   Autoconf requires GNU M4 version 1.4.8 or later in order to generate
the scripts.  It uses features that some versions of M4, including GNU
M4 1.3, do not have.  Autoconf works better with GNU M4 version 1.4.16
or later, though this is not required.

   *Note Autoconf 1::, for information about upgrading from version 1.
*Note History::, for the story of Autoconf's development.  *Note FAQ::,
for answers to some common questions about Autoconf.

   See the Autoconf web page (https://www.gnu.org/software/autoconf/)
for up-to-date information, details on the mailing lists, pointers to a
list of known bugs, etc.

   Mail suggestions to the Autoconf mailing list .
Past suggestions are archived
(https://lists.gnu.org/archive/html/autoconf/).

   Mail bug reports to the Autoconf Bugs mailing list
.  Past bug reports are archived
(https://lists.gnu.org/archive/html/bug-autoconf/).

   If possible, first check that your bug is not already solved in
current development versions, and that it has not been reported yet.  Be
sure to include all the needed information and a short ‘configure.ac’
that demonstrates the problem.

   Autoconf's development tree is accessible via ‘git’; see the Autoconf
Summary (https://savannah.gnu.org/projects/autoconf/) for details, or
view the actual repository
(https://git.savannah.gnu.org/cgit/autoconf.git).  Patches relative to
the current ‘git’ version can be sent for review to the Autoconf Patches
mailing list , with discussion on prior
patches archived (https://lists.gnu.org/archive/html/autoconf-patches/);
and all commits are posted in the read-only Autoconf Commit mailing list
, which is also archived
(https://lists.gnu.org/archive/html/autoconf-commit/).

   Because of its mission, the Autoconf package itself includes only a
set of often-used macros that have already demonstrated their
usefulness.  Nevertheless, if you wish to share your macros, or find
existing ones, see the Autoconf Macro Archive
(https://www.gnu.org/software/autoconf-archive/), which is kindly run by
Peter Simons .

© manpagez.com 2000-2025
Individual documents may contain additional copyright information.