lisp: fix a failure with Solaris /usr/xpg4/bin/sh
[platform/upstream/automake.git] / NEWS
1 * WARNING: New versioning scheme for Automake.
2
3   - Starting with this version onward, Automake will use an update and
4     more rational versioning scheme, one that will allow users to know
5     which kind of changes can be expected from a new version, based on
6     its version number.
7
8     + Micro versions (e.g., 1.13.3, 2.0.1, 3.2.8) will introduce only
9       documentation updates and bug and regression fixes; they will
10       not introduce new features, nor any backward-incompatibility (any
11       such incompatibility would be considered a bug, to be fixed with
12       a further micro release).
13
14     + Minor versions (e.g., 1.14, 2.1) can introduce new backward
15       compatible features; the only backward-incompatibilities allowed
16       in such a release are new *non-fatal* deprecations and warnings,
17       and possibly fixes for old or non-trivial bugs (or even inefficient
18       behaviours) that could unfortunately have been seen, and used, by
19       some developers as "corner case features".  Possible disruptions
20       caused by this kind of fixes should hopefully be quite rare.
21
22     + Major versions (now expected to be released every 18 or 24 months,
23       and not more often) can introduce new big features (possibly with
24       rough edges and not-fully-stabilized APIs), removal of deprecated
25       features, backward-incompatible changes of behaviour, and possibly
26       major refactorings (that, while ideally transparent to the user,
27       could introduce new bugs).  Incompatibilities should however not
28       be introduced gratuitously and abruptly; a proper deprecation path
29       should be duly implemented in the preceding minor releases.
30
31   - According to this new scheme, the next major version of Automake
32     (the one that has until now been labelled as '1.14') will actually
33     become "Automake 2.0".  Automake 1.14 will be the next minor version,
34     which will introduce new features, deprecations and bug fixes, but
35     no real backward incompatibility.
36
37   - See discussion about automake bug#13578 for more details and
38     background: <http://debbugs.gnu.org/cgi/bugreport.cgi?bug=13578>
39
40 * WARNING: Future backward-incompatibilities!
41
42   - Automake 2.0 will require Autoconf 2.70 or later (which is still
43     unreleased at the moment of writing, but is planned to be released
44     before Automake 2.0 is).
45
46   - Automake 2.0 will drop support for the long-deprecated 'configure.in'
47     name for the Autoconf input file.  You are advised to start using the
48     recommended name 'configure.ac' instead, ASAP.
49
50   - The ACLOCAL_AMFLAGS special make variable will be fully deprecated
51     in Automake 2.0 (where it will raise warnings in the "obsolete"
52     category).  You are advised to start relying on the new Automake
53     support for AC_CONFIG_MACRO_DIRS instead (which was introduced in
54     Automake 1.13).
55
56   - Automake 2.0 will remove support for automatic dependency tracking
57     with the SGI C/C++ compilers on IRIX.  The SGI depmode has been
58     reported broken "in the wild" already, and we don't think investing
59     time in debugging and fixing is worthwhile, especially considering
60     that SGI has last updated those compilers in 2006, and is expected
61     to retire support for them in December 2013:
62     <http://www.sgi.com/services/support/irix_mips_support.html>
63
64   - Future versions of Automake might remove support for MS-DOS and
65     Windows 95/98/ME (support for them was offered by relying on the
66     DJGPP project).  Note however that both Cygwin and MSYS/MinGW on
67     modern Windows versions will continue to be fully supported.
68
69   - Automake-provided scripts and makefile recipes might (finally!)
70     start assuming a POSIX shell in Automake 2.0.
71
72   - Starting from Automake 2.0, third-party m4 files located in the
73     system-wide aclocal directory, as well as in any directory listed
74     in the ACLOCAL_PATH environment variable, will take precedence
75     over "built-in" Automake macros.  For example (assuming Automake
76     is installed in the /usr/local hierarchy), a definition of the
77     AM_PROG_VALAC macro found in '/usr/local/share/aclocal/my-vala.m4'
78     should take precedence over the same-named automake-provided macro
79     (defined in '/usr/local/share/aclocal-2.0/vala.m4').
80
81 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
82
83 New in 1.13.3:
84
85 * Bugs fixed:
86
87   - Byte-compilation of Emacs lisp files could fail spuriously on Solaris,
88     when /bin/ksh or /usr/xpg4/bin/sh were used as shell.
89
90 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
91
92 New in 1.13.2:
93
94 * Obsolescent features:
95
96   - Use of suffix-less info files (that can be specified through the
97     '@setfilename' macro in Texinfo input files) is discouraged, and
98     its use will raise warnings in the 'obsolete' category.
99
100   - Use of Texinfo input files with '.txi' or '.texinfo' extensions
101     is discouraged, and its use will raise warnings in the 'obsolete'
102     category.  You are advised to simply use the '.texi' extension
103     instead.
104
105 * Documentation fixes:
106
107   - The long-deprecated but still supported two-arguments invocation form
108     of AM_INIT_AUTOMAKE is documented once again.  This seems the sanest
109     thing to do, given that support for such an usage might need to remain
110     in place for a unspecified amount of time in order to cater for people
111     who want to define the version number for their package dynamically at
112     configure runtime (unfortunately, Autoconf does not yet support this
113     scenario, so we cannot delegate the work to it).
114
115   - The serial testsuite harness is no longer reported as "deprecated",
116     but as "discouraged".  We have no plan to remove it, not to make its
117     use cause runtime warnings.
118
119   - The parallel testsuite is no longer reported as "experimental"; it
120     is well tested, and should be stable now.
121
122   - The 'shar' and 'tarZ' distribution formats and the 'dist-shar' and
123     'dist-tarZ' options are obsolescent, and their use is deprecated
124     in the documentation.
125
126   - Other minor miscellaneous fixes and improvements; in particular,
127     some improvements in cross-references.
128
129 * Bugs fixed:
130
131   - When the 'ustar' option is used, the generated configure script no
132     longer risks hanging during the tests for the availability of the
133     'pax' utility, even if the user running configure has a UID or GID
134     that requires more than 21 bits to be represented.
135     See automake bug#8343 and bug#13588.
136
137   - The obsolete macros AM_CONFIG_HEADER or AM_PROG_CC_STDC work once
138     again, as they did in Automake 1.12.x (albeit printing runtime
139     warnings in the 'obsolete' category).  Removing them has turned
140     out to be a very bad idea, because it complicated distro packing
141     enormously.  Making them issue fatal warnings, as we did in
142     Automake 1.13, has turned out to be a similarly very bad idea,
143     for exactly the same reason.
144
145   - aclocal will no longer error out if the first local m4 directory
146     (as specified by the '-I' option or the 'AC_CONFIG_MACRO_DIRS' or
147     'AC_CONFIG_MACRO_DIR' macros) doesn't exist; it will merely report
148     a warning in the 'unsupported' category.  This is done to support
149     some pre-existing real-world usages.  See automake bug#13514.
150
151   - aclocal will no longer consider directories for extra m4 files more
152     than once, even if they are specified multiple times.  This ensures
153     packages that specify both
154
155         AC_CONFIG_MACRO_DIR([m4])       in configure.ac
156         ACLOCAL_AMFLAGS = -I m4         in Makefile.am
157
158     will work correctly, even when the 'm4' directory contains no
159     package-specific files, but is used only to install third-party
160     m4 files (as can happen with e.g., "libtoolize --install").
161     See automake bug#13514.
162
163   - Analysis of make flags in Automake-generated rules has been made more
164     robust, and more future-proof.  For example, in presence of make that
165     (like '-I') take an argument, the characters in said argument will no
166     longer be spuriously considered as a set of additional make options.
167     In particular, automake-generated rules will no longer spuriously
168     believe to be running in dry mode ("make -n") if run with an invocation
169     like "make -I noob"; nor will they believe to be running in keep-going
170     mode ("make -k") if run with an invocation like "make -I kool"
171     (automake bug#12554).
172
173 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
174
175 New in 1.13.1:
176
177 * Bugs fixed:
178
179   - Use of the obsolete macros AM_CONFIG_HEADER or AM_PROG_CC_STDC now
180     causes a clear and helpful error message, instead of obscure ones
181     (issue introduced in Automake 1.13).
182
183 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
184
185 New in 1.13:
186
187 * Bugs fixed:
188
189   - ylwrap renames properly header guards in generated header files
190     (*.h), instead of leaving Y_TAB_H.
191
192   - ylwrap now also converts header guards in implementation files
193     (*.c).  Because ylwrap failed to rename properly #include in the
194     implementation files, current versions of Bison (e.g., 2.7)
195     duplicate the generated header file in the implementation file.
196     The header guard then protects the implementation file from
197     duplicate definitions from the header file.
198
199 * Version requirements:
200
201   - Autoconf 2.65 or greater is now required.
202
203   - The rules to build PDF and DVI output from Texinfo input now
204     require Texinfo 4.9 or later.
205
206 * Obsolete features:
207
208   - Support for the "Cygnus-style" trees (once enabled by the 'cygnus'
209     option) has been removed.  See discussion about automake bug#11034
210     for more background: <http://debbugs.gnu.org/11034>.
211
212   - The deprecated aclocal option '--acdir' has been removed.  You
213     should use the options '--automake-acdir' and '--system-acdir'
214     instead (which have been introduced in Automake 1.11.2).
215
216   - The following long-obsolete m4 macros have been removed:
217
218       AM_PROG_CC_STDC:    superseded by AC_PROG_CC since October 2002
219       fp_PROG_CC_STDC:    broken alias for AM_PROG_CC_STDC
220       fp_WITH_DMALLOC:    old alias for AM_WITH_DMALLOC
221       AM_CONFIG_HEADER:   superseded by AC_CONFIG_HEADERS since July 2002
222       ud_PATH_LISPDIR:    old alias for AM_PATH_LISPDIR
223       jm_MAINTAINER_MODE: old alias for AM_MAINTAINER_MODE
224       ud_GNU_GETTEXT:     old alias for AM_GNU_GETTEXT
225       gm_PROG_LIBTOOL:    old alias for AC_PROG_LIBTOOL
226       fp_C_PROTOTYPES:    old alias for AM_C_PROTOTYPES (which was part
227                           of the now-removed automatic de-ANSI-fication
228                           support of Automake)
229
230   - All the "old alias" macros in 'm4/obsolete.m4' have been removed.
231
232   - Use of the long-deprecated two- and three-arguments invocation forms
233     of the AM_INIT_AUTOMAKE is no longer documented.  It's still supported
234     though (albeit with a warning in the 'obsolete' category), to cater
235     for people who want to define the version number for their package
236     dynamically (e.g., from the current VCS revision).  We'll have to
237     continue this support until Autoconf itself is fixed to allow better
238     support for such dynamic version numbers.
239
240 * Elisp byte-compilation:
241
242   - The byte compilation of '.el' files into '.elc' files is now done
243     with a suffix rule.  This has simplified the compilation process, and
244     more importantly made it less brittle.  The downside is that emacs is
245     now invoked once for each '.el' files, which cause some noticeable
246     slowdowns.  These should however be mitigated on multicore machines
247     (which are becoming the norm today) if concurrent  make ("make -j")
248     is used.
249
250   - Elisp files placed in a subdirectory are now byte-compiled to '.elc'
251     files in the same subdirectory; for example, byte-compiling of file
252     'sub/foo.el' file will result in 'sub/foo.elc' rather than in
253     'foo.elc'.  This behaviour is backward-incompatible with older
254     Automake versions, but it is more natural and more sane.  See also
255     automake bug#7441.
256
257   - The Emacs invocation performing byte-compilation of '.el' files honors
258     the $(AM_ELCFLAGS) and $(ELCFLAGS) variables; as typical, the former
259     one is  developer-reserved and the latter one user-reserved.
260
261   - The 'elisp-comp' script, once provided by Automake, has been rendered
262     obsoleted by the just-described changes, and thus removed.
263
264 * Changes to Automake-generated testsuite harnesses:
265
266   - The parallel testsuite harness (previously only enabled by the
267     'parallel-tests' option) is the default one; the older serial
268     testsuite harness will still be available through the use of the
269     'serial-tests' option (introduced in Automake 1.12).
270
271   - The 'color-tests' option is now unconditionally activated by default.
272     In particular, this means that testsuite output is now colorized by
273     default if the attached terminal seems to support ANSI escapes, and
274     that the user can force output colorization by setting the variable
275     AM_COLOR_TESTS to "always".  The 'color-tests' is still recognized
276     for backward-compatibility, although it's a handled as a no-op now.
277
278 * Silent rules support:
279
280   - Support for silent rules is now always active in Automake-generated
281     Makefiles.  So, although the verbose output is still the default,
282     the user can now always use "./configure --enable-silent-rules" or
283     "make V=0" to enable quieter output in the package he's building.
284
285   - The 'silent-rules' option has now become a no-op, preserved for
286     backward-compatibility only.  In particular, its use no longer
287     disables the warnings in the 'portability-recursive' category.
288
289 * Texinfo Support:
290
291   - The rules to build PDF and DVI files from Texinfo input now require
292     Texinfo 4.9 or later.
293
294   - The rules to build PDF and DVI files from Texinfo input now use the
295     '--build-dir' option, to keep the auxiliary files used by texi2dvi
296     and texi2pdf around without cluttering the build directory, and to
297     make it possible to run the "dvi" and "pdf" recipes in parallel.
298
299 * Automatic remake rules and 'missing' script:
300
301   - The 'missing' script no longer tries to update the timestamp of
302     out-of-date files that require a maintainer-specific tool to be
303     remade, in case the user lacks such a tool (or has a too-old version
304     of it).  It just gives a useful warning, and in some cases also a
305     tip about how to obtain such a tool.
306
307   - The missing script has thus become useless as a (poor) way to work
308     around the sketched-timestamps issues that can happen for projects
309     that keep generated files committed in their VCS repository.  Such
310     projects are now encouraged to write a custom "fix-timestamps.sh"
311     script to avoid such issues; a simple example is provided in the
312     "CVS and generated files" chapter of the automake manual.
313
314 * Recursive targets:
315
316   - The user can now define his own recursive targets that recurse
317     in the directories specified in $(SUBDIRS).  This can be done by
318     specifying the name of such targets in invocations of the new
319     'AM_EXTRA_RECURSIVE_TARGETS' m4 macro.
320
321 * Tags:
322
323   - Any failure in the recipe of the "tags", "ctags", "cscope" or
324     "cscopelist" targets in a subdirectory is now propagated to the
325     top-level make invocation.
326
327   - Tags are correctly computed also for files in _SOURCES variables that
328     only list files with non-standard suffixes (see automake bug#12372).
329
330 * Improvements to aclocal and related rebuilds rules:
331
332   - Autoconf-provided macros AC_CONFIG_MACRO_DIR and AC_CONFIG_MACRO_DIRS
333     are now traced by aclocal, and can be used to declare the local m4
334     include directories.  Formerly, one had to specify it with an explicit
335     '-I' option to the 'aclocal' invocation.
336
337   - The special make variable ACLOCAL_AMFLAGS is deprecated; future
338     Automake versions will warn about its use, and later version will
339     remove support for it altogether.
340
341 * The depcomp script:
342
343   - Dropped support for libtool 1.4.
344
345   - Various internal refactorings.  They should cause no visible change,
346     but the chance for regression is there anyway, so please report any
347     unexpected or suspicious behaviour.
348
349   - Support for pre-8.0 versions of the Intel C Compiler has been dropped.
350     This should cause no problem, since icc 8.0 has been released in
351     December 2003 -- almost nine years ago.
352
353   - Support for tcc (the Tiny C Compiler) has been improved, and is now
354     handled through a dedicated 'tcc' mode.
355
356 * The ylwrap script:
357
358   - ylwrap generates header guards with a single '_' for series of non
359     alphabetic characters, instead of several.  This is what Bison >=
360     2.5.1 does.
361
362 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
363
364 Bugs fixed in 1.12.6:
365
366 * Python-related bugs:
367
368   - The default installation location for python modules has been improved
369     for Python 3 on Debian and Ubuntu systems, changing from:
370
371         ${prefix}/lib/python3/dist-packages
372
373     to
374
375         ${prefix}/lib/python3.x/site-packages
376
377     This change should ensure modules installed using the default ${prefix}
378     "/usr/local" are found by default by system python 3.x installations.
379     See automake bug#10227.
380
381   - Python byte-compilation supports the new layout mandated by PEP-3147,
382     with its __pycache__ directory (automake bug#8847).
383
384 * Build system issues:
385
386   - The maintainer rebuild rules for Makefiles and aclocal.m4 in
387     Automake's own build system works correctly again (bug introduced
388     in Automake 1.12.5).
389
390 * Testsuite issues:
391
392   - The Vala-related tests has been changed to adjust to the removal of
393     the 'posix' profile in the valac compiler.  See automake bug#12934
394     a.k.a. bug#12522.
395
396   - Some spurious testsuite failures related to older tools and systems
397     have been fixed.
398
399 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
400
401 New in 1.12.5:
402
403 * Vala support:
404
405   - The AM_PROG_VALAC macro has been enhanced to takes two further
406     optional arguments; it's signature now being
407
408         AM_PROG_VALAC([MINIMUM-VERSION], [ACTION-IF-FOUND],
409                       [ACTION-IF-NOT-FOUND])
410
411   - By default, AM_PROG_VALAC no longer aborts the configure invocation
412     if the Vala compiler found is too old, but simply prints a warning
413     messages (as it did when the Vala compiler was not found).  This
414     should avoid unnecessary difficulties for end users that just want
415     to compile the unmodified, distributed Vala-generated C sources,
416     but happens to have an old Vala compiler in their PATH.  This fixes
417     automake bug#12688.
418
419   - If no proper Vala compiler is found at configure runtime, AM_PROG_VALAC
420     will set the AC_SUBST'd variable 'VALAC' to 'valac' rather than to ':'.
421     This is a better default, because with it a triggered makefile rule
422     invoking a Vala compilation will clearly fail with an informative error
423     message like "valac: command not found", rather than silently, with
424     the error possibly going unnoticed or triggering harder-to-diagnose
425     fallout failures in later steps.
426
427 * Miscellaneous changes:
428
429   - automake and aclocal no longer honours the 'perllibdir' environment
430     variable.  That had always been intended only as an hack required in
431     the testsuite, not meant for any use beyond that.
432
433 Bugs fixed in 1.12.5:
434
435 * Long-standing bugs:
436
437   - Automake no longer generates spurious remake rules invoking autoheader
438     to regenerate the template corresponding to header files specified after
439     the first one in AC_CONFIG_HEADERS (automake bug#12495).
440
441   - When wrapping Microsoft tools, the 'compile' script falls back to
442     finding classic 'libname.a' style libraries when 'name.lib' and
443     'name.dll.lib' aren't available.
444
445 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
446
447 New in 1.12.4:
448
449 * Warnings and deprecations:
450
451   - Warnings in the 'obsolete' category are enabled by default both in
452     automake and aclocal.
453
454 * Miscellaneous changes:
455
456   - Some testsuite weaknesses and spurious failures have been fixed.
457
458 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
459
460 New in 1.12.3:
461
462 * Miscellaneous changes:
463
464   - The '.m4' files provided by Automake no longer define serial numbers.
465     This should cause no difference in the behaviour of aclocal though.
466
467   - Some testsuite weaknesses and spurious failures have been fixed.
468
469   - There is initial support for automatic dependency tracking with the
470     Portland Group C/C++ compilers, thanks to the new new depmode 'pgcc'.
471
472 Bugs fixed in 1.12.3:
473
474 * Long-standing bugs:
475
476   - Instead of renaming only self-references of files (typically for
477     #lines), ylwrap now also renames references to the other generated
478     files.  This fixes support for GLR and C++ parsers from Bison (PR
479     automake/491 and automake bug#7648): 'parser.c' now properly
480     #includes 'parser.h' instead of 'y.tab.h'.
481
482   - Generated files unknown to ylwrap are now preserved.  This fixes
483     C++ support for Bison (automake bug#7648): location.hh and the
484     like are no longer discarded.
485
486 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
487
488 New in 1.12.2:
489
490 * Warnings and deprecations:
491
492   - Automake now issues a warning (in the 'portability' category) if
493     'configure.in' is used instead of 'configure.ac' as the Autoconf
494     input file.  Such a warning will also be present in the next
495     Autoconf version (2.70).
496
497 * Cleaning rules:
498
499   - Recursive cleaning rules descends into the $(SUBDIRS) in the natural
500     order (as done by the other recursive rules), rather than in the
501     inverse order.  They used to do that in order to work a round a
502     limitation in an older implementation of the automatic dependency
503     tracking support, but that limitation had been lifted years ago
504     already, when the automatic dependency tracking based on side-effects
505     of compilation had been introduced.
506
507   - Cleaning rules for compiled objects (both "plain" and libtool) work
508     better when subdir objects are involved, not triggering a distinct
509     'rm' invocation for each such object.  They do so by removing *any*
510     compiled object file that is in the same directory of a subdir
511     object.  See automake bug#10697.
512
513 * Silent rules support:
514
515   - A new predefined $(AM_V_P) make variable is provided; it expands
516     to a shell conditional that can be used in recipes to know whether
517     make is being run in silent or verbose mode.
518
519 Bugs fixed in 1.12.2:
520
521 * SECURITY VULNERABILITIES!
522
523   - The 'distcheck' recipe no longer grants temporary world-write
524     permissions on the extracted distdir.  Even if such rights were
525     only granted for a vanishingly small time window, the implied
526     race condition proved to be enough to allow a local attacker
527     to run arbitrary code with the privileges of the user running
528     "make distcheck".  This is CVE-2012-3386.
529
530 * Long-standing bugs:
531
532   - The "recheck" targets behaves better in the face of build failures
533     related to previously failed tests.  For example, if a test is a
534     compiled program that must be rerun by "make recheck", and its
535     compilation fails, it will still be rerun by further "make recheck"
536     invocations.  See automake bug#11791.
537
538 * Bugs introduced by 1.12.1:
539
540   - Automake provides once again the '$(mkdir_p)' make variable and the
541     '@mkdir_p@' substitution (both as simple aliases for '$(MKDIR_P)'),
542     for better backward-compatibility.
543
544 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
545
546 New in 1.12.1:
547
548 * New supported languages:
549
550   - Support for Objective C++ has been added; it should work similarly to
551     the support for Objective C.
552
553 * Deprecated obsolescent features:
554
555   - Use of the long-deprecated two- and three-arguments invocation forms
556     of the AM_INIT_AUTOMAKE macro now elicits a warning in the 'obsolete'
557     category.  Starting from some future major Automake release (likely
558     post-1.13), such usages will no longer be allowed.
559
560   - Support for the "Cygnus-style" trees (enabled by the 'cygnus' option) is
561     now deprecated (its use triggers a warning in the 'obsolete' category).
562     It will be removed in the next major Automake release (1.13).
563
564   - The long-obsolete (since 1.10) automake-provided $(mkdir_p) make
565     variable, @mkdir_p@ configure-time substitution and AM_PROG_MKDIR
566     m4 macro are deprecated, eliciting a warning in the 'obsolete'
567     category.
568
569 * Miscellaneous changes:
570
571   - The Automake test cases now require a proper POSIX-conforming shell.
572     Older non-POSIX Bourne shells (like Solaris 10 /bin/sh) will no longer
573     be accepted.  In most cases, the user shouldn't have to specify such
574     POSIX shell explicitly, since it will be looked up at configure time.
575     Still, when this lookup fails, or when the user wants to override its
576     conclusion, the variable 'AM_TEST_RUNNER_SHELL' can be used (pointing
577     to the shell that will be used to run the Automake test cases).
578
579 Bugs fixed in 1.12.1:
580
581 * Bugs introduced by 1.12:
582
583   - Several weaknesses in Automake's own build system and test suite
584     have been fixed.
585
586 * Bugs introduced by 1.11.3:
587
588   - When given non-option arguments, aclocal rejects them, instead of
589     silently ignoring them.
590
591 * Long-standing bugs:
592
593   - When the 'color-tests' option is in use, forcing of colored testsuite
594     output through "AM_COLOR_TESTS=always" works even if the terminal is
595     a non-ANSI one, i.e., if the TERM environment variable has a value of
596     "dumb".
597
598   - Several inefficiencies and poor performances in the implementation
599     of the parallel-tests 'check' and 'recheck' targets have been fixed.
600
601   - The post-processing of output "#line" directives done the ylwrap
602     script is more faithful w.r.t. files in a subdirectory; for example,
603     if the processed file is "src/grammar.y", ylwrap will correctly
604     produce directives like:
605         #line 7 "src/grammar.y"
606     rather than like
607         #line 7 "grammar.y"
608     as it did before.
609
610 * Bugs with new Perl versions:
611
612   - Aclocal works correctly with perl 5.16.0 (automake bug#11543).
613
614 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
615
616 New in 1.12:
617
618 * Obsolete features removed:
619
620   - The never documented nor truly used script 'acinstall' has been
621     removed.
622
623   - Support for automatic de-ANSI-fication has been removed.
624
625   - The support for the "obscure" multilib feature has been removed
626     from Automake core (but remains available in the 'contrib/'
627     directory of the Automake distribution).
628
629   - Support for ".log -> .html" conversion and the check-html and
630     recheck-html targets has been removed from Automake core (but
631     remains available in the 'contrib/' directory of the Automake
632     distribution).
633
634   - The deprecated 'lzma' compression format for distribution archives
635     has been removed, in favor of 'xz' and 'lzip'.
636
637   - The obsolete AM_WITH_REGEX macro has been removed.
638
639   - The long-deprecated options '--output-dir', '--Werror' and
640     '--Wno-error' have been removed.
641
642   - The chapter on the history of Automake has been moved out of the
643     reference manual, into a new dedicated Texinfo file.
644
645 * New targets:
646
647   - New 'cscope' target to build a cscope database for the source tree.
648
649 * Changes to Automake-generated testsuite harnesses:
650
651   - The new automake option 'serial-tests' has been introduced.  It can
652     be used to explicitly instruct automake to use the older serial
653     testsuite harness.  This is still the default at the moment, but it
654     might change in future versions.
655
656   - The 'recheck' target (provided by the parallel testsuite harness) now
657     depends on the 'all' target.  This allows for a better user-experience
658     in test-driven development.  See automake bug#11252.
659
660   - Test scripts that exit with status 99 to signal an "hard error" (e.g.,
661     and unexpected or internal error, or a failure to set up the test case
662     scenario) have their outcome reported as an 'ERROR' now.  Previous
663     versions of automake reported such an outcome as a 'FAIL' (the only
664     difference with normal failures being that hard errors were counted
665     as failures even when the test originating them was listed in
666     XFAIL_TESTS).
667
668   - The testsuite summary displayed by the parallel-test harness has a
669     completely new format, that always list the numbers of passed, failed,
670     xfailed, xpassed, skipped and errored tests, even when these numbers
671     are zero (but using smart coloring when the color-tests option is in
672     effect).
673
674   - The default testsuite driver offered by the 'parallel-tests' option is
675     now implemented (partly at least) with the help of automake-provided
676     auxiliary scripts (e.g., 'test-driver'), instead of relying entirely
677     on code in the generated Makefile.in.
678     This has two noteworthy implications.  The first one is that projects
679     using the 'parallel-tests' option should now either run automake with
680     the '--add-missing' option, or manually copy the 'test-driver' script
681     into their tree.  The second, and more important, implication is that
682     now, when the 'parallel-tests' option is in use, TESTS_ENVIRONMENT can
683     no longer be used to define a test runner, and the command specified
684     in LOG_COMPILER (and <ext>_LOG_COMPILER) must be a *real* executable
685     program or script.  For example, this is still a valid usage (albeit
686     a little contorted):
687
688       TESTS_ENVIRONMENT = \
689         if test -n '$(STRICT_TESTS)'; then \
690           maybe_errexit='-e'; \
691         else \
692           maybe_errexit=''; \
693         fi;
694       LOG_COMPILER = $(SHELL) $$maybe_errexit
695
696     OTOH, this is no longer a valid usage:
697
698       TESTS_ENVIRONMENT = \
699         $(SHELL) `test -n '$(STRICT_TESTS_CHECKING)' && echo ' -e'`
700
701     neither is this:
702
703       TESTS_ENVIRONMENT = \
704         run_with_perl_or_shell () \
705         { \
706           if grep -q '^#!.*perl' $$1; then
707             $(PERL) $$1; \
708           else \
709             $(SHELL) $$1; \
710           fi; \
711         }
712       LOG_COMPILER = run_with_perl_or_shell
713
714   - The package authors can now use customary testsuite drivers within
715     the framework provided by the 'parallel-tests' testsuite harness.
716     Consistently with the existing syntax, this can be done by defining
717     special makefile variables 'LOG_DRIVER' and '<ext>_LOG_DRIVER'.
718
719   - A new developer-reserved variable 'AM_TESTS_FD_REDIRECT' can be used
720     to redirect/define file descriptors used by the test scripts.
721
722   - The parallel-tests harness generates now, in addition the '.log' files
723     holding the output produced by the test scripts, a new set of '.trs'
724     files, holding "metadata" derived by the execution of the test scripts;
725     among such metadata are the outcomes of the test cases run by a script.
726
727   - Initial and still experimental support for the TAP test protocol is
728     now provided.
729
730 * Changes to Yacc and Lex support:
731
732   - C source and header files derived from non-distributed Yacc and/or
733     Lex sources are now removed by a simple "make clean" (while they were
734     previously removed only by "make maintainer-clean").
735
736   - Slightly backward-incompatible change, relevant only for use of Yacc
737     with C++: the extensions of the header files produced by the Yacc
738     rules are now modelled after the extension of the corresponding
739     sources.  For example, yacc files named "foo.y++" and "bar.yy" will
740     produce header files named "foo.h++" and "bar.hh" respectively, where
741     they would have previously produced header files named simply "foo.h"
742     and "bar.h".  This change offers better compatibility with 'bison -o'.
743
744 * Miscellaneous changes:
745
746   - The AM_PROG_VALAC macro now causes configure to exit with status 77,
747     rather than 1, if the vala compiler found is too old.
748
749   - The build system of Automake itself now avoids the use of make
750     recursion as much as possible.
751
752   - Automake now prefers to quote 'like this' or "like this", rather
753     than `like this', in diagnostic message and generated Makefiles,
754     to accommodate the new GNU Coding Standards recommendations.
755
756   - Automake has a new option '--print-libdir' that prints the path of the
757     directory containing the Automake-provided scripts and data files.
758
759   - The 'dist' and 'dist-all' targets now can run compressors in parallel.
760
761   - The rules to create pdf, dvi and ps output from Texinfo files now
762     works better with modern 'texi2dvi' script, by explicitly passing
763     it the '--clean' option to ensure stray auxiliary files are not
764     left to clutter the build directory.
765
766   - Automake can now generate silenced rules for texinfo outputs.
767
768   - Some auxiliary files that are automatically distributed by Automake
769     (e.g., 'install-sh', or the 'depcomp' script for packages compiling
770     C sources) might now be listed in the DIST_COMMON variable in many
771     Makefile.in files, rather than in the top-level one.
772
773   - Messages of types warning or error from 'automake' and 'aclocal'
774     are now prefixed with the respective type, and presence of -Werror
775     is noted.
776
777   - Automake's early configure-time sanity check now tries to avoid
778     sleeping for a second, which slowed down cached configure runs
779     noticeably.  In that case, it will check back at the end of the
780     configure script to ensure that at least one second has passed, to
781     avoid time stamp issues with makefile rules rerunning autotools
782     programs.
783
784   - The warnings in the category 'extra-portability' are now enabled by
785     '-Wall'.  In previous versions, one has to use '-Wextra-portability'
786     to enable them.
787
788 Bugs fixed in 1.12:
789
790   - Various minor bugfixes for recent or long-standing bugs.
791
792 * Bugs introduced by 1.11:
793
794   - The AM_COND_IF macro also works if the shell expression for the
795     conditional is no longer valid for the condition.
796
797   - The automake-provided parallel testsuite harness no longer fails
798     with BSD make used in parallel mode when there are test scripts in
799     a subdirectory, like in:
800
801       TESTS = sub/foo.test sub/bar.test
802
803 * Long-standing bugs:
804
805   - Automake's own build system finally have a real "installcheck" target.
806
807   - Vala-related cleanup rules are now more complete, and work better in
808     a VPATH setup.
809
810   - Files listed with the AC_REQUIRE_AUX_FILE macro in configure.ac are
811     now automatically distributed also if the directory of the auxiliary
812     files coincides with the top-level directory.
813
814   - Automake now detects the presence of the '-d' flag in the various
815     '*YFLAGS' variables even when their definitions involve indirections
816     through other variables, such as in:
817       foo_opts = -d
818       AM_YFLAGS = $(foo_opts)
819
820   - Automake now complains if a '*YFLAGS' variable has any conditional
821     content, not only a conditional definition.
822
823   - Explicit enabling and/or disabling of Automake warning categories
824     through the '-W...' options now always takes precedence over the
825     implicit warning level implied by Automake strictness (foreign, gnu
826     or gnits), regardless of the order in which such strictness and
827     warning flags appear.  For example, a setting like:
828       AUTOMAKE_OPTIONS = -Wall --foreign
829     will cause the warnings in category 'portability' to be enabled, even
830     if those warnings are by default disabled in 'foreign' strictness.
831
832 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
833
834 Bugs fixed in 1.11.5:
835
836 * Bugs introduced by 1.11.3:
837
838   - Vala files with '.vapi' extension are now recognized and handled
839     correctly again.  See automake bug#11222.
840
841   - Vala support work again for projects that contain some program
842     built from '.vala' (and possibly '.c') sources and some other
843     program built from '.c' sources *only*.  See automake bug#11229.
844
845 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
846
847 New in 1.11.4:
848
849 * Miscellaneous changes:
850
851   - The 'ar-lib' script now ignores the "s" (symbol index) and "S" (no
852     symbol index) modifiers as well as the "s" action, as the symbol index
853     is created unconditionally by Microsoft lib.  Also, the "q" (quick)
854     action is now a synonym for "r" (replace).  Also, the script has been
855     ignoring the "v" (verbose) modifier already since Automake 1.11.3.
856
857   - When the 'compile' script is used to wrap MSVC, it now accepts an
858     optional space between the -I, -L and -l options and their respective
859     arguments, for better POSIX compliance.
860
861   - There is an initial, experimental support for automatic dependency
862     tracking with tcc (the Tiny C Compiler).  Its associated depmode is
863     currently recognized as "icc" (but this and other details are likely
864     to change in future versions).
865
866   - Automatic dependency tracking now works also with the IBM XL C/C++
867     compilers, thanks to the new new depmode 'xlc'.
868
869 Bugs fixed in 1.11.4:
870
871 * Bugs introduced by 1.11.2:
872
873   - A definition of 'noinst_PYTHON' before 'python_PYTHON' (or similar)
874     no longer cause spurious failures upon "make install".
875
876   - The user can now instruct the 'uninstall-info' rule not to update
877     the '${infodir}/dir' file by exporting the environment variable
878     'AM_UPDATE_INFO_DIR' to the value "no".  This is done for consistency
879     with how the 'install-info' rule operates since automake 1.11.2.
880
881 * Long-standing bugs:
882
883   - It is now possible for a foo_SOURCES variable to hold Vala sources
884     together with C header files, as well as with sources and headers for
885     other supported languages (e.g., C++).  Previously, only mixing C and
886     Vala sources was supported.
887
888   - If "aclocal --install" is used, and the first directory specified with
889     '-I' is non-existent, aclocal will now create it before trying to copy
890     files in it.
891
892   - An empty declaration of a "foo_PRIMARY" no longer cause the generated
893     install rules to create an empty $(foodir) directory; for example, if
894     Makefile.am contains something like:
895
896       pkglibexec_SCRIPTS =
897       if FALSE
898       pkglibexec_SCRIPTS += bar.sh
899       endif
900
901     the $(pkglibexec) directory will not be created upon "make install".
902
903 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
904
905 New in 1.11.3:
906
907 * Miscellaneous changes:
908
909   - Automake's own build system is more silent by default, making use of
910     the 'silent-rules' option.
911
912   - The master copy of the 'gnupload' script is now maintained in gnulib,
913     not in automake.
914
915   - The 'missing' script no longer tries to wrap calls to 'tar'.
916
917   - "make dist" no longer wraps 'tar' invocations with the 'missing'
918     script.  Similarly, the obsolescent variable '$(AMTAR)' (which you
919     shouldn't be using BTW ;-) no longer invokes the 'missing' script
920     to wrap tar, but simply invokes the 'tar' program itself.
921
922   - "make dist" can now create lzip-compressed tarballs.
923
924   - In the Automake info documentation, the Top node and the nodes about
925     the invocation of the automake and aclocal programs have been renamed;
926     now, calling "info automake" will open the Top node, while calling
927     "info automake-invocation" and "info aclocal-invocation" will access
928     the nodes about the invocation of respectively automake and aclocal.
929
930   - Automake is now distributed as a gzip-compressed and an xz-compressed
931     tarball.  Previously, bzip2 was used instead of xz.
932
933   - The last relics of Python 1.5 support have been removed from the
934     AM_PATH_PYTHON macro.
935
936   - For programs and libraries, automake now detects EXTRA_foo_DEPENDENCIES
937     and adds them to the normal list of dependencies, but without
938     overwriting the foo_DEPENDENCIES variable, which is normally computed
939     by automake.
940
941 Bugs fixed in 1.11.3:
942
943 * Bugs introduced by 1.11.2:
944
945   - Automake now correctly recognizes the prefix/primary combination
946    'pkglibexec_SCRIPTS' as valid.
947
948   - The parallel-tests harness no longer trips on sed implementations
949     with stricter limits on the length of input lines (problem seen at
950     least on Solaris 8).
951
952 * Long-standing bugs:
953
954   - The "deleted header file problem" for *.am files is avoided by stub
955     rules.  This allows 'make' to trigger a rerun of 'automake' also if
956     some previously needed '.am' file has been removed.
957
958   - The 'silent-rules' option now generates working makefiles even
959     for the uncommon 'make' implementations that do not support the
960     nested-variables extension to POSIX 2008.  For such 'make'
961     implementations, whether a build is silent is determined at
962     configure time, and cannot be overridden at make time with
963     "make V=0" or "make V=1".
964
965   - Vala support now works better in VPATH setups.
966
967 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
968
969 New in 1.11.2:
970
971 * Changes to aclocal:
972
973   - The `--acdir' option is deprecated.  Now you should use the new options
974     `--automake-acdir' and `--system-acdir' instead.
975
976   - The `ACLOCAL_PATH' environment variable is now interpreted as a
977     colon-separated list of additional directories to search after the
978     automake internal acdir (by default ${prefix}/share/aclocal-APIVERSION)
979     and before the system acdir (by default ${prefix}/share/aclocal).
980
981 * Miscellaneous changes:
982
983   - The Automake support for automatic de-ANSI-fication has been
984     deprecated.  It will probably be removed in the next major Automake
985     release (1.12).
986
987   - The `lzma' compression scheme and associated automake option `dist-lzma'
988     is obsoleted by `xz' and `dist-xz' due to upstream changes.
989
990   - You may adjust the compression options used in dist-xz and dist-bzip2.
991     The default is now merely -e for xz, but still -9 for bzip;  you may
992     specify a different level via the XZ_OPT and BZIP2 envvars respectively.
993     E.g., "make dist-xz XZ_OPT=-7" or "make dist-bzip2 BZIP2=-5"
994
995   - The `compile' script now converts some options for MSVC for a better
996     user experience.  Similarly, the new `ar-lib' script wraps Microsoft lib.
997
998   - The py-compile script now accepts empty arguments passed to the options
999     `--destdir' and `--basedir', and complains about unrecognized options.
1000     Moreover, a non-option argument or a special `--' argument terminates
1001     the list of options.
1002
1003   - A developer that needs to pass specific flags to configure at "make
1004     distcheck" time can now, and indeed is advised to, do so by defining
1005     the developer-reserved makefile variable AM_DISTCHECK_CONFIGURE_FLAGS,
1006     instead of the old DISTCHECK_CONFIGURE_FLAGS.
1007     The DISTCHECK_CONFIGURE_FLAGS variable should now be reserved for the
1008     user; still, the old Makefile.am files that used to define it will
1009     still continue to work as before.
1010
1011   - New macro AM_PROG_AR that looks for an archiver and wraps it in the new
1012     'ar-lib' auxiliary script if the selected archiver is Microsoft lib.
1013     This new macro is required for LIBRARIES and LTLIBRARIES when automake
1014     is run with -Wextra-portability and -Werror.
1015
1016   - When using DejaGnu-based testsuites, the user can extend the `site.exp'
1017     file generated by automake-provided rules by defining the special make
1018     variable `$(EXTRA_DEJAGNU_SITE_CONFIG)'.
1019
1020   - The `install-info' rule can now be instructed not to create/update
1021     the `${infodir}/dir' file, by exporting the new environment variable
1022     `AM_UPDATE_INFO_DIR' to the value "no".
1023
1024 Bugs fixed in 1.11.2:
1025
1026 * Bugs introduced by 1.11:
1027
1028   - The parallel-tests driver no longer produces erroneous results with
1029     Tru64/OSF 5.1 sh upon unreadable log files.
1030
1031   - The `parallel-tests' test driver does not report spurious successes
1032     when used with concurrent FreeBSD make (e.g., "make check -j3").
1033
1034   - When the parallel-tests driver is in use, automake now explicitly
1035     rejects invalid entries and conditional contents in TEST_EXTENSIONS,
1036     instead of issuing confusing and apparently unrelated error messages
1037     (e.g., "non-POSIX variable name", "bad characters in variable name",
1038     or "redefinition of TEST_EXTENSIONS), or even, in some situations,
1039     silently producing broken `Makefile.in' files.
1040
1041   - The `silent-rules' option now truly silences all compile rules, even
1042     when dependency tracking is disabled.  Also, when `silent-rules' is
1043     not used, `make' output no longer contains spurious backslash-only
1044     lines, thus once again matching what Automake did before 1.11.
1045
1046   - The AM_COND_IF macro also works if the shell expression for the
1047     conditional is no longer valid for the condition.
1048
1049 * Long-standing bugs:
1050
1051   - The order of Yacc and Lex flags is fixed to be consistent with other
1052     languages: $(AM_YFLAGS) comes before $(YFLAGS), and $(AM_LFLAGS) before
1053     $(LFLAGS), so that the user variables override the developer variables.
1054
1055   - "make distcheck" now correctly complains also when "make uninstall"
1056     leaves one and only one file installed in $(prefix).
1057
1058   - A "make uninstall" issued before a "make install", or after a mere
1059     "make install-data" or a mere "make install-exec" does not spuriously
1060     fail anymore.
1061
1062   - Automake now warns about more primary/directory invalid combinations,
1063     such as "doc_LIBRARIES" or "pkglib_PROGRAMS".
1064
1065   - Rules generated by Automake now try harder to not change any files when
1066     `make -n' is invoked.  Fixes include compilation of Emacs Lisp, Vala, or
1067     Yacc source files and the rule to update config.h.
1068
1069   - Several scripts and the parallel-tests testsuite driver now exit with
1070     the right exit status upon receiving a signal.
1071
1072   - A per-Makefile.am setting of -Werror does not erroneously carry over
1073     to the handling of other Makefile.am files.
1074
1075   - The code for automatic dependency tracking works around a Solaris
1076     make bug triggered by sources containing repeated slashes when the
1077     `subdir-objects' option was used.
1078
1079   - The makedepend and hp depmodes now work better with VPATH builds.
1080
1081   - Java sources specified with check_JAVA are no longer compiled for
1082     "make all", but only for "make check".
1083
1084   - An usage like "java_JAVA = foo.java" will now cause Automake to warn
1085     and error out if `javadir' is undefined, instead of silently producing
1086     a broken Makefile.in.
1087
1088   - aclocal and automake now honour the configure-time definitions of
1089     AUTOCONF and AUTOM4TE when they spawn autoconf or autom4te processes.
1090
1091   - The `install-info' recipe no longer tries to guess whether the
1092     `install-info' program is from Debian or from GNU, and adaptively
1093     change its behaviour; this has proven to be frail and easy to
1094     regress.
1095
1096 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1097
1098 Bugs fixed in 1.11.1:
1099
1100   - Lots of minor bugfixes.
1101
1102 * Bugs introduced by 1.11:
1103
1104   - The `parallel-tests' test driver works around a GNU make 3.80 bug with
1105     trailing white space in the test list (`TESTS = foo $(EMPTY)').
1106
1107 * Long standing bugs:
1108
1109   - On Darwin 9, `pythondir' and `pyexecdir' pointed below `/Library/Python'
1110     even if the `--prefix' argument pointed outside of a system directory.
1111     AM_PATH_PYTHON has been fixed to ignore the value returned from python's
1112     `get_python_lib' function if it points outside the configured prefix,
1113     unless the `--prefix' argument was either `/usr' or below `/System'.
1114
1115   - The testsuite does not try to change the mode of `ltmain.sh' files from
1116     a Libtool installation (symlinked to test directories) any more.
1117
1118   - AM_PROG_GCJ uses AC_CHECK_TOOLS to look for `gcj' now, so that prefixed
1119     tools are preferred in a cross-compile setup.
1120
1121   - The distribution is tarred up with mode 755 now by the `dist*' targets.
1122     This fixes a race condition where untrusted users could modify files
1123     in the $(PACKAGE)-$(VERSION) distdir before packing if the toplevel
1124     build directory was world-searchable.  This is CVE-2009-4029.
1125
1126 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1127
1128 New in 1.11:
1129
1130 * Version requirements:
1131
1132   - Autoconf 2.62 or greater is required.
1133
1134 * Changes to aclocal:
1135
1136   - The autoconf version check implemented by aclocal in aclocal.m4
1137     (and new in Automake 1.10) is degraded to a warning.  This helps
1138     in the common case where the Autoconf versions used are compatible.
1139
1140 * Changes to automake:
1141
1142   - The automake program can run multiple threads for creating most
1143     Makefile.in files concurrently, if at least Perl 5.7.2 is available
1144     with interpreter-based threads enabled.  Set the environment variable
1145     AUTOMAKE_JOBS to the maximum number of threads to use, in order to
1146     enable this experimental feature.
1147
1148 * Changes to Libtool support:
1149
1150   - Libtool generic flags are now passed to the install and uninstall
1151     modes as well.
1152
1153   - distcheck works with Libtool 2.x even when LT_OUTPUT is used, as
1154     config.lt is removed correctly now.
1155
1156 * Languages changes:
1157
1158   - subdir-object mode works now with Fortran (F77, FC, preprocessed
1159     Fortran, and Ratfor).
1160
1161   - For files with extension .f90, .f95, .f03, or .f08, the flag
1162     $(FCFLAGS_f[09]x) computed by AC_FC_SRCEXT is now used in compile rules.
1163
1164   - Files with extension .sx are also treated as preprocessed assembler.
1165
1166   - The default source file extension (.c) can be overridden with
1167     AM_DEFAULT_SOURCE_EXT now.
1168
1169   - Python 3.0 is supported now, Python releases prior to 2.0 are no
1170     longer supported.
1171
1172   - AM_PATH_PYTHON honors python's idea about the site directory.
1173
1174   - There is initial support for the Vala programming language, when using
1175     Vala 0.7.0 or later.
1176
1177 * Miscellaneous changes:
1178
1179   - Automake development is done in a git repository on Savannah now, see
1180
1181       http://git.sv.gnu.org/gitweb/?p=automake.git
1182
1183     A read-only CVS mirror is provided at
1184
1185       cvs -d :pserver:anonymous@pserver.git.sv.gnu.org:/automake.git \
1186           checkout -d automake HEAD
1187
1188   - "make dist" can now create xz-compressed tarballs,
1189     as well as (deprecated?) lzma-compressed tarballs.
1190
1191   - `automake --add-missing' will by default install the GPLv3 file as
1192     COPYING if it is missing.  It will also warn that the license file
1193     should be added to source control.  Note that Automake will never
1194     overwrite an existing COPYING file, even when the `--force-missing'
1195     option is used.
1196
1197   - The manual is now distributed under the terms of the GNU FDL 1.3.
1198
1199   - Automake ships and installs man pages for automake and aclocal now.
1200
1201   - New shorthand `$(pkglibexecdir)' for `$(libexecdir)/@PACKAGE@'.
1202
1203   - install-sh supports -C, which does not update the installed file
1204     (and its time stamps) if the contents did not change.
1205
1206   - The `gnupload' script has been revamped.
1207
1208   - The `depcomp' and `compile' scripts now work with MSVC under MSYS.
1209
1210   - The targets `install' and `uninstall' are more efficient now, in that
1211     for example multiple files from one Automake variable such as
1212     `bin_SCRIPTS' are copied in one `install' (or `libtool --mode=install')
1213     invocation if they do not have to be renamed.
1214
1215     Both install and uninstall may sometimes enter (`cd' into) the target
1216     installation directory now, when no build-local scripts are used.
1217
1218     Both install and uninstall do not fail anymore but do nothing if an
1219     installation directory variable like `bindir' is set to the empty string.
1220
1221     For built-in rules, `make install' now fails reliably if installation
1222     of a file failed.  Conversely, `make uninstall' even succeeds when
1223     issued multiple times.
1224
1225     These changes may need some adjustments from users:  For example,
1226     some `install' programs refuse to install multiple copies of the
1227     same file in one invocation, so you may need to remove duplicate
1228     entries from file lists.
1229
1230     Also, within one set of files, say, nobase_data_DATA, the order of
1231     installation may be changed, or even unstable among different hosts,
1232     due to the use of associative arrays in awk.  The increased use of
1233     awk matches a similar move in Autoconf to provide for better scaling.
1234
1235     Further, most undocumented per-rule install command variables such as
1236     binSCRIPT_INSTALL have been removed because they are not needed any
1237     more.  Packages which use them should be using the appropriate one of
1238     INSTALL_{DATA,PROGRAM,SCRIPT} or their install_sh_{DATA,PROGRAM,SCRIPT}
1239     counterpart, depending on the type of files and the need for automatic
1240     target directory creation.
1241
1242   - The "deleted header file problem" for *.m4 files is avoided by
1243     stub rules.  This allows `make' to trigger a rerun of `aclocal'
1244     also if some previously needed macro file has been removed.
1245
1246   - Rebuild rules now also work for a removed `subdir/Makefile.in' in
1247     an otherwise up to date tree.
1248
1249   - The `color-tests' option causes colored test result output on terminals.
1250
1251   - The `parallel-tests' option enables a new test driver that allows for
1252     parallel test execution, inter-test dependencies, lazy test execution
1253     for unit-testing, re-testing only failed tests, and formatted result output
1254     as RST (reStructuredText) and HTML.  Enabling this option may require some
1255     changes to your test suite setup; see the manual for details.
1256
1257   - The `silent-rules' option enables Linux kernel-style silent build output.
1258     This option requires the widely supported but non-POSIX `make' feature
1259     of recursive variable expansion, so do not use it if your package needs
1260     to build with `make' implementations that do not support it.
1261
1262     To enable less verbose build output, the developer has to use the Automake
1263     option `silent-rules' in `AM_INIT_AUTOMAKE', or call the `AM_SILENT_RULES'
1264     macro.  The user may then set the default verbosity by passing the
1265     `--enable-silent-rules' option to `configure'.  At `make' run time, this
1266     default may be overridden using `make V=0' for less verbose, and `make V=1'
1267     for backward-compatible verbose output.
1268
1269   - New prefix `notrans_' for manpages which should not be transformed
1270     by --program-transform.
1271
1272   - New macro AM_COND_IF for conditional evaluation and conditional
1273     config files.
1274
1275   - For AC_CONFIG_LINKS, if source and destination are equal, do not
1276     remove the file in a non-VPATH build.  Such setups work with Autoconf
1277     2.62 or newer.
1278
1279   - AM_MAINTAINER_MODE now allows for an optional argument specifying
1280     the default setting.
1281
1282   - AM_SUBST_NOTMAKE may prevent substitution of AC_SUBSTed variables,
1283     useful especially for multi-line values.
1284
1285   - Automake's early configure-time sanity check now diagnoses an
1286     unsafe absolute source directory name and makes configure fail.
1287
1288   - The Automake macros and rules cope better with whitespace in the
1289     current directory name, as long as the relative path to `configure'
1290     does not contain whitespace.  To this end, the values of `$(MISSING)'
1291     and `$(install_sh)' may contain suitable quoting, and their expansion
1292     might need `eval'uation if used outside of a makefile.  These
1293     undocumented variables may be used in several documented macros such
1294     as $(AUTOCONF) or $(MAKEINFO).
1295
1296 Bugs fixed in 1.11:
1297
1298 * Long-standing bugs:
1299
1300   - Fix aix dependency tracking for libtool objects.
1301
1302   - Work around AIX sh quoting issue in AC_PROG_CC_C_O, leading to
1303     unnecessary use of the `compile' script.
1304
1305   - For nobase_*_LTLIBRARIES with nonempty directory components, the
1306     correct `-rpath' argument is used now.
1307
1308   - `config.status --file=Makefile depfiles' now also works with the
1309     extra quoting used internally by Autoconf 2.62 and newer
1310     (it used to work only without the `--file=' bit).
1311
1312   - The `missing' script works better with versioned tool names.
1313
1314   - Semantics for `missing help2man' have been revamped:
1315
1316     Previously, if `help2man' was not present, `missing help2man' would have
1317     the following semantics: if some man page was out of date but present, then
1318     a warning would be printed, but the exit status was 0.  If the man page was
1319     not present at all, then `missing' would create a replacement man page
1320     containing an error message, and exit with a status of 2.  This does not play
1321     well with `make': the next run will see this particular man page as being up
1322     to date, and will only error out on the next generated man page, if any;
1323     repeat until all pages are done.  This was not desirable.
1324
1325     These are the new semantics: if some man page is not present, and help2man
1326     is not either, then `missing' will warn and generate the replacement page
1327     containing the error message, but exit successfully.  However, `make dist'
1328     will ensure that no such bogus man pages are packaged into a tarball.
1329
1330   - Targets provided by automake behave better with `make -n', in that they
1331     take care not to create files.
1332
1333   - `config.status Makefile... depfiles' works fine again in the presence of
1334     disabled dependency tracking.
1335
1336   - The default no-op recursive rules for these targets also work with BSD make
1337     now: html, install-html, install-dvi, install-pdf, install-pdf, install-info.
1338
1339   - `make distcheck' works also when both a directory and some file below it
1340     have been added to a distribution variable, such as EXTRA_DIST or *_SOURCES.
1341
1342   - Texinfo dvi, ps, pdf, and html output files are not removed upon
1343     `make mostlyclean' any more; only the LaTeX by-products are.
1344
1345   - Renamed objects also work with the `subdir-objects' option and
1346     source file languages which Automake does not know itself.
1347
1348   - `automake' now correctly complains about variable assignments which are
1349     preceded by a comment, extend over multiple lines with backslash-escaped
1350     newlines, and end in a comment sign.  Previous versions would silently
1351     and wrongly ignore such assignments completely.
1352
1353 * Bugs introduced by 1.10:
1354
1355   - Fix output of dummy dependency files in presence of post-processed
1356     Makefile.in's again, but also cope with long lines.
1357
1358   - $(EXEEXT) is automatically appended to filenames of XFAIL_TESTS
1359     that have been declared as programs in the same Makefile.
1360     This is for consistency with the analogous change to TESTS in 1.10.
1361
1362   - Fix order of standard includes to again be `-I. -I$(srcdir)',
1363     followed by directories containing config headers.
1364
1365 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1366
1367 New in 1.10:
1368
1369 * Version requirements:
1370
1371   - Autoconf 2.60 or greater is required.
1372
1373   - Perl 5.6 or greater is required.
1374
1375 * Changes to aclocal:
1376
1377   - aclocal now also supports -Wmumble and -Wno-mumble options.
1378
1379   - `dirlist' entries (for the aclocal search path) may use shell
1380     wildcards such as `*', `?', or `[...]'.
1381
1382   - aclocal supports an --install option that will cause system-wide
1383     third-party macros to be installed in the local directory
1384     specified with the first -I flag.  This option also uses #serial
1385     lines in M4 files to upgrade local macros.
1386
1387     The new aclocal options --dry-run and --diff help to review changes
1388     before they are installed.
1389
1390   - aclocal now outputs an autoconf version check in aclocal.m4 in
1391     projects using automake.
1392
1393     For a few years, automake and aclocal have been calling autoconf
1394     (or its underlying engine autom4te) to accurately retrieve the
1395     data they need from configure.ac and its siblings.  Doing so can
1396     only work if all autotools use the same version of autoconf.  For
1397     instance a Makefile.in generated by automake for one version of
1398     autoconf may stop working if configure is regenerated with another
1399     version of autoconf, and vice versa.
1400
1401     This new version check ensures that the whole build system has
1402     been generated using the same autoconf version.
1403
1404 * Support for new Autoconf macros:
1405
1406   - The new AC_REQUIRE_AUX_FILE Autoconf macro is supported.
1407
1408   - If `subdir-objects' is set, and AC_CONFIG_LIBOBJ_DIR is specified,
1409     $(LIBOBJS), $(LTLIBOBJS), $(ALLOCA), and $(LTALLOCA) can be used
1410     in different directories.  However, only one instance of such a
1411     library objects directory is supported.
1412
1413 * Change to Libtool support:
1414
1415   - Libtool generic flags (those that go before the --mode=MODE option)
1416     can be specified using AM_LIBTOOLFLAGS and target_LIBTOOLFLAGS.
1417
1418 * Yacc and Lex changes:
1419
1420   - The rebuild rules for distributed Yacc and Lex output will avoid
1421     overwriting existing files if AM_MAINTAINER_MODE and maintainer-mode
1422     is not enabled.
1423
1424   - ylwrap is now always used for lex and yacc source files,
1425     regardless of whether there is more than one source per directory.
1426
1427 * Languages changes:
1428
1429   - Preprocessed assembler (*.S) compilation now honors CPPFLAGS,
1430     AM_CPPFLAGS and per-target _CPPFLAGS, and supports dependency
1431     tracking, unlike non-preprocessed assembler (*.s).
1432
1433   - subdir-object mode works now with Assembler.  Automake assumes
1434     that the compiler understands `-c -o'.
1435
1436   - Preprocessed assembler (*.S) compilation now also honors
1437     $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES).
1438
1439   - Improved support for Objective C:
1440     - Autoconf's new AC_PROG_OBJC will enable automatic dependency tracking.
1441     - A new section of the manual documents the support.
1442
1443   - New support for Unified Parallel C:
1444     - AM_PROG_UPC looks for a UPC compiler.
1445     - A new section of the manual documents the support.
1446
1447   - Per-target flags are now correctly handled in link rules.
1448
1449     For instance maude_CFLAGS correctly overrides AM_CFLAGS; likewise
1450     for maude_LDFLAGS and AM_LDFLAGS.  Previous versions bogusly
1451     preferred AM_CFLAGS over maude_CFLAGS while linking, and they
1452     used both AM_LDFLAGS and maude_LDFLAGS on the same link command.
1453
1454     The fix for compiler flags (i.e., using maude_CFLAGS instead of
1455     AM_CFLAGS) should not hurt any package since that is how _CFLAGS
1456     is expected to work (and actually works during compilation).
1457
1458     However using maude_LDFLAGS "instead of" AM_LDFLAGS rather than
1459     "in addition to" breaks backward compatibility with older versions.
1460     If your package used both variables, as in
1461
1462       AM_LDFLAGS = common flags
1463       bin_PROGRAMS = a b c
1464       a_LDFLAGS = more flags
1465       ...
1466
1467     and assumed *_LDFLAGS would sum up, you should rewrite it as
1468
1469       AM_LDFLAGS = common flags
1470       bin_PROGRAMS = a b c
1471       a_LDFLAGS = $(AM_LDFLAGS) more flags
1472       ...
1473
1474     This new behavior of *_LDFLAGS is more coherent with other
1475     per-target variables, and the way *_LDFLAGS variables were
1476     considered internally.
1477
1478 * New installation targets:
1479
1480   - New targets mandated by GNU Coding Standards:
1481       install-dvi
1482       install-html
1483       install-ps
1484       install-pdf
1485     By default they will only install Texinfo manuals.
1486     You can customize them with *-local variants:
1487       install-dvi-local
1488       install-html-local
1489       install-ps-local
1490       install-pdf-local
1491
1492   - The undocumented recursive target `uninstall-info' no longer exists.
1493     (`uninstall' is in charge of removing all possible documentation
1494     flavors, including optional formats such as dvi, ps, or info even
1495     when `no-installinfo' is used.)
1496
1497 * Miscellaneous changes:
1498
1499   - Automake no longer complains if input files for AC_CONFIG_FILES
1500     are specified using shell variables.
1501
1502   - clean, distribution, or rebuild rules are normally disabled for
1503     inputs and outputs of AC_CONFIG_FILES, AC_CONFIG_HEADERS, and
1504     AC_CONFIG_LINK specified using shell variables.  However, if these
1505     variables are used as ${VAR}, and AC_SUBSTed, then Automake will
1506     be able to output rules anyway.
1507     (See the Automake documentation for AC_CONFIG_FILES.)
1508
1509   - $(EXEEXT) is automatically appended to filenames of TESTS
1510     that have been declared as programs in the same Makefile.
1511     This is mostly useful when some check_PROGRAMS are listed in TESTS.
1512
1513   - `-Wportability' has finally been turned on by default for `gnu' and
1514     `gnits' strictness.  This means, automake will complain about %-rules
1515     or $(GNU Make functions) unless you switch to `foreign' strictness or
1516     use `-Wno-portability'.
1517
1518   - Automake now uses AC_PROG_MKDIR_P (new in Autoconf 2.60), and uses
1519     $(MKDIR_P) instead of $(mkdir_p) to create directories.  The
1520     $(mkdir_p) variable is still defined (to the same value as
1521     $(MKDIR_P)) but should be considered obsolete.  If you are using
1522     $(mkdir_p) in some of your rules, please plan to update them to
1523     $(MKDIR_P) at some point.
1524
1525   - AM_C_PROTOTYPES and ansi2knr are now documented as being obsolete.
1526     They still work in this release, but may be withdrawn in a future one.
1527
1528   - Inline compilation rules for gcc3-style dependency tracking are
1529     more readable.
1530
1531   - Automake installs a "Hello World!" example package in $(docdir).
1532     This example is used throughout the new "Autotools Introduction"
1533     chapter of the manual.
1534
1535 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1536
1537 New in 1.9:
1538
1539 * Makefile.in bloat reduction:
1540
1541   - Inference rules are used to compile sources in subdirectories when
1542     the `subdir-objects' option is used and no per-target flags are
1543     used.  This should reduce the size of some projects a lot, because
1544     Automake used to output an explicit rule for each such object in
1545     the past.
1546
1547   - Automake no longer outputs three rules (.o, .obj, .lo) for each
1548     object that must be built with explicit rules.  It just outputs
1549     the rules required to build the kind of object considered: either
1550     the two .o and .obj rules for usual objects, or the .lo rule for
1551     libtool objects.
1552
1553 * Change to Libtool support:
1554
1555   - Libtool tags are used with libtool versions that support them.
1556     (I.e., with Libtool 1.5 or greater.)
1557
1558   - Automake is now able to handle setups where a libtool library is
1559     conditionally installed in different directories, as in
1560
1561       if COND
1562         lib_LTLIBRARIES = liba.la
1563       else
1564         pkglib_LTLIBRARIES = liba.la
1565       endif
1566       liba_la_SOURCES = ...
1567
1568 * Changes to aclocal:
1569
1570   - aclocal now ensures that AC_DEFUNs and AU_DEFUNs it discovers are
1571     really evaluated, before it decides to include them in aclocal.m4.
1572     This solves nasty problems with conditional redefinitions of
1573     Autoconf macros in /usr/share/aclocal/*.m4 files causing extraneous
1574     *.m4 files to be included in any project using these macros.
1575     (Calls to AC_PROG_EGREP causing libtool.m4 to be included is the
1576     most famous instance of this bug.)
1577
1578   - Do not complain about missing conditionally AC_REQUIREd macros
1579     that are not actually used.  In 1.8.x aclocal would correctly
1580     determine which of these macros were really needed (and include
1581     only these in the package); unfortunately it would also require
1582     all of them to be present in order to run.  This created
1583     situations were aclocal would not work on a tarball distributing
1584     all the macros it uses.  For instance running aclocal on a project
1585     containing only the subset of the Gettext macros in use by the
1586     project did not work, because gettext conditionally requires other
1587     macros.
1588
1589 * Portability improvements:
1590
1591   - Tar format can be chosen with the new options tar-v7, tar-ustar, and
1592     tar-pax.  The new option filename-length-max=99 helps diagnosing
1593     filenames that are too long for tar-v7.  (PR/414)
1594
1595   - Variables aumented with `+=' are now automatically flattened (i.e.,
1596     trailing backslashes removed) and then wrapped around 80 colummns
1597     (adding trailing backslashes).  In previous versions, a long series
1598     of
1599       VAR += value1
1600       VAR += value2
1601       VAR += value3
1602       ...
1603     would result in a single-line definition of VAR that could possibly
1604     exceed the maximum line length of some make implementations.
1605
1606     Non-augmented variables are still output as they are defined in
1607     the Makefile.am.
1608
1609 * Miscellaneous:
1610
1611   - Support Fortran 90/95 with the new "fc" and "ppfc" languages.
1612     Works the same as the old Fortran 77 implementation; just replace
1613     F77 with FC everywhere (exception: FFLAGS becomes FCFLAGS).
1614     Requires a version of autoconf which provides AC_PROG_FC (>=2.59).
1615
1616   - Support for conditional _LISP.
1617
1618   - Support for conditional -hook and -local rules (PR/428).
1619
1620   - Diagnose AC_CONFIG_AUX_DIR calls following AM_INIT_AUTOMAKE. (PR/49)
1621
1622   - Automake will not write any Makefile.ins after the first error it
1623     encounters.  The previous Makefile.ins (if any) will be left in
1624     place.  (Warnings will not prevent output, but remember they can
1625     be turned into errors with -Werror.)
1626
1627   - The restriction that SUBDIRS must contain direct children is gone.
1628     Do not abuse.
1629
1630   - The manual tells more about SUBDIRS vs. DIST_SUBDIRS.
1631     It also gives an example of nested packages using AC_CONFIG_SUBDIRS.
1632
1633 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1634
1635 Bugs fixed in 1.8.5:
1636
1637 * Long-standing bugs:
1638
1639   - Define DIST_SUBDIRS even when the `no-dist' or `cygnus' options are used
1640     so that `make distclean' and `make maintainer-clean' can work.
1641
1642   - Define AR and ARFLAGS even when only EXTRA_LIBRARIES are defined.
1643
1644   - Fix many rules to please FreeBSD make, which runs commands with `sh -e'.
1645
1646   - Polish diagnostic when no input file is found.
1647
1648 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1649
1650 Bugs fixed in 1.8.4:
1651
1652 * Long-standing bugs:
1653
1654   - Fix AM_PATH_PYTHON to correctly display $PYTHON when it has been
1655     overridden by the user.
1656
1657   - Honor PATH_SEPARATOR in various places of the Automake package, for
1658     the sake of OS/2.
1659
1660   - Adjust dependency tracking mode detection to ICC 8.0's new output.
1661     (PR/416)
1662
1663   - Fix install-sh so it can install the `mv' binary... using `mv'.
1664
1665   - Fix tru64 dependency tracking for libtool objects.
1666
1667   - Work around Exuberant Ctags when creating a TAGS files in a directory
1668     without files to scan but with subdirectories to include.
1669
1670 * Bugs introduced by 1.8:
1671
1672   - Fix an "internal error" when @LIBOBJS@ is used in a variable that is
1673     not defined in the same conditions as the _LDADD that uses it.
1674
1675   - Do not warn when JAVAROOT is overridden, this is legitimate.
1676
1677 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1678
1679 Bugs fixed in 1.8.3:
1680
1681 * Long-standing bugs:
1682
1683   - Quote filenames in installation rules, in case $DESTDIR, $prefix,
1684     or any of the other *dir variables contain a space.
1685
1686     Please note that Automake does not and cannot support spaces in
1687     filenames that are involved during the build.  This change affects
1688     only installation paths, so that `make install' does not bomb out
1689     in packages configured with
1690       ./configure --prefix '/c/Program Files'
1691
1692   - Fix the depfiles output so it works with GNU sed (<4.1) even when
1693     POSIXLY_CORRECT is set.
1694
1695   - Do not AC_SUBST(LIBOBJS) in AM_WITH_REGEX.  This macro was unusable
1696     since Autoconf 2.54, which defines LIBOBJS itself.
1697
1698   - Fix a potential (but unlikely) race condition in parallel elisp
1699     builds.  (Introduced in 1.7.3.)
1700
1701   - Do not assume that users override _DEPENDENCIES in all conditions
1702     where Automake will try to define them.
1703
1704   - Do not use `mkdir -p' in mkinstalldirs, unless this is GNU mkdir.
1705     Solaris 8's `mkdir -p' is not thread-safe and can break parallel
1706     builds.
1707
1708     This fix also affects the $(mkdir_p) variable defined since
1709     Automake 1.8.  It will be set to `mkdir -p' only if mkdir is GNU
1710     mkdir, and to `mkinstalldirs' or `install-sh -d' otherwise.
1711
1712   - Secure temporary directory creation in `make distcheck'. (PR/413)
1713
1714   - Do not generate two build rules for `parser.h' when the
1715     parser appears in two different conditionals.
1716
1717   - Work around a Solaris 8 /bin/sh bug in the test for dependency
1718     checking.  Usually ./configure will not pick this shell; so this
1719     fix only helps cases where the shell is forced to /bin/sh.
1720
1721 * Bugs introduced by 1.8:
1722
1723   - In some situations (hand-written `m4_include's), aclocal would
1724     call the `File::Spec->rel2abs' method, which was only introduced
1725     in Perl 5.6.  This new version reestablish support Perl 5.005.
1726
1727     It is likely that the next major Automake releases will require at
1728     least Perl 5.6.  Consider upgrading your development environment
1729     if you are still using the five-year-old Perl 5.005.
1730
1731   - Automake would sometimes fail to define rules for targets listed
1732     in variables defined in multiple conditions.  For instance on
1733       if C1
1734         bin_PROGRAMS = a
1735       else
1736         bin_PROGRAMS = b
1737       endif
1738     it would define only the `a.$(OBJEXT): a.c' rule and omit the
1739     `b.$(OBJEXT): b.c' rule.
1740
1741 * New sections in manual:
1742
1743   - Third-Party Makefiles: how to interface third party Makefiles.
1744   - Upgrading: upgrading packages to newer Automake versions.
1745   - Multiple Outputs: handling tools that produce many outputs.
1746
1747 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1748
1749 Bug fixed in 1.8.2:
1750
1751 * A (well known) portability bug slipped in the changes made to
1752   install-sh in Automake 1.8.1.  The broken install-sh would refuse to
1753   install anything on Tru64.
1754
1755 * Fix install rules for conditionally built python files.  (This never
1756   really worked.)
1757
1758 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1759
1760 Bug fixed in 1.8.1:
1761
1762 * Bugs introduced by 1.8:
1763
1764   - Fix Config.pm import error with old Perl versions (at least
1765     5.005_03).  One symptom is that aclocal could not find its macro
1766     directory.
1767
1768   - Automake 1.8 used `mkdir -m 0755 -p --' to ensure that directories
1769     created by `make install' are always world readable, even if the
1770     installer happens to have an overly restrictive umask (e.g. 077).
1771     This was a mistake and has been reverted.  There are at least two
1772     reasons why we must not use `-m 0755':
1773       - it causes special bits like SGID to be ignored,
1774       - it may be too restrictive (some setups expect 775 directories).
1775
1776   - Fix aclocal to honor definitions located in files which have been
1777     m4_included manually.  aclocal 1.8 had been updated to check
1778     m4_included files for new requirements, but forgot that these
1779     m4_included files can also provide new definitions.
1780
1781     Note that if you have such a setup, we recommend you get rid of
1782     it.  In the past, there was a reason to m4_include files manually:
1783     aclocal used to duplicate entire M4 files into aclocal.m4, even
1784     files that were distributed.  Some packages were therefore
1785     m4_including the distributed file directly, and playing some
1786     tricks to ensure aclocal would not copy that file to aclocal.m4,
1787     in order to limit the amount of duplication.  Since aclocal 1.8.x
1788     will precisely output m4_includes for local M4 files, we recommend
1789     that you clean up your setup, removing all manual m4_includes and
1790     letting aclocal output them.
1791
1792   - Output detailed menus in the Info version if the Automake manual,
1793     so that Emacs can locate the indexes.
1794
1795   - configure.ac and configure were listed twice in DIST_COMMON (an
1796     internal variable where Automake lists configury files to
1797     distribute).  This was harmless, but unaesthetic.
1798
1799   - Use `chmod a-w' instead of `chmod -w' as the latter honors umask.
1800     This was an issue only in the Automake package itself, not in
1801     its output.
1802
1803   - Automake assumed that all AC_CONFIG_LINKS arguments had the form
1804     DEST:SRC.  This was wrong, as some packages do
1805     AC_CONFIG_LINKS($computedlinks).  This version no longer abort in
1806     that situation.
1807
1808   - Contrary to mkinstalldirs, $(mkdir_p) was expecting exactly one
1809     argument.  This caused two kinds of failures:
1810       - Rules installing data in a conditionally defined directory
1811         failed when that directory was undefined.  In this case no
1812         argument was supplied.
1813       - `make installdirs' failed, because several directories were
1814         passed to $(mkdir_p).  This was an issue only on platform
1815         were $(mkdir_p) is implemented with `install-sh -d'.
1816     $(mkdir_p) as been changed to accept 0 or more arguments, as
1817     mkinstalldirs did.
1818
1819 * Long-standing bugs:
1820
1821   - Fix an unexpected diagnostic occurring when users attempt
1822     to override some internal variables that Automake appends to.
1823
1824   - aclocal now scans configure.ac for macro definitions (PR/319).
1825
1826   - Fix a portability issue with OSF1/Tru64 Make.  If a directory
1827     distributes files which are outside itself (this usually occurs
1828     when using AC_CONFIG_AUX_DIR([../dir]) to use auxiliary files
1829     from a parent package), then `make distcheck' fails due to an
1830     optimization performed by OSF1/Tru64 Make in its VPATH handling.
1831     (tests/subpkg2.test failure)
1832
1833   - Fix another portability issue with Sun and OSF1/Tru64 Make.
1834     In a VPATH-build configuration, `make install' would install
1835     nobase_ files to wrong locations.
1836
1837   - Fix a Perl `uninitialized value' diagnostic occurring when
1838     automake complains that a Texinfo file does not have a
1839     @setfilename statement.
1840
1841   - Erase config.status.lineno during `make distclean'.  This file
1842     can be created by config.status.  Automake already knew about
1843     configure.lineno, but forgot config.status.lineno.
1844
1845   - Distribute all files, even those which are built and installed
1846     conditionally.  This change affects files listed in conditionally
1847     defined *_HEADERS and *_PYTHON variable (unless they are nodist_*)
1848     as well as those listed in conditionally defined dist_*_DATA,
1849     dist_*_JAVA, dist_*_LISP, and dist_*_SCRIPTS variables.
1850
1851   - Fix AM_PATH_LISPDIR to avoid \? in sed regular expressions; it
1852     doesn't conform to POSIX.
1853
1854   - Normalize help strings for configure variables and options added
1855     by Automake macros.
1856
1857 * Anticipation:
1858
1859   - Check for python2.4 in AM_PATH_PYTHON.
1860
1861 * Spurious failures in test suite:
1862
1863   - tests/libtool5.test, tests/ltcond.test, tests/ltcond2.test,
1864     tests/ltconv.test: fix failures with CVS Libtool.
1865   - tests/aclocal6.test: fix failure if autom4te.cache is disabled.
1866   - tests/txinfo24.test, tests/txinfo25.test, tests/txinfo28.test:
1867     fix failures with old Texinfo versions.
1868
1869 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1870
1871 New in 1.8:
1872
1873 * Meta-News
1874
1875   - The NEWS file is more verbose.
1876
1877 * Requirements
1878
1879   - Autoconf 2.58 or greater is required.
1880
1881 * New features
1882
1883   - Default source file names in the absence of a _SOURCES declaration
1884     are made by removing any target extension before appending `.c', so
1885     to make the libtool module `foo.la' from `foo.c', you only need to
1886     do this:
1887
1888         lib_LTLIBRARIES = foo.la
1889         foo_la_LDFLAGS  = -module
1890
1891     For backward compatibility, foo_la.c will be used instead of
1892     foo.c if this file exists or is the explicit target of a rule.
1893     However -Wobsolete will warn about this deprecated naming.
1894
1895   - AR's `cru' flags are now set in a global ARFLAGS variable instead
1896     of being hard-coded in each $(AR) invocation, so they can be
1897     substituted from configure.ac.  This has been requested by people
1898     dealing with non-POSIX ar implementations.
1899
1900   - New warning option: -Woverride.  This will warn about any user
1901     target or variable definitions which override Automake
1902     definitions.
1903
1904   - Texinfo rules back up and restore info files when makeinfo fails.
1905
1906   - Texinfo rules now support the `html' target.
1907     Running this requires Texinfo 4.0 or greater.
1908
1909     `html' is a new recursive target, so if your package mixes
1910     hand-crafted `Makefile.in's with Automake-generated
1911     `Makefile.in's, you should adjust the former to support (or
1912     ignore) this target so that `make html' recurses successfully.  If
1913     you had a custom `html' rule in your `Makefile.am', it's better to
1914     rename it as `html-local', otherwise your rule will override
1915     Automake's new rule (you can check that by running `automake
1916     -Woverride') and that will stop the recursion to subdirectories.
1917
1918     Last but not least, this `html' rule is declared PHONY, even when
1919     overridden.  Fortunately, it appears that few packages use a
1920     non-PHONY `html' rule.
1921
1922   - Any file which is m4_included from configure.ac will appear as a
1923     configure and Makefile.in dependency, and will be automatically
1924     distributed.
1925
1926   - The rules for rebuilding Makefiles and Makefile.ins will now
1927     rebuild all Makefiles and all Makefile.ins at once when one of
1928     configure's dependencies has changed.  This is considerably faster
1929     than previous implementations, where config.status and automake
1930     were run separately in each directory (this still happens when you
1931     change a Makefile.am locally, without touching configure.ac or
1932     friends).  Doing this also solves a longstanding issue: these
1933     rebuild rules failed to work when adding new directories to the
1934     tree, forcing you to run automake manually.
1935
1936   - For similar reasons, the rules to rebuild configure,
1937     config.status, and aclocal.m4 are now defined in all directories.
1938     Note that if you were using the CONFIG_STATUS_DEPENDENCIES and
1939     CONFIGURE_DEPENDENCIES (formerly undocumented) variables, you
1940     should better define them in all directories.  This is easily done
1941     using an AC_SUBST (make sure you prefix these dependencies with
1942     $(top_srcdir) since this variable will appear at different
1943     levels of the build tree).
1944
1945   - aclocal will now use `m4_include' instead of copying local m4
1946     files into aclocal.m4.  (Local m4 files are those you ship with
1947     your project, other files will be copied as usual.)
1948
1949     Because m4_included files are automatically distributed, it means
1950     for most projects there is no point in EXTRA_DISTing the list of
1951     m4 files which are used.  (You can probably get rid of
1952     m4/Makefile.am if you had one.)
1953
1954   - aclocal will avoid touching aclocal.m4 when possible, so that
1955     Autom4te's cache isn't needlessly invalidated.  This behavior can
1956     be switched off with the new `--force' option.
1957
1958   - aclocal now uses Autoconf's --trace to detect macros which are
1959     actually used and will no longer include unused macros simply
1960     because they where mentioned.  This was often the case for macros
1961     called conditionally.
1962
1963   - New options no-dist and no-dist-gzip.
1964
1965   - compile, depcomp, elisp-comp, install-sh, mdate-sh, mkinstalldirs,
1966     py-compile, and ylwrap, now all understand --version and --help.
1967
1968   - Automake will now recognize AC_CONFIG_LINKS so far as removing created
1969     links as part of the distclean target and including source files in
1970     distributions.
1971
1972   - AM_PATH_PYTHON now supports ACTION-IF-FOUND and ACTION-IF-NOT-FOUND
1973     argument.  The latter can be used to override the default behavior
1974     (which is to abort).
1975
1976   - Automake will exit with $? = 63 on version mismatch.  (So does
1977     Autoconf 2.58)  missing knows this, and in this case it will
1978     emulate the tools as if they were absent.  Because older versions
1979     of Automake and Autoconf did not use this exit code, this change
1980     will only be useful in projects generated with future versions of
1981     these tools.
1982
1983   - When using AC_CONFIG_FILES with multiple input files, Automake
1984     generates the first ".in" input file for which a ".am" exists.
1985     (Former versions would try to use only the first input file.)
1986
1987   - lisp_DATA is now allowed.  If you are using the empty ELCFILES
1988     idiom to disable byte-compilation of lisp_LISP files, it is
1989     recommended that you switch to using lisp_DATA.  Note that
1990     this is not strictly equivalent: lisp_DATA will install elisp
1991     files even if emacs is not installed, while *_LISP do not
1992     install anything unless emacs is found.
1993
1994   - Makefiles will prefer `mkdir -p' over mkinstalldirs if it is
1995     available.  This selection is achieved through the Makefile
1996     variable $(mkdir_p) that is set by AM_INIT_AUTOMAKE to either
1997     `mkdir -m 0755 -p --', `$(mkinstalldirs) -m 0755', or
1998     `$(install_sh) -m 0755 -d'.
1999
2000 * Obsolete features
2001
2002   - Because `mkdir -p' is available on most platforms, and we can use
2003     `install-sh -d' when it is not, the use of the mkinstalldirs
2004     script is being phased out.  `automake --add-missing' no longer
2005     installs it, and if you remove mkinstalldirs from your package,
2006     automake will define $(mkinstalldirs) as an alias for $(mkdir_p).
2007
2008     Gettext 0.12.1 still requires mkinstalldirs.  Fortunately
2009     gettextize and autopoint will install it when needed.  Automake
2010     will continue to define the $(mkinstalldirs) and to distribute
2011     mkinstalldirs when this script is in the source tree.
2012
2013   - AM_PROG_CC_STDC is now empty.  The content of this macro was
2014     merged in AC_PROG_CC.  If your code uses $am_cv_prog_cc_stdc, you
2015     should adjust it to use $ac_cv_prog_cc_stdc instead.  (This
2016     renaming should be safe, even if you have to support several,
2017     versions of Automake, because AC_PROG_CC defines this variable
2018     since Autoconf 2.54.)
2019
2020   - Some users where using the undocumented ACLOCAL_M4_SOURCES
2021     variable to override the aclocal.m4 dependencies computed
2022     (inaccurately) by older versions of Automake.  Because Automake
2023     now tracks configure's m4 dependencies accurately (see m4_include
2024     above), the use of ACLOCAL_M4_SOURCES should be considered
2025     obsolete and will be flagged as such when running `automake
2026     -Wobsolete'.
2027
2028 * Bug fixes
2029
2030   - Defining programs conditionally using Automake conditionals no
2031     longer leads to a combinatorial explosion.  The following
2032     construct used to be troublesome when used with dozens of
2033     conditions.
2034
2035       bin_PROGRAMS = a
2036       if COND1
2037         bin_PROGRAMS += a1
2038       endif
2039       if COND2
2040         bin_PROGRAMS += a2
2041       endif
2042       if COND3
2043         bin_PROGRAMS += a3
2044       endif
2045       ...
2046
2047     Likewise for _SOURCES, _LDADD, and _LIBADD variables.
2048
2049   - Due to implementation constraints, previous versions of Automake
2050     proscribed multiple conditional definitions of some variables
2051     like bin_PROGRAMS:
2052
2053       if COND1
2054         bin_PROGRAMS = a1
2055       endif
2056       if COND2
2057         bin_PROGRAMS = a2
2058       endif
2059
2060     All _PROGRAMS, _LDADD, and _LIBADD variables were affected.
2061     This restriction has been lifted, and these variables now
2062     support multiple conditional definitions as do other variables.
2063
2064   - Cleanup the definitions of $(distdir) and $(top_distdir).
2065     $(top_distdir) now points to the root of the distribution
2066     directory created during `make dist', as it did in Automake 1.4,
2067     not to the root of the build tree as it did in intervening
2068     versions.  Furthermore these two variables are now only defined in
2069     the top level Makefile, and passed to sub-directories when running
2070     `make dist'.
2071
2072   - The --no-force option now correctly checks the Makefile.in's
2073     dependencies before deciding not to update it.
2074
2075   - Do not assume that make files are called Makefile in cleaning rules.
2076
2077   - Update .info files in the source tree, not in the build tree.  This
2078     is what the GNU Coding Standard recommend.  Only Automake 1.7.x
2079     used to update these files in the build tree (previous versions did
2080     it in the source tree too), and it caused several problems, varying
2081     from mere annoyance to portability issues.
2082
2083   - COPYING, COPYING.LIB, and COPYING.LESSER are no longer overwritten
2084     when --add-missing and --force-missing are used.  For backward
2085     compatibility --add-missing will continue to install COPYING (in
2086     `gnu' strictness) when none of these three files exist, but this
2087     use is deprecated: you should better choose a license yourself and
2088     install it once for all in your source tree (and in your code
2089     management system).
2090
2091   - Fix ylwrap so that it does not overwrite header files that haven't
2092     changed, as the inline rule already does.
2093
2094   - User-defined rules override automake-defined rules for the same
2095     targets, even when rules do not have commands.  This is not new
2096     (and was documented), however some of the automake-generated
2097     rules have escaped this principle in former Automake versions.
2098     Rules for the following targets are affected by this fix:
2099
2100        clean, clean-am, dist-all, distclean, distclean-am, dvi, dvi-am,
2101        info, info-am, install-data-am, install-exec-am, install-info,
2102        install-info-am, install-man, installcheck-am, maintainer-clean,
2103        maintainer-clean-am, mostlyclean, mostlyclean-am, pdf, pdf-am,
2104        ps, ps-am, uninstall-am, uninstall-info, uninstall-man
2105
2106     Practically it means that an attempt to supplement the dependencies
2107     of some target, as in
2108
2109        clean: my-clean-rule
2110
2111     will now *silently override* the automake definition of the
2112     rule for this target.  Running `automake -Woverride' will diagnose
2113     all such overriding definitions.
2114
2115     It should be noted that almost all of these targets support a *-local
2116     variant that is meant to supplement the automake-defined rule
2117     (See node `Extending' in the manual).  The above rule should
2118     be rewritten as
2119
2120       clean-local: my-clean-rule
2121
2122     These *-local targets have been documented since at least
2123     Automake 1.2, so you should not fear the change if you have
2124     to support multiple automake versions.
2125
2126 * Miscellaneous
2127
2128   - The Automake manual is now distributed under the terms of the GNU FDL.
2129
2130   - Targets dist-gzip, dist-bzip2, dist-tarZ, dist-zip are always defined.
2131
2132   - core dumps are no longer removed by the cleaning rules.  There are
2133     at least three reasons for this:
2134       1. These files should not be created by any build step,
2135          so their removal do not fit any of the cleaning rules.
2136          Actually, they may be precious to the developer.
2137       2. If such file is created during a build, then it's clearly a
2138          bug Automake should not hide.  Not removing the file will
2139          cause `make distcheck' to complain about its presence.
2140       3. Operating systems have different naming conventions for
2141          core dump files.  A core file on one system might be a
2142          completely legitimate data file on another system.
2143
2144   - RUNTESTFLAGS, CTAGSFLAGS, ETAGSFLAGS, JAVACFLAGS are no longer
2145     defined by Automake.  This means that any definition in the
2146     environment will be used, unless overridden in the Makefile.am or
2147     on the command line.  The old behavior, where these variables were
2148     defined empty in each Makefile, can be obtained by AC_SUBSTing or
2149     AC_ARG_VARing each variable from configure.ac.
2150
2151   - CONFIGURE_DEPENDENCIES and CONFIG_STATUS_DEPENDENCIES are now
2152     documented.  (The is not a new feature, these variables have
2153     been there since at least Automake 1.4.)
2154
2155 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2156
2157 Bugs fixed in 1.7.9:
2158 * Fix install-strip to work with nobase_ binaries.
2159 * Fix renaming of #line directives in ylwrap.
2160 * Rebuild with Autoconf 2.59.  (1.7.8 was not installable with pdksh.)
2161
2162 Bugs fixed in 1.7.8:
2163 * Remove spurious blank lines in cleaning rules introduced in 1.7.7.
2164 * Fix detection of Debian's install-info, broken since version 1.5.
2165   (Debian bug #213524).
2166 * Honor -module if it appears in AM_LDFLAGS (i.e., relax name checking)
2167   This was only done for libfoo_LDFLAGS and LDFLAGS in previous versions.
2168
2169 Bugs fixed in 1.7.7:
2170 * The implementation of automake's --no-force option is unreliable,
2171   so this option is ignored in this version.  A real fix will appear in
2172   Automake 1.8.  (Debian Bug #206299)
2173 * AM_PATH_PYTHON: really check the whole list of interpreters if no
2174   argument is given.  (PR/399)
2175 * Do not warn about leading `_' in variable names, even with -Wportability.
2176 * Support user redefinitions of TEXINFO_TEX.
2177 * depcomp: support AIX Compiler version 6.
2178 * Fix missing rebuilds during `make dist' with BSD make.
2179   (Could produce tarballs containing out-of-date files.)
2180 * Resurrect multilib support.
2181 * Noteworthy manual updates:
2182   - Extending aclocal: how to write m4 macros that won't trigger warnings
2183     with Automake 1.8.
2184   - A Shared Library: Rewrite and split into subsections.
2185
2186 Bugs fixed in 1.7.6:
2187 * Fix depcomp's icc mode for ICC 7.1.
2188 * Diagnose calls to AC_CONFIG_FILES and friends with not enough arguments.
2189 * Fix maintainer-clean's removal of autom4te.cache in VPATH builds.
2190 * Fix AM_PATH_LISPDIR to work with POSIXLY_CORRECT=1.
2191 * Fix the location reported in some diagnostics related to AUTOMAKE_OPTIONS.
2192 * Remove Latin-1 characters from elisp-comp.
2193 * Update the manual's @dircategory to match the Free Software Directory.
2194
2195 Bugs fixed in 1.7.5:
2196 * Update install-sh's license to remove an advertising clause.
2197   (Debian bug #191717)
2198 * Fix a bug introduced in 1.7.4, related to BUILT_SOURCE handling,
2199   that caused invalid Makefile.ins to be generated.
2200 * Make sure AM_MAKE_INCLUDE doesn't fail when a `doit' file exists.
2201 * New FAQ entry: renamed objects.
2202
2203 Bugs fixed in 1.7.4:
2204 * Tweak the TAGS rule to support Exuberant Ctags (in addition to
2205   the Emacs implementation)
2206 * Fix output of aclocal.m4 dependencies in subdirectories.
2207 * Use `mv -f' instead of `mv' in fastdep rules.
2208 * Upgrade mdate-sh to work on OS/2.
2209 * Don't byte-compile elisp files when ELCFILES is set empty.
2210   (this documented feature was broken by 1.7.3)
2211 * Diagnose trailing backslashes on last line of Makefile.am.
2212 * Diagnose whitespace following trailing backslashes.
2213 * Multiple tests are now correctly supported in DEJATOOL. (PR/388)
2214 * Fix rebuilt rules for AC_CONFIG_FILES([Makefile:Makefile.in:Makefile.bot])
2215   Makefiles. (PR/389)
2216 * `make install' will build `BUILT_SOURCES' first.
2217 * Minor documentation fixes.
2218
2219 Bugs fixed in 1.7.3:
2220 * Fix stamp files numbering (when using multiple AC_CONFIG_HEADERS).
2221 * Query distutils for `pythondir' and `pythonexecdir', instead of
2222   using an hardcoded path.  This should allow builds on 64-bit
2223   distributions that usually use lib64/ instead of lib/.
2224 * AM_PATH_PYTHON will also search for python2.3.
2225 * elisp files are now built all at once instead of one by one. Besides
2226   incurring a speed-up, this is required to support interdependent elisp files.
2227 * Support for DJGPP:
2228   - `make distcheck' will now work in `_inst/' and `_build' instead
2229     of `=inst/' and `=build/'
2230   - use `_dirstamp' when the file-system doesn't support `.dirstamp'
2231   - install/uninstall `*.i[0-9][0-9]'-style info files
2232   - more changes that affect only the Automake package (not its output)
2233 * Fix some incompatibilities with upcoming perl-5.10.
2234 * Properly quote AC_PACKAGE_TARNAME and AC_PACKAGE_VERSION when defining
2235   PACKAGE and VERSION.
2236 * depcomp fixes:
2237   - dashmstdout and dashXmstdout modes: don't use `-o /dev/null', this
2238     is troublesome with gcc and Solaris compilers. (PR/385)
2239   - makedepend mode: work with Libtool. (PR/385 too)
2240   - support for ICC.
2241 * better support for unusual gettext setups, such as multiple po/ directories
2242   (PR/381):
2243   - Flag missing po/ and intl/ directories as warnings, not errors.
2244   - Disable these warnings if po/ does not exist.
2245 * Noteworthy manual updates:
2246   - New FAQ chapter.
2247   - Document how AC_CONFIG_AUX_DIR interacts with missing files.
2248     (Debian Bug #39542)
2249   - Document `AM_YFLAGS = -d'.  (PR/382)
2250
2251 Bugs fixed in 1.7.2:
2252 * Fix installation and uninstallation of Info files built in subdirectories.
2253 * Do not run `./configure --with-included-gettext' during `make distcheck'
2254   if AM_GNU_GETTEXT([external]) is used.
2255 * Correctly uninstall renamed man pages.
2256 * Do not strip escaped newline in variables defined in one condition
2257   and augmented in another condition.
2258 * Fix ansi2knr rules for LIBOBJS sources.
2259 * Clean all known Texinfo index files, not only those which appear to
2260   be used, because we cannot know which indexes are used in included files.
2261   (PR/375, Debian Bug #168671)
2262 * Honor only the first @setfilename seen in a Texinfo file.
2263 * Treat "required file X not found" diagnostics as errors (exit status 1).
2264 * Don't complain that a required file is not found when it is a Makefile
2265   target. (PR/357)
2266 * Don't use single suffix inference rules when building `.info'-less
2267   Info files, for the sake of Solaris make.
2268 * The `check' target now depends on `$(BUILT_SOURCES)'. (PR/359)
2269 * Recognize multiple inference rules such as `.a.b .c.d:'. (PR/371)
2270 * Warn about multiple inference rules when -Wportability is used. (PR/372)
2271 * Fix building of deansified files from subdirectories. (PR/370)
2272 * Add missing `fi' in the .c->.obj rules.
2273 * Improve install-sh to work even when names contain spaces or certain
2274   (but not all) shell metachars.
2275 * Fix the following spurious failures in the test suite:
2276   depcomp2.test, gnits2.test, gnits3.test, python3.test, texinfo13.test
2277 * Noteworthy manual updates:
2278   - Augment the section about BUILT_SOURCES.
2279   - Mention that AM_PROG_CC_STDC is a relic that is better avoided today.
2280
2281 Bugs fixed in 1.7.1:
2282 * Honor `ansi2knr' for files built in subdirectories, or using per-targets
2283   flags.
2284 * Aclocal should now recognize macro names containing parentheses, e.g.
2285   AC_DEFUN([AC_LANG_PREPROC(Fortran 90)], [...]).
2286 * Erase *.sum and *.log files created by DejaGnu, during `make distclean'.
2287   (Debian Bug#153697)
2288 * Install Python files even if they were built.  (PR/369)
2289 * Have stamp-vti dependent upon configure instead of configure.ac, as the
2290   version might not be defined in the latter. (PR/358)
2291 * Reorder arguments passed to a couple of commands, so things works
2292   when POSIXLY_CORRECT=1.
2293 * Fix a regex that can cause Perl to segfault on large input.
2294   (Debian Bug#162583)
2295 * Fix distribution of packages that have some sources defined conditionally,
2296   as in the `Conditional compilation using Automake conditionals' example
2297   of the manual.
2298 * Fix spurious test suite failures on IRIX.
2299 * Don't report a required variable as undefined if it has been
2300   defined conditionally for the "right" conditions.
2301 * Fix cleaning of the /tmp subdirectory used by `make distcheck', in case
2302   `make distcheck' fails.
2303 * Fix distribution of included Makefile fragment, so we don't create
2304   spurious directories in the distribution. (PR/366)
2305 * Don't complain that a target lacks `.$(EXEEXT)' when it has it.
2306
2307 New in 1.7:
2308 * Autoconf 2.54 is required.
2309 * `aclocal' and `automake' will no longer warn about obsolete
2310   configure macros.  This is done by `autoconf -Wobsolete'.
2311 * AM_CONFIG_HEADER, AM_SYS_POSIX_TERMIOS and
2312   AM_HEADER_TIOCGWINSZ_NEEDS_SYS_IOCTL are obsolete (although still
2313   supported).  You should use AC_CONFIG_HEADERS, AC_SYS_POSIX_TERMIOS,
2314   and AC_HEADER_TIOCGWINSZ instead.  `autoupdate' can upgrade
2315   `configure.ac' for you.
2316 * Support for per-program and per-library `_CPPFLAGS'.
2317 * New `ctags' target (builds CTAGS files).
2318 * Support for -Wmumble and -Wno-mumble, where mumble is a warning category
2319   (see `automake --help' or the manual for a list of them).
2320 * Honor the WARNINGS environment variable.
2321 * Omit the call to depcomp when using gcc3: call the compiler directly.
2322 * A new option, std-options, tests that programs support --help and --version
2323   when `make installcheck' is run.  This is enabled by --gnits.
2324 * Texinfo rules now support the `ps' and `pdf' targets.
2325 * Info files are now created in the build directory, not the source directory.
2326 * info_TEXINFOS supports files in subdirectories (this requires Texinfo 4.1
2327   or greater).
2328 * `make distcheck' will enforce DESTDIR support by attempting
2329   a DESTDIR install.
2330 * `+=' can be used in conditionals, even if the augmented variable
2331   was defined for another condition.
2332 * Makefile fragments (inserted with `include') are always distributed.
2333 * Use Autoconf's --trace interface to inspect configure.ac and get
2334   a more accurate view of it.
2335 * Add support for extending aclocal's default macro search path
2336   using a `dirlist' file within the aclocal directory.
2337 * automake --output-dir is deprecated.
2338 * The part of the distcheck target that checks whether uninstall actually
2339   removes all installed files has been moved in a separate target,
2340   distuninstallcheck, so it can be overridden easily.
2341 * Many bug fixes.
2342
2343 New in 1.6.3:
2344 * Support for AM_INIT_GETTEXT([external])
2345 * Bug fixes, including:
2346   - Fix Automake's own `make install' so it works even if `ln' doesn't.
2347   - nobase_ programs and scripts honor --program-transform correctly.
2348   - Erase configure.lineno during `make distclean'.
2349   - Erase YACC and LEX outputs during `make maintainer-clean'.
2350
2351 New in 1.6.2:
2352 * Many bug fixes, including:
2353   - Requiring the current version works.
2354   - Fix "$@" portability issues (for Zsh).
2355   - Fix output of dummy dependency files in presence of post-processed
2356     Makefile.in's.
2357   - Don't compute dependencies in background to avoid races with libtool.
2358   - Fix handling of _OBJECTS variables for targets sharing source variables.
2359   - Check dependency mode for Java when AM_PROG_GCJ is used.
2360
2361 New in 1.6.1:
2362 * automake --output-dir is deprecated
2363 * Many bug fixes, including:
2364   - Don't choke on AM_LDFLAGS definitions.
2365   - Clean libtool objects from subdirectories.
2366   - Allow configure variables with reserved suffix and unknown prefix
2367     (e.g. AC_SUBST(mumble_LDFLAGS) when 'mumble' is not a target).
2368   - Fix the definition of AUTOMAKE and ACLOCAL in configure.
2369
2370 New in 1.6:
2371 * Autoconf 2.52 is required.
2372 * automake no longer run libtoolize.
2373   This is the job of autoreconf (from GNU Autoconf).
2374 * `dist' generates all the archive flavors, as did `dist-all'.
2375 * `dist-gzip' generates the Gzip tar file only.
2376 * Combining Automake Makefile conditionals no longer lead to a combinatorial
2377   explosion.  Makefile.in's keep a reasonable size.
2378 * AM_FUNC_ERROR_AT_LINE, AM_FUNC_STRTOD, AM_FUNC_OBSTACK, AM_PTRDIFF_T
2379   are no longer shipped, since Autoconf 2.52 provides them (both as AM_
2380   and AC_).
2381 * `#line' of Lex and Yacc files are properly set.
2382 * EXTRA_DIST can contain generated directories.
2383 * Support for dot-less extensions in suffix rules.
2384 * The part of the distcheck target that checks whether distclean actually
2385   cleans all built files has been moved in a separate target, distcleancheck,
2386   so it can be overridden easily.
2387 * `make distcheck' will pass additional options defined in
2388   $(DISTCHECK_CONFIGURE_FLAGS) to configure.
2389 * Fixed CDPATH portability problems, in particular for MacOS X.
2390 * Fixed handling of nobase_ targets.
2391 * Fixed support of implicit rules leading to .lo objects.
2392 * Fixed late inclusion of --add-missing files (e.g. depcomp) in DIST_COMMON
2393 * Added uninstall-hook target
2394 * `AC_INIT AM_INIT_AUTOMAKE(tarname,version)' is an obsolete construct.
2395   You can now use `AC_INIT(pkgname,version) AM_INIT_AUTOMAKE' instead.
2396   (Note that "pkgname" is not "tarname", see the manual for details.)
2397   It is also possible to pass a list of global Automake options as
2398   first argument to this new form of AM_INIT_AUTOMAKE.
2399 * Compiler-based assembler is now called `CCAS'; people expected `AS'
2400   to be a real assembler.
2401 * AM_INIT_AUTOMAKE will set STRIP itself when it needs it.  Adding
2402   AC_CHECK_TOOL([STRIP], [strip]) manually is no longer required.
2403 * aclocal and automake are also installed with the version number
2404   appended, and some of the install directory names have changed.
2405   This lets you have multiple versions installed simultaneously.
2406 * Support for parsers and lexers in subdirectories.
2407
2408 New in 1.5:
2409 * Support for `configure.ac'.
2410 * Support for `else COND', `endif COND' and negated conditions `!COND'.
2411 * `make dist-all' is much faster.
2412 * Allows '@' AC_SUBSTs in macro names.
2413 * Faster AM_INIT_AUTOMAKE (requires update of `missing' script)
2414 * User-side dependency tracking.  Developers no longer need GNU make
2415 * Python support
2416 * Uses DIST_SUBDIRS in some situations when SUBDIRS is conditional
2417 * Most files are correctly handled if they appear in subdirs
2418   For instance, a _DATA file can appear in a subdir
2419 * GNU tar is no longer required for `make dist'
2420 * Added support for `dist_' and `nodist_' prefixes
2421 * Added support for `nobase_' prefix
2422 * Compiled Java support
2423 * Support for per-executable and per-library compilation flags
2424 * Many bug fixes
2425
2426 New in 1.4:
2427 * Added support for the Fortran 77 programming language.
2428 * Re-indexed the Automake Texinfo manual.
2429 * Added `AM_FOOFLAGS' variable for each compiler invocation;
2430   e.g. AM_CFLAGS can be used in Makefile.am to set C compiler flags
2431 * Support for latest autoconf, including support for objext
2432 * Can now put `.' in SUBDIRS to control build order
2433 * `include' command and `+=' support for macro assignment
2434 * Dependency tracking no long susceptible to deleted header file problem
2435 * Maintainer mode now a conditional.  @MAINT@ is now an anachronism.
2436 * Bug fixes
2437
2438 New in 1.3:
2439 * Bug fixes
2440 * Better Cygwin32 support
2441 * Support for suffix rules with _SOURCES variables
2442 * New options `readme-alpha' and `check-news'; Gnits mode sets these
2443 * @LEXLIB@ no longer required when lex source seen
2444   Lex support in `missing', and new lex macro.  Update your missing script.
2445 * Built-in support for assembly
2446 * aclocal gives error if `AM_' macro not found
2447 * Passed YFLAGS, not YACCFLAGS, to yacc
2448 * AM_PROG_CC_STDC does not have to come before AC_PROG_CPP
2449 * Dependencies computed as a side effect of compilation
2450 * Preliminary support for Java
2451 * DESTDIR support at "make install" time
2452 * Improved ansi2knr support; you must use the latest ansi2knr.c (included)
2453
2454 New in 1.2:
2455 * Bug fixes
2456 * Better DejaGnu support
2457 * Added no-installinfo option
2458 * Added Emacs Lisp support
2459 * Added --no-force option
2460 * Included `aclocal' program
2461 * Automake will now generate rules to regenerate aclocal.m4, if appropriate
2462 * Now uses `AM_' macro names everywhere
2463 * ansi2knr option can have directory prefix (eg `../lib/ansi2knr')
2464   ansi2knr now works correctly on K&R sources
2465 * Better C++, yacc, lex support
2466 * Will compute _DEPENDENCIES variables automatically if not supplied
2467 * Will interpolate $(...) and ${...} when examining contents of a variable
2468 * .deps files now in build directory, not source directory; dependency
2469   handling generally rewritten
2470 * DATA, MANS and BUILT_SOURCES no longer included in distribution
2471 * can now put config.h into a subdir
2472 * Added dist-all target
2473 * Support for install-info program (see texinfo 3.9)
2474 * Support for "yacc -d"
2475 * configure substitutions are automatically discovered and included
2476   in generated Makefile.in
2477 * Special --cygnus mode
2478 * OMIT_DEPENDENCIES can now hold list of dependencies to be omitted
2479   when making distribution.  Some dependencies are auto-ignored.
2480 * Changed how libraries are specified in _LIBRARIES variable
2481 * Full libtool support, from Gord Matzigkeit
2482 * No longer have to explicitly touch stamp-h when using AC_CONFIG_HEADER;
2483   AM_CONFIG_HEADER handles it automatically
2484 * Texinfo output files no longer need .info extension
2485 * Added `missing' support
2486 * Cygwin32 support
2487 * Conditionals in Makefile.am, from Ian Taylor
2488
2489 New in 1.0:
2490 * Bug fixes
2491 * distcheck target runs install and installcheck targets
2492 * Added preliminary support for DejaGnu.
2493
2494 New in 0.33:
2495 * More bug fixes
2496 * More checking
2497 * More libtool fixes from Gord Matzigkeit; libtool support is still
2498   preliminary however
2499 * Added support for jm_MAINTAINER_MODE
2500 * dist-zip support
2501 * New "distcheck" target
2502
2503 New in 0.32:
2504 * Many bug fixes
2505 * mkinstalldirs and mdate-sh now appear in directory specified by
2506   AC_CONFIG_AUX_DIR.
2507 * Removed DIST_SUBDIRS, DIST_OTHER
2508 * AC_ARG_PROGRAM only required when an actual program exists
2509 * dist-hook target now run before distribution packaged up; idea from
2510   Dieter Baron.  Other hooks exist, too.
2511 * Preliminary (unfinished) support for libtool
2512 * Added short option names.
2513 * Better "dist" support when gluing together multiple packages
2514
2515 New in 0.31:
2516 * Bug fixes
2517 * Documentation updates (many from François Pinard)
2518 * strictness `normal' now renamed to `foreign'
2519 * Renamed --install-missing to --add-missing
2520 * Now handles AC_CONFIG_AUX_DIR
2521 * Now handles TESTS macro
2522 * DIST_OTHER renamed to EXTRA_DIST
2523 * DIST_SUBDIRS is deprecated
2524 * @ALLOCA@ and @LIBOBJS@ now work in _LDADD variables
2525 * Better error messages in many cases
2526 * Program names are canonicalized
2527 * Added "check" prefix; from Gord Matzigkeit
2528
2529 New in 0.30:
2530 * Bug fixes
2531 * configure.in scanner knows about AC_PATH_XTRA, AC_OUTPUT ":" syntax
2532 * Beginnings of a test suite
2533 * Automatically adds -I options for $(srcdir), ".", and path to config.h
2534 * Doesn't print anything when running
2535 * Beginnings of MAINT_CHARSET support
2536 * Can specify version in AUTOMAKE_OPTIONS
2537 * Most errors recognizable by Emacs' M-x next-error
2538 * Added --verbose option
2539 * All "primary" variables now obsolete; use EXTRA_PRIMARY to supply
2540   configure-generated names
2541 * Required macros now distributed in aclocal.m4
2542 * New documentation
2543 * --strictness=gnu is default
2544
2545 New in 0.29:
2546 * Many bug fixes
2547 * More sophisticated configure.in scanning; now understands ALLOCA and
2548   LIBOBJS directly, handles AC_CONFIG_HEADER more precisely, etc.
2549 * TEXINFOS and MANS now obsolete; use info_TEXINFOS and man_MANS instead.
2550 * CONFIG_HEADER variable now obsolete
2551 * Can handle multiple Texinfo sources
2552 * Allow hierarchies deeper than 2.  From Gord Matzigkeit.
2553 * HEADERS variable no longer needed; now can put .h files directly into
2554   foo_SOURCES variable.
2555 * Automake automatically rebuilds files listed in AC_OUTPUT.  The
2556   corresponding ".in" files are included in the distribution.
2557
2558 New in 0.28:
2559 * Added --gnu and --gnits options
2560 * More standards checking
2561 * Bug fixes
2562 * Cleaned up 'dist' targets
2563 * Added AUTOMAKE_OPTIONS variable and several options
2564 * Now scans configure.in to get some information (preliminary)
2565
2566 New in 0.27:
2567 * Works with Perl 4 again
2568
2569 New in 0.26:
2570 * Added --install-missing option.
2571 * Pretty-prints generated macros and rules
2572 * Comments in Makefile.am are placed more intelligently in Makefile.in
2573 * Generates .PHONY target
2574 * Rule or macro in Makefile.am now overrides contents of Automake file
2575 * Substantial cleanups from François Pinard
2576
2577 New in 0.25:
2578 * Bug fixes.
2579 * Works with Perl 4 again.
2580
2581 New in 0.24:
2582 * New uniform naming scheme.
2583 * --strictness option
2584 * Works with Perl 5
2585 * '.c' files corresponding to '.y' or '.l' files are automatically
2586   distributed.
2587 * Many bug fixes and cleanups
2588
2589 New in 0.23:
2590 * Allow objects to be conditionally included in libraries via lib_LIBADD.
2591
2592 New in 0.22:
2593 * Bug fixes in 'clean' code.
2594 * Now generates 'installdirs' target.
2595 * man page installation reworked.
2596 * 'make dist' no longer re-creates all Makefile.in's.
2597
2598 New in 0.21:
2599 * Reimplemented in Perl
2600 * Added --amdir option (for debugging)
2601 * Texinfo support cleaned up.
2602 * Automatic de-ANSI-fication cleaned up.
2603 * Cleaned up 'clean' targets.
2604
2605 New in 0.20:
2606 * Automatic dependency tracking
2607 * More documentation
2608 * New variables DATA and PACKAGEDATA
2609 * SCRIPTS installed using $(INSTALL_SCRIPT)
2610 * No longer uses double-colon rules
2611 * Bug fixes
2612 * Changes in advance of internationalization
2613
2614 -----
2615
2616 Copyright (C) 1995-2013 Free Software Foundation, Inc.
2617
2618 This program is free software; you can redistribute it and/or modify
2619 it under the terms of the GNU General Public License as published by
2620 the Free Software Foundation; either version 2, or (at your option)
2621 any later version.
2622
2623 This program is distributed in the hope that it will be useful,
2624 but WITHOUT ANY WARRANTY; without even the implied warranty of
2625 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
2626 GNU General Public License for more details.
2627
2628 You should have received a copy of the GNU General Public License
2629 along with this program.  If not, see <http://www.gnu.org/licenses/>.