Improve year-2038 documentation
[autoconf.git] / NEWS
blob2e988bed490dc97227b7998962b04d679d735d4a
1 GNU Autoconf NEWS - User visible changes.
3 * Noteworthy changes in release ?.? (????-??-??) [?]
5 ** Backward incompatibilities
7 *** Autoconf now requires perl 5.10 (2007) or later.
8   Generated 'configure' scripts continue to run without perl.
10 *** Autoconf now requires GNU M4 1.4.8 (2006) or later.
11   Generated 'configure' scripts continue to run without M4.
13   Use of GNU M4 1.4.16 or later is recommended, as all earlier versions
14   are known to have had serious bugs in the text-processing builtins
15   on some, but not all, operating systems.  Autoconf’s own configure
16   script will attempt to find a version of M4 that is not affected by
17   these bugs.
19   Note: Autoconf 2.70 and 2.71 include code that malfunctions with
20   M4 1.4.6 or 1.4.7.  However, the only effect of the malfunction is
21   that you will get a confusing error message if you run autoconf on
22   a configure.ac that neglects to use AC_INIT or AC_OUTPUT.
24 *** m4sh diversions like BINSH have been renumbered.
25   This matters only for uses that, contrary to the documentation
26   and despite warnings, use m4_divert with numbered diversions.
28 ** New features
30 *** New macro AC_SYS_YEAR2038.
31   This causes 'configure' to widen time_t if possible on systems where
32   time_t by default cannot represent file and other timestamps after
33   January 2038.  Widening is possible only on 32-bit GNU/Linux x86 and
34   ARM systems with glibc 2.34 or later.  To prevent widening,
35   configure with --disable-year2038.
37   This macro also has the effects as AC_SYS_LARGEFILE, because in
38   practice time_t cannot be widened without large-file sypport.
40   Application and library builders should take care that packages
41   configured with --enable-year2038 and --disable-year2038 options
42   are configured consistently, to avoid breaking binary compatibility.
43   This is similar to longstanding consistency requirements with
44   --enable-largefile and --disable-largefile.
46 *** AC_SYS_LARGEFILE now optionally arranges to widen time_t.
47   It now acts like AC_SYS_YEAR2038, except 'configure' defaults to
48   --disable-year2038 unless AC_SYS_YEAR2038 is also present.
49   As with AC_SYS_YEAR2038, application and library builders should
50   configure consistently.
52 *** New macros AC_SYS_LARGEFILE_REQUIRED and AC_SYS_YEAR2038_REQUIRED.
53   These act like AC_SYS_LARGEFILE and AC_SYS_YEAR2038 respectively,
54   except that they require large-file and year-2038 support respectively.
55   As with AC_SYS_YEAR2038, application and library builders should
56   configure consistently.
58 *** AC_USE_SYSTEM_EXTENSIONS now enables C23 Annex F extensions
59   by defining __STDC_WANT_IEC_60559_EXT__.
61 ** Obsolete features and new warnings
63 *** Autoconf now quotes 'like this' instead of `like this'.
65   Autoconf’s diagnostics now follow current GNU coding standards,
66   which say that diagnostics in the C locale should quote 'like this'
67   with plain apostrophes instead of the older GNU style `like this'
68   with grave accent and apostrophe.
70 ** Notable bug fixes
72 *** Autoconf caches now use finer-grained timestamps.
74   Autoconf now uses floating-point numbers rather than integers to
75   represent cache file timestamps, thus avoiding some problems where
76   automake incorrectly decides not to regenerate stale caches.
78 *** AC_HEADER_STDBOOL, AC_CHECK_HEADER_STDBOOL are obsolescent and less picky.
80   These macros are now obsolescent, as programs can simply include
81   stdbool.h unconditionally.  If you use these macros, they now accept
82   a stdbool.h that exists but does nothing, so long as ‘bool’, ‘true’,
83   and ‘false’ work anyway.  This is for compatibility with C23 and
84   with C++.
86 *** AC_PROG_MKDIR_P now falls back on plain 'mkdir -p'.
88   When AC_PROG_MKDIR_P cannot find a mkdir implementation that is
89   known to lack race condition bugs, it now falls back on 'mkdir -p'
90   instead of falling back on a relative path to install-sh, as the
91   relative paths now seem to be a more important problem than the
92   problems of ancient mkdir implementations with race condition bugs.
93   See <https://savannah.gnu.org/support/?110740>.  The only ancient
94   mkdir still in common use is Solaris 10 /usr/bin/mkdir, and for that
95   platform AC_PROG_MKDIR_P falls back on /opt/sfw/bin/mkdir which
96   should work.
98 * Noteworthy changes in release 2.71 (2021-01-28) [stable]
100 ** Bug fixes, including:
102 *** Compilers that support C99 but not C2011 are detected correctly.
104 *** Compatibility improved with clang and Oracle C++.
106 *** Compatibility restored with automake's rules for regenerating configure.
108 *** Compatibility restored with old versions of std-gnu11.m4.
110   Packages that wish to maintain compatibility with Autoconf 2.69 or
111   older, should update their copy of std-gnu11.m4 from Gnulib as soon
112   as practical, as the compatibility code bulks up the configure script.
114   Packages that require Autoconf 2.70 can drop this file entirely.
116 * Noteworthy changes in release 2.70 (2020-12-08) [stable]
118 ** Backward incompatibilities:
120 *** Warnings about obsolete constructs are now on by default.
122   These warnings can be turned off with ‘-Wno-obsolete’.
124   Many of these warnings advise maintainers to run autoupdate.
125   Be aware that autoupdate cannot solve all backward compatibility
126   problems, and cannot completely solve all of the problems it does
127   address.  A configure script edited by autoupdate is likely to
128   need further manual fix-ups.
130 *** Many macros have become pickier about argument quotation.
132   If you get a shell syntax error from your generated configure
133   script, or seemingly impossible misbehavior (e.g. entire blocks of
134   the configure script not getting executed), check first that all
135   macro arguments are properly quoted. The “M4 Quotation” section of
136   the manual explains how to quote macro arguments properly.
138   It is unfortunately not possible for autoupdate to correct
139   quotation errors.
141 *** Many macros no longer AC_REQUIRE as many other macros as they used to.
143   This can expose several classes of latent bugs.  These are the ones
144   we know about:
146    - Make sure to explicitly invoke all of the macros that set result
147      variables used later in the configure script, or in generated
148      Makefiles.
150    - Autoconf macros that use AC_REQUIRE are not safe to use in shell
151      control-flow constructs that appear outside of macros defined by
152      AC_DEFUN.  Use AS_IF, AS_CASE, etc. instead.  (See the
153      “Prerequisite Macros” section of the manual for details.)
155      The set of macros that use AC_REQUIRE internally may change from
156      release to release.  The only macros that are guaranteed *not* to
157      use AC_REQUIRE are the macros for acting on the results of a
158      test: AC_DEFINE, AC_SUBST, AC_MSG_*, AC_CACHE_CHECK, etc.
160    - AC_REQUIRE cannot be applied to macros that need to be used with
161      arguments.  Instead, invoke the macro normally, with its arguments.
163 *** More macros use config.sub and config.guess internally.
165   As a consequence of improved support for cross compilation (see below),
166   more macros now use the auxiliary scripts ‘config.sub’ and ‘config.guess’.
167   If you use any of the affected macros, these scripts must be available
168   when your configure script is run, even if you have no intention of
169   ever cross-compiling your program.
171   autoreconf will issue an error if any auxiliary scripts are needed but
172   cannot be found.  (It is not currently possible to make autoconf
173   itself issue this error.)
175   ‘autoreconf --install’ will add ‘config.sub’, ‘config.guess’, and
176   ‘install-sh’ to your source tree if they are needed.  If you are
177   using Automake, scripts added to your tree by ‘autoreconf --install’
178   will automatically be included in the tarball produced by ‘make dist’;
179   otherwise, you will need to arrange for them to be distributed
180   yourself.
182   See the “Input” section of the manual for more detail, including
183   where to get the auxiliary scripts that may be needed by autoconf macros.
185 *** Setting CC to a C++ compiler is no longer supported.
187   The C and C++ languages have diverged enough that we can no longer
188   guarantee that test C programs will be processed as intended by a
189   C++ compiler.  In this release, configure will proceed anyway, but
190   many test results will be incorrect.  In a future release, we may
191   make AC_PROG_CC error out if it detects that CC is a C++ compiler.
193   See the “Language Choice” section of the manual for instructions on
194   how to write configure scripts for C++ programs, and for programs
195   with code in more than one language.
197 *** Running configure tests with warnings promoted to errors is not supported.
199   For instance, setting ‘CC="gcc -Werror"’ on the configure command
200   line, or adding -Werror to CFLAGS early in the configure script when
201   the compiler recognizes this option, is very likely to cause
202   subsequent tests to fail.
204   This has never been guaranteed to work; the code generated by
205   AC_CHECK_FUNC, for instance, is incorrect by a strict reading of the
206   original 1989 C standard, and has been ever since that macro was
207   introduced.  Problems are more likely with newer, pickier compilers.
209   To enable compiler warnings and/or warnings-as-errors mode for your
210   own code, we currently recommend a dedicated Makefile variable
211   (e.g. ‘WARN_CFLAGS’) that is set by AC_SUBST when appropriate.
212   The Gnulib ‘warnings’ and ‘manywarnings’ modules can help with this.
213   We plan to add core support for probing for useful sets of compiler
214   warnings in a future release.
216 *** Including confdefs.h manually may cause test failures.
218   This has never been necessary; confdefs.h is automatically included
219   at the beginning of all test programs (by AC_LANG_SOURCE).  Because
220   of the way confdefs.h is generated and used, it is not practical to
221   give it a multiple inclusion guard.  Therefore, if you include it
222   yourself, all of its definitions will be scanned twice.
224   Historically this has not been a problem, because confdefs.h only
225   makes macro definitions, and the C standard allows redefinitions
226   of macros as long as they’re exactly the same, but newer, pickier
227   compilers may complain anyway (see for instance GCC bug 97998).
229 *** Older versions of automake and aclocal (< 1.8) are no longer supported.
231 *** AC_CONFIG_SUBDIRS no longer directly supports Cygnus configure.
233   If you are still using an Autoconf script to drive configuration of
234   a multi-package build tree where some subdirectories use Cygnus
235   configure, copy or link $ac_aux_dir/configure into each subdirectory
236   where it is needed.  Please also contact us; we were under the
237   impression nobody used this very old tool anymore.
239 *** AC_CHECK_HEADER and AC_CHECK_HEADERS only do a compilation test.
241   This completes the transition from preprocessor-based header tests
242   begun in Autoconf 2.56.
244   The double test that was the default since Autoconf 2.64 is no
245   longer available.  You can still request a preprocessor-only test
246   by specifying [-] as the fourth argument to either macro, but this
247   is now deprecated.  If you really need that behavior use
248   AC_PREPROC_IFELSE.
250 *** AC_INCLUDES_DEFAULT assumes an ISO C90 compliant C implementation.
252   Specifically, it assumes that the ISO C90 header <stddef.h>
253   is available, without checking for it, and it does not include
254   the pre-standard header <memory.h> at all.  If the POSIX header
255   <strings.h> exists, it will be included, without first testing
256   whether both <string.h> and <strings.h> can be included in the
257   same source file.
259   AC_INCLUDES_DEFAULT still checks for the existence of <stdlib.h>,
260   <string.h>, and <stdio.h>, because these headers may not exist
261   in a “freestanding environment” (a compilation mode intended for OS
262   kernels and similar, where most of the features of the C library are
263   optional).  Most programs need not use ‘#ifdef HAVE_STDLIB_H’ etc in
264   their own code.
266   For compatibility’s sake, the C preprocessor macro STDC_HEADERS
267   will be defined when both <stdlib.h> and <string.h> are available;
268   however, <stdarg.h> and <float.h> are no longer checked for
269   (these, like <stddef.h>, are required to exist in a freestanding
270   environment).  New code should not refer to this macro.
272   Future releases of Autoconf may reduce the set of headers checked
273   for by AC_INCLUDES_DEFAULT.
275 *** AS_ECHO and AS_ECHO_N unconditionally use ‘printf’.
277   This is substantially simpler, more reliable, and, in most cases,
278   faster than attempting to use ‘echo’ at all.  However, if ‘printf’
279   is not a shell builtin, configure scripts will run noticeably
280   slower, and if ‘printf’ is not available at all, they will crash.
281   The only systems where this is known to be a problem are extremely
282   old, and unlikely to be able to handle modern C programs for other
283   reasons (e.g. not having a C90-compliant compiler at all).
285 *** Configure scripts require support for $( ... ) command substitution.
287   This POSIX shell feature is approximately the same age as
288   user-defined functions, but there do exist shells that support
289   functions and not $( ... ), such as Solaris 10 /bin/sh.
291   Configure scripts will automatically locate a shell that supports
292   this feature and re-execute themselves with it, if necessary, so
293   the new requirement should be transparent to most users.
295   In this release, most of Autoconf’s code still uses the older `...`
296   notation for command substitution.
298 *** AC_INIT now trims extra white space from its arguments.
300   For instance, AC_INIT([  GNU  Hello  ], [1.0]) will set PACKAGE_NAME
301   to “GNU Hello”.
303 *** Macros that take whitespace-separated lists as arguments
304     now always expand macros within those arguments.
306   Formerly, these macros would *usually* expand those arguments, but
307   the behavior was not reliable nor was it consistent between autoconf
308   and autoheader.
310   Macro expansion within these arguments is deprecated; if expansion
311   changes the list, a warning in the “obsolete” category will be
312   emitted.  Note that ‘dnl’ is a macro.  Putting ‘dnl’ comments inside
313   any argument to an Autoconf macro is, in general, only supported
314   when that argument takes more Autoconf code (e.g. the ACTION-IF-TRUE
315   argument to AC_COMPILE_IFELSE).
317   The affected macros are AC_CHECK_FILES, AC_CHECK_FUNCS,
318   AC_CHECK_FUNCS_ONCE, AC_CHECK_HEADERS, AC_CHECK_HEADERS_ONCE,
319   AC_CONFIG_MACRO_DIRS, AC_CONFIG_SUBDIRS, and AC_REPLACE_FUNCS.
321 *** AC_FUNC_VFORK no longer ignores a signal-handling bug in Solaris 2.4.
323   This bug was being ignored because Emacs wanted to use ‘vfork’ on
324   Solaris 2.4 anyway, but current versions of Emacs have dropped
325   support for Solaris 2.4.  Most programs will want to avoid ‘vfork’
326   on this OS because of this bug.
328 *** AC_FUNC_STRERROR_R assumes strerror_r is unavailable if it’s not declared.
330   The fallback technique it used to probe strerror_r’s return type
331   when the function was present in the C library, but not declared by
332   <string.h>, was fragile and did not work at all when cross-compiling.
333   The systems where this fallback was necessary were all obsolete.
335   Programs that use AC_FUNC_STRERROR_R should make sure to test the
336   preprocessor macro HAVE_DECL_STRERROR_R before using strerror_r at all.
338 *** AC_OPENMP can’t be used if you have files named ‘mp’ or ‘penmp’.
340   Autoconf will now issue an error if AC_OPENMP is used in a configure
341   script that’s in the same directory as a file named ‘mp’ or ‘penmp’.
342   Configure scripts that use AC_OPENMP will now error out upon
343   encountering files with these names in their working directory
344   (e.g. when the build directory is separate from the source directory).
346   If you have files with these names at the top level of your source
347   tree, we recommend either renaming them or moving them into a
348   subdirectory.  See the documentation of AC_OPENMP for further
349   explanation.
351 ** New features
353 *** Configure scripts now support a ‘--runstatedir’ option.
355   This defaults to ‘${localstatedir}/run’.  It can be used, for
356   instance, to place per-process temporary runtime files (such as pid
357   files) into ‘/run’ instead of ‘/var/run’.
359 *** autoreconf will now run gtkdocize and intltoolize when appropriate.
361 *** autoreconf now recognizes AM_GNU_GETTEXT_REQUIRE_VERSION.
363   This macro can be used with gettext 0.19.6 or later to specify
364   a *minimum* version requirement for gettext, instead of the *fixed*
365   version requirement specified by AM_GNU_GETTEXT_VERSION.
367 *** autoheader handles secondary config headers better.
369   It is no longer necessary to duplicate AC_DEFINE templates in the
370   main configuration header for autoheader to notice them.
372 *** AC_PROG_CC now enables C2011 mode if the compiler supports it.
374   If not, it will fall back to C99 and C89, as before.  Similarly,
375   AC_PROG_CXX now enables C++2011 if available, falling back on C++98.
377 *** New macro AC_C__GENERIC tests for C2011 _Generic support.
379 *** AC_C_VARARRAYS has been aligned with C2011.
381   It now defines __STDC_NO_VLA__ if variable-length arrays are not
382   supported but the compiler does not define __STDC_NO_VLA__.
384   For backward compatibility with Autoconf 2.61-2.69 AC_C_VARARRAYS
385   still defines HAVE_C_VARARRAYS, but this result macro is obsolescent.
387 *** New macro AC_CONFIG_MACRO_DIRS.
389   This macro can be used more than once and accepts a list of
390   directories to search for local M4 macros.  With Automake 1.13 and
391   later, use of this macro eliminates a reason to use ACLOCAL_AMFLAGS
392   in Makefile.am.
394   The older AC_CONFIG_MACRO_DIR, which could only be used once, is
395   still supported but considered deprecated.
397 *** AC_USE_SYSTEM_EXTENSIONS knows about more extensions to enable.
399   System extensions will now be enabled on HP-UX, macOS, and MINIX.
400   Optional ISO C library components (e.g. decimal floating point) will
401   also be enabled.
403 *** New compatibility macro AC_CHECK_INCLUDES_DEFAULT.
405   This macro runs the checks normally performed as a side-effect by
406   AC_INCLUDES_DEFAULT, if they haven’t already been done.  Autoupdate
407   will replace certain obsolete constructs, whose only remaining
408   useful effect is to trigger those checks, with this macro.  It is
409   unlikely to be useful otherwise.
411 *** AC_REQUIRE_AUX_FILE has been improved.
413   Configure scripts now check, on startup, for the availability of all
414   the aux files that were mentioned in an AC_REQUIRE_AUX_FILE
415   invocation.  This should help prevent certain classes of packaging
416   errors.
418   Also, it is no longer necessary for third-party macros that use
419   AC_REQUIRE_AUX_FILE to mention AC_CONFIG_AUX_DIR_DEFAULT.  However,
420   if you are using AC_CONFIG_AUX_DIR_DEFAULT *without* also using
421   AC_REQUIRE_AUX_FILE, please start using AC_REQUIRE_AUX_FILE to
422   specify the aux files you actually need, so that the check can be
423   effective.
425 *** AC_PROG_LEX has an option to not look for yywrap.
427   AC_PROG_LEX now takes one argument, which may be either ‘yywrap’ or
428   ‘noyywrap’.  If it is ‘noyywrap’, AC_PROG_LEX will only set LEXLIB
429   to ‘-lfl’ or ‘-ll’ if a scanner that defines both main and yywrap
430   itself still needs something else from that library.  On the other
431   hand, if it is ‘yywrap’, AC_PROG_LEX will fail (setting LEX to ‘:’
432   and LEXLIB to nothing) if it can’t find a library that defines yywrap.
434   In the absence of arguments, AC_PROG_LEX’s behavior is bug-compatible
435   with 2.69, which did neither of the above things (see the manual for
436   details).  This mode is deprecated.
438   We encourage all programs that use AC_PROG_LEX to use the new
439   ‘noyywrap’ mode, and to define yywrap themselves, or use %noyywrap.
440   The yywrap function in lib(f)l is trivial, and self-contained
441   scanners are easier to work with.
443 ** Obsolete features and new warnings
445 *** Use of the long-deprecated name ‘configure.in’ for the autoconf
446     input file now elicits a warning in the “obsolete” category.
448 *** Use of the undocumented internal shell variables $as_echo and
449     $as_echo_n now elicits a warning in the “obsolete” category.
450     The macros AS_ECHO and AS_ECHO_N should be used instead.
452 *** autoconf will now issue warnings (in the “syntax” category)
453     if the input file is missing a call to AC_INIT and/or AC_OUTPUT.
455 *** autoconf will now issue warnings (in the “syntax” category)
456     for a non-literal URL argument to AC_INIT, and for a TARNAME
457     argument to AC_INIT which is either non-literal or contains
458     characters that should not be used in file names (e.g. ‘*’).
460 *** AC_PROG_CC_STDC, AC_PROG_CC_C89, AC_PROG_CC_C99 are now obsolete.
462   Applications should use AC_PROG_CC.
464 *** AC_HEADER_STDC and AC_HEADER_TIME are now stubs.
466   They still define the C preprocessor macros STDC_HEADERS and
467   TIME_WITH_SYS_TIME, respectively, but they no longer check for the
468   ancient, non-ISO-C90 compliant systems where formerly those macros
469   would not be defined.  Autoupdate will remove them.
471   These macros were already labeled obsolete in the manual.
473 *** AC_DIAGNOSE, AC_FATAL, AC_WARNING, and _AC_COMPUTE_INT are now
474     replaced with modern equivalents by autoupdate.
476   These macros were already labeled obsolete in the manual.
478 *** AC_CONFIG_HEADER is now diagnosed as obsolete, and replaced with
479     AC_CONFIG_HEADERS by autoupdate.
481   This macro has been considered obsolete for many years and was not
482   documented at all.
484 *** The macro AC_OBSOLETE is obsolete.
486   Autoupdate will replace it with m4_warn([obsolete], [explanation]).
487   If possible, macros using AC_OBSOLETE should be converted to use
488   AU_DEFUN or AU_ALIAS instead, which enables autoupdate to replace
489   them, but this has to be done by hand and is not always possible.
491   This macro has been considered obsolete for many years, but was not
492   officially declared as such.
494 *** Man pages for config.guess and config.sub are no longer provided.
496   They were moved to the master source tree for config.guess and
497   config.sub.
499 ** Notable bug fixes
501 *** Compatible with current Automake, Libtool, Perl, Texinfo, and shells.
503   All of autoconf’s tools and generated scripts, and the build process
504   and testsuite for autoconf itself, have been tested to work
505   correctly with current versions of Automake, Libtool, Perl, Texinfo,
506   bash, ksh93, zsh, and FreeBSD and NetBSD /bin/sh.
508   Generated configure scripts are expected to work reliably with an
509   even wider variety of shells, including BusyBox sh and various
510   proprietary Unixes’ /bin/sh, as long as they are minimally compliant
511   with the Unix95 shell specification.  Notably, support for
512   shell-script functions and the ‘printf’ builtin are required.
514 *** Checks compatible with current language standards and compilers.
516   Many individual macros have been improved to accommodate changes in
517   recent versions of the C and C++ language standards, and new
518   features and quirks of commonly used compilers (both free and
519   proprietary).
521 *** Improved support for cross compilation.
523   Many individual macros have been improved to produce more accurate
524   results when cross-compiling.
526 *** Improved robustness against unusual build environments.
528   Many bugs have been fixed where generated configure scripts would
529   fail catastrophically under unusual conditions, such as stdout being
530   closed, or $TMPDIR not being an absolute path, or the root directory
531   being mentioned in $PATH.
533 *** AC_CHECK_FUNCS_ONCE and AC_CHECK_HEADERS_ONCE now support multiple
534     programming languages.  They no longer perform all checks in the
535     language active upon the first use of the macro.
537 *** AC_CHECK_DECL and AC_CHECK_DECLS will now detect missing declarations for
538     library functions that are also Clang compiler builtins.
540 *** AC_PATH_X and AC_PATH_XTRA don’t search for X11 when cross-compiling.
542   Libraries and headers found by running xmkmf or searching /usr/X11,
543   /usr/X11R7, etc. are likely to belong to a native X11 installation
544   for the build machine and to be inappropriate for cross compilation.
546   To cross-compile programs that require X11, we recommend putting the
547   headers and libraries for the host system in your cross-compiler’s
548   default search paths.  Alternatively, use configure’s --x-includes
549   and --x-libraries command line options to tell it where they are.
551 *** AS_IF’s if-false argument may be empty after macro expansion.
553   This long-standing limitation broke configure scripts that used
554   macros in this position that emitted shell code in 2.69 but no
555   longer do, so we have lifted it.
557 *** AC_HEADER_MAJOR detects the location of the major, minor, and
558     makedev macros correctly under glibc 2.25 and later.
560 *** AC_FC_LINE_LENGTH now documents the maximum portable length of
561     “unlimited” Fortran source code lines to be 250 columns, not 254.
563 *** AC_INIT and AS_INIT no longer embed (part of) the path to the
564     source directory in generated files.
566   We believe this was the only case where generated file contents
567   could change depending on the environment outside the source tree
568   itself.  If you find any other cases please report them as bugs.
570 *** config.log properly escapes arguments in the header comment.
572 *** config.status --config output is now quoted in a more readable fashion.
574 ** Autotest enhancements
576 *** Autotest provides a new macro AT_DATA_UNQUOTED, similar to AT_DATA
577     but processing variable substitutions, command substitutions and
578     backslashes in the contents argument.
580 *** AC_CONFIG_TESTDIR will automatically pass EXEEXT to a testsuite (via
581     the atconfig file).
583 *** AT_TESTED arguments can use variable or command substitutions, including
584     in particular $EXEEXT
586 *** New macros AT_PREPARE_TESTS, AT_PREPARE_EACH_TEST, and AT_TEST_HELPER_FN.
588    These provide an official way to define testsuite-specific
589    initialization code and shell functions.
591 * Noteworthy changes in release 2.69 (2012-04-24) [stable]
593 ** Autoconf now requires perl 5.6 or better (but generated configure
594    scripts continue to run without perl).
596 * Noteworthy changes in release 2.68b (2012-03-01) [beta]
597   Released by Eric Blake, based on git versions 2.68.*.
599 ** Autoconf-generated configure scripts now unconditionally re-execute
600    themselves with $CONFIG_SHELL, if that's set in the environment.
602 ** The texinfo documentation no longer specifies "front-cover" or
603    "back-cover" texts, so that it may now be included in Debian's
604    "main" section.
606 ** Support for the Go programming language has been added.  The new macro
607    AC_LANG_GO sets variables GOC and GOFLAGS.
609 ** AS_LITERAL_IF again treats '=' as a literal.  Regression introduced in
610    2.66.
612 ** The macro AS_EXECUTABLE_P, present since 2.50, is now documented.
614 ** Macros
616 - AC_PROG_LN_S and AS_LN_S now fall back on 'cp -pR' (not 'cp -p') if 'ln -s'
617   does not work.  This works better for symlinks to directories.
619 - New macro AC_HEADER_CHECK_STDBOOL.
621 - New and updated macros for Fortran support:
623     AC_FC_CHECK_BOUNDS to enable array bounds checking
624     AC_F77_IMPLICIT_NONE and AC_FC_IMPLICIT_NONE to disable implicit integer
625     AC_FC_MODULE_EXTENSION to compute the Fortran 90 module name extension
626     AC_FC_MODULE_FLAG for the Fortran 90 module search path flag
627     AC_FC_MODULE_OUTPUT_FLAG for the Fortran 90 module output directory flag
628     AC_FC_PP_SRCEXT for preprocessed Fortran source files extensions
629     AC_FC_PP_DEFINE for the Fortran preprocessor define flag
631 * Noteworthy changes in release 2.68 (2010-09-22) [stable]
632   Released by Eric Blake, based on git versions 2.67.*.
634 ** AC_MSG_ERROR (and AS_ERROR) can once again be followed immediately by
635    'dnl'.  Regression introduced in 2.66.
637 ** AC_INIT again allows URLs with '?' for its BUG-REPORT argument.
638    Regression introduced in 2.66.
640 ** AC_REPLACE_FUNCS again allows a non-literal argument, such as a shell
641    variable that expands to a list of functions to check.  Regression
642    introduced in 2.66.
644 ** AT_BANNER() with empty argument will cause visual separation from previous
645    test category.
647 ** The macros AC_PREPROC_IFELSE, AC_COMPILE_IFELSE, AC_LINK_IFELSE, and
648    AC_RUN_IFELSE now warn if the first argument failed to use
649    AC_LANG_SOURCE or AC_LANG_PROGRAM to generate the conftest file
650    contents.  A new macro AC_LANG_DEFINES_PROVIDED exists if you have
651    a compelling reason why you cannot use AC_LANG_SOURCE but must
652    avoid the warning.
654 ** The macro m4_define_default is now documented.
656 ** Symlinked config.cache files are supported; configure now tries to
657    update non-symlinked cache files atomically, so that concurrent configure
658    runs do not leave behind broken cache files.  It is still unspecified
659    which subset or union of results is cached though.
661 ** Autotest testsuites should not contain long text lines any more, and be
662    portable even when very many test groups are used.
664 ** AT_CHECK semantics with respect to the Autotest variable $at_status and
665    shell execution environment of the arguments are documented now.
667 ** AC_FC_LIBRARY_LDFLAGS now tolerates output from newer gfortran.
669 ** Newly obsolete macros
670    The following macros have been marked obsolete.  New programs
671    should use the corresponding Gnulib modules.  Gnulib not only
672    detects a larger set of portability problems with these functions,
673    but also provides complete workarounds.
675      AC_FUNC_ERROR_AT_LINE  AC_FUNC_LSTAT_FOLLOWS_SLASHED_SYMLINK
676      AC_FUNC_MKTIME  AC_FUNC_STRTOD
679 * Major changes in Autoconf 2.67 (2010-07-21) [stable]
680   Released by Eric Blake, based on git versions 2.66.*.
682 ** AC_CONFIG_SUBDIRS with more than one subdirectory at a time works again.
683    Regression introduced in 2.66.
685 ** AC_CHECK_SIZEOF of a pointer type works again.  Regression introduced in
686    2.66.
688 ** New macro AC_FC_LINE_LENGTH to accept long Fortran source code lines.
690 ** AC_PREPROC_IFELSE now keeps the preprocessed output in the conftest.i
691    file for inspection by the commands in the ACTION-IF-TRUE argument.
693 ** AC_INIT again allows parentheses and other characters that are literal
694    in single- or double-quoted strings, and in quoted and unquoted
695    here-documents, for its PACKAGE and VERSION arguments.  Regression
696    introduced in 2.66.
698 ** autoreconf passes warning flags to new enough versions of aclocal.
700 ** Running an Autotest testsuite in parallel mode no longer triggers a
701    race condition that could cause the testsuite run to end early,
702    fixing a sporadic failure in autoconf's own testsuite.  Bug present
703    since introduction of parallel tests in 2.63b.
706 * Major changes in Autoconf 2.66 (2010-07-02) [stable]
707   Released by Eric Blake, based on git versions 2.65.*.
709 ** AC_FUNC_MMAP works in C++ mode again.  Regression introduced in 2.65.
711 ** Use of m4_divert without a named diversion now issues a syntax warning,
712    since it is seldom right to change diversions behind autoconf's back.
714 ** The macros AC_TYPE_INT8_T, AC_TYPE_INT16_T, AC_TYPE_INT32_T, and
715    AC_TYPE_INT64_T work again.  Regression introduced in 2.65.
717 ** AC_PROG_INSTALL correctly uses 'shtool' again.  Regression introduced
718    in 2.64.
720 ** Autoconf should work on EBCDIC hosts.
722 ** AC_CHECK_DECL and AC_CHECK_DECLS accept optional function argument types
723    for overloaded C++ functions.
725 ** AS_SET_CATFILE accepts nonliterals in its variable name argument now.
727 ** Autotest testsuites accept an option --recheck to rerun tests that
728    failed or passed unexpectedly during the last non-debug testsuite run.
730 ** AC_ARG_ENABLE and AC_ARG_WITH now also accept '+' signs in '--enable-*'
731    and '--with-*' arguments, converting them to underscores for the variable
732    names.
734 ** In configure scripts, loading CONFIG_SITE no longer searches PATH,
735    and problems in loading the configuration site files are diagnosed.
737 ** Autotest testsuites may optionally provide colored test results.
739 ** The previously undocumented Autotest macros AT_ARG_OPTION and
740    AT_ARG_OPTION_ARG have seen bug fixes and are documented now.
741    AT_ARG_OPTION has been changed in that the negative of a long option
742    --OPTION is now --no-OPTION rather than --noOPTION.
744 ** The macro AS_LITERAL_IF is slightly more conservative; text
745    containing shell quotes are no longer treated as literals.
746    Furthermore, a new macro, AS_LITERAL_WORD_IF, adds an additional
747    level of checking that no whitespace occurs in literals.
749 ** The macros AS_TR_SH and AS_TR_CPP no longer expand their results.
751 ** The following macros are now documented:
752    AS_BOX
754 ** New macro AC_FC_FIXEDFORM to accept fixed-form Fortran.
757 * Major changes in Autoconf 2.65 (2009-11-21) [stable]
758   Released by Eric Blake, based on git versions 2.64.*.
760 ** Autoconf is now licensed under the General Public License version 3
761    or later (GPLv3+).  As with earlier versions, the license includes
762    an exception clause so that you may release a configure script
763    generated by autoconf under the license of your own program.
765 ** New macros to support Objective C++.
766    AC_PROG_OBJCXX  AC_PROG_OBJCXXCPP
768 ** The following undocumented autoconf macros, removed in Autoconf 2.64,
769    have been reinstated:
770    AH_CHECK_HEADERS
772    These macros are present only for backwards compatibility purposes.
774 ** The macro AC_LANG_COMPILER no longer fails on embedded systems that
775    lack fopen in the C library, such as AVR or RTEMS (regression
776    introduced in 2.64).
778 ** The AC_FC_FREEFORM macro no longer suffers from a whitespace bug that
779    made it fail with some Fortran compilers (regression introduced in
780    2.64).
782 ** The AC_TYPE_UINT64_T and AC_TYPE_INT64_T macros have been fixed to no
783    longer mistakenly select a 32-bit type on some compilers (bug present
784    since macros were introduced in 2.59c).
786 ** The AC_FUNC_MMAP macro has been fixed to be portable to systems like
787    Cygwin (bug present since macro was introduced in 2.0).
789 ** The following documented autotest macros are new:
790    AT_CHECK_EUNIT
792 ** The following m4sugar macros now quote their expansion:
793    m4_toupper  m4_tolower
795 ** The following m4sugar macros are new:
796    m4_escape
798 ** The m4sugar macro m4_text_wrap now copes with embedded quoting without
799    requiring quadrigraphs.  For uses like AC_ARG_VAR([a], [[b c]]),
800    this gives the intuitive behavior of "[b c]" in the output (2.63
801    gave the output of "[b], [c]", and 2.64 encountered a failure).
803 ** The '$tmp' temporary directory used in config.status is documented for
804    public use now.
806 ** config.status now provides a --config option to produce the configuration.
808 ** Many cache variables used by Autoconf's macros are now documented.
810 ** Configure scripts work better on DJGPP by avoiding a bug present in
811    the DJGPP port of bash 2.04 in handling 'return' in a shell
812    function (regression introduced in 2.64).
814 * Major changes in Autoconf 2.64 (2009-07-26) [stable]
815   Released by Eric Blake, based on git versions 2.63b.*.
817 ** Autoconf now requires GNU M4 1.4.6 or later.  Earlier versions of M4
818    have a bug in regular expression handling that interferes with some
819    of the speedups provided since Autoconf 2.63.  GNU M4 1.4.13 or
820    later is recommended.
822 ** AS_IF and AS_CASE have been taught to avoid syntax errors even when
823    given arguments that expand to just whitespace.
825 ** The following documented autoconf macros are new:
826    AC_ERLANG_SUBST_ERTS_VER
828 ** The autoheader tool now understands m4 macro arguments passed to
829    AC_DEFINE and AC_DEFINE_UNQUOTED.
831 ** Ensure AT_CHECK can support commands that include a # given with
832    proper m4 quoting.  For shell comments, this is a new feature; for
833    non-shell comments, this fixes a regression introduced in 2.63b.
834    Additionally, AT_CHECK correctly supplies shell escapes for
835    metacharacters occurring in m4 macro expansions within the expected
836    stdout and stderr parameters.
838 ** The macro AT_CHECK now understands the concept of hard failure.  If
839    a test exits with an unexpected status 99, cleanup actions for the
840    test are inhibited and the test is treated as a failure regardless
841    of AT_XFAIL_IF.  It also understands the new directives
842    ignore-nolog, stdout-nolog, and stderr-nolog.
844 ** The following documented autotest macros are new:
845    AT_CHECK_UNQUOTED  AT_FAIL_IF  AT_SKIP_IF
847 ** The following documented m4sugar macros are new:
848    m4_argn  m4_copy_force  m4_default_nblank  m4_default_nblank_quoted
849    m4_ifblank  m4_ifnblank  m4_rename_force
851 ** The autoconf testsuite now exercises all Erlang macros.
853 * Major changes in Autoconf 2.63b (2009-03-31) [beta]
854   Released by Eric Blake, based on git versions 2.63.*.
856 ** The manual is now shipped under the terms of the GNU FDL 1.3.
858 ** AC_REQUIRE now detects the case of an outer macro which first expands
859    then later indirectly requires the same inner macro.  Previously,
860    this case led to silent out-of-order expansion (bug present since
861    2.50); it now issues a syntax warning, and duplicates the expansion
862    of the inner macro to guarantee dependencies have been met.  See
863    the manual for advice on how to refactor macros in order to avoid
864    the bug in earlier autoconf versions and avoid increased script
865    size in the current version.
867 ** AC_DEFUN_ONCE has improved semantics.  Previously, a macro declared
868    with AC_DEFUN_ONCE warned on a second invocation; and out-of-order
869    expansion was still possible.  Now, dependencies are guaranteed,
870    and subsequent invocations are a silent no-op.  This makes
871    AC_DEFUN_ONCE an ideal macro for silencing AC_REQUIRE warnings.
873 ** The following macros are now defined with AC_DEFUN_ONCE.  This means
874    a subtle change in semantics; previously, an AC_DEFUN macro could
875    expand one of these macros multiple times or surround the macro
876    inside shell conditional text to bypass the effects of these
877    macros, but now the macro will expand exactly once, and prior to
878    the start of any enclosing AC_DEFUN macro:
879    AC_CANONICAL_BUILD  AC_CANONICAL_HOST  AC_CANONICAL_TARGET
880    AC_HEADER_ASSERT  AC_PROG_INSTALL  AC_PROG_MKDIR_P
881    AC_USE_SYSTEM_EXTENSIONS
883 ** AC_LANG_ERLANG works once again (regression introduced in 2.61a).
885 ** AC_HEADER_ASSERT is fixed so that './configure --enable-assert' no
886    longer mistakenly disables assertions.
888 ** AC_INIT now takes an optional fifth parameter that can be used to
889    set AC_PACKAGE_URL, a URL for the package's home page; the URL is
890    used in 'configure --help' and is also available via AC_DEFINE.
892 ** Autotest testsuites accept an option --jobs[=N] for parallel testing.
893    This feature is still in testing, and may not work on every
894    platform, help in improving it would be appreciated.
896 ** Autotest testsuites do not attempt to write startup error messages
897    to the log file before that is opened (regression introduced in 2.63).
899 ** Configure scripts now use shell functions.  This feature leads to
900    smaller configure files and faster execution.
902 ** Present But Cannot Be Compiled: Autoconf will now proceed with
903    the compiler's result if a header is present but cannot be compiled.
904    The warning is still printed, and you should really fix it by
905    providing a fourth parameter to AC_CHECK_HEADER/AC_CHECK_HEADERS.
907 ** Autoreconf added aclocal to the set of programs affected by the
908    'autoreconf -I dir' option.
910 ** The following documented m4sugar macros are new:
911    m4_chomp  m4_chomp_all  m4_cleardivert  m4_curry  m4_default_quoted
912    m4_esyscmd_s  m4_map_args  m4_map_args_pair  m4_map_args_sep
913    m4_map_args_w  m4_set_map  m4_set_map_sep  m4_stack_foreach
914    m4_stack_foreach_lifo  m4_stack_foreach_sep
915    m4_stack_foreach_sep_lifo
917 ** The following m4sugar macros are documented now, but in some cases
918    with slightly different semantics than what the previous
919    undocumented version had:
920    m4_copy  m4_dumpdefs  m4_rename  m4_version_prereq
922 ** The m4sugar macro m4_expand has been taught to handle unterminated
923    comments and shell case statements.  As a result, it is used
924    internally in more places, such as AC_DEFINE and AT_CHECK.  Most
925    uses of AC_DEFINE and AT_CHECK should not behave any differently;
926    however, it may be necessary to add double-quoting around
927    unbalanced '(' where single-quoting used to be sufficient.
929 ** The following documented m4sh macros are new:
930    AS_INIT_GENERATED  AS_LINENO_PREPARE  AS_ME_PREPARE  AS_SET_STATUS
931    AS_VAR_APPEND  AS_VAR_ARITH  AS_VAR_COPY
933 ** The following m4sh macros are documented now, but in some cases
934    with slightly different semantics than what the previous
935    undocumented version had:
936    AS_ECHO  AS_ECHO_N  AS_ESCAPE  AS_EXIT  AS_LITERAL_IF  AS_UNSET
937    AS_VAR_IF  AS_VAR_POPDEF  AS_VAR_PUSHDEF  AS_VAR_SET  AS_VAR_SET_IF
938    AS_VAR_TEST_SET  AS_VERSION_COMPARE
940 ** The m4sh macros AS_IF and AS_CASE can now be used in shell lists.
941    The responsibility for supplying a trailing newline now belongs to
942    the call site, but since most users did not add dnl, this generally
943    results in fewer empty lines in configure.
946 * Major changes in Autoconf 2.63 (2008-09-09) [stable]
947   Released by Eric Blake, based on git versions 2.62.*.
949 ** AC_C_BIGENDIAN does not mistakenly report "universal" for some
950    bigendian hosts, a regression introduced with universal binary
951    support in 2.62.
953 ** AC_PATH_X now includes /lib64 and /usr/lib64 in its list of default
954    library directories.
956 ** AC_USE_SYSTEM_EXTENSIONS no longer conflicts with an external
957    AC_DEFINE([__EXTENSIONS__]).  This fixes a regression introduced in
958    2.62 when using macros such as AC_AIX that were made obsolete in
959    favor of the more portable AC_USE_SYSTEM_EXTENSIONS.
961 ** AC_CHECK_TARGET_TOOLS is usable in the non-cross-compile case.
963 ** Newly obsolete macros
964    The following macro has been marked obsolete, since current porting
965    targets can safely assume C89 semantics that signal handlers return
966    void.  We have no current plans to remove the macro.
968      AC_TYPE_SIGNAL
970 ** The macros m4_map and m4_map_sep now ignore any list elements
971    consisting of just empty quotes, and m4_map_sep now expands its
972    separator.  This fixes a regression in 2.62 when these macros were
973    first documented, for the sake of clients expecting the semantics
974    that these macros had prior to that time.  The new macros m4_mapall
975    and m4_mapall_sep, along with extra quoting of the separator, can
976    be used to get the semantics that m4_map_sep had in 2.62.
978 ** Clients of m4_expand, such as AS_HELP_STRING and AT_SETUP, can now
979    handle properly quoted but otherwise unbalanced parentheses (for
980    some macros, this fixes a regression in 2.62).
982 ** Two new quadrigraphs have been introduced: @{:@ for (, and @:}@ for ),
983    allowing the output of unbalanced parentheses in more contexts.
985 ** The following m4sugar macros are new:
986    m4_cleardivert  m4_joinall  m4_mapall  m4_mapall_sep  m4_reverse
987    m4_set_add  m4_set_add_all  m4_set_contains  m4_set_contents
988    m4_set_delete  m4_set_difference  m4_set_dump  m4_set_empty
989    m4_set_foreach  m4_set_intersection  m4_set_list  m4_set_listc
990    m4_set_remove  m4_set_size  m4_set_union
992 ** The following m4sugar macros now accept multiple arguments, as is the
993    case with underlying m4:
994    m4_defn  m4_popdef  m4_undefine
996 ** The following m4sugar macros now guarantee linear scaling; they
997    previously had linear scaling with m4 1.6 but quadratic scaling
998    when using m4 1.4.x.  All macros built on top of these also gain
999    the scaling improvements.
1000    m4_bmatch  m4_bpatsubsts  m4_case  m4_cond  m4_do  m4_dquote_elt
1001    m4_foreach  m4_join  m4_list_cmp  m4_map  m4_map_sep  m4_max
1002    m4_min  m4_shiftn
1004 ** AT_KEYWORDS once again performs expansion on its argument, such that
1005    AT_KEYWORDS([m4_if([$1], [], [default])]) no longer complains about
1006    the possibly unexpanded m4_if [regression introduced in 2.62].
1008 ** Config header templates '#undef UNDEFINED /* comment */' do not lead to
1009    nested comments any more; regression introduced in 2.62.
1012 * Major changes in Autoconf 2.62 (2008-04-05) [stable]
1013   Released by Eric Blake, based on git versions 2.61a.*.
1015 ** Many optimizations have been applied to make overall execution faster.
1017 ** Autotest now makes use of shell functions.
1019 ** config.status now uses awk instead of sed also for config headers.
1021    - As a side effect, AC_DEFINE and AC_DEFINE_UNQUOTED now handle multi-line
1022      values, i.e., backslash-newline combinations are handled correctly.
1023      Further, for config headers, the total size of values is not limited by
1024      the POSIX length limit of text lines any more, only each single line.
1026 ** New config variable 'top_build_prefix'.
1028 ** New Autoconf macros:
1029    AC_AUTOCONF_VERSION  AC_OPENMP  AC_PATH_PROGS_FEATURE_CHECK
1031 ** AC_C_BIGENDIAN now supports universal binaries a la Mac OS X.
1033 ** AC_C_RESTRICT now prefers to #define 'restrict' to a variant spelling
1034    like '__restrict' if the variant spelling is available, as this is
1035    more likely to work when mixing C and C++ code.
1037 ** AC_CHECK_ALIGNOF's type argument T is now documented better: it must
1038    be a string of tokens such that "T y;" is a valid member declaration
1039    in a struct.
1041 ** AC_CHECK_SIZEOF now accepts objects as well as types: the general rule
1042    is that sizeof (X) works, then AC_CHECK_SIZEOF (X) should work.
1044 ** AC_CHECK_TYPE and AC_CHECK_TYPES now work on any C type-name; formerly,
1045    they did not work for function types.  In C++, they now work on any
1046    type-id that can be the operand of sizeof; this is similar to C,
1047    except it excludes anonymous struct and union types.  Formerly,
1048    some (but not all) C++ types involving anonymous struct and union
1049    were accepted, though this was not documented.
1051 ** AC_CONFIG_LINKS now prefers to link against files in the build tree
1052    if found, and it works to link against a file of the same name in
1053    the source tree, even if both trees coincide.
1055 ** AC_INIT no longer alters $@; regression introduced in 2.60.
1057 ** AC_USE_SYSTEM_EXTENSIONS now defines _ALL_SOURCE for Interix platforms.
1059 ** AS_HELP_STRING no longer underquotes its first argument; it also handles
1060    the case where the first argument contains single-quoted commas.
1061    For example, "AS_HELP_STRING([-a, [--arg[=foo]]], [bar])" produces:
1062      "  -a, --arg[=foo]         bar"
1063    Additionally, the macro now takes two additional arguments,
1064    indent-column and wrap-column; these should not normally be needed,
1065    but can be used to fine-tune how the output text is wrapped.
1067 ** AC_PROG_INSTALL now requires an install program that can install multiple
1068    files into a target directory.
1070 ** The command 'autoconf -' now correctly processes a file from stdin.
1072 ** 'autoreconf -m' now honors $MAKE.
1074 ** For all of the directory arguments for 'configure', such as '--prefix'
1075    or '--bindir', trailing slashes are stripped.  As an example, if
1076    tab completion in the user's shell appends trailing slashes, the
1077    command './configure --prefix=/usr/' will still result in an
1078    expanded libdir value of /usr/lib, not /usr//lib.
1080 ** 'configure --help=recursive' now works in read-only trees and from
1081    unconfigured build trees.
1083 ** If precious variables differ only in whitespace, then the cache consistency
1084    check warns instead of fails, and reuses the old value.
1086 ** AT_BANNER is now documented.
1088 ** AT_SETUP now handles macro expansions properly when calculating line
1089    length.
1091 ** Autotest now determines $srcdir correctly.
1093 ** Testsuites built by autotest now accept a -C/--directory=DIR option
1094    to adjust the working directory prior to creating files.
1096 ** Autoconf now requires GNU M4 1.4.5 or later.  Earlier versions of M4 have
1097    a bug in macro tracing that interferes with the interaction between
1098    Autoconf and Automake.  GNU M4 1.4.11 or later is recommended.  The
1099    configure search for a working M4 is improved.
1101 ** For portability with the eventual M4 2.0, macros should no longer use
1102    anything larger than $9 to refer to arguments.
1104 ** Documentation for m4sugar is improved.
1106    - The following macros were previously available as undocumented
1107      interfaces; the macros are now documented as stable interfaces.
1109      __oline__  m4_assert  m4_bmatch  m4_bpatsubsts  m4_car  m4_case
1110      m4_cdr  m4_default  m4_divert_once  m4_divert_pop  m4_divert_push
1111      m4_divert_text  m4_do  m4_errprintn  m4_fatal  m4_flatten
1112      m4_ifndef  m4_ifset  m4_ifval  m4_ifvaln  m4_location
1113      m4_n  m4_shiftn  m4_strip  m4_warn
1115    - The following macros were previously available as undocumented
1116      interfaces, but had bug fixes or semantic changes as part of this
1117      release.  Packages that relied on the undocumented behavior
1118      should be analyzed to make sure they will still work with the
1119      new documented behavior.
1121      m4_cmp  m4_list_cmp  m4_join  m4_map  m4_map_sep  m4_sign
1122      m4_text_box  m4_text_wrap  m4_version_compare
1124    - The m4_wrap macro used to have unspecified order, but now
1125      guarantees FIFO order.  m4_wrap_lifo was added to guarantee LIFO
1126      order.
1128    - Packages using the undocumented m4sugar macro m4_PACKAGE_VERSION
1129      should consider using the new AC_AUTOCONF_VERSION instead.
1131    - m4sugar macros that are not documented in the manual are still
1132      deemed experimental, and should not be used outside of Autoconf.
1134 ** The m4sugar macros m4_append and m4_append_uniq, first documented in
1135    2.60, have been fixed to treat both the string and the separator
1136    arguments consistently with regards to quoting.  Prior to this fix,
1137    m4_append_uniq could mistakenly duplicate entries if the expansion
1138    of the separator resulted in a different string (for example, if it
1139    contained quotes, a comma, or a macro name).  However, it means
1140    that programs previously using
1141      m4_append([name], [string], [[, ]])
1142    are now using a four-character separator instead of the intended
1143    comma and space.  If you need portability to earlier versions of
1144    Autoconf, you can insert the following snippet after AC_INIT but
1145    before any other macro expansions, to enforce the new semantics:
1146      m4_pushdef([m4_append], [m4_define([$1],
1147            m4_ifdef([$1], [m4_defn([$1])[$3]])[$2])])
1148    Additionally, m4_append_uniq now takes optional parameters that can
1149    be used to take action depending on whether anything was appended,
1150    and warns if a non-empty separator occurs within the string being
1151    appended, since that can lead to duplicates.
1153 ** The following m4sugar macros are new:
1154    m4_append_uniq_w  m4_apply  m4_combine  m4_cond  m4_count
1155    m4_dquote_elt  m4_echo  m4_expand  m4_ignore  m4_make_list  m4_max
1156    m4_min  m4_newline  m4_shift2  m4_shift3  m4_unquote  m4_wrap_lifo
1158 ** Warnings are now generated by default when an installer invokes
1159    'configure' with an unknown --enable-* or --with-* option.
1160    These warnings can be disabled with the new AC_DISABLE_OPTION_CHECKING
1161    macro, or by invoking 'configure' with --disable-option-checking.
1163 ** Existing obsolete macros
1164    The documentation for the following macros is adjusted to make it
1165    more clear that they have previously been marked obsolete, as their
1166    functionality can be accomplished by other macros.  We have no
1167    current plans to remove them from Autoconf.
1169      AC_ENABLE  AC_STRUCT_ST_BLKSIZE  AC_STRUCT_ST_RDEV  AC_WITH
1171 ** Newly obsolete macros
1172    The following macros have been marked obsolete, as they only
1173    perform a subset of AC_USE_SYSTEM_EXTENSIONS.  We have no current
1174    plans to remove them.
1176      AC_AIX  AC_GNU_SOURCE  AC_ISC_POSIX  AC_MINIX
1178 ** AC_C_LONG_DOUBLE is obsolescent.
1179    The documentation now says that AC_C_LONG_DOUBLE is obsolescent: it
1180    tests for problems that are so old that it is no longer of
1181    practical importance on current systems.  New programs need not use
1182    AC_C_LONG_DOUBLE.  We have no current plans to remove it.
1184 ** AC_DIAGNOSE, AC_WARNING, and AC_FATAL are obsolescent.
1185    The documentation now favors the use of M4sugar macros m4_warn and
1186    m4_fatal, since the naming makes it more obvious that the
1187    diagnostics are associated with M4 expansion (ie. when running
1188    'autoconf'), and offers less confusion with the AC_MSG_ERROR,
1189    AC_MSG_FAILURE, and AC_MSG_WARN macros which manage diagnostics
1190    when running 'configure'.  We have no current plans to remove these
1191    macros.
1194 * Major changes in Autoconf 2.61a (2006-12-11)
1196 ** AC_FUNC_FSEEKO was broken in 2.61; it didn't make fseeko and ftello visible
1197    on many platforms.  This has been fixed.
1199 ** AC_FUNC_SETVBUF_REVERSED is now obsolete.  It is still defined for backward
1200    compatibility but it does nothing.  The macro was already
1201    obsolescent, as the last systems to have the problem were those
1202    based on SVR2, which became obsolete in 1987.  The macro had bugs
1203    on some modern systems and could no longer be maintained reliably
1204    due to lack of ancient systems to test it on.
1206 ** config.status now uses awk instead of sed for most substitutions, for speed.
1208    - As a side effect multi-line values of substituted variables no
1209      longer have a small limit in total size, though for portability
1210      each line should not exceed the POSIX length limit for text lines.
1212    - It is now documented that Makefile.in should not contain
1213      overlapping variable occurrences, e.g., @VAR1@VAR2@.
1214      Autoconf's behavior was always iffy in such cases, and the
1215      awk implementation has changed the behavior.
1217 ** Many uses of 'echo' have been rewritten so that Autoconf-generated
1218    scripts have fewer problems with strings or file names containing
1219    embedded special characters such as backslash or leading "-".  This
1220    was implemented by using 'printf '%s\n' "$foo"' instead of 'echo
1221    "$foo"' when printf works.  Due to the implementation technique
1222    used, Autoconf-generated scripts now run considerably more slowly
1223    on ancient implementations lacking printf.  However, this should
1224    not be a problem, since Autoconf-generated scripts in practice
1225    invariably find a more-modern shell these days.
1228 * Major changes in Autoconf 2.61 (2006-11-17)
1230 ** New macros AC_C_FLEXIBLE_ARRAY_MEMBER, AC_C_VARARRAYS.
1232 ** AC_ARG_ENABLE and AC_ARG_WITH now allow '.' in feature and package names.
1235 * Major changes in Autoconf 2.60b (2006-10-22)
1237 ** BIN_SH
1238   Autoconf-generated shell scripts no longer export BIN_SH, due to
1239   configuration hassles with this.  Installers who need BIN_SH in
1240   their environment should set it before invoking 'configure' and
1241   'make'.  As far as we know, this affects only Unixware installations.
1243 ** Obsolescent macros
1244   The documentation now says that the following macros are obsolescent,
1245   as they are superseded by Gnulib:
1247     AC_FUNC_FNMATCH  AC_FUNC_FNMATCH_GNU  AC_FUNC_GETLOADAVG
1248     AC_REPLACE_FNMATCH
1250   New programs should use the Gnulib counterparts of these macros.
1251   We have no current plans to remove them from Autoconf.
1253 ** AC_COMPUTE_INT no longer caches or reports results.
1255 ** AC_CHECK_DECL now also works with aggregate objects.
1257 ** AC_USE_SYSTEM_EXTENSIONS now defines _TANDEM_SOURCE for NonStop platforms.
1259 ** GNU M4 1.4.7 or later is now recommended.
1261 ** m4_mkstemp
1262   New M4sugar macro, which is more secure than the POSIX M4 maketemp.
1264 ** m4_maketemp
1265   Now an alias for m4_mkstemp.
1267 * Major changes in Autoconf 2.60a (2006-08-25)
1269 ** GNU M4 1.4.6 or later is now recommended.
1271 ** The check for C99 now tests for varargs macros, as documented.
1272   It also tests that the preprocessor supports 64-bit integers.
1274 ** Autoconf now uses constructs like "#ifdef HAVE_STDLIB_H" rather than
1275   "#if HAVE_STDLIB_H", so that it now works with "gcc -Wundef -Werror".
1277 ** The functionality of the undocumented _AC_COMPUTE_INT is now provided
1278   by a public and documented macro, AC_COMPUTE_INT.  The parameters to the
1279   two macros are different, so autoupdate will not change the old private name
1280   to the new one.  _AC_COMPUTE_INT may be removed in a future release.
1282 ** AC_TYPE_LONG_LONG_INT and AC_TYPE_UNSIGNED_LONG_LONG_INT now require
1283    that long long types be at least 64 bits wide, as C99 and tradition
1284    requires.  Formerly, they accepted implementations of any width.
1287 * Major changes in Autoconf 2.60
1289   Released 2006-06-23, by Ralf Wildenhues.
1291 ** Autoconf no longer depends on whether m4wrap is FIFO (as Posix requires)
1292   or LIFO (as in GNU M4 1.4.x).  GNU M4 2.0 is expected to conform to Posix
1293   here, so m4wrap/m4_wrap users should no longer depend on LIFO behavior.
1295 ** Provide a way to turn off warnings about the changed directory variables.
1297 * Major changes in Autoconf 2.59d
1299   Released 2006-06-05, by Ralf Wildenhues.
1301 ** GNU make now recommended for VPATH builds
1302   INSTALL now suggests VPATH builds (e.g., "sh ../srcdir/configure")
1303   only if you use GNU make.  In practice, other 'make' implementations
1304   have too many subtle incompatibilities in their support for VPATH.
1305   Many packages (including Autoconf itself) are portable to other
1306   'make' implementations, but some packages are not, and recommending
1307   GNU make keeps the installation instructions simpler.
1309 ** Even more safety checks for the new Directory variables:
1310   Warn about suspicious '${datarootdir}' found in config files output.
1312 ** AC_TRY_COMMAND, AC_TRY_EVAL, ac_config_guess, ac_config_sub, ac_configure
1313   These never-documented macros and variables have been marked with
1314   comments saying that they may be removed in a future release,
1315   because their use can lead to unintended code being executed.
1316   If you need functionality that only these macros or variables
1317   currently supply, please write bug-autoconf@gnu.org.
1319 ** AC_SUBST, AC_DEFINE
1320   Literal arguments to these are passed to m4_pattern_allow now.
1322 ** AC_PROG_CC_STDC
1323   Passing 'ac_cv_prog_cc_stdc=no' to 'configure' now sets ac_cv_prog_cc_c99
1324   and ac_cv_prog_cc_c89 to 'no' as well, for backward compatibility with
1325   obsolete K&R tests in the Automake test suite.
1327 ** AC_PROG_CXX_C_O
1328   New macro.
1330 ** AC_PROG_MKDIR_P
1331   New macro.
1333 ** AS_MKDIR_P
1334   Now more robust with special characters in file names, or when
1335   multiple processes create the same directory at the same time.
1337 ** Obsolescent macros
1338   The documentation now says that the following macros are obsolescent:
1339   they test for problems that are so old that they are no longer of
1340   practical importance on current systems.
1342     AC_C_BACKSLASH_A       AC_FUNC_MEMCMP            AC_HEADER_DIRENT
1343     AC_C_CONST             AC_FUNC_SELECT_ARGTYPES   AC_HEADER_STAT
1344     AC_C_PROTOTYPES        AC_FUNC_SETPGRP           AC_HEADER_STDC
1345     AC_C_STRINGIZE         AC_FUNC_SETVBUF_REVERSED  AC_HEADER_SYS_WAIT
1346     AC_C_VOLATILE          AC_FUNC_STAT              AC_HEADER_TIME
1347     AC_FUNC_CLOSEDIR_VOID  AC_FUNC_STRFTIME          AC_ISC_POSIX
1348     AC_FUNC_GETPGRP        AC_FUNC_UTIME_NULL        AC_PROG_GCC_TRADITIONAL
1349     AC_FUNC_LSTAT          AC_FUNC_VPRINTF           AC_STRUCT_TM
1351   New programs need not use these macros.  We have no current plans to
1352   remove them.
1354 ** autoreconf
1355   For compatibility with future Libtool 2.0, autoreconf will invoke
1356   libtoolize with the option '--ltdl' now, if LT_CONFIG_LTDL_DIR is
1357   used.
1359 * Major changes in Autoconf 2.59c
1361   Released 2006-04-12, by Ralf Wildenhues.
1363 ** The configure command now redirects standard input from /dev/null,
1364   to help avoid problems with subsidiary commands that might mistakenly
1365   read standard input.  AS_ORIGINAL_STDIN_FD points to the original
1366   standard input before this redirection, if you really want configure to
1367   read from standard input.
1369 ** Directory variables adjusted to recent changes in the GNU Coding Standards.
1370   The following directory variables are new:
1372     datarootdir   read-only architecture-independent data root [PREFIX/share]
1373     localedir     locale-specific message catalogs [DATAROOTDIR/locale]
1374     docdir        documentation root [DATAROOTDIR/doc/PACKAGE]
1375     htmldir       html documentation [DOCDIR]
1376     dvidir        dvi documentation [DOCDIR]
1377     pdfdir        pdf documentation [DOCDIR]
1378     psdir         ps documentation [DOCDIR]
1380   The following variables have new default values:
1382     datadir       read-only architecture-independent data [DATAROOTDIR]
1383     infodir       info documentation [DATAROOTDIR/info]
1384     mandir        man documentation [DATAROOTDIR/man]
1386   This means that if you use any of '@datadir@', '@infodir@', or
1387   '@mandir@' in a file, you will have to ensure '${datarootdir}' is
1388   defined in this file.  As a temporary measure, if any of those are
1389   found but no mention of 'datarootdir', the substitutions will be
1390   replaced with values that do not contain '${datarootdir}', and a
1391   warning will be issued.
1393 ** @top_builddir@ is now a dir name: it is always nonempty and doesn't have
1394   a trailing slash.  Similar change will be made to ac_top_builddir in a
1395   future release; the old style value, which matches (../)*, is (and will
1396   continue to be) available as ac_top_build_prefix.
1398 ** AC_C_TYPEOF
1399   New macro to check for support of 'typeof' syntax a la GNU C.
1401 ** AC_CHECK_DECLS_ONCE, AC_CHECK_FUNCS_ONCE, AC_CHECK_HEADERS_ONCE
1402   New "once-only" variants of commonly-used macros, to make 'configure'
1403   smaller and faster in common cases.
1405 ** AC_FUNC_STRTOLD
1406   New macro to check for strtold with C99 semantics.
1408 ** AC_HEADER_ASSERT
1409   New macro that lets builder disable assertions at 'configure'-time.
1411 ** AC_PATH_X
1412   Now checks for X11/Xlib.h and XrmInitialize (X proper) rather than
1413   X11/Intrinsic.h and XtMalloc (Xt).
1415 ** AC_PRESERVE_HELP_ORDER
1416   New macro that causes 'configure' to display help strings for AC_ARG_ENABLE
1417   and AC_ARG_WITH arguments in one region, in the order defined.  The default
1418   behavior is to group options of each classes separately.
1420 ** AC_PROG_CC, AC_PROG_CXX
1421   No longer automatically arrange to declare the 'exit' function of C,
1422   when a C++ compiler is used.  Standard Autoconf macros no longer use
1423   'exit', so this is no longer an issue for them.  If you use C++, and
1424   want to call 'exit', you'll have to arrange for its declaration
1425   yourself.  But we now suggest you return from 'main' instead.
1427 ** AC_PROG_CC_C89, AC_PROG_CC_C99
1428   New macros for ISO C99 support.  AC_PROG_CC_C89 and AC_PROG_CC_C99
1429   check for ANSI C89 and ISO C99 support respectively.
1431 ** AC_PROG_CC_STDC
1432   Has been unobsoleted, and will check if the compiler supports ISO
1433   C99, falling back to ANSI C89 if not.  ac_cv_prog_cc_stdc is
1434   retained for backwards compatibility, assuming the value of
1435   ac_cv_prog_cc_c99 or ac_cv_prog_cc_c89 (whichever is valid, in
1436   that order).
1438 ** AC_STRUCT_DIRENT_D_INO, AC_STRUCT_DIRENT_D_TYPE
1439   New macros for checking commonly-used members of struct dirent.
1441 ** AC_SUBST
1442   The substituted value can now contain newlines.
1444 ** AC_SUBST_FILE
1445   The substitution now occurs only when @variable@ is on a line by itself,
1446   optionally surrounded by spaces and tabs.  The whole line is replaced.
1448 ** AC_TYPE_LONG_DOUBLE, AC_TYPE_LONG_DOUBLE_WIDER
1449   New macros to check for long double, and whether it is wider than double.
1450   The old macro AC_C_TYPE_LONG_DOUBLE has been marked as obsolete;
1451   applications should switch to the new macro.
1453 ** AC_TYPE_INT8_T, AC_TYPE_INT16_T, AC_TYPE_INT32_T, AC_TYPE_INT64_T,
1454    AC_TYPE_INTMAX_T, AC_TYPE_INTPTR_T, AC_TYPE_LONG_LONG_INT, AC_TYPE_SSIZE_T,
1455    AC_TYPE_UINT8_T, AC_TYPE_UINT16_T, AC_TYPE_UINT32_T, AC_TYPE_UINT64_T,
1456    AC_TYPE_UINTMAX_T, AC_TYPE_UINTPTR_T, AC_TYPE_UNSIGNED_LONG_LONG_INT
1457   New macros to check for C99 and POSIX types.
1459 ** AC_USE_SYSTEM_EXTENSIONS
1460   New macro to enable extensions to Posix.
1462 ** AH_HEADER
1463   New macro which is defined to the name of the first declared config header
1464   or undefined if no config headers have been declared yet.
1466 ** AS_HELP_STRING
1467   The macro correctly handles quadrigraphs now.
1469 ** AS_BOURNE_COMPATIBLE, AS_SHELL_SANITIZE, AS_CASE
1470   These macros are new or published now.
1472 ** AT_COPYRIGHT
1473   New macro for copyright notices in testsuite files.
1475 ** ALLOCA, LIBOBJS, LTLIBOBJS
1476   Object names added to these variables are now prefixed with '${LIBOBJDIR}',
1477   as in '${LIBOBJDIR}alloca.o'.  LIBOBJDIR is meant to be defined from
1478   'Makefile.in' in case the object files lie in a different directory.
1479   The LIBOBJDIR feature is experimental.
1481 ** autoreconf
1482   Supports --no-recursive now.
1484 ** New macros to support Erlang/OTP.
1485   New macros for configuring paths to Erlang tools and libraries:
1486   AC_ERLANG_PATH_ERLC, AC_ERLANG_NEED_ERLC, AC_ERLANG_PATH_ERL,
1487   AC_ERLANG_NEED_ERL, AC_ERLANG_CHECK_LIB, AC_ERLANG_SUBST_ROOT_DIR,
1488   AC_ERLANG_SUBST_LIB_DIR.
1490   New macros for configuring installation of Erlang libraries:
1491   AC_ERLANG_SUBST_INSTALL_LIB_DIR, AC_ERLANG_SUBST_INSTALL_LIB_SUBDIR.
1493 ** The manual now mentions Gnulib more prominently.
1495 ** New macros to support Objective C.
1496   AC_PROG_OBJC, AC_PROG_OBJCPP.
1498 * Major changes in Autoconf 2.59b
1500   Released 2004-08-20, by Paul Eggert.
1502 ** AC_CHECK_ALIGNOF
1503   New macro that computes the default alignment of a type.
1505 ** AC_CHECK_TOOL, AC_PATH_TOOL, AC_CHECK_TOOLS
1506   When cross-compiling, these macros will give a warning if the tool
1507   is not prefixed.  In the future, unprefixed cross tools will not
1508   be detected; please consult the info documentation for information
1509   about the reason of this change.
1511 ** AC_CHECK_TARGET_TOOL, AC_PATH_TARGET_TOOL, AC_CHECK_TARGET_TOOLS
1512   New macros that detect programs whose name is prefixed with the
1513   target type, if the build type and target type are different.
1515 ** AC_REQUIRE_AUX_FILE
1516   New trace macro that declares expected auxiliary files.
1518 ** AC_PROG_GREP
1519   New macro that tests for a grep program that accepts as a long a line
1520   as possible.
1522 ** AC_PROG_EGREP, AC_PROG_FGREP
1523   These macros now require AC_PROG_GREP, and try EGREP="$GREP -E" and
1524   FGREP="$GREP -F" respectively if possible, or else run a path search for
1525   a program that accepts as long a line as possible.
1527 ** AC_PROG_SED
1528   New macro that tests for a sed program that truncates as few characters
1529   as possible.
1531 * Major changes in Autoconf 2.59
1533   Released 2003-11-04, by Akim Demaille
1535 ** ac_abs_builddir etc.
1536   Absolute file names were actually relative in 2.58.
1538 * Major changes in Autoconf 2.58
1540   Released 2003-11-04, by Akim Demaille
1542 ** core.*
1543   core.* files are no longer removed, as they may be valid user files.
1545 ** autoreconf and auxiliary directory
1546   Autoreconf creates the auxiliary directory if needed.  This is
1547   especially useful for initial "bootstrapping" of fresh CVS checkouts.
1549 ** AC_CONFIG_MACRO_DIR
1550   Use this macro to declare the directory for local M4 macros for aclocal.
1552 ** AC_LIBOBJS
1553   No longer includes twice the same file in LIBOBJS if invoked
1554   multiple times.
1556 ** AC_CONFIG_COMMANDS
1557   The directory for its first argument is automatically created.  For
1558   instance, with
1560       AC_CONFIG_COMMANDS([src/modules.hh], [...])
1562   $top_builddir/src/ is created if needed.
1564 ** Autotest and local.at
1565   The optional file local.at is always included in Autotest test suites.
1567 ** Warnings
1568   The warnings are always issued, including with cached runs.
1569   This became a significant problem since aclocal and automake can
1570   run autoconf behind the scene.
1572 ** autoheader warnings
1573   The warnings of autoheader can be turned off, using --warning.
1574   For instance, -Wno-obsolete disables the complaints about acconfig.h
1575   and other deprecated constructs.
1577 ** New macros
1578   AC_C_RESTRICT, AC_INCLUDES_DEFAULT, AC_LANG_ASSERT, AC_LANG_WERROR,
1579   AS_SET_CATFILE.
1581 ** AC_DECL_SYS_SIGLIST
1582   Works again.
1584 ** AC_FUNC_MKTIME
1585   Now checks that mktime is the inverse of localtime.
1587 ** Improve DJGPP portability
1588   The Autoconf tools and configure behave better under DJGPP.
1590 ** Present But Cannot Be Compiled
1591   New FAQ section dedicated to the mystic
1593     configure: WARNING: pi.h: present but cannot be compiled
1594     configure: WARNING: pi.h: check for missing prerequisite headers?
1595     configure: WARNING: pi.h: proceeding with the preprocessor's result
1596       messages.
1598 ** Concurrent executions of autom4te
1599   autom4te now locks its internal files, which enables concurrent
1600   executions of autom4te, likely to happen if automake, autoconf,
1601   autoheader etc. are run simultaneously.
1603 ** Libtool
1604   Use of Libtool 1.5 and higher is encouraged.  Compatibility with
1605   Libtool pre-1.4 is not checked.
1607 ** Autotest
1608   Testsuites no longer rerun failed tests in verbose mode; instead,
1609   failures are logged while the test is run.
1611   In addition, expected failures can be marked as such.
1613 * Major changes in Autoconf 2.57
1615   Released 2002-12-03 by Paul Eggert.
1617 Bug fixes for problems with AIX linker, with freestanding C compilers,
1618 with GNU M4 limitations, and with obsolete copies of GNU documents.
1620 The Free Documentation License has been upgraded from 1.1 to 1.2.
1622 * Major changes in Autoconf 2.56
1624   Released 2002-11-15 by Akim Demaille.
1626 One packaging problem fixed (config/install-sh was not executable).
1628 * Major changes in Autoconf 2.55
1630   Released 2002-11-14 by Akim Demaille.
1632 Release tips:
1634            Have your configure.ac checked by autoscan ("autoscan").
1635              Try the warning options ("autoreconf -fv -Wall").
1637 ** Documentation
1639 - AC_CHECK_HEADER, AC_CHECK_HEADERS
1640   More information on proper use.
1642 - Writing Test Programs
1644   This sections explains how to write good test sources to use with
1645   AC_COMPILE_IFELSE etc.  It documents AC_LANG_PROGRAM and so forth.
1647 - AC_FOO_IFELSE vs. AC_TRY_FOO
1649   Explains why Autoconf moves from AC_TRY_COMPILE etc. to
1650   AC_COMPILE_IFELSE and AC_LANG_PROGRAM etc.
1652 ** autoreconf
1654 - Is more robust to different Gettext installations.
1656 - Produces messages (when --verbose) to be understood by Emacs'
1657   compile mode.
1659 - Supports -W/--warnings.
1661 - -m/--make
1662   Once the GNU Build System reinstalled, run './config.status
1663   --recheck && ./config.status && make' if possible.
1665 ** autom4te
1667 - Supports --cache, and --no-cache.
1669 - ~/.autom4te.cfg makes it possible to disable the caching mechanism
1670   (autom4te.cache).  See 'Customizing autom4te' in the documentation.
1672 ** config.status
1673   Supports --quiet.
1675 ** Obsolete options
1677   Support for the obsoleted options -m, --macrodir, -l, --localdir is
1678   dropped in favor of the safer --include/--prepend-include scheme.
1680 ** Macros
1682 - New macros
1683   AC_COMPILER_IFELSE, AC_FUNC_MBRTOWC, AC_HEADER_STDBOOL,
1684   AC_LANG_CONFTEST, AC_LANG_SOURCE, AC_LANG_PROGRAM, AC_LANG_CALL,
1685   AC_LANG_FUNC_TRY_LINK, AC_MSG_FAILURE, AC_PREPROC_IFELSE.
1687 - Obsoleted
1688   Obsoleted macros are kept for Autoconf backward compatibility, but
1689   should be avoided in configure.ac.  Running autoupdate is advised.
1690   AC_DECL_SYS_SIGLIST.
1692 - AC_DEFINE/AC_DEFINE_UNQUOTED
1694   We have to stop using the old compatibility scheme --that tried to
1695   avoid useless backslashes-- because Libtool 1.4.3 contains a
1697   AC_DEFINE([error_t], [int],
1698             [Define to a type to use for \`error_t' if it is not
1699              otherwise available.])
1701   We have to quote the single quotes and backslashes with \.  The old
1702   compatibility scheme saw that ` was backslashed, and therefore did
1703   not quote the single quote...  Failure.  Hence, Autoconf 2.54 is not
1704   compatible with Libtool.  Autoconf 2.55 is, but in some cases might
1705   produce more \ than wanted.
1707   Please, note that in the future the same problem will happen with
1708   AC_MSG_*: use 'autoreconf -f -Wall'.
1710 ** Bug Fixes
1712 - Portability of the Autoconf package to Solaris.
1714 - Spurious warnings caused by config.status.
1715   This bug is benign, but painful: on some systems (typically
1716   FreeBSD), warnings such as:
1718      config.status: creating Makefile
1719      mv: Makefile: set owner/group (was: 1357/0): Operation not permitted
1721   could be issued.  This is fixed.
1723 - Parallel Builds
1724   Simultaneous executions of config.status are possible again.
1726 - Precious variables accumulation
1728   config.status could stack several copies of the precious variables
1729   assignments.
1732 ** Plans for later versions
1734 - ./configure <host>
1736   The compatibility hooks with the old scheme will be completely
1737   removed.  Please, advice/use '--build', '--host', and '--target'
1738   only.
1740 - AC_CHECK_HEADER, AC_CHECK_HEADERS
1742   The tests will be stricter, please make sure your invocations are
1743   valid.
1745 - shell functions
1747   Shell functions will gradually be introduced, probably starting with
1748   Autotest.  If you know machines which are in use that you suspect
1749   *not* to support shell functions, please run the test suite of
1750   Autoconf 2.55 on it, and report the results to
1751   bug-autoconf@gnu.org.
1753 - AC_MSG_*
1755   Special characters in AC_MSG_* need not be quoted.  Currently,
1756   Autoconf has heuristics to decide when a string is escaped, or has
1757   to be escaped.  This scheme is fragile, and will be removed; the
1758   only risk is uglified messages.  Please, run 'autoreconf -f -Wall'
1759   to find occurrences that will be affected.
1761 * Major changes in Autoconf 2.54
1763   Released 2002-09-13 by Akim Demaille.
1765 ** Executables
1767 - autoreconf no longer changes the version of the gettext/po/intl
1768   support files. It now adds the files the correspond to the
1769   AM_GNU_GETTEXT_VERSION declared in configure.ac.
1771   Warning: It now relies on the 'autopoint' program, which is part
1772   of GNU gettext 0.11.4 and newer.
1774   Please note that you need to have a GNU gettext version that
1775   corresponds at least to the AM_GNU_GETTEXT_VERSION declared
1776   in configure.ac. You can upgrade to newer GNU gettext versions,
1777   though, without needing to change configure.ac.
1779 - The -I DIR or --include=DIR option now appends DIR to the include path
1780   instead of prepending; this is for consistency with other GNU tools.
1781   The new -B DIR or --prepend-include=DIR option has the old behavior.
1783 ** Macros
1785 - AC_OUTPUT
1786   Now handles all the gory details about LIBOBJS and LTLIBOBJS.
1787   Please, remove lines such as
1789         # This is necessary so that .o files in LIBOBJS are also
1790         # built via the ANSI2KNR-filtering rules.
1791         LIBOBJS=`echo $LIBOBJS|sed 's/\.o /\$U.o /g;s/\.o$/\$U.o/'`
1793   and read the 'AC_LIBOBJ vs LIBOBJS' section.  Do not define U in
1794   your Makefiles either.
1796 - AC_CONFIG_LINKS now makes copies if it can't make links.
1798 - AC_FUNC_FNMATCH now tests only for POSIX compatibility, reverting to
1799   Autoconf 2.13 behavior.  The new macro AC_FUNC_FNMATCH_GNU also
1800   tests for GNU extensions to fnmatch, and replaces fnmatch if needed.
1802 - AC_FUNC_SETVBUF_REVERSED no longer fails when cross-compiling.
1804 - AC_PROG_CC_STDC is integrated into AC_PROG_CC.
1806 - AC_PROG_F77 default search no longer includes cf77 and cfg77.
1808 - New macros
1810   AC_C_BACKSLASH_A, AC_CONFIG_LIBOBJ_DIR, AC_GNU_SOURCE,
1811   AC_PROG_EGREP, AC_PROG_FGREP, AC_REPLACE_FNMATCH,
1812   AC_FUNC_FNMATCH_GNU, AC_FUNC_REALLOC, AC_TYPE_MBSTATE_T.
1814 - AC_FUNC_GETLOADAVG
1815   looks for getloadavg.c in the CONFIG_LIBOBJ_DIR.
1817 - AC_FUNC_MALLOC
1818   Now defines HAVE_MALLOC to 0 if 'malloc' does not work, and asks
1819   for an AC_LIBOBJ replacement.
1821 ** Bug fixes
1823 - Spurious complaints from 'm4_bmatch' about invalid regular
1824   expressions are suppressed.
1826 - Empty top_builddirs are properly handled.
1828 - AC_CHECK_MEMBER works correctly when the member is an aggregate.
1830 - AC_PATH_PROG
1831   Now colon in the optional path arguments are properly handled.
1833 ** Improved portability
1835 - Both Autoconf the package, and the scripts it produces, should run
1836   more reliably with Zsh.  Bear in mind it is the default Bourne shell
1837   on Darwin.
1839 - Autoconf and the scripts it produces no longer assume the existence of
1840   the obsolescent commands egrep and fgrep.
1842 ** Documentation
1844 - Limitations of Make
1845   More of them.
1847 - GNATS
1848   The GNATS base moved to
1849   https://bugs.gnu.org/cgi-bin/gnatsweb.pl?database=autoconf
1850   (It is no longer available, though.)
1852 ** Misc.
1854 - config.log
1855   Now contains the list of output variables and files (AC_SUBST,
1856   AC_SUBST_FILES).
1858 * Major changes in Autoconf 2.53
1860   Released 2002-03-08 by Akim Demaille.
1862 ** Requirements
1864   Perl 5.005_03 or later is required: autom4te is written in Perl and is
1865   needed by autoconf.  autoheader, autoreconf, ifnames, and autoscan are
1866   rewritten in Perl.
1868 ** Documentation
1870 - AC_INIT
1871   Argument requirements, output variables, defined macros.
1872 - M4sugar, M4sh, Autotest
1873   First sketch.
1874 - Double quoting macros
1875   AC_TRY_CPP, AC_TRY_COMPILE, AC_TRY_LINK and AC_TRY_RUN.
1876 - Licensing
1877   The Autoconf manual is now distributed under the terms of the GNU FDL.
1878 - Section 'Hosts and Cross-Compilation'
1879   Explains the rationale for the 2.5x changes in the cross-compilation
1880   chain, and in the relationships between build, host, and target
1881   types.
1882   Emphasizes that 'cross-compilation' == '--host is given'.
1883   If you are working on compilers etc., be sure to read this section.
1884 - Section 'AC_LIBOBJ vs. LIBOBJS'
1885   Explains why assigning LIBOBJS directly is now an error.
1886   Details how to update the code.
1888 ** configure
1890 - $LINENO
1891   Now used instead of hard coded line numbers.
1892   This eases the comparison of 'configure's, and diminishes the
1893   pressure over control version archives.
1894   Automatic replacement for shells that don't support this feature.
1895 - New output variables
1896   @builddir@, @top_builddir@, @abs_srcdir@, @abs_top_srcdir@, @abs_builddir@,
1897   @abs_top_builddir@.
1899 ** Emacs
1901   Autoconf and Autotest modes are provided.
1903 ** Executables
1905 - autom4te
1906   New, used by the Autoconf suite to cache and speed up most processing.
1907 - --force, -f
1908   Supported by autom4te, autoconf and autoheader.
1909 - --include, -I
1910   Replaces --autoconf-dir and --localdir in autoconf, autoheader,
1911   autoupdate, and autoreconf.
1912 - autoreconf
1913   No longer passes --cygnus, --foreign, --gnits, --gnu, --include-deps:
1914   automake options are to be given via AUTOMAKE_OPTIONS.
1915 - autoreconf
1916   Runs gettextize and libtoolize when appropriate.
1917 - autoreconf
1918   --m4dir is no longer supported.
1919 - autoreconf
1920   Now runs only in the specified directories, defaulting to '.',
1921   but understands AC_CONFIG_SUBDIRS for dependent directories.
1922   Before, it used to run on all the 'configure.ac' found in the
1923   current tree.
1924   Independent packages are properly updated.
1926 ** Bug fixes
1928 - The top level $prefix is propagated to the AC_CONFIG_SUBDIRS configures.
1929 - AC_TRY_RUN
1930   Under the user pressure, $? is finally available.  Probably a mistake.
1931 - AC_F77_LIBRARY_LDFLAGS now supports the HP/UX f90 compiler.
1932 - Precious variables accumulation
1933   config.status could stack several copies of the precious variables
1934   assignments.
1935 - AC_PATH_PROG and family.
1936   Works properly when given a literal path.
1937 - AC_FUNC_SETPGRP
1938   Somewhere since 2.13, the result had been reversed.
1940 ** C Macros
1942 - AC_C_BIGENDIAN supports the cross-compiling case.
1943 - AC_C_BIGENDIAN accepts ACTION-IF-TRUE, ACTION-IF-FALSE, and
1944   ACTION-IF-UNKNOWN arguments.  All are optional, and the default
1945   for ACTION-IF-TRUE is to define WORDS_BIGENDIAN like AC_C_BIGENDIAN
1946   always did.
1947 - AC_C_LONG_DOUBLE now succeeds only if 'long double' has more range or
1948   precision than 'double'.
1950 ** Generic macros
1952 - AC_INIT
1953   It now defines the preprocessor symbols PACKAGE_NAME,
1954   PACKAGE_TARNAME, PACKAGE_VERSION, PACKAGE_STRING, and
1955   PACKAGE_BUGREPORT.
1957 - AC_INIT
1958   Admits a fourth optional parameter: the tar name.
1960 - AC_CONFIG_COMMANDS, HEADERS, FILES, LINKS.
1961   Provide the user with srcdir, ac_srcdir, ac_top_srcdir, ac_builddir,
1962   ac_top_builddir, ac_abs_srcdir, ac_abs_top_srcdir, ac_abs_builddir,
1963   ac_abs_top_builddir.
1965 - AC_CONFIG_COMMANDS, HEADERS, FILES, LINKS and AC_OUTPUT.
1966   Are much less expensive when using long lists of files.
1968 - AC_PREFIX_PROGRAM
1969   Works with shell variables, and non alphanumeric names.
1971 ** Library macros
1973 - AC_FUNC_STRERROR_R now sets STRERROR_R_CHAR_P, not HAVE_WORKING_STRERROR_R,
1974   because POSIX 1003.1-200x draft 7 says strerror_r returns int, not char *.
1976 - AC_FUNC_STRTOD substitutes POW_LIB.
1978 - AC_FUNC_STRNLEN
1979   New.
1981 * Major changes in Autoconf 2.52
1983   Released 2001-07-18 by Akim Demaille.
1985 ** Documentation
1986 - AC_ARG_VAR
1987 - Quadrigraphs
1988   This feature was present in autoconf 2.50 but was not documented.
1989   For example, '@<:@' is translated to '[' just before output.  This
1990   is useful when writing strings that contain unbalanced quotes, or
1991   other hard-to-quote constructs.
1992 - m4_pattern_forbid, m4_pattern_allow
1993 - Tips for upgrading from 2.13.
1994 - Using autoscan to maintain a configure.ac.
1996 ** Default includes
1997 - Now include stdint.h.
1998 - sys/types.h and sys/stat.h are guarded.
1999 - strings.h is included if available, and not conflicting with string.h.
2001 ** Bug fixes
2002 - The test suite is more robust and presents less false failures.
2003 - Invocation of GNU M4 now robust to POSIXLY_CORRECT.
2004 - configure accepts --prefix='' again.
2005 - AC_CHECK_LIB works properly when its first argument is not a
2006   literal.
2007 - HAVE_INTTYPES_H is defined only if not conflicting with sys/types.h.
2008 - build_, host_, and target_alias are AC_SUBST as in 2.13.
2009 - AC_ARG_VAR properly propagates precious variables inherited from the
2010   environment to ./config.status.
2011 - Using --program-suffix/--program-prefix is portable.
2012 - Failures to detect the default compiler's output extension are less
2013   likely.
2014 - 'config.status foo' works properly when 'foo' depends on variables
2015   set in an AC_CONFIG_THING INIT-CMD.
2016 - autoheader is more robust to broken input.
2017 - Fixed Fortran name-mangling and link tests on a number of systems,
2018   e.g. NetBSD; see AC_F77_DUMMY_MAIN, below.
2020 ** Generic macros
2021 - AC_CHECK_HEADER and AC_CHECK_HEADERS support a fourth argument to
2022   specify pre-includes.  In this case, the headers are compiled with
2023   cc, not merely preprocessed by cpp.  Therefore it is the _usability_
2024   of a header which is checked for, not just its availability.
2025 - AC_ARG_VAR refuses to run configure when precious variables have
2026   changed.
2027 - Versions of compilers are dumped in the logs.
2028 - AC_CHECK_TYPE recognizes use of 'foo_t' as a replacement type.
2030 ** Specific Macros
2031 - AC_PATH_XTRA only adds -ldnet to $LIBS if it's needed to link.
2032 - AC_FUNC_WAIT3 and AC_SYS_RESTARTABLE_SYSCALLS are obsoleted.
2033 - AM_FUNC_ERROR_AT_LINE, AM_FUNC_FNMATCH, AM_FUNC_MKTIME,
2034   AM_FUNC_OBSTACK, and AM_FUNC_STRTOD are now activated.
2035   Be sure to read 'Upgrading from Version 2.13' to understand why
2036   running 'autoupdate' is needed.
2037 - AC_F77_DUMMY_MAIN, AC_F77_MAIN: new macros to detect whether
2038   a main-like routine is required/possible when linking C/C++ with
2039   Fortran.  Users of e.g. AC_F77_WRAPPERS should be aware of these.
2040 - AC_FUNC_GETPGRP behaves better when cross-compiling.
2042 * Major changes in Autoconf 2.51
2043 There was no release of Autoconf 2.51 since some packagers had used
2044 this version number without permission to ship intermediary versions
2045 of 2.50.  The version was skipped to avoid confusion.
2047 * Major changes in Autoconf 2.50
2049   Released 2001-05-21 by Akim Demaille.
2051 ** Lots of bug fixes
2052 There have been far too many to enumerate them here.  Check out
2053 ChangeLog if you really want to know more.
2055 ** Improved documentation
2056 In particular, portability issues are better covered.
2058 ** Use of Automake
2059 All the standard GNU Makefile targets are supported.  The layout has
2060 changed: m4/ holds the M4 extensions Autoconf needs for its
2061 configuration, doc/ contains the documentation, and tests/ contains
2062 the test suite.
2064 ** Man pages are provided
2065 For autoconf, autoreconf, autoupdate, autoheader, autoscan, ifnames,
2066 config.guess, config.sub.
2068 ** autoconf
2069 - --trace
2070   Provides a safe and powerful means to trace the macro uses.  This
2071   provide the parsing layer for tools which need to 'study'
2072   configure.in.
2074 - --warnings
2075   Specify what category of warnings should be enabled.
2077 - When recursing into subdirectories, try for configure.gnu before
2078   configure to adapt for packages not using autoconf on case-insensitive
2079   file systems.
2081 - Diagnostics
2082   More errors are now caught (circular AC_REQUIRE dependencies,
2083   AC_DEFINE in the action part of an AC_CACHE_CHECK, too many pops
2084   etc.).  In addition, their location and call stack are given.
2086 ** autoupdate
2087 autoupdate is much more powerful, and is able to provide the glue code
2088 which might be needed to move from an old macro to its newer
2089 equivalent.
2091 You are strongly encouraged to use it to modernize both your
2092 'configure.in' and your .m4 extension files.
2094 ** autoheader
2095 The internal machinery of autoheader has completely changed.  As a
2096 result, using 'acconfig.h' should be considered to be obsoleted, and
2097 you are encouraged to get rid of it using the AH macros.
2099 ** autoreconf
2100 Extensive overhaul.
2102 ** Fortran 77 compilers
2103 Globally, the support for Fortran 77 is considerably improved.
2105 Support for automatically determining a Fortran 77 compiler's
2106 name-mangling scheme.  New CPP macros F77_FUNC and F77_FUNC_ are
2107 provided to wrap C/C++ identifiers, thus making it easier and more
2108 transparent for C/C++ to call Fortran 77 routines, and Fortran 77 to
2109 call C/C++ routines.  See the Texinfo documentation for details.
2111 ** Test suite
2112 The test suite no longer uses DejaGNU.  It should be easy to submit
2113 test cases in this new framework.
2115 ** configure
2116 - --help, --help=long, -hl
2117   no longer dumps useless items.
2118 - --help=short, -hs
2119   lists only specific options.
2120 - --help=recursive, -hr
2121   displays the help of all the embedded packages.
2122 - Remembers environment variables when reconfiguring.
2123   The previous scheme to set envvar before running configure was
2124     ENV=VAL ./configure
2125   what prevented configure from remembering the environment in which
2126   it was run, therefore --recheck was run in an inconsistent
2127   environment.  Now, one should run
2128     ./configure ENV=VAR
2129   and then --recheck will work properly.  Variables declared with
2130   AC_ARG_VAR are also preserved.
2131 - cross-compilation
2132   $build defaults to `config.guess`, $host to $build, and then $target
2133   to $host.
2134   Cross-compilation is a global status of the package, it no longer
2135   depends upon the current language.
2136   Cross compilation is enabled iff the user specified '--host'.
2137   'configure' now fails if it can't run the executables it compiles,
2138   unless cross-compilation is enabled.
2139 - Cache file
2140   The cache file is disabled by default.  The new options
2141   '--config-cache', '-C' set the cache to 'config.cache'.
2143 ** config.status
2144 - faster
2145   Much faster on most architectures.
2146 - concurrent executions
2147   It is safe to use 'make -j' with config.status.
2148 - human interface improved
2149   It is possible to invoke
2150     ./config.status foobar
2151   instead of the former form (still valid)
2152     CONFIG_COMMANDS= CONFIG_HEADERS= CONFIG_LINKS= \
2153     CONFIG_FILES=foobar:foo.in:bar.in \
2154     ./config.status
2155   The same holds for configuration headers and links.
2156   You can instantiate unknown files and headers:
2157     ./config.status --header foo.h:foo.h.in --file bar:baz
2158 - has a useful --help
2159 - accepts special file name "-" for stdin/stdout
2162 ** Identity Macros
2163 - AC_COPYRIGHT
2164   Specify additional copyright information.
2166 - AC_INIT
2167   Now expects the identity of the package as argument.
2169 ** General changes.
2170 - Uniform quotation
2171   Most macros, if not all, now strictly follow the 'one quotation
2172   level' rule.  This results in a more predictable expansion.
2174 - AC_REQUIRE
2175   A sly bug in the AC_REQUIRE machinery, which could produce incorrect
2176   configure scripts, was fixed by Axel Thimm.
2178 ** Setup Macros
2179 - AC_ARG_VAR
2180   Document and ask for the registration of an envvar.
2182 - AC_CONFIG_SRCDIR
2183   Specifies the file which 'configure' should look for when trying to
2184   find the source tree (used to be handled by AC_INIT).
2186 - AC_CONFIG_COMMANDS
2187   To add new actions to config.status.  Should be used instead of
2188   AC_OUTPUT_COMMANDS.
2190 - AC_CONFIG_LINKS
2191   Replaces AC_LINK_FILES.
2193 - AC_CONFIG_HEADERS, AC_CONFIG_COMMANDS, AC_CONFIG_SUBDIRS,
2194   AC_CONFIG_LINKS, and AC_CONFIG_FILES
2195   They now obey sh: you should no longer use shell variables as
2196   argument.  Instead of
2198         test "$package_foo_enabled" = yes && $my_subdirs="$my_subdirs foo"
2199         AC_CONFIG_SUBDIRS($my_subdirs)
2201   write
2203         if test "$package_foo_enabled" = yes; then
2204           AC_CONFIG_SUBDIRS(foo)
2205         fi
2207 - AC_HELP_STRING
2208   To format an Autoconf macro's help string so that it looks pretty
2209   when the user executes 'configure --help'.
2212 ** Generic Test Macros
2213 - AC_CHECK families
2214   The interface of the AC_CHECK families of macros (decl, header,
2215   type, member, func) is now uniform.  They support the same set of
2216   default includes.
2218 - AC_CHECK_DECL, AC_CHECK_DECLS
2219   To check whether a symbol is declared.
2221 - AC_CHECK_SIZEOF, AC_C_CHAR_UNSIGNED.
2222   No longer need a cross-compilation default.
2224 - AC_CHECK_TYPE
2225   The test it performs is much more robust than previously, and makes
2226   it possible to test builtin types in addition to typedefs.
2227   It is now schizophrenic:
2228     - AC_CHECK_TYPE(TYPE, REPLACEMENT)
2229       remains for backward compatibility, but its use is discouraged.
2230     - AC_CHECK_TYPE(TYPE, IF-FOUND, IF-NOT-FOUND, INCLUDES)
2231       behaves exactly like the other AC_CHECK macros.
2233 - AC_CHECK_TYPES
2234   Checks whether given types are supported by the system.
2236 - AC_CHECK_MEMBER, AC_CHECK_MEMBERS
2237   Check for given members in aggregates (e.g., pw_gecos in struct
2238   passwd).
2240 - AC_PROG_CC_STDC
2241   Checks if the compiler supports ISO C, included when needs special
2242   options.
2244 - AC_PROG_CPP
2245   Checking whether the preprocessor indicates missing includes by the
2246   error code. stderr is checked by AC_TRY_CPP only as a fallback.
2248 - AC_LANG
2249   Takes a language as argument and replaces AC_LANG_C,
2250   AC_LANG_CPLUSPLUS and AC_LANG_FORTRAN77.
2252 - AC_LANG_PUSH, AC_LANG_POP
2253   Are preferred to AC_LANG_SAVE, AC_LANG_RESTORE.
2255 ** Specific Macros
2256 - AC_FUNC_CHOWN, AC_FUNC_MALLOC, AC_FUNC_STRERROR_R,
2257   AC_FUNC_LSTAT_FOLLOWS_SLASHED_SYMLINK, AC_FUNC_STAT, AC_FUNC_LSTAT,
2258   AC_FUNC_ERROR_AT_LINE, AC_FUNC_OBSTACK, AC_FUNC_STRTOD, AC_FUNC_FSEEKO.
2259   New.
2261 - AC_FUNC_GETGROUPS
2262   Sets GETGROUPS_LIBS.
2264 - AC_FUNC_GETLOADAVG
2265   Defines 'HAVE_STRUCT_NLIST_N_UN_N_NAME' instead of 'NLIST_NAME_UNION'.
2267 - AC_PROG_LEX
2268   Now integrates 'AC_DECL_YYTEXT' which is obsoleted.
2270 - AC_SYS_LARGEFILE
2271   Arrange for large-file support.
2273 - AC_EXEEXT, AC_OBJEXT
2274   You are no longer expected to use them: their computation is
2275   performed by default.
2277 ** C++ compatibility
2278   Every macro has been revisited in order to support at best CC=c++.
2280 Major changes in Autoconf 2.14:
2281   There was no release of GNU Autoconf 2.14.
2283 Major changes in Autoconf 2.13:
2285   Released 1999-05-01 by Ben Elliston.
2287 * Support for building on 32-bit Windows systems where the only available C or
2288   C++ compiler is the Microsoft Visual C++ command line compiler
2289   ('cl').  Additional support for building on 32-bit Windows systems which are
2290   using the Cygwin or Mingw32 environments.
2291 * Support for alternative object file and executable file extensions.
2292   On 32-bit Windows, for example, these are .obj and .exe. These are discovered
2293   using AC_OBJEXT and AC_EXEEXT, which substitute @OBJEXT@ and
2294   @EXEEXT@ in the output, respectively.
2295 * New macros: AC_CACHE_LOAD, AC_CACHE_SAVE, AC_FUNC_SELECT_ARGTYPES,
2296   AC_VALIDATE_CACHED_SYSTEM_TUPLE, AC_SEARCH_LIBS, AC_TRY_LINK_FUNC,
2297   AC_C_STRINGIZE, AC_CHECK_FILE(S), AC_PROG_F77 (and friends).
2298 * AC_DEFINE now has an optional third argument for a description to be
2299   placed in the config header input file (e.g. config.h.in).
2300 * The C++ code fragment compiled for the C++ compiler test had to be
2301   improved to include an explicit return type for main(). This was
2302   causing failures on systems using recent versions of the EGCS C++
2303   compiler.
2304 * Fixed an important bug in AC_CHECK_TYPE that would cause a configure
2305   script to report that 'sometype_t' was present when only 'type_t'
2306   was defined.
2307 * Merge of the FSF version of config.guess and config.sub to modernize
2308   these scripts. Add support for a few new hosts in config.guess.
2309   Incorporate latest versions of install-sh, mkinstalldirs and
2310   texinfo.tex from the FSF.
2311 * autoreconf is capable of running automake if necessary (and
2312   applicable).
2313 * Support for Fortran 77. See the Texinfo documentation for details.
2314 * Bug fixes and workarounds for quirky bugs in vendor utilities.
2316 Major changes in Autoconf 2.12:
2318   Released 1996-11-26 by David J. MacKenzie
2320 * AC_OUTPUT and AC_CONFIG_HEADERS can create output files by
2321   concatenating multiple input files separated by colons, like so:
2322   AC_CONFIG_HEADERS([config.h:conf.pre:config.h.in:conf.post])
2323   AC_OUTPUT([Makefile:Makefile.in:Makefile.rules])
2324   The arguments may be shell variables, to compute the lists on the fly.
2325 * AC_LINK_FILES and AC_CONFIG_SUBDIRS may be called multiple times.
2326 * New macro AC_OUTPUT_COMMANDS adds more commands to run in config.status.
2327 * Bug fixes.
2329 Major changes in Autoconf 2.11:
2331   Released November 18th, 1996, by David J. MacKenzie
2333 * AC_PROG_CC and AC_PROG_CXX check whether the compiler works.
2334   They also default CFLAGS/CXXFLAGS to "-g -O2" for gcc, instead of "-g -O".
2335 * AC_REPLACE_FUNCS defines HAVE_foo if the system has the function 'foo'.
2336 * AC_CONFIG_HEADERS expands shell variables in its argument.
2337 * New macros: AC_FUNC_FNMATCH, AC_FUNC_SETPGRP.
2338 * The "checking..." messages and the source code for test programs that
2339   fail are saved in config.log.
2340 * Another workaround has been added for seds with small command length limits.
2341 * config.sub and config.guess recognize more system types.
2342 * Bug fixes.
2344 Major changes in Autoconf 2.10:
2346   Released May 7th, 1996, by Roland McGrath
2348 * Bug fixes.
2349 * The cache variable names used by 'AC_CHECK_LIB(LIB, FUNC, ...)' has
2350   changed: now $ac_cv_lib_LIB_FUNC, previously $ac_cv_lib_LIB.
2352 Major changes in Autoconf 2.9:
2354   Released March 16th, 1996, by Roland McGrath
2356 * Bug fixes.
2358 Major changes in Autoconf 2.8:
2360   Released March 8th, 1996, by Roland McGrath
2362 * Bug fixes.
2364 Major changes in Autoconf 2.7:
2366   Released November 22nd, 1995, by David J. MacKenzie
2368 * Bug fixes.
2370 Major changes in Autoconf 2.6:
2372   Released November 20th, 1995, by David J. MacKenzie
2374 * Bug fixes.
2376 Major changes in Autoconf 2.5:
2378   Released November 17th, 1995, by Roland McGrath
2380 * New configure options --bindir, --libdir, --datadir, etc., with
2381   corresponding output variables.
2382 * New macro: AC_CACHE_CHECK, to make using the cache easier.
2383 * config.log contains the command being run as well as any output from it.
2384 * AC_CHECK_LIB can check for libraries with "." or "/" or "+" in their name.
2385 * AC_PROG_INSTALL doesn't cache a name for install-sh, for sharing caches.
2386 * AC_CHECK_PROG, AC_PATH_PROG, AC_CHECK_PROGS, AC_PATH_PROGS, and
2387   AC_CHECK_TOOL can search a path other than $PATH.
2388 * AC_CHECK_SIZEOF takes an optional size to use when cross-compiling.
2390 Major changes in Autoconf 2.4:
2392   Released June 14th, 1995, by David J. MacKenzie
2394 * Fix a few bugs found by Emacs testers.
2396 Major changes in Autoconf 2.3:
2398   Released March 27th, 1995, by David J. MacKenzie
2400 * Fix the cleanup trap in several ways.
2401 * Handle C compilers that are picky about option placement.
2402 * ifnames gets the version number from the right directory.
2404 Major changes in Autoconf 2.2:
2406   Released March 8th, 1995, by David J. MacKenzie
2408 * The ifnames utility is much faster but requires a "new awk" interpreter.
2409 * AC_CHECK_LIB and AC_HAVE_LIBRARY check and add the new
2410   library before existing libs, not after, in case it uses them.
2411 * New macros: AC_FUNC_GETPGRP, AC_CHECK_TOOL.
2412 * Lots of bug fixes.
2413 * Many additions to the TODO file :-)
2415 Major changes in Autoconf 2.1:
2417   Released November 4th, 1994, by David J. MacKenzie
2419 * Fix C++ problems.
2420 * More explanations in the manual.
2421 * Fix a spurious failure in the testsuite.
2422 * Clarify some warning messages.
2423 * autoreconf by default only rebuilds configure and config.h.in files
2424   that are older than any of their particular input files; there is a
2425   --force option to use after installing a new version of Autoconf.
2427 Thanks to everybody who's submitted changes and additions to Autoconf!
2428 I've incorporated many of them, and am still considering others for
2429 future releases -- but I didn't want to postpone this release indefinitely.
2431 Caution: don't indiscriminately rebuild configure scripts with
2432 Autoconf version 2.  Some configure.in files need minor adjustments to
2433 work with it; the documentation has a chapter on upgrading.  A few
2434 configure.in files, including those for GNU Emacs and the GNU C
2435 Library, need major changes because they relied on undocumented
2436 internals of version 1.  Future releases of those packages will have
2437 updated configure.in files.
2439 It's best to use GNU M4 1.3 (or later) with Autoconf version 2.
2440 Autoconf now makes heavy use of M4 diversions, which were implemented
2441 inefficiently in GNU M4 releases before 1.3.
2443 Major changes in Autoconf 2.0:
2445   Released October 26th, 1994, by David J. MacKenzie
2447 ** New copyright terms:
2448 * There are no restrictions on distribution or use of configure scripts.
2450 ** Documentation:
2451 * Autoconf manual is reorganized to make information easier to find
2452   and has several new indexes.
2453 * INSTALL is reorganized and clearer and is now made from Texinfo source.
2455 ** New utilities:
2456 * autoscan to generate a preliminary configure.in for a package by
2457   scanning its source code for commonly used nonportable functions,
2458   programs, and header files.
2459 * ifnames to list the symbols used in #if and #ifdef directives in a
2460   source tree.
2461 * autoupdate to update a configure.in to use the version 2 macro names.
2462 * autoreconf to recursively remake configure and configuration header
2463   files in a source tree.
2465 ** Changed utilities:
2466 * autoheader can take pieces of acconfig.h to replace config.h.{top,bot}.
2467 * autoconf and autoheader can look for package-local definition files
2468   in an alternate directory.
2470 ** New macros:
2471 * AC_CACHE_VAL to share results of tests between configure runs.
2472 * AC_DEFUN to define macros, automatically AC_PROVIDE them, and ensure
2473   that macros invoked with AC_REQUIRE don't interrupt other macros.
2474 * AC_CONFIG_AUX_DIR, AC_CANONICAL_SYSTEM, AC_CANONICAL_HOST, AC_LINK_FILES to
2475   support deciding unguessable features based on the host and target types.
2476 * AC_CONFIG_SUBDIRS to recursively configure a source tree.
2477 * AC_ARG_PROGRAM to use the options --program-prefix,
2478   --program-suffix, and --program-transform-name to change the names
2479   of programs being installed.
2480 * AC_PREFIX_DEFAULT to change the default installation prefix.
2481 * AC_TRY_COMPILE to compile a test program without linking it.
2482 * AC_CHECK_TYPE to check whether sys/types.h or stdlib.h defines a given type.
2483 * AC_CHECK_LIB to check for a particular function and library.
2484 * AC_MSG_CHECKING and AC_MSG_RESULT to print test results, on a single line,
2485   whether or not the test succeeds.  They obsolete AC_CHECKING and AC_VERBOSE.
2486 * AC_SUBST_FILE to insert one file into another.
2487 * AC_FUNC_MEMCMP to check whether memcmp is 8-bit clean.
2488 * AC_FUNC_STRFTIME to find strftime even if it's in -lintl.
2489 * AC_FUNC_GETMNTENT to find getmntent even if it's in -lsun or -lseq.
2490 * AC_HEADER_SYS_WAIT to check whether sys/wait.h is POSIX.1 compatible.
2492 ** Changed macros:
2493 * Many macros renamed systematically, but old names are accepted for
2494   backward compatibility.
2495 * AC_OUTPUT adds the "automatically generated" comment to
2496   non-Makefiles where it finds @configure_input@ in an input file, to
2497   support files with various comment syntaxes.
2498 * AC_OUTPUT does not replace "prefix" and "exec_prefix" in generated
2499   files when they are not enclosed in @ signs.
2500 * AC_OUTPUT allows the optional environment variable CONFIG_STATUS to
2501   override the file name "config.status".
2502 * AC_OUTPUT takes an optional argument for passing variables from
2503   configure to config.status.
2504 * AC_OUTPUT and AC_CONFIG_HEADERS allow you to override the input-file names.
2505 * AC_OUTPUT automatically substitutes the values of CFLAGS, CXXFLAGS,
2506   CPPFLAGS, and LDFLAGS from the environment.
2507 * AC_PROG_CC and AC_PROG_CXX now set CFLAGS and CXXFLAGS, respectively.
2508 * AC_PROG_INSTALL looks for install-sh or install.sh in the directory
2509   specified by AC_CONFIG_AUXDIR, or srcdir or srcdir/.. or
2510   srcdir/../.. by default.
2511 * AC_DEFINE, AC_DEFINE_UNQUOTED, and AC_SUBST are more robust and smaller.
2512 * AC_DEFINE no longer prints anything, because of the new result reporting
2513   mechanism (AC_MSG_CHECKING and AC_MSG_RESULT).
2514 * AC_VERBOSE pays attention to --quiet/--silent, not --verbose.
2515 * AC_ARG_ENABLE and AC_ARG_WITH support whitespace in the arguments to
2516   --enable- and --with- options.
2517 * AC_CHECK_FUNCS and AC_CHECK_HEADERS take optional shell commands to
2518   execute on success or failure.
2519 * Checking for C functions in C++ works.
2521 ** Removed macros:
2522 * AC_REMOTE_TAPE and AC_RSH removed; too specific to tar and cpio, and
2523   better maintained with them.
2524 * AC_ARG_ARRAY removed because no one was likely using it.
2525 * AC_HAVE_POUNDBANG replaced with AC_SYS_INTERPRETER, which doesn't
2526   take arguments, for consistency with all of the other specific checks.
2528 ** New files:
2529 * Comes with config.sub and config.guess, and uses them optionally.
2530 * Uses config.cache to cache test results.  An alternate cache file
2531   can be selected with the --cache-file=FILE option.
2532 * Uses optional shell scripts $prefix/share/config.site and
2533   $prefix/etc/config.site to perform site or system specific initializations.
2534 * configure saves compiler output to ./config.log for debugging.
2535 * New files autoconf.m4 and autoheader.m4 load the other Autoconf macros.
2536 * acsite.m4 is the new name for the system-wide aclocal.m4.
2537 * Has a DejaGnu test suite.
2539 Major changes in Autoconf 1.11:
2541 * AC_PROG_INSTALL calls install.sh with the -c option.
2542 * AC_SET_MAKE cleans up after itself.
2543 * AC_OUTPUT sets prefix and exec_prefix if they weren't set already.
2544 * AC_OUTPUT prevents shells from looking in PATH for config.status.
2546 Plus a few other bug fixes.
2548 Major changes in Autoconf 1.10:
2550 * autoheader uses config.h.bot if present, analogous to config.h.top.
2551 * AC_PROG_INSTALL looks for install.sh in srcdir or srcdir/.. and
2552   never uses cp.
2553 * AC_PROG_CXX looks for cxx as a C++ compiler.
2555 Plus several bugs fixed.
2557 Major changes in Autoconf 1.9:
2559 * AC_YYTEXT_POINTER replaces AC_DECLARE_YYTEXT.
2560 * AC_SIZEOF_TYPE generates the cpp symbol name automatically,
2561   and autoheader generates entries for those names automatically.
2562 * AC_FIND_X gets the result from xmkmf correctly.
2563 * AC_FIND_X assumes no X if --without-x was given.
2564 * AC_FIND_XTRA adds libraries to the variable X_EXTRA_LIBS.
2565 * AC_PROG_INSTALL finds OSF/1 installbsd.
2567 Major changes in Autoconf 1.8:
2569 ** New macros:
2570 * New macros AC_LANG_C, AC_LANG_CPLUSPLUS, AC_LANG_SAVE, AC_LANG_RESTORE,
2571   AC_PROG_CXX, AC_PROG_CXXCPP, AC_REQUIRE_CPP
2572   for checking both C++ and C features in one configure script.
2573 * New macros AC_CHECKING, AC_VERBOSE, AC_WARN, AC_ERROR for printing messages.
2574 * New macros AC_FIND_XTRA, AC_MMAP, AC_SIZEOF_TYPE, AC_PREREQ,
2575   AC_SET_MAKE, AC_ENABLE.
2577 ** Changed macros:
2578 * AC_FIND_X looks for X in more places.
2579 * AC_PROG_INSTALL defaults to install.sh instead of cp, if it's in srcdir.
2580   install.sh is distributed with Autoconf.
2581 * AC_DECLARE_YYTEXT has been removed because it can't work, pending
2582   a rewrite of quoting in AC_DEFINE.
2583 * AC_OUTPUT adds its comments in C format when substituting in C files.
2584 * AC_COMPILE_CHECK protects its ECHO-TEXT argument with double quotes.
2586 ** New or changed command line options:
2587 * configure accepts --enable-FEATURE[=ARG] and --disable-FEATURE options.
2588 * configure accepts --without-PACKAGE, which sets withval=no.
2589 * configure accepts --x-includes=DIR and --x-libraries=DIR.
2590 * Giving --with-PACKAGE no argument sets withval=yes instead of withval=1.
2591 * configure accepts --help, --version, --silent/--quiet, --no-create options.
2592 * configure accepts and ignores most other Cygnus configure options, and
2593   warns about unknown options.
2594 * config.status accepts --help, --version options.
2596 ** File names and other changes:
2597 * Relative srcdir values are not made absolute.
2598 * The values of @prefix@ and @exec_prefix@ and @top_srcdir@ get substituted.
2599 * Autoconf library files are installed in ${datadir}/autoconf, not ${datadir}.
2600 * autoheader optionally copies config.h.top to the beginning of config.h.in.
2601 * The example Makefile dependencies for configure et al. work better.
2602 * Namespace cleanup: all shell variables used internally by Autoconf
2603   have names beginning with 'ac_'.
2605 More big improvements are in process for future releases, but have not
2606 yet been (variously) finished, integrated, tested, or documented enough
2607 to release yet.
2609 Major changes in Autoconf 1.7:
2611 * New macro AC_OBSOLETE.
2612 * Bugs in Makefile.in fixed.
2613 * AC_LONG_FILE_NAMES improved.
2615 Major changes in Autoconf 1.6:
2617 * New macro AC_LONG_64_BITS.
2618 * Multiple .h files can be created.
2619 * AC_FIND_X looks for X files directly if it doesn't find xmkmf.
2620 * AC_ALLOCA defines C_ALLOCA if using alloca.c.
2621 * --with-NAME can take a value, e.g., --with-targets=sun4,hp300bsd.
2622 * Unused --no-create option to configure removed.
2623 * autoheader doesn't change the timestamp of its output file if
2624   the file didn't change.
2625 * All macros that look for libraries now use AC_HAVE_LIBRARY.
2626 * config.status checks three optional environment variables to
2627   modify its behavior.
2628 * The usual bug fixes.
2630 Major changes in Autoconf 1.5:
2632 * New macros AC_FIND_X, AC_OFF_T, AC_STAT_MACROS_BROKEN, AC_REVISION.
2633 * autoconf and autoheader scripts have GNU standards conforming
2634   --version and --help options (they print their message and exit).
2635 * Many bug fixes.
2637 Major changes in Autoconf 1.4:
2639 * New macros AC_HAVE_POUNDBANG, AC_TIME_WITH_SYS_TIME, AC_LONG_DOUBLE,
2640   AC_GETGROUPS_T, AC_DEFINE_UNQUOTED.
2641 * autoconf and autoheader use the M4 environment variable to determine the
2642   name of the M4 program to use.
2643 * The --macrodir option to autoconf and autoheader specifies the directory
2644   in which acspecific.m4, acgeneral.m4, etc. reside if not the default.
2645 * autoconf and autoheader can take '-' as their file names, which means to
2646   read stdin as input.
2647 * Resulting configure scripts can take a --verbose option which causes them
2648   to print the results of their tests.
2649 * AC_DEFINE quotes its second argument in such a way that spaces, magic
2650   shell characters, etc. will be preserved during various stages of
2651   expansion done by the shell.  If you don't want this, use
2652   AC_DEFINE_UNQUOTED instead.
2653 * Much textual processing done with external calls to tr and sed have been
2654   internalized with builtin M4 'patsubst' and 'translit' calls.
2655 * AC_OUTPUT doesn't hardwire the file names it outputs.  Instead, you can
2656   set the shell variables 'gen_files' and 'gen_config' to the list of
2657   file names to output.
2658 * AC_DECLARE_YYTEXT does an AC_SUBST of 'LEX_OUTPUT_ROOT', which may be
2659   "lex.yy" or "lexyy", depending on the system.
2660 * AC_PROGRAMS_CHECK takes an optional third arg.  If given, it is used as
2661   the default value.
2662 * If AC_ALLOCA chooses alloca.c, it also defines STACK_DIRECTION.
2663 * AC_CONST works much more reliably on more systems.
2664 * Many bug fixes.
2666 Major changes in Autoconf 1.3:
2668 configure no longer requires awk for packages that use a config.h.
2669 Support handling --with-PACKAGE options.
2670 New 'autoheader' script to create 'config.h.in' from 'configure.in'.
2671 Ignore troublesome -lucb and -lPW when searching for alloca.
2672 Rename --exec_prefix to --exec-prefix for GNU standards conformance.
2673 Improve detection of STDC library.
2674 Add AC_HAVE_LIBRARY to check for non-default libraries.
2675 Function checking should work with future GNU libc releases.
2677 Major changes in Autoconf 1.2:
2679 The --srcdir option is now usually unnecessary.
2680 Add a file containing sample comments describing CPP macros.
2681 A comment in config.status tells which host it was configured on.
2682 Substituted variable values can now contain commas.
2683 Fix bugs in various feature checks.
2685 Major changes in Autoconf 1.1:
2687 Added AC_STRCOLL macro.
2688 Made AC_GETLOADAVG check for more things.
2689 AC_OUTPUT argument is now optional.
2690 Various bug fixes.
2692 -----
2694 Copyright (C) 1993-1996, 1998-2017, 2020-2023 Free Software Foundation,
2695 Inc.
2697 Copying and distribution of this file, with or without modification,
2698 are permitted in any medium without royalty provided the copyright
2699 notice and this notice are preserved.  This file is offered as-is,
2700 without warranty of any kind.
2702 Local Variables:
2703 mode: outline
2704 End: