manual: another grammar improvement.
[autoconf.git] / doc / autoconf.texi
blob15798a4907cf51914807fa86f35f78eecd0af969
1 \input texinfo @c -*-texinfo-*-
2 @comment ========================================================
3 @comment %**start of header
4 @setfilename autoconf.info
5 @include version.texi
6 @settitle Autoconf
7 @setchapternewpage odd
8 @ifnothtml
9 @setcontentsaftertitlepage
10 @end ifnothtml
11 @finalout
13 @c @ovar(ARG)
14 @c ----------
15 @c The ARG is an optional argument.  To be used for macro arguments in
16 @c their documentation (@defmac).
17 @macro ovar{varname}
18 @r{[}@var{\varname\}@r{]}@c
19 @end macro
21 @c @dvar(ARG, DEFAULT)
22 @c -------------------
23 @c The ARG is an optional argument, defaulting to DEFAULT.  To be used
24 @c for macro arguments in their documentation (@defmac).
25 @macro dvar{varname, default}
26 @r{[}@var{\varname\} = @samp{\default\}@r{]}@c
27 @end macro
29 @c Handling the indexes with Texinfo yields several different problems.
31 @c Because we want to drop out the AC_ part of the macro names in the
32 @c printed manual, but not in the other outputs, we need a layer above
33 @c the usual @acindex{} etc.  That's why we first define indexes such as
34 @c acx meant to become the macro @acindex.  First of all, using ``ac_''
35 @c does not work with makeinfo, and using ``ac1'' doesn't work with TeX.
36 @c So use something more regular ``acx''.  Then you finish with a printed
37 @c index saying ``index is not existent''.  Of course: you ought to use
38 @c two letters :(  So you use capitals.
40 @c Second, when defining a macro in the TeX world, following spaces are
41 @c eaten.  But then, since we embed @acxindex commands that use the end
42 @c of line as an end marker, the whole things wrecks itself.  So make
43 @c sure you do *force* an additional end of line, add a ``@c''.
45 @c Finally, you might want to get rid of TeX expansion, using --expand
46 @c with texi2dvi.  But then you wake up an old problem: we use macros
47 @c in @defmac etc. where TeX does perform the expansion, but not makeinfo.
49 @c Define an environment variable index.
50 @defcodeindex ev
51 @c Define an output variable index.
52 @defcodeindex ov
53 @c Define a CPP variable index.
54 @defcodeindex cv
55 @c Define an Autoconf macro index that @defmac doesn't write to.
56 @defcodeindex AC
57 @c Define an Autotest macro index that @defmac doesn't write to.
58 @defcodeindex AT
59 @c Define an M4sugar macro index that @defmac doesn't write to.
60 @defcodeindex MS
61 @c Define an index for *foreign* programs: `mv' etc.  Used for the
62 @c portability sections and so on.
63 @defindex pr
65 @c shortindexflag
66 @c --------------
67 @c Shall we factor AC_ out of the Autoconf macro index etc.?
68 @iftex
69 @set shortindexflag
70 @end iftex
72 @c @acindex{MACRO}
73 @c ---------------
74 @c Registering an AC_\MACRO\.
75 @ifset shortindexflag
76 @macro acindex{macro}
77 @ACindex \macro\
79 @end macro
80 @end ifset
81 @ifclear shortindexflag
82 @macro acindex{macro}
83 @ACindex AC_\macro\
84 @end macro
85 @end ifclear
87 @c @ahindex{MACRO}
88 @c ---------------
89 @c Registering an AH_\MACRO\.
90 @macro ahindex{macro}
91 @ACindex AH_\macro\
93 @end macro
95 @c @asindex{MACRO}
96 @c ---------------
97 @c Registering an AS_\MACRO\.
98 @ifset shortindexflag
99 @macro asindex{macro}
100 @MSindex \macro\
102 @end macro
103 @end ifset
104 @ifclear shortindexflag
105 @macro asindex{macro}
106 @MSindex AS_\macro\
107 @end macro
108 @end ifclear
110 @c @atindex{MACRO}
111 @c ---------------
112 @c Registering an AT_\MACRO\.
113 @ifset shortindexflag
114 @macro atindex{macro}
115 @ATindex \macro\
117 @end macro
118 @end ifset
119 @ifclear shortindexflag
120 @macro atindex{macro}
121 @ATindex AT_\macro\
122 @end macro
123 @end ifclear
125 @c @auindex{MACRO}
126 @c ---------------
127 @c Registering an AU_\MACRO\.
128 @macro auindex{macro}
129 @ACindex AU_\macro\
131 @end macro
133 @c @hdrindex{MACRO}
134 @c ----------------
135 @c Indexing a header.
136 @macro hdrindex{macro}
137 @prindex @file{\macro\}
139 @end macro
141 @c @msindex{MACRO}
142 @c ---------------
143 @c Registering an m4_\MACRO\.
144 @ifset shortindexflag
145 @macro msindex{macro}
146 @MSindex \macro\
148 @end macro
149 @end ifset
150 @ifclear shortindexflag
151 @macro msindex{macro}
152 @MSindex m4_\macro\
153 @end macro
154 @end ifclear
157 @c Define an index for functions: `alloca' etc.  Used for the
158 @c portability sections and so on.  We can't use `fn' (aka `fnindex),
159 @c since `@defmac' goes into it => we'd get all the macros too.
161 @c   FIXME: Aaarg!  It seems there are too many indices for TeX :(
163 @c   ! No room for a new @write .
164 @c   l.112 @defcodeindex fu
166 @c   so don't define yet another one :(  Just put some tags before each
167 @c   @prindex which is actually a @funindex.
169 @c   @defcodeindex fu
172 @c   @c Put the programs and functions into their own index.
173 @c   @syncodeindex fu pr
175 @comment %**end of header
176 @comment ========================================================
178 @copying
180 This manual (@value{UPDATED}) is for @acronym{GNU} Autoconf
181 (version @value{VERSION}),
182 a package for creating scripts to configure source code packages using
183 templates and an M4 macro package.
185 Copyright @copyright{} 1992, 1993, 1994, 1995, 1996, 1998, 1999, 2000,
186 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009 Free Software
187 Foundation, Inc.
189 @quotation
190 Permission is granted to copy, distribute and/or modify this document
191 under the terms of the @acronym{GNU} Free Documentation License,
192 Version 1.3 or any later version published by the Free Software
193 Foundation; with no Invariant Sections, with the Front-Cover texts
194 being ``A @acronym{GNU} Manual,'' and with the Back-Cover Texts as in
195 (a) below.  A copy of the license is included in the section entitled
196 ``@acronym{GNU} Free Documentation License.''
198 (a) The FSF's Back-Cover Text is: ``You have the freedom to copy and
199 modify this @acronym{GNU} manual.  Buying copies from the @acronym{FSF}
200 supports it in developing @acronym{GNU} and promoting software
201 freedom.''
202 @end quotation
203 @end copying
207 @dircategory Software development
208 @direntry
209 * Autoconf: (autoconf).         Create source code configuration scripts.
210 @end direntry
212 @dircategory Individual utilities
213 @direntry
214 * autoscan: (autoconf)autoscan Invocation.
215                                 Semi-automatic @file{configure.ac} writing
216 * ifnames: (autoconf)ifnames Invocation.        Listing conditionals in source.
217 * autoconf-invocation: (autoconf)autoconf Invocation.
218                                 How to create configuration scripts
219 * autoreconf: (autoconf)autoreconf Invocation.
220                                 Remaking multiple @command{configure} scripts
221 * autoheader: (autoconf)autoheader Invocation.
222                                 How to create configuration templates
223 * autom4te: (autoconf)autom4te Invocation.
224                                 The Autoconf executables backbone
225 * configure: (autoconf)configure Invocation.    Configuring a package.
226 * autoupdate: (autoconf)autoupdate Invocation.
227                                 Automatic update of @file{configure.ac}
228 * config.status: (autoconf)config.status Invocation. Recreating configurations.
229 * testsuite: (autoconf)testsuite Invocation.    Running an Autotest test suite.
230 @end direntry
232 @titlepage
233 @title Autoconf
234 @subtitle Creating Automatic Configuration Scripts
235 @subtitle for version @value{VERSION}, @value{UPDATED}
236 @author David MacKenzie
237 @author Ben Elliston
238 @author Akim Demaille
239 @page
240 @vskip 0pt plus 1filll
241 @insertcopying
242 @end titlepage
244 @contents
247 @ifnottex
248 @node Top
249 @top Autoconf
250 @insertcopying
251 @end ifnottex
253 @c The master menu, created with texinfo-master-menu, goes here.
255 @menu
256 * Introduction::                Autoconf's purpose, strengths, and weaknesses
257 * The GNU Build System::        A set of tools for portable software packages
258 * Making configure Scripts::    How to organize and produce Autoconf scripts
259 * Setup::                       Initialization and output
260 * Existing Tests::              Macros that check for particular features
261 * Writing Tests::               How to write new feature checks
262 * Results::                     What to do with results from feature checks
263 * Programming in M4::           Layers on top of which Autoconf is written
264 * Programming in M4sh::         Shell portability layer
265 * Writing Autoconf Macros::     Adding new macros to Autoconf
266 * Portable Shell::              Shell script portability pitfalls
267 * Portable Make::               Makefile portability pitfalls
268 * Portable C and C++::          C and C++ portability pitfalls
269 * Manual Configuration::        Selecting features that can't be guessed
270 * Site Configuration::          Local defaults for @command{configure}
271 * Running configure Scripts::   How to use the Autoconf output
272 * config.status Invocation::    Recreating a configuration
273 * Obsolete Constructs::         Kept for backward compatibility
274 * Using Autotest::              Creating portable test suites
275 * FAQ::                         Frequent Autoconf Questions, with answers
276 * History::                     History of Autoconf
277 * GNU Free Documentation License::  License for copying this manual
278 * Indices::                     Indices of symbols, concepts, etc.
280 @detailmenu
281  --- The Detailed Node Listing ---
283 The @acronym{GNU} Build System
285 * Automake::                    Escaping makefile hell
286 * Gnulib::                      The @acronym{GNU} portability library
287 * Libtool::                     Building libraries portably
288 * Pointers::                    More info on the @acronym{GNU} build system
290 Making @command{configure} Scripts
292 * Writing Autoconf Input::      What to put in an Autoconf input file
293 * autoscan Invocation::         Semi-automatic @file{configure.ac} writing
294 * ifnames Invocation::          Listing the conditionals in source code
295 * autoconf Invocation::         How to create configuration scripts
296 * autoreconf Invocation::       Remaking multiple @command{configure} scripts
298 Writing @file{configure.ac}
300 * Shell Script Compiler::       Autoconf as solution of a problem
301 * Autoconf Language::           Programming in Autoconf
302 * Autoconf Input Layout::       Standard organization of @file{configure.ac}
304 Initialization and Output Files
306 * Initializing configure::      Option processing etc.
307 * Versioning::                  Dealing with Autoconf versions
308 * Notices::                     Copyright, version numbers in @command{configure}
309 * Input::                       Where Autoconf should find files
310 * Output::                      Outputting results from the configuration
311 * Configuration Actions::       Preparing the output based on results
312 * Configuration Files::         Creating output files
313 * Makefile Substitutions::      Using output variables in makefiles
314 * Configuration Headers::       Creating a configuration header file
315 * Configuration Commands::      Running arbitrary instantiation commands
316 * Configuration Links::         Links depending on the configuration
317 * Subdirectories::              Configuring independent packages together
318 * Default Prefix::              Changing the default installation prefix
320 Substitutions in Makefiles
322 * Preset Output Variables::     Output variables that are always set
323 * Installation Directory Variables::  Other preset output variables
324 * Changed Directory Variables:: Warnings about @file{datarootdir}
325 * Build Directories::           Supporting multiple concurrent compiles
326 * Automatic Remaking::          Makefile rules for configuring
328 Configuration Header Files
330 * Header Templates::            Input for the configuration headers
331 * autoheader Invocation::       How to create configuration templates
332 * Autoheader Macros::           How to specify CPP templates
334 Existing Tests
336 * Common Behavior::             Macros' standard schemes
337 * Alternative Programs::        Selecting between alternative programs
338 * Files::                       Checking for the existence of files
339 * Libraries::                   Library archives that might be missing
340 * Library Functions::           C library functions that might be missing
341 * Header Files::                Header files that might be missing
342 * Declarations::                Declarations that may be missing
343 * Structures::                  Structures or members that might be missing
344 * Types::                       Types that might be missing
345 * Compilers and Preprocessors::  Checking for compiling programs
346 * System Services::             Operating system services
347 * Posix Variants::              Special kludges for specific Posix variants
348 * Erlang Libraries::            Checking for the existence of Erlang libraries
350 Common Behavior
352 * Standard Symbols::            Symbols defined by the macros
353 * Default Includes::            Includes used by the generic macros
355 Alternative Programs
357 * Particular Programs::         Special handling to find certain programs
358 * Generic Programs::            How to find other programs
360 Library Functions
362 * Function Portability::        Pitfalls with usual functions
363 * Particular Functions::        Special handling to find certain functions
364 * Generic Functions::           How to find other functions
366 Header Files
368 * Header Portability::          Collected knowledge on common headers
369 * Particular Headers::          Special handling to find certain headers
370 * Generic Headers::             How to find other headers
372 Declarations
374 * Particular Declarations::     Macros to check for certain declarations
375 * Generic Declarations::        How to find other declarations
377 Structures
379 * Particular Structures::       Macros to check for certain structure members
380 * Generic Structures::          How to find other structure members
382 Types
384 * Particular Types::            Special handling to find certain types
385 * Generic Types::               How to find other types
387 Compilers and Preprocessors
389 * Specific Compiler Characteristics::  Some portability issues
390 * Generic Compiler Characteristics::  Language independent tests and features
391 * C Compiler::                  Checking its characteristics
392 * C++ Compiler::                Likewise
393 * Objective C Compiler::        Likewise
394 * Erlang Compiler and Interpreter::  Likewise
395 * Fortran Compiler::            Likewise
397 Writing Tests
399 * Language Choice::             Selecting which language to use for testing
400 * Writing Test Programs::       Forging source files for compilers
401 * Running the Preprocessor::    Detecting preprocessor symbols
402 * Running the Compiler::        Detecting language or header features
403 * Running the Linker::          Detecting library features
404 * Runtime::                     Testing for runtime features
405 * Systemology::                 A zoology of operating systems
406 * Multiple Cases::              Tests for several possible values
408 Writing Test Programs
410 * Guidelines::                  General rules for writing test programs
411 * Test Functions::              Avoiding pitfalls in test programs
412 * Generating Sources::          Source program boilerplate
414 Results of Tests
416 * Defining Symbols::            Defining C preprocessor symbols
417 * Setting Output Variables::    Replacing variables in output files
418 * Special Chars in Variables::  Characters to beware of in variables
419 * Caching Results::             Speeding up subsequent @command{configure} runs
420 * Printing Messages::           Notifying @command{configure} users
422 Caching Results
424 * Cache Variable Names::        Shell variables used in caches
425 * Cache Files::                 Files @command{configure} uses for caching
426 * Cache Checkpointing::         Loading and saving the cache file
428 Programming in M4
430 * M4 Quotation::                Protecting macros from unwanted expansion
431 * Using autom4te::              The Autoconf executables backbone
432 * Programming in M4sugar::      Convenient pure M4 macros
434 Programming in M4sh
436 * Common Shell Constructs::     Portability layer for common shell constructs
437 * Polymorphic Variables::       Support for indirect variable names
438 * Initialization Macros::       Macros to establish a sane shell environment
439 * File Descriptor Macros::      File descriptor macros for input and output
441 M4 Quotation
443 * Active Characters::           Characters that change the behavior of M4
444 * One Macro Call::              Quotation and one macro call
445 * Quoting and Parameters::      M4 vs. shell parameters
446 * Quotation and Nested Macros::  Macros calling macros
447 * Changequote is Evil::         Worse than INTERCAL: M4 + changequote
448 * Quadrigraphs::                Another way to escape special characters
449 * Balancing Parentheses::       Dealing with unbalanced parentheses
450 * Quotation Rule Of Thumb::     One parenthesis, one quote
452 Using @command{autom4te}
454 * autom4te Invocation::         A @acronym{GNU} M4 wrapper
455 * Customizing autom4te::        Customizing the Autoconf package
457 Programming in M4sugar
459 * Redefined M4 Macros::         M4 builtins changed in M4sugar
460 * Diagnostic Macros::           Diagnostic messages from M4sugar
461 * Diversion support::           Diversions in M4sugar
462 * Conditional constructs::      Conditions in M4
463 * Looping constructs::          Iteration in M4
464 * Evaluation Macros::           More quotation and evaluation control
465 * Text processing Macros::      String manipulation in M4
466 * Number processing Macros::    Arithmetic computation in M4
467 * Set manipulation Macros::     Set manipulation in M4
468 * Forbidden Patterns::          Catching unexpanded macros
470 Writing Autoconf Macros
472 * Macro Definitions::           Basic format of an Autoconf macro
473 * Macro Names::                 What to call your new macros
474 * Reporting Messages::          Notifying @command{autoconf} users
475 * Dependencies Between Macros::  What to do when macros depend on other macros
476 * Obsoleting Macros::           Warning about old ways of doing things
477 * Coding Style::                Writing Autoconf macros @`a la Autoconf
479 Dependencies Between Macros
481 * Prerequisite Macros::         Ensuring required information
482 * Suggested Ordering::          Warning about possible ordering problems
483 * One-Shot Macros::             Ensuring a macro is called only once
485 Portable Shell Programming
487 * Shellology::                  A zoology of shells
488 * Here-Documents::              Quirks and tricks
489 * File Descriptors::            FDs and redirections
490 * File System Conventions::     File names
491 * Shell Pattern Matching::      Pattern matching
492 * Shell Substitutions::         Variable and command expansions
493 * Assignments::                 Varying side effects of assignments
494 * Parentheses::                 Parentheses in shell scripts
495 * Slashes::                     Slashes in shell scripts
496 * Special Shell Variables::     Variables you should not change
497 * Shell Functions::             What to look out for if you use them
498 * Limitations of Builtins::     Portable use of not so portable /bin/sh
499 * Limitations of Usual Tools::  Portable use of portable tools
501 Portable Make Programming
503 * $< in Ordinary Make Rules::   $< in ordinary rules
504 * Failure in Make Rules::       Failing portably in rules
505 * Special Chars in Names::      Special Characters in Macro Names
506 * Backslash-Newline-Newline::   Empty last lines in macro definitions
507 * Backslash-Newline Comments::  Spanning comments across line boundaries
508 * Long Lines in Makefiles::     Line length limitations
509 * Macros and Submakes::         @code{make macro=value} and submakes
510 * The Make Macro MAKEFLAGS::    @code{$(MAKEFLAGS)} portability issues
511 * The Make Macro SHELL::        @code{$(SHELL)} portability issues
512 * Comments in Make Rules::      Other problems with Make comments
513 * obj/ and Make::               Don't name a subdirectory @file{obj}
514 * make -k Status::              Exit status of @samp{make -k}
515 * VPATH and Make::              @code{VPATH} woes
516 * Single Suffix Rules::         Single suffix rules and separated dependencies
517 * Timestamps and Make::         Subsecond timestamp resolution
519 @code{VPATH} and Make
521 * VPATH and Double-colon::      Problems with @samp{::} on ancient hosts
522 * $< in Explicit Rules::        @code{$<} does not work in ordinary rules
523 * Automatic Rule Rewriting::    @code{VPATH} goes wild on Solaris
524 * Tru64 Directory Magic::       @command{mkdir} goes wild on Tru64
525 * Make Target Lookup::          More details about @code{VPATH} lookup
527 Portable C and C++ Programming
529 * Varieties of Unportability::  How to make your programs unportable
530 * Integer Overflow::            When integers get too large
531 * Preprocessor Arithmetic::     @code{#if} expression problems
532 * Null Pointers::               Properties of null pointers
533 * Buffer Overruns::             Subscript errors and the like
534 * Volatile Objects::            @code{volatile} and signals
535 * Floating Point Portability::  Portable floating-point arithmetic
536 * Exiting Portably::            Exiting and the exit status
538 Manual Configuration
540 * Specifying Target Triplets::  Specifying target triplets
541 * Canonicalizing::              Getting the canonical system type
542 * Using System Type::           What to do with the system type
544 Site Configuration
546 * Help Formatting::             Customizing @samp{configure --help}
547 * External Software::           Working with other optional software
548 * Package Options::             Selecting optional features
549 * Pretty Help Strings::         Formatting help string
550 * Option Checking::             Controlling checking of @command{configure} options
551 * Site Details::                Configuring site details
552 * Transforming Names::          Changing program names when installing
553 * Site Defaults::               Giving @command{configure} local defaults
555 Transforming Program Names When Installing
557 * Transformation Options::      @command{configure} options to transform names
558 * Transformation Examples::     Sample uses of transforming names
559 * Transformation Rules::        Makefile uses of transforming names
561 Running @command{configure} Scripts
563 * Basic Installation::          Instructions for typical cases
564 * Compilers and Options::       Selecting compilers and optimization
565 * Multiple Architectures::      Compiling for multiple architectures at once
566 * Installation Names::          Installing in different directories
567 * Optional Features::           Selecting optional features
568 * Particular Systems::          Particular systems
569 * System Type::                 Specifying the system type
570 * Sharing Defaults::            Setting site-wide defaults for @command{configure}
571 * Defining Variables::          Specifying the compiler etc.
572 * configure Invocation::        Changing how @command{configure} runs
574 Obsolete Constructs
576 * Obsolete config.status Use::  Obsolete convention for @command{config.status}
577 * acconfig Header::             Additional entries in @file{config.h.in}
578 * autoupdate Invocation::       Automatic update of @file{configure.ac}
579 * Obsolete Macros::             Backward compatibility macros
580 * Autoconf 1::                  Tips for upgrading your files
581 * Autoconf 2.13::               Some fresher tips
583 Upgrading From Version 1
585 * Changed File Names::          Files you might rename
586 * Changed Makefiles::           New things to put in @file{Makefile.in}
587 * Changed Macros::              Macro calls you might replace
588 * Changed Results::             Changes in how to check test results
589 * Changed Macro Writing::       Better ways to write your own macros
591 Upgrading From Version 2.13
593 * Changed Quotation::           Broken code which used to work
594 * New Macros::                  Interaction with foreign macros
595 * Hosts and Cross-Compilation::  Bugward compatibility kludges
596 * AC_LIBOBJ vs LIBOBJS::        LIBOBJS is a forbidden token
597 * AC_ACT_IFELSE vs AC_TRY_ACT::  A more generic scheme for testing sources
599 Generating Test Suites with Autotest
601 * Using an Autotest Test Suite::  Autotest and the user
602 * Writing Testsuites::          Autotest macros
603 * testsuite Invocation::        Running @command{testsuite} scripts
604 * Making testsuite Scripts::    Using autom4te to create @command{testsuite}
606 Using an Autotest Test Suite
608 * testsuite Scripts::           The concepts of Autotest
609 * Autotest Logs::               Their contents
611 Frequent Autoconf Questions, with answers
613 * Distributing::                Distributing @command{configure} scripts
614 * Why GNU M4::                  Why not use the standard M4?
615 * Bootstrapping::               Autoconf and @acronym{GNU} M4 require each other?
616 * Why Not Imake::               Why @acronym{GNU} uses @command{configure} instead of Imake
617 * Defining Directories::        Passing @code{datadir} to program
618 * Autom4te Cache::              What is it?  Can I remove it?
619 * Present But Cannot Be Compiled::  Compiler and Preprocessor Disagree
620 * Expanded Before Required::    Expanded Before Required
622 History of Autoconf
624 * Genesis::                     Prehistory and naming of @command{configure}
625 * Exodus::                      The plagues of M4 and Perl
626 * Leviticus::                   The priestly code of portability arrives
627 * Numbers::                     Growth and contributors
628 * Deuteronomy::                 Approaching the promises of easy configuration
630 Indices
632 * Environment Variable Index::  Index of environment variables used
633 * Output Variable Index::       Index of variables set in output files
634 * Preprocessor Symbol Index::   Index of C preprocessor symbols defined
635 * Autoconf Macro Index::        Index of Autoconf macros
636 * M4 Macro Index::              Index of M4, M4sugar, and M4sh macros
637 * Autotest Macro Index::        Index of Autotest macros
638 * Program & Function Index::    Index of those with portability problems
639 * Concept Index::               General index
641 @end detailmenu
642 @end menu
644 @c ============================================================= Introduction.
646 @node Introduction
647 @chapter Introduction
648 @cindex Introduction
650 @flushright
651 A physicist, an engineer, and a computer scientist were discussing the
652 nature of God.  ``Surely a Physicist,'' said the physicist, ``because
653 early in the Creation, God made Light; and you know, Maxwell's
654 equations, the dual nature of electromagnetic waves, the relativistic
655 consequences@enddots{}'' ``An Engineer!,'' said the engineer, ``because
656 before making Light, God split the Chaos into Land and Water; it takes a
657 hell of an engineer to handle that big amount of mud, and orderly
658 separation of solids from liquids@enddots{}'' The computer scientist
659 shouted: ``And the Chaos, where do you think it was coming from, hmm?''
661 ---Anonymous
662 @end flushright
663 @c (via Franc,ois Pinard)
665 Autoconf is a tool for producing shell scripts that automatically
666 configure software source code packages to adapt to many kinds of
667 Posix-like systems.  The configuration scripts produced by Autoconf
668 are independent of Autoconf when they are run, so their users do not
669 need to have Autoconf.
671 The configuration scripts produced by Autoconf require no manual user
672 intervention when run; they do not normally even need an argument
673 specifying the system type.  Instead, they individually test for the
674 presence of each feature that the software package they are for might need.
675 (Before each check, they print a one-line message stating what they are
676 checking for, so the user doesn't get too bored while waiting for the
677 script to finish.)  As a result, they deal well with systems that are
678 hybrids or customized from the more common Posix variants.  There is
679 no need to maintain files that list the features supported by each
680 release of each variant of Posix.
682 For each software package that Autoconf is used with, it creates a
683 configuration script from a template file that lists the system features
684 that the package needs or can use.  After the shell code to recognize
685 and respond to a system feature has been written, Autoconf allows it to
686 be shared by many software packages that can use (or need) that feature.
687 If it later turns out that the shell code needs adjustment for some
688 reason, it needs to be changed in only one place; all of the
689 configuration scripts can be regenerated automatically to take advantage
690 of the updated code.
692 @c "Those who do not understand Unix are condemned to reinvent it, poorly."
693 @c --Henry Spencer, 1987 (see http://en.wikipedia.org/wiki/Unix_philosophy)
694 Those who do not understand Autoconf are condemned to reinvent it, poorly.
695 The primary goal of Autoconf is making the @emph{user's} life easier;
696 making the @emph{maintainer's} life easier is only a secondary goal.
697 Put another way, the primary goal is not to make the generation of
698 @file{configure} automatic for package maintainers (although patches
699 along that front are welcome, since package maintainers form the user
700 base of Autoconf); rather, the goal is to make @file{configure}
701 painless, portable, and predictable for the end user of each
702 @dfn{autoconfiscated} package.  And to this degree, Autoconf is highly
703 successful at its goal --- most complaints to the Autoconf list are
704 about difficulties in writing Autoconf input, and not in the behavior of
705 the resulting @file{configure}.  Even packages that don't use Autoconf
706 will generally provide a @file{configure} script, and the most common
707 complaint about these alternative home-grown scripts is that they fail
708 to meet one or more of the @acronym{GNU} Coding Standards that users
709 have come to expect from Autoconf-generated @file{configure} scripts.
711 The Metaconfig package is similar in purpose to Autoconf, but the
712 scripts it produces require manual user intervention, which is quite
713 inconvenient when configuring large source trees.  Unlike Metaconfig
714 scripts, Autoconf scripts can support cross-compiling, if some care is
715 taken in writing them.
717 Autoconf does not solve all problems related to making portable
718 software packages---for a more complete solution, it should be used in
719 concert with other @acronym{GNU} build tools like Automake and
720 Libtool.  These other tools take on jobs like the creation of a
721 portable, recursive makefile with all of the standard targets,
722 linking of shared libraries, and so on.  @xref{The GNU Build System},
723 for more information.
725 Autoconf imposes some restrictions on the names of macros used with
726 @code{#if} in C programs (@pxref{Preprocessor Symbol Index}).
728 Autoconf requires @acronym{GNU} M4 version 1.4.5 or later in order to
729 generate the scripts.  It uses features that some versions of M4,
730 including @acronym{GNU} M4 1.3, do not have.  Autoconf works better
731 with @acronym{GNU} M4 version 1.4.11 or later, though this is not
732 required.
734 @xref{Autoconf 1}, for information about upgrading from version 1.
735 @xref{History}, for the story of Autoconf's development.  @xref{FAQ},
736 for answers to some common questions about Autoconf.
738 See the @uref{http://@/www.gnu.org/@/software/@/autoconf/,
739 Autoconf web page} for up-to-date information, details on the mailing
740 lists, pointers to a list of known bugs, etc.
742 Mail suggestions to @email{autoconf@@gnu.org, the Autoconf mailing
743 list}.  Past suggestions are
744 @uref{http://@/lists.gnu.org/@/archive/@/html/@/autoconf/, archived}.
746 Mail bug reports to @email{bug-autoconf@@gnu.org, the
747 Autoconf Bugs mailing list}.  Past bug reports are
748 @uref{http://@/lists.gnu.org/@/archive/@/html/@/bug-autoconf/, archived}.
750 If possible, first check that your bug is
751 not already solved in current development versions, and that it has not
752 been reported yet.  Be sure to include all the needed information and a
753 short @file{configure.ac} that demonstrates the problem.
755 Autoconf's development tree is accessible via @command{git}; see the
756 @uref{http://@/savannah.gnu.org/@/projects/@/autoconf/, Autoconf
757 Summary} for details, or view
758 @uref{http://@/git.sv.gnu.org/@/gitweb/@/?p=autoconf.git, the actual
759 repository}.  Anonymous @acronym{CVS} access is also available, see
760 @file{README} for more details.  Patches relative to the
761 current @command{git} version can be sent for review to the
762 @email{autoconf-patches@@gnu.org, Autoconf Patches mailing list}, with
763 discussion on prior patches
764 @uref{http://@/lists.gnu.org/@/archive/@/html/@/autoconf-@/patches/,
765 archived}; and all commits are posted in the read-only
766 @email{autoconf-commit@@gnu.org, Autoconf Commit mailing list}, which is
767 also @uref{http://@/lists.gnu.org/@/archive/@/html/@/autoconf-commit/,
768 archived}.
770 Because of its mission, the Autoconf package itself
771 includes only a set of often-used
772 macros that have already demonstrated their usefulness.  Nevertheless,
773 if you wish to share your macros, or find existing ones, see the
774 @uref{http://@/autoconf-archive.cryp.to/, Autoconf Macro
775 Archive}, which is kindly run by @email{simons@@cryp.to,
776 Peter Simons}.
779 @c ================================================= The GNU Build System
781 @node The GNU Build System
782 @chapter The @acronym{GNU} Build System
783 @cindex @acronym{GNU} build system
785 Autoconf solves an important problem---reliable discovery of
786 system-specific build and runtime information---but this is only one
787 piece of the puzzle for the development of portable software.  To this
788 end, the @acronym{GNU} project has developed a suite of integrated
789 utilities to finish the job Autoconf started: the @acronym{GNU} build
790 system, whose most important components are Autoconf, Automake, and
791 Libtool.  In this chapter, we introduce you to those tools, point you
792 to sources of more information, and try to convince you to use the
793 entire @acronym{GNU} build system for your software.
795 @menu
796 * Automake::                    Escaping makefile hell
797 * Gnulib::                      The @acronym{GNU} portability library
798 * Libtool::                     Building libraries portably
799 * Pointers::                    More info on the @acronym{GNU} build system
800 @end menu
802 @node Automake
803 @section Automake
805 The ubiquity of @command{make} means that a makefile is almost the
806 only viable way to distribute automatic build rules for software, but
807 one quickly runs into its numerous limitations.  Its lack of
808 support for automatic dependency tracking, recursive builds in
809 subdirectories, reliable timestamps (e.g., for network file systems), and
810 so on, mean that developers must painfully (and often incorrectly)
811 reinvent the wheel for each project.  Portability is non-trivial, thanks
812 to the quirks of @command{make} on many systems.  On top of all this is the
813 manual labor required to implement the many standard targets that users
814 have come to expect (@code{make install}, @code{make distclean},
815 @code{make uninstall}, etc.).  Since you are, of course, using Autoconf,
816 you also have to insert repetitive code in your @file{Makefile.in} to
817 recognize @code{@@CC@@}, @code{@@CFLAGS@@}, and other substitutions
818 provided by @command{configure}.  Into this mess steps @dfn{Automake}.
819 @cindex Automake
821 Automake allows you to specify your build needs in a @file{Makefile.am}
822 file with a vastly simpler and more powerful syntax than that of a plain
823 makefile, and then generates a portable @file{Makefile.in} for
824 use with Autoconf.  For example, the @file{Makefile.am} to build and
825 install a simple ``Hello world'' program might look like:
827 @example
828 bin_PROGRAMS = hello
829 hello_SOURCES = hello.c
830 @end example
832 @noindent
833 The resulting @file{Makefile.in} (~400 lines) automatically supports all
834 the standard targets, the substitutions provided by Autoconf, automatic
835 dependency tracking, @code{VPATH} building, and so on.  @command{make}
836 builds the @code{hello} program, and @code{make install} installs it
837 in @file{/usr/local/bin} (or whatever prefix was given to
838 @command{configure}, if not @file{/usr/local}).
840 The benefits of Automake increase for larger packages (especially ones
841 with subdirectories), but even for small programs the added convenience
842 and portability can be substantial.  And that's not all@enddots{}
844 @node Gnulib
845 @section Gnulib
847 @acronym{GNU} software has a well-deserved reputation for running on
848 many different types of systems.  While our primary goal is to write
849 software for the @acronym{GNU} system, many users and developers have
850 been introduced to us through the systems that they were already using.
852 @cindex Gnulib
853 Gnulib is a central location for common @acronym{GNU} code, intended to
854 be shared among free software packages.  Its components are typically
855 shared at the source level, rather than being a library that gets built,
856 installed, and linked against.  The idea is to copy files from Gnulib
857 into your own source tree.  There is no distribution tarball; developers
858 should just grab source modules from the repository.  The source files
859 are available online, under various licenses, mostly @acronym{GNU}
860 @acronym{GPL} or @acronym{GNU} @acronym{LGPL}.
862 Gnulib modules typically contain C source code along with Autoconf
863 macros used to configure the source code.  For example, the Gnulib
864 @code{stdbool} module implements a @file{stdbool.h} header that nearly
865 conforms to C99, even on old-fashioned hosts that lack @file{stdbool.h}.
866 This module contains a source file for the replacement header, along
867 with an Autoconf macro that arranges to use the replacement header on
868 old-fashioned systems.
870 @node Libtool
871 @section Libtool
873 Often, one wants to build not only programs, but libraries, so that
874 other programs can benefit from the fruits of your labor.  Ideally, one
875 would like to produce @emph{shared} (dynamically linked) libraries,
876 which can be used by multiple programs without duplication on disk or in
877 memory and can be updated independently of the linked programs.
878 Producing shared libraries portably, however, is the stuff of
879 nightmares---each system has its own incompatible tools, compiler flags,
880 and magic incantations.  Fortunately, @acronym{GNU} provides a solution:
881 @dfn{Libtool}.
882 @cindex Libtool
884 Libtool handles all the requirements of building shared libraries for
885 you, and at this time seems to be the @emph{only} way to do so with any
886 portability.  It also handles many other headaches, such as: the
887 interaction of Make rules with the variable suffixes of
888 shared libraries, linking reliably with shared libraries before they are
889 installed by the superuser, and supplying a consistent versioning system
890 (so that different versions of a library can be installed or upgraded
891 without breaking binary compatibility).  Although Libtool, like
892 Autoconf, can be used without Automake, it is most simply utilized in
893 conjunction with Automake---there, Libtool is used automatically
894 whenever shared libraries are needed, and you need not know its syntax.
896 @node Pointers
897 @section Pointers
899 Developers who are used to the simplicity of @command{make} for small
900 projects on a single system might be daunted at the prospect of
901 learning to use Automake and Autoconf.  As your software is
902 distributed to more and more users, however, you otherwise
903 quickly find yourself putting lots of effort into reinventing the
904 services that the @acronym{GNU} build tools provide, and making the
905 same mistakes that they once made and overcame.  (Besides, since
906 you're already learning Autoconf, Automake is a piece of cake.)
908 There are a number of places that you can go to for more information on
909 the @acronym{GNU} build tools.
911 @itemize @minus
913 @item Web
915 The project home pages for
916 @uref{http://@/www@/.gnu@/.org/@/software/@/autoconf/, Autoconf},
917 @uref{http://@/www@/.gnu@/.org/@/software/@/automake/, Automake},
918 @uref{http://@/www@/.gnu@/.org/@/software/@/gnulib/, Gnulib}, and
919 @uref{http://@/www@/.gnu@/.org/@/software/@/libtool/, Libtool}.
921 @item Automake Manual
923 @xref{Top, , Automake, automake, @acronym{GNU} Automake}, for more
924 information on Automake.
926 @item Books
928 The book @cite{@acronym{GNU} Autoconf, Automake and
929 Libtool}@footnote{@cite{@acronym{GNU} Autoconf, Automake and Libtool},
930 by G. V. Vaughan, B. Elliston, T. Tromey, and I. L. Taylor.  SAMS (originally
931 New Riders), 2000, ISBN 1578701902.} describes the complete @acronym{GNU}
932 build environment.  You can also find
933 @uref{http://@/sources.redhat.com/@/autobook/, the entire book on-line}.
935 @end itemize
937 @c ================================================= Making configure Scripts.
939 @node Making configure Scripts
940 @chapter Making @command{configure} Scripts
941 @cindex @file{aclocal.m4}
942 @cindex @command{configure}
944 The configuration scripts that Autoconf produces are by convention
945 called @command{configure}.  When run, @command{configure} creates several
946 files, replacing configuration parameters in them with appropriate
947 values.  The files that @command{configure} creates are:
949 @itemize @minus
950 @item
951 one or more @file{Makefile} files, usually one in each subdirectory of the
952 package (@pxref{Makefile Substitutions});
954 @item
955 optionally, a C header file, the name of which is configurable,
956 containing @code{#define} directives (@pxref{Configuration Headers});
958 @item
959 a shell script called @file{config.status} that, when run, recreates
960 the files listed above (@pxref{config.status Invocation});
962 @item
963 an optional shell script normally called @file{config.cache}
964 (created when using @samp{configure --config-cache}) that
965 saves the results of running many of the tests (@pxref{Cache Files});
967 @item
968 a file called @file{config.log} containing any messages produced by
969 compilers, to help debugging if @command{configure} makes a mistake.
970 @end itemize
972 @cindex @file{configure.in}
973 @cindex @file{configure.ac}
974 To create a @command{configure} script with Autoconf, you need to write an
975 Autoconf input file @file{configure.ac} (or @file{configure.in}) and run
976 @command{autoconf} on it.  If you write your own feature tests to
977 supplement those that come with Autoconf, you might also write files
978 called @file{aclocal.m4} and @file{acsite.m4}.  If you use a C header
979 file to contain @code{#define} directives, you might also run
980 @command{autoheader}, and you can distribute the generated file
981 @file{config.h.in} with the package.
983 Here is a diagram showing how the files that can be used in
984 configuration are produced.  Programs that are executed are suffixed by
985 @samp{*}.  Optional files are enclosed in square brackets (@samp{[]}).
986 @command{autoconf} and @command{autoheader} also read the installed Autoconf
987 macro files (by reading @file{autoconf.m4}).
989 @noindent
990 Files used in preparing a software package for distribution:
991 @example
992 your source files --> [autoscan*] --> [configure.scan] --> configure.ac
994 @group
995 configure.ac --.
996                |   .------> autoconf* -----> configure
997 [aclocal.m4] --+---+
998                |   `-----> [autoheader*] --> [config.h.in]
999 [acsite.m4] ---'
1000 @end group
1002 Makefile.in -------------------------------> Makefile.in
1003 @end example
1005 @noindent
1006 Files used in configuring a software package:
1007 @example
1008 @group
1009                        .-------------> [config.cache]
1010 configure* ------------+-------------> config.log
1011                        |
1012 [config.h.in] -.       v            .-> [config.h] -.
1013                +--> config.status* -+               +--> make*
1014 Makefile.in ---'                    `-> Makefile ---'
1015 @end group
1016 @end example
1018 @menu
1019 * Writing Autoconf Input::      What to put in an Autoconf input file
1020 * autoscan Invocation::         Semi-automatic @file{configure.ac} writing
1021 * ifnames Invocation::          Listing the conditionals in source code
1022 * autoconf Invocation::         How to create configuration scripts
1023 * autoreconf Invocation::       Remaking multiple @command{configure} scripts
1024 @end menu
1026 @node Writing Autoconf Input
1027 @section Writing @file{configure.ac}
1029 To produce a @command{configure} script for a software package, create a
1030 file called @file{configure.ac} that contains invocations of the
1031 Autoconf macros that test the system features your package needs or can
1032 use.  Autoconf macros already exist to check for many features; see
1033 @ref{Existing Tests}, for their descriptions.  For most other features,
1034 you can use Autoconf template macros to produce custom checks; see
1035 @ref{Writing Tests}, for information about them.  For especially tricky
1036 or specialized features, @file{configure.ac} might need to contain some
1037 hand-crafted shell commands; see @ref{Portable Shell, , Portable Shell
1038 Programming}.  The @command{autoscan} program can give you a good start
1039 in writing @file{configure.ac} (@pxref{autoscan Invocation}, for more
1040 information).
1042 Previous versions of Autoconf promoted the name @file{configure.in},
1043 which is somewhat ambiguous (the tool needed to process this file is not
1044 described by its extension), and introduces a slight confusion with
1045 @file{config.h.in} and so on (for which @samp{.in} means ``to be
1046 processed by @command{configure}'').  Using @file{configure.ac} is now
1047 preferred.
1049 @menu
1050 * Shell Script Compiler::       Autoconf as solution of a problem
1051 * Autoconf Language::           Programming in Autoconf
1052 * Autoconf Input Layout::       Standard organization of @file{configure.ac}
1053 @end menu
1055 @node Shell Script Compiler
1056 @subsection A Shell Script Compiler
1058 Just as for any other computer language, in order to properly program
1059 @file{configure.ac} in Autoconf you must understand @emph{what} problem
1060 the language tries to address and @emph{how} it does so.
1062 The problem Autoconf addresses is that the world is a mess.  After all,
1063 you are using Autoconf in order to have your package compile easily on
1064 all sorts of different systems, some of them being extremely hostile.
1065 Autoconf itself bears the price for these differences: @command{configure}
1066 must run on all those systems, and thus @command{configure} must limit itself
1067 to their lowest common denominator of features.
1069 Naturally, you might then think of shell scripts; who needs
1070 @command{autoconf}?  A set of properly written shell functions is enough to
1071 make it easy to write @command{configure} scripts by hand.  Sigh!
1072 Unfortunately, even in 2008, where shells without any function support are
1073 far and few between, there are pitfalls to avoid when making use of them.
1074 Also, finding a Bourne shell that accepts shell functions is not trivial,
1075 even though there is almost always one on interesting porting targets.
1077 So, what is really needed is some kind of compiler, @command{autoconf},
1078 that takes an Autoconf program, @file{configure.ac}, and transforms it
1079 into a portable shell script, @command{configure}.
1081 How does @command{autoconf} perform this task?
1083 There are two obvious possibilities: creating a brand new language or
1084 extending an existing one.  The former option is attractive: all
1085 sorts of optimizations could easily be implemented in the compiler and
1086 many rigorous checks could be performed on the Autoconf program
1087 (e.g., rejecting any non-portable construct).  Alternatively, you can
1088 extend an existing language, such as the @code{sh} (Bourne shell)
1089 language.
1091 Autoconf does the latter: it is a layer on top of @code{sh}.  It was
1092 therefore most convenient to implement @command{autoconf} as a macro
1093 expander: a program that repeatedly performs @dfn{macro expansions} on
1094 text input, replacing macro calls with macro bodies and producing a pure
1095 @code{sh} script in the end.  Instead of implementing a dedicated
1096 Autoconf macro expander, it is natural to use an existing
1097 general-purpose macro language, such as M4, and implement the extensions
1098 as a set of M4 macros.
1101 @node Autoconf Language
1102 @subsection The Autoconf Language
1103 @cindex quotation
1105 The Autoconf language differs from many other computer
1106 languages because it treats actual code the same as plain text.  Whereas
1107 in C, for instance, data and instructions have different syntactic
1108 status, in Autoconf their status is rigorously the same.  Therefore, we
1109 need a means to distinguish literal strings from text to be expanded:
1110 quotation.
1112 When calling macros that take arguments, there must not be any white
1113 space between the macro name and the open parenthesis.  Arguments should
1114 be enclosed within the M4 quote characters @samp{[} and @samp{]}, and be
1115 separated by commas.  Any leading blanks or newlines in arguments are ignored,
1116 unless they are quoted.  You should always quote an argument that
1117 might contain a macro name, comma, parenthesis, or a leading blank or
1118 newline.  This rule applies recursively for every macro
1119 call, including macros called from other macros.
1121 For instance:
1123 @example
1124 AC_CHECK_HEADER([stdio.h],
1125                 [AC_DEFINE([HAVE_STDIO_H], [1],
1126                    [Define to 1 if you have <stdio.h>.])],
1127                 [AC_MSG_ERROR([Sorry, can't do anything for you])])
1128 @end example
1130 @noindent
1131 is quoted properly.  You may safely simplify its quotation to:
1133 @example
1134 AC_CHECK_HEADER([stdio.h],
1135                 [AC_DEFINE([HAVE_STDIO_H], 1,
1136                    [Define to 1 if you have <stdio.h>.])],
1137                 [AC_MSG_ERROR([Sorry, can't do anything for you])])
1138 @end example
1140 @noindent
1141 because @samp{1} cannot contain a macro call.  Here, the argument of
1142 @code{AC_MSG_ERROR} must be quoted; otherwise, its comma would be
1143 interpreted as an argument separator.  Also, the second and third arguments
1144 of @samp{AC_CHECK_HEADER} must be quoted, since they contain
1145 macro calls.  The three arguments @samp{HAVE_STDIO_H}, @samp{stdio.h},
1146 and @samp{Define to 1 if you have <stdio.h>.} do not need quoting, but
1147 if you unwisely defined a macro with a name like @samp{Define} or
1148 @samp{stdio} then they would need quoting.  Cautious Autoconf users
1149 would keep the quotes, but many Autoconf users find such precautions
1150 annoying, and would rewrite the example as follows:
1152 @example
1153 AC_CHECK_HEADER(stdio.h,
1154                 [AC_DEFINE(HAVE_STDIO_H, 1,
1155                    [Define to 1 if you have <stdio.h>.])],
1156                 [AC_MSG_ERROR([Sorry, can't do anything for you])])
1157 @end example
1159 @noindent
1160 This is safe, so long as you adopt good naming conventions and do not
1161 define macros with names like @samp{HAVE_STDIO_H}, @samp{stdio}, or
1162 @samp{h}.  Though it is also safe here to omit the quotes around
1163 @samp{Define to 1 if you have <stdio.h>.} this is not recommended, as
1164 message strings are more likely to inadvertently contain commas.
1166 The following example is wrong and dangerous, as it is underquoted:
1168 @example
1169 AC_CHECK_HEADER(stdio.h,
1170                 AC_DEFINE(HAVE_STDIO_H, 1,
1171                    Define to 1 if you have <stdio.h>.),
1172                 AC_MSG_ERROR([Sorry, can't do anything for you]))
1173 @end example
1175 In other cases, you may have to use text that also resembles a macro
1176 call.  You must quote that text even when it is not passed as a macro
1177 argument:
1179 @example
1180 echo "Hard rock was here!  --[AC_DC]"
1181 @end example
1183 @noindent
1184 which results in:
1186 @example
1187 echo "Hard rock was here!  --AC_DC"
1188 @end example
1190 @noindent
1191 When you use the same text in a macro argument, you must therefore have
1192 an extra quotation level (since one is stripped away by the macro
1193 substitution).  In general, then, it is a good idea to @emph{use double
1194 quoting for all literal string arguments}:
1196 @example
1197 AC_MSG_WARN([[AC_DC stinks  --Iron Maiden]])
1198 @end example
1200 You are now able to understand one of the constructs of Autoconf that
1201 has been continually misunderstood@enddots{}  The rule of thumb is that
1202 @emph{whenever you expect macro expansion, expect quote expansion};
1203 i.e., expect one level of quotes to be lost.  For instance:
1205 @example
1206 AC_COMPILE_IFELSE([char b[10];], [], [AC_MSG_ERROR([you lose])])
1207 @end example
1209 @noindent
1210 is incorrect: here, the first argument of @code{AC_COMPILE_IFELSE} is
1211 @samp{char b[10];} and is expanded once, which results in
1212 @samp{char b10;}.  (There was an idiom common in Autoconf's past to
1213 address this issue via the M4 @code{changequote} primitive, but do not
1214 use it!)  Let's take a closer look: the author meant the first argument
1215 to be understood as a literal, and therefore it must be quoted twice:
1217 @example
1218 AC_COMPILE_IFELSE([[char b[10];]], [], [AC_MSG_ERROR([you lose])])
1219 @end example
1221 @noindent
1222 Voil@`a, you actually produce @samp{char b[10];} this time!
1224 On the other hand, descriptions (e.g., the last parameter of
1225 @code{AC_DEFINE} or @code{AS_HELP_STRING}) are not literals---they
1226 are subject to line breaking, for example---and should not be double quoted.
1227 Even if these descriptions are short and are not actually broken, double
1228 quoting them yields weird results.
1230 Some macros take optional arguments, which this documentation represents
1231 as @ovar{arg} (not to be confused with the quote characters).  You may
1232 just leave them empty, or use @samp{[]} to make the emptiness of the
1233 argument explicit, or you may simply omit the trailing commas.  The
1234 three lines below are equivalent:
1236 @example
1237 AC_CHECK_HEADERS([stdio.h], [], [], [])
1238 AC_CHECK_HEADERS([stdio.h],,,)
1239 AC_CHECK_HEADERS([stdio.h])
1240 @end example
1242 It is best to put each macro call on its own line in
1243 @file{configure.ac}.  Most of the macros don't add extra newlines; they
1244 rely on the newline after the macro call to terminate the commands.
1245 This approach makes the generated @command{configure} script a little
1246 easier to read by not inserting lots of blank lines.  It is generally
1247 safe to set shell variables on the same line as a macro call, because
1248 the shell allows assignments without intervening newlines.
1250 You can include comments in @file{configure.ac} files by starting them
1251 with the @samp{#}.  For example, it is helpful to begin
1252 @file{configure.ac} files with a line like this:
1254 @example
1255 # Process this file with autoconf to produce a configure script.
1256 @end example
1258 @node Autoconf Input Layout
1259 @subsection Standard @file{configure.ac} Layout
1261 The order in which @file{configure.ac} calls the Autoconf macros is not
1262 important, with a few exceptions.  Every @file{configure.ac} must
1263 contain a call to @code{AC_INIT} before the checks, and a call to
1264 @code{AC_OUTPUT} at the end (@pxref{Output}).  Additionally, some macros
1265 rely on other macros having been called first, because they check
1266 previously set values of some variables to decide what to do.  These
1267 macros are noted in the individual descriptions (@pxref{Existing
1268 Tests}), and they also warn you when @command{configure} is created if they
1269 are called out of order.
1271 To encourage consistency, here is a suggested order for calling the
1272 Autoconf macros.  Generally speaking, the things near the end of this
1273 list are those that could depend on things earlier in it.  For example,
1274 library functions could be affected by types and libraries.
1276 @display
1277 @group
1278 Autoconf requirements
1279 @code{AC_INIT(@var{package}, @var{version}, @var{bug-report-address})}
1280 information on the package
1281 checks for programs
1282 checks for libraries
1283 checks for header files
1284 checks for types
1285 checks for structures
1286 checks for compiler characteristics
1287 checks for library functions
1288 checks for system services
1289 @code{AC_CONFIG_FILES(@r{[}@var{file@dots{}}@r{]})}
1290 @code{AC_OUTPUT}
1291 @end group
1292 @end display
1295 @node autoscan Invocation
1296 @section Using @command{autoscan} to Create @file{configure.ac}
1297 @cindex @command{autoscan}
1299 The @command{autoscan} program can help you create and/or maintain a
1300 @file{configure.ac} file for a software package.  @command{autoscan}
1301 examines source files in the directory tree rooted at a directory given
1302 as a command line argument, or the current directory if none is given.
1303 It searches the source files for common portability problems and creates
1304 a file @file{configure.scan} which is a preliminary @file{configure.ac}
1305 for that package, and checks a possibly existing @file{configure.ac} for
1306 completeness.
1308 When using @command{autoscan} to create a @file{configure.ac}, you
1309 should manually examine @file{configure.scan} before renaming it to
1310 @file{configure.ac}; it probably needs some adjustments.
1311 Occasionally, @command{autoscan} outputs a macro in the wrong order
1312 relative to another macro, so that @command{autoconf} produces a warning;
1313 you need to move such macros manually.  Also, if you want the package to
1314 use a configuration header file, you must add a call to
1315 @code{AC_CONFIG_HEADERS} (@pxref{Configuration Headers}).  You might
1316 also have to change or add some @code{#if} directives to your program in
1317 order to make it work with Autoconf (@pxref{ifnames Invocation}, for
1318 information about a program that can help with that job).
1320 When using @command{autoscan} to maintain a @file{configure.ac}, simply
1321 consider adding its suggestions.  The file @file{autoscan.log}
1322 contains detailed information on why a macro is requested.
1324 @command{autoscan} uses several data files (installed along with Autoconf)
1325 to determine which macros to output when it finds particular symbols in
1326 a package's source files.  These data files all have the same format:
1327 each line consists of a symbol, one or more blanks, and the Autoconf macro to
1328 output if that symbol is encountered.  Lines starting with @samp{#} are
1329 comments.
1331 @command{autoscan} accepts the following options:
1333 @table @option
1334 @item --help
1335 @itemx -h
1336 Print a summary of the command line options and exit.
1338 @item --version
1339 @itemx -V
1340 Print the version number of Autoconf and exit.
1342 @item --verbose
1343 @itemx -v
1344 Print the names of the files it examines and the potentially interesting
1345 symbols it finds in them.  This output can be voluminous.
1347 @item --debug
1348 @itemx -d
1349 Don't remove temporary files.
1351 @item --include=@var{dir}
1352 @itemx -I @var{dir}
1353 Append @var{dir} to the include path.  Multiple invocations accumulate.
1355 @item --prepend-include=@var{dir}
1356 @itemx -B @var{dir}
1357 Prepend @var{dir} to the include path.  Multiple invocations accumulate.
1358 @end table
1360 @node ifnames Invocation
1361 @section Using @command{ifnames} to List Conditionals
1362 @cindex @command{ifnames}
1364 @command{ifnames} can help you write @file{configure.ac} for a software
1365 package.  It prints the identifiers that the package already uses in C
1366 preprocessor conditionals.  If a package has already been set up to have
1367 some portability, @command{ifnames} can thus help you figure out what its
1368 @command{configure} needs to check for.  It may help fill in some gaps in a
1369 @file{configure.ac} generated by @command{autoscan} (@pxref{autoscan
1370 Invocation}).
1372 @command{ifnames} scans all of the C source files named on the command line
1373 (or the standard input, if none are given) and writes to the standard
1374 output a sorted list of all the identifiers that appear in those files
1375 in @code{#if}, @code{#elif}, @code{#ifdef}, or @code{#ifndef}
1376 directives.  It prints each identifier on a line, followed by a
1377 space-separated list of the files in which that identifier occurs.
1379 @noindent
1380 @command{ifnames} accepts the following options:
1382 @table @option
1383 @item --help
1384 @itemx -h
1385 Print a summary of the command line options and exit.
1387 @item --version
1388 @itemx -V
1389 Print the version number of Autoconf and exit.
1390 @end table
1392 @node autoconf Invocation
1393 @section Using @command{autoconf} to Create @command{configure}
1394 @cindex @command{autoconf}
1396 To create @command{configure} from @file{configure.ac}, run the
1397 @command{autoconf} program with no arguments.  @command{autoconf} processes
1398 @file{configure.ac} with the M4 macro processor, using the
1399 Autoconf macros.  If you give @command{autoconf} an argument, it reads that
1400 file instead of @file{configure.ac} and writes the configuration script
1401 to the standard output instead of to @command{configure}.  If you give
1402 @command{autoconf} the argument @option{-}, it reads from the standard
1403 input instead of @file{configure.ac} and writes the configuration script
1404 to the standard output.
1406 The Autoconf macros are defined in several files.  Some of the files are
1407 distributed with Autoconf; @command{autoconf} reads them first.  Then it
1408 looks for the optional file @file{acsite.m4} in the directory that
1409 contains the distributed Autoconf macro files, and for the optional file
1410 @file{aclocal.m4} in the current directory.  Those files can contain
1411 your site's or the package's own Autoconf macro definitions
1412 (@pxref{Writing Autoconf Macros}, for more information).  If a macro is
1413 defined in more than one of the files that @command{autoconf} reads, the
1414 last definition it reads overrides the earlier ones.
1416 @command{autoconf} accepts the following options:
1418 @table @option
1419 @item --help
1420 @itemx -h
1421 Print a summary of the command line options and exit.
1423 @item --version
1424 @itemx -V
1425 Print the version number of Autoconf and exit.
1427 @item --verbose
1428 @itemx -v
1429 Report processing steps.
1431 @item --debug
1432 @itemx -d
1433 Don't remove the temporary files.
1435 @item --force
1436 @itemx -f
1437 Remake @file{configure} even if newer than its input files.
1439 @item --include=@var{dir}
1440 @itemx -I @var{dir}
1441 Append @var{dir} to the include path.  Multiple invocations accumulate.
1443 @item --prepend-include=@var{dir}
1444 @itemx -B @var{dir}
1445 Prepend @var{dir} to the include path.  Multiple invocations accumulate.
1447 @item --output=@var{file}
1448 @itemx -o @var{file}
1449 Save output (script or trace) to @var{file}.  The file @option{-} stands
1450 for the standard output.
1452 @item --warnings=@var{category}
1453 @itemx -W @var{category}
1454 @evindex WARNINGS
1455 Report the warnings related to @var{category} (which can actually be a
1456 comma separated list).  @xref{Reporting Messages}, macro
1457 @code{AC_DIAGNOSE}, for a comprehensive list of categories.  Special
1458 values include:
1460 @table @samp
1461 @item all
1462 report all the warnings
1464 @item none
1465 report none
1467 @item error
1468 treats warnings as errors
1470 @item no-@var{category}
1471 disable warnings falling into @var{category}
1472 @end table
1474 Warnings about @samp{syntax} are enabled by default, and the environment
1475 variable @env{WARNINGS}, a comma separated list of categories, is
1476 honored as well.  Passing @option{-W @var{category}} actually behaves as if
1477 you had passed @option{--warnings syntax,$WARNINGS,@var{category}}.  To
1478 disable the defaults and @env{WARNINGS}, and then
1479 enable warnings about obsolete constructs, use @option{-W
1480 none,obsolete}.
1482 @cindex Back trace
1483 @cindex Macro invocation stack
1484 Because @command{autoconf} uses @command{autom4te} behind the scenes, it
1485 displays a back trace for errors, but not for warnings; if you want
1486 them, just pass @option{-W error}.  @xref{autom4te Invocation}, for some
1487 examples.
1489 @item --trace=@var{macro}[:@var{format}]
1490 @itemx -t @var{macro}[:@var{format}]
1491 Do not create the @command{configure} script, but list the calls to
1492 @var{macro} according to the @var{format}.  Multiple @option{--trace}
1493 arguments can be used to list several macros.  Multiple @option{--trace}
1494 arguments for a single macro are not cumulative; instead, you should
1495 just make @var{format} as long as needed.
1497 The @var{format} is a regular string, with newlines if desired, and
1498 several special escape codes.  It defaults to @samp{$f:$l:$n:$%}; see
1499 @ref{autom4te Invocation}, for details on the @var{format}.
1501 @item --initialization
1502 @itemx -i
1503 By default, @option{--trace} does not trace the initialization of the
1504 Autoconf macros (typically the @code{AC_DEFUN} definitions).  This
1505 results in a noticeable speedup, but can be disabled by this option.
1506 @end table
1509 It is often necessary to check the content of a @file{configure.ac}
1510 file, but parsing it yourself is extremely fragile and error-prone.  It
1511 is suggested that you rely upon @option{--trace} to scan
1512 @file{configure.ac}.  For instance, to find the list of variables that
1513 are substituted, use:
1515 @example
1516 @group
1517 $ @kbd{autoconf -t AC_SUBST}
1518 configure.ac:2:AC_SUBST:ECHO_C
1519 configure.ac:2:AC_SUBST:ECHO_N
1520 configure.ac:2:AC_SUBST:ECHO_T
1521 @i{More traces deleted}
1522 @end group
1523 @end example
1525 @noindent
1526 The example below highlights the difference between @samp{$@@},
1527 @samp{$*}, and @samp{$%}.
1529 @example
1530 @group
1531 $ @kbd{cat configure.ac}
1532 AC_DEFINE(This, is, [an
1533 [example]])
1534 $ @kbd{autoconf -t 'AC_DEFINE:@@: $@@}
1535 *: $*
1536 %: $%'
1537 @@: [This],[is],[an
1538 [example]]
1539 *: This,is,an
1540 [example]
1541 %: This:is:an [example]
1542 @end group
1543 @end example
1545 @noindent
1546 The @var{format} gives you a lot of freedom:
1548 @example
1549 @group
1550 $ @kbd{autoconf -t 'AC_SUBST:$$ac_subst@{"$1"@} = "$f:$l";'}
1551 $ac_subst@{"ECHO_C"@} = "configure.ac:2";
1552 $ac_subst@{"ECHO_N"@} = "configure.ac:2";
1553 $ac_subst@{"ECHO_T"@} = "configure.ac:2";
1554 @i{More traces deleted}
1555 @end group
1556 @end example
1558 @noindent
1559 A long @var{separator} can be used to improve the readability of complex
1560 structures, and to ease their parsing (for instance when no single
1561 character is suitable as a separator):
1563 @example
1564 @group
1565 $ @kbd{autoconf -t 'AM_MISSING_PROG:$@{|:::::|@}*'}
1566 ACLOCAL|:::::|aclocal|:::::|$missing_dir
1567 AUTOCONF|:::::|autoconf|:::::|$missing_dir
1568 AUTOMAKE|:::::|automake|:::::|$missing_dir
1569 @i{More traces deleted}
1570 @end group
1571 @end example
1573 @node autoreconf Invocation
1574 @section Using @command{autoreconf} to Update @command{configure} Scripts
1575 @cindex @command{autoreconf}
1577 Installing the various components of the @acronym{GNU} Build System can be
1578 tedious: running @command{autopoint} for Gettext, @command{automake} for
1579 @file{Makefile.in} etc.@: in each directory.  It may be needed either
1580 because some tools such as @command{automake} have been updated on your
1581 system, or because some of the sources such as @file{configure.ac} have
1582 been updated, or finally, simply in order to install the @acronym{GNU} Build
1583 System in a fresh tree.
1585 @command{autoreconf} runs @command{autoconf}, @command{autoheader},
1586 @command{aclocal}, @command{automake}, @command{libtoolize}, and
1587 @command{autopoint} (when appropriate) repeatedly to update the
1588 @acronym{GNU} Build System in the specified directories and their
1589 subdirectories (@pxref{Subdirectories}).  By default, it only remakes
1590 those files that are older than their sources.  The environment variables
1591 @env{AUTOCONF}, @env{AUTOHEADER}, @env{AUTOMAKE}, @env{ACLOCAL},
1592 @env{AUTOPOINT}, @env{LIBTOOLIZE}, @env{M4}, and @env{MAKE} may be used
1593 to override the invocation of the respective tools.
1595 If you install a new version of some tool, you can make
1596 @command{autoreconf} remake @emph{all} of the files by giving it the
1597 @option{--force} option.
1599 @xref{Automatic Remaking}, for Make rules to automatically
1600 rebuild @command{configure} scripts when their source files change.  That
1601 method handles the timestamps of configuration header templates
1602 properly, but does not pass @option{--autoconf-dir=@var{dir}} or
1603 @option{--localdir=@var{dir}}.
1605 @cindex Gettext
1606 @cindex @command{autopoint}
1607 Gettext supplies the @command{autopoint} command to add translation
1608 infrastructure to a source package.  If you use @command{autopoint},
1609 your @file{configure.ac} should invoke both @code{AM_GNU_GETTEXT} and
1610 @code{AM_GNU_GETTEXT_VERSION(@var{gettext-version})}.  @xref{autopoint
1611 Invocation, , Invoking the @code{autopoint} Program, gettext,
1612 @acronym{GNU} @code{gettext} utilities}, for further details.
1614 @noindent
1615 @command{autoreconf} accepts the following options:
1617 @table @option
1618 @item --help
1619 @itemx -h
1620 Print a summary of the command line options and exit.
1622 @item --version
1623 @itemx -V
1624 Print the version number of Autoconf and exit.
1626 @item --verbose
1627 @itemx -V
1628 Print the name of each directory @command{autoreconf} examines and the
1629 commands it runs.  If given two or more times, pass @option{--verbose}
1630 to subordinate tools that support it.
1632 @item --debug
1633 @itemx -d
1634 Don't remove the temporary files.
1636 @item --force
1637 @itemx -f
1638 Remake even @file{configure} scripts and configuration headers that are
1639 newer than their input files (@file{configure.ac} and, if present,
1640 @file{aclocal.m4}).
1642 @item --install
1643 @itemx -i
1644 Install the missing auxiliary files in the package.  By default, files
1645 are copied; this can be changed with @option{--symlink}.
1647 If deemed appropriate, this option triggers calls to
1648 @samp{automake --add-missing},
1649 @samp{libtoolize}, @samp{autopoint}, etc.
1651 @item --no-recursive
1652 Do not rebuild files in subdirectories to configure (see @ref{Subdirectories},
1653 macro @code{AC_CONFIG_SUBDIRS}).
1655 @item --symlink
1656 @itemx -s
1657 When used with @option{--install}, install symbolic links to the missing
1658 auxiliary files instead of copying them.
1660 @item --make
1661 @itemx -m
1662 When the directories were configured, update the configuration by
1663 running @samp{./config.status --recheck && ./config.status}, and then
1664 run @samp{make}.
1666 @item --include=@var{dir}
1667 @itemx -I @var{dir}
1668 Append @var{dir} to the include path.  Multiple invocations accumulate.
1669 Passed on to @command{aclocal}, @command{autoconf} and
1670 @command{autoheader} internally.
1672 @item --prepend-include=@var{dir}
1673 @itemx -B @var{dir}
1674 Prepend @var{dir} to the include path.  Multiple invocations accumulate.
1675 Passed on to @command{autoconf} and @command{autoheader} internally.
1677 @item --warnings=@var{category}
1678 @itemx -W @var{category}
1679 @evindex WARNINGS
1680 Report the warnings related to @var{category} (which can actually be a
1681 comma separated list).
1683 @table @samp
1684 @item cross
1685 related to cross compilation issues.
1687 @item obsolete
1688 report the uses of obsolete constructs.
1690 @item portability
1691 portability issues
1693 @item syntax
1694 dubious syntactic constructs.
1696 @item all
1697 report all the warnings
1699 @item none
1700 report none
1702 @item error
1703 treats warnings as errors
1705 @item no-@var{category}
1706 disable warnings falling into @var{category}
1707 @end table
1709 Warnings about @samp{syntax} are enabled by default, and the environment
1710 variable @env{WARNINGS}, a comma separated list of categories, is
1711 honored as well.  Passing @option{-W @var{category}} actually behaves as if
1712 you had passed @option{--warnings syntax,$WARNINGS,@var{category}}.  To
1713 disable the defaults and @env{WARNINGS}, and then
1714 enable warnings about obsolete constructs, use @option{-W
1715 none,obsolete}.
1716 @end table
1718 If you want @command{autoreconf} to pass flags that are not listed here
1719 on to @command{aclocal}, set @code{ACLOCAL_AMFLAGS} in your @file{Makefile.am}.
1720 Due to a limitation in the Autoconf implementation these flags currently
1721 must be set on a single line in @file{Makefile.am}, without any
1722 backslash-newlines.
1724 @c ========================================= Initialization and Output Files.
1726 @node Setup
1727 @chapter Initialization and Output Files
1729 Autoconf-generated @command{configure} scripts need some information about
1730 how to initialize, such as how to find the package's source files and
1731 about the output files to produce.  The following sections describe the
1732 initialization and the creation of output files.
1734 @menu
1735 * Initializing configure::      Option processing etc.
1736 * Versioning::                  Dealing with Autoconf versions
1737 * Notices::                     Copyright, version numbers in @command{configure}
1738 * Input::                       Where Autoconf should find files
1739 * Output::                      Outputting results from the configuration
1740 * Configuration Actions::       Preparing the output based on results
1741 * Configuration Files::         Creating output files
1742 * Makefile Substitutions::      Using output variables in makefiles
1743 * Configuration Headers::       Creating a configuration header file
1744 * Configuration Commands::      Running arbitrary instantiation commands
1745 * Configuration Links::         Links depending on the configuration
1746 * Subdirectories::              Configuring independent packages together
1747 * Default Prefix::              Changing the default installation prefix
1748 @end menu
1750 @node Initializing configure
1751 @section Initializing @command{configure}
1753 Every @command{configure} script must call @code{AC_INIT} before doing
1754 anything else.  The only other required macro is @code{AC_OUTPUT}
1755 (@pxref{Output}).
1757 @anchor{AC_INIT}
1758 @defmac AC_INIT (@var{package}, @var{version}, @ovar{bug-report}, @
1759   @ovar{tarname}, @ovar{url})
1760 @acindex{INIT}
1761 Process any command-line arguments and perform various initializations
1762 and verifications.
1764 Set the name of the @var{package} and its @var{version}.  These are
1765 typically used in @option{--version} support, including that of
1766 @command{configure}.  The optional argument @var{bug-report} should be
1767 the email to which users should send bug reports.  The package
1768 @var{tarname} differs from @var{package}: the latter designates the full
1769 package name (e.g., @samp{GNU Autoconf}), while the former is meant for
1770 distribution tar ball names (e.g., @samp{autoconf}).  It defaults to
1771 @var{package} with @samp{GNU } stripped, lower-cased, and all characters
1772 other than alphanumerics and underscores are changed to @samp{-}.  If
1773 provided, @var{url} should be the home page for the package.
1775 It is preferable that the arguments of @code{AC_INIT} be static, i.e.,
1776 there should not be any shell computation, but they can be computed by
1779 The following M4 macros (e.g., @code{AC_PACKAGE_NAME}), output variables
1780 (e.g., @code{PACKAGE_NAME}), and preprocessor symbols (e.g.,
1781 @code{PACKAGE_NAME}), are defined by @code{AC_INIT}:
1783 @table @asis
1784 @item @code{AC_PACKAGE_NAME}, @code{PACKAGE_NAME}
1785 @acindex{PACKAGE_NAME}
1786 @ovindex PACKAGE_NAME
1787 @cvindex PACKAGE_NAME
1788 Exactly @var{package}.
1790 @item @code{AC_PACKAGE_TARNAME}, @code{PACKAGE_TARNAME}
1791 @acindex{PACKAGE_TARNAME}
1792 @ovindex PACKAGE_TARNAME
1793 @cvindex PACKAGE_TARNAME
1794 Exactly @var{tarname}, possibly generated from @var{package}.
1796 @item @code{AC_PACKAGE_VERSION}, @code{PACKAGE_VERSION}
1797 @acindex{PACKAGE_VERSION}
1798 @ovindex PACKAGE_VERSION
1799 @cvindex PACKAGE_VERSION
1800 Exactly @var{version}.
1802 @item @code{AC_PACKAGE_STRING}, @code{PACKAGE_STRING}
1803 @acindex{PACKAGE_STRING}
1804 @ovindex PACKAGE_STRING
1805 @cvindex PACKAGE_STRING
1806 Exactly @samp{@var{package} @var{version}}.
1808 @item @code{AC_PACKAGE_BUGREPORT}, @code{PACKAGE_BUGREPORT}
1809 @acindex{PACKAGE_BUGREPORT}
1810 @ovindex PACKAGE_BUGREPORT
1811 @cvindex PACKAGE_BUGREPORT
1812 Exactly @var{bug-report}, if one was provided.
1814 @item @code{AC_PACKAGE_URL}, @code{PACKAGE_URL}
1815 @acindex{PACKAGE_URL}
1816 @ovindex PACKAGE_URL
1817 @cvindex PACKAGE_URL
1818 Exactly @var{url}, if one was provided.  If @var{url} was empty, but
1819 @var{package} begins with @samp{GNU }, then this defaults to
1820 @samp{http://@/www.gnu.org/@/software/@/@var{tarname}/}, otherwise, no URL is
1821 assumed.
1822 @end table
1823 @end defmac
1825 If your @command{configure} script does its own option processing, it
1826 should inspect @samp{$@@} or @samp{$*} immediately after calling
1827 @code{AC_INIT}, because other Autoconf macros liberally use the
1828 @command{set} command to process strings, and this has the side effect
1829 of updating @samp{$@@} and @samp{$*}.  However, we suggest that you use
1830 standard macros like @code{AC_ARG_ENABLE} instead of attempting to
1831 implement your own option processing.  @xref{Site Configuration}.
1833 @node Versioning
1834 @section Dealing with Autoconf versions
1835 @cindex Autoconf version
1836 @cindex version, Autoconf
1838 The following optional macros can be used to help choose the minimum
1839 version of Autoconf that can successfully compile a given
1840 @file{configure.ac}.
1842 @defmac AC_PREREQ (@var{version})
1843 @acindex{PREREQ}
1844 @cindex Version
1845 Ensure that a recent enough version of Autoconf is being used.  If the
1846 version of Autoconf being used to create @command{configure} is
1847 earlier than @var{version}, print an error message to the standard
1848 error output and exit with failure (exit status is 63).  For example:
1850 @example
1851 AC_PREREQ([@value{VERSION}])
1852 @end example
1854 This macro is the only macro that may be used before @code{AC_INIT}, but
1855 for consistency, you are invited not to do so.
1856 @end defmac
1858 @defmac AC_AUTOCONF_VERSION
1859 @acindex{AUTOCONF_VERSION}
1860 This macro was introduced in Autoconf 2.62.  It identifies the version
1861 of Autoconf that is currently parsing the input file, in a format
1862 suitable for @code{m4_version_compare} (@pxref{m4_version_compare}); in
1863 other words, for this release of Autoconf, its value is
1864 @samp{@value{VERSION}}.  One potential use of this macro is for writing
1865 conditional fallbacks based on when a feature was added to Autoconf,
1866 rather than using @code{AC_PREREQ} to require the newer version of
1867 Autoconf.  However, remember that the Autoconf philosophy favors feature
1868 checks over version checks.
1870 You should not expand this macro directly; use
1871 @samp{m4_defn([AC_AUTOCONF_VERSION])} instead.  This is because some
1872 users might
1873 have a beta version of Autoconf installed, with arbitrary letters
1874 included in its version string.  This means it is possible for the
1875 version string to contain the name of a defined macro, such that
1876 expanding @code{AC_AUTOCONF_VERSION} would trigger the expansion of that
1877 macro during rescanning, and change the version string to be different
1878 than what you intended to check.
1879 @end defmac
1881 @node Notices
1882 @section Notices in @command{configure}
1883 @cindex Notices in @command{configure}
1885 The following macros manage version numbers for @command{configure}
1886 scripts.  Using them is optional.
1888 @defmac AC_COPYRIGHT (@var{copyright-notice})
1889 @acindex{COPYRIGHT}
1890 @cindex Copyright Notice
1891 State that, in addition to the Free Software Foundation's copyright on
1892 the Autoconf macros, parts of your @command{configure} are covered by the
1893 @var{copyright-notice}.
1895 The @var{copyright-notice} shows up in both the head of
1896 @command{configure} and in @samp{configure --version}.
1897 @end defmac
1900 @defmac AC_REVISION (@var{revision-info})
1901 @acindex{REVISION}
1902 @cindex Revision
1903 Copy revision stamp @var{revision-info} into the @command{configure}
1904 script, with any dollar signs or double-quotes removed.  This macro lets
1905 you put a revision stamp from @file{configure.ac} into @command{configure}
1906 without @acronym{RCS} or @acronym{CVS} changing it when you check in
1907 @command{configure}.  That way, you can determine easily which revision of
1908 @file{configure.ac} a particular @command{configure} corresponds to.
1910 For example, this line in @file{configure.ac}:
1912 @c The @w prevents RCS from changing the example in the manual.
1913 @example
1914 AC_REVISION([@w{$}Revision: 1.30 $])
1915 @end example
1917 @noindent
1918 produces this in @command{configure}:
1920 @example
1921 #!/bin/sh
1922 # From configure.ac Revision: 1.30
1923 @end example
1924 @end defmac
1927 @node Input
1928 @section Finding @command{configure} Input
1930 @anchor{AC_CONFIG_SRCDIR}
1931 @defmac AC_CONFIG_SRCDIR (@var{unique-file-in-source-dir})
1932 @acindex{CONFIG_SRCDIR}
1933 @var{unique-file-in-source-dir} is some file that is in the package's
1934 source directory; @command{configure} checks for this file's existence to
1935 make sure that the directory that it is told contains the source code in
1936 fact does.  Occasionally people accidentally specify the wrong directory
1937 with @option{--srcdir}; this is a safety check.  @xref{configure
1938 Invocation}, for more information.
1939 @end defmac
1942 @c FIXME: Remove definitively once --install explained.
1944 @c Small packages may store all their macros in @code{aclocal.m4}.  As the
1945 @c set of macros grows, or for maintenance reasons, a maintainer may prefer
1946 @c to split the macros in several files.  In this case, Autoconf must be
1947 @c told which files to load, and in which order.
1949 @c @defmac AC_INCLUDE (@var{file}@dots{})
1950 @c @acindex{INCLUDE}
1951 @c @c FIXME: There is no longer shell globbing.
1952 @c Read the macro definitions that appear in the listed files.  A list of
1953 @c space-separated file names or shell globbing patterns is expected.  The
1954 @c files are read in the order they're listed.
1956 @c Because the order of definition of macros is important (only the last
1957 @c definition of a macro is used), beware that it is @code{AC_INIT} that
1958 @c loads @file{acsite.m4} and @file{aclocal.m4}.  Note that
1959 @c @code{AC_INCLUDE}ing a file before @code{AC_INIT} or within
1960 @c @file{aclocal.m4} is different from doing so after @code{AC_INIT}: in
1961 @c the latter case, non-macro lines from included files may end up in the
1962 @c @file{configure} script, whereas in the former case, they'd be discarded
1963 @c just like any text that appear before @code{AC_INIT}.
1964 @c @end defmac
1966 Packages that do manual configuration or use the @command{install} program
1967 might need to tell @command{configure} where to find some other shell
1968 scripts by calling @code{AC_CONFIG_AUX_DIR}, though the default places
1969 it looks are correct for most cases.
1971 @defmac AC_CONFIG_AUX_DIR (@var{dir})
1972 @acindex{CONFIG_AUX_DIR}
1973 Use the auxiliary build tools (e.g., @file{install-sh},
1974 @file{config.sub}, @file{config.guess}, Cygnus @command{configure},
1975 Automake and Libtool scripts, etc.)@: that are in directory @var{dir}.
1976 These are auxiliary files used in configuration.  @var{dir} can be
1977 either absolute or relative to @file{@var{srcdir}}.  The default is
1978 @file{@var{srcdir}} or @file{@var{srcdir}/..} or
1979 @file{@var{srcdir}/../..}, whichever is the first that contains
1980 @file{install-sh}.  The other files are not checked for, so that using
1981 @code{AC_PROG_INSTALL} does not automatically require distributing the
1982 other auxiliary files.  It checks for @file{install.sh} also, but that
1983 name is obsolete because some @command{make} have a rule that creates
1984 @file{install} from it if there is no makefile.
1986 The auxiliary directory is commonly named @file{build-aux}.
1987 If you need portability to @acronym{DOS} variants, do not name the
1988 auxiliary directory @file{aux}.  @xref{File System Conventions}.
1989 @end defmac
1991 @defmac AC_REQUIRE_AUX_FILE (@var{file})
1992 @acindex{REQUIRE_AUX_FILE}
1993 Declares that @var{file} is expected in the directory defined above.  In
1994 Autoconf proper, this macro does nothing: its sole purpose is to be
1995 traced by third-party tools to produce a list of expected auxiliary
1996 files.  For instance it is called by macros like @code{AC_PROG_INSTALL}
1997 (@pxref{Particular Programs}) or @code{AC_CANONICAL_BUILD}
1998 (@pxref{Canonicalizing}) to register the auxiliary files they need.
1999 @end defmac
2001 Similarly, packages that use @command{aclocal} should declare where
2002 local macros can be found using @code{AC_CONFIG_MACRO_DIR}.
2004 @defmac AC_CONFIG_MACRO_DIR (@var{dir})
2005 @acindex{CONFIG_MACRO_DIR}
2006 Specify @var{dir} as the location of additional local Autoconf macros.
2007 This macro is intended for use by future versions of commands like
2008 @command{autoreconf} that trace macro calls.  It should be called
2009 directly from @file{configure.ac} so that tools that install macros for
2010 @command{aclocal} can find the macros' declarations.
2012 Note that if you use @command{aclocal} from Automake to generate
2013 @file{aclocal.m4}, you must also set @code{ACLOCAL_AMFLAGS = -I
2014 @var{dir}} in your top-level @file{Makefile.am}.  Due to a limitation in
2015 the Autoconf implementation of @command{autoreconf}, these include
2016 directives currently must be set on a single line in @file{Makefile.am},
2017 without any backslash-newlines.
2018 @end defmac
2021 @node Output
2022 @section Outputting Files
2023 @cindex Outputting files
2025 Every Autoconf script, e.g., @file{configure.ac}, should finish by
2026 calling @code{AC_OUTPUT}.  That is the macro that generates and runs
2027 @file{config.status}, which in turn creates the makefiles and any
2028 other files resulting from configuration.  This is the only required
2029 macro besides @code{AC_INIT} (@pxref{Input}).
2031 @anchor{AC_OUTPUT}
2032 @defmac AC_OUTPUT
2033 @acindex{OUTPUT}
2034 @cindex Instantiation
2035 Generate @file{config.status} and launch it.  Call this macro once, at
2036 the end of @file{configure.ac}.
2038 @file{config.status} performs all the configuration actions: all the
2039 output files (see @ref{Configuration Files}, macro
2040 @code{AC_CONFIG_FILES}), header files (see @ref{Configuration Headers},
2041 macro @code{AC_CONFIG_HEADERS}), commands (see @ref{Configuration
2042 Commands}, macro @code{AC_CONFIG_COMMANDS}), links (see
2043 @ref{Configuration Links}, macro @code{AC_CONFIG_LINKS}), subdirectories
2044 to configure (see @ref{Subdirectories}, macro @code{AC_CONFIG_SUBDIRS})
2045 are honored.
2047 The location of your @code{AC_OUTPUT} invocation is the exact point
2048 where configuration actions are taken: any code afterwards is
2049 executed by @command{configure} once @command{config.status} was run.  If
2050 you want to bind actions to @command{config.status} itself
2051 (independently of whether @command{configure} is being run), see
2052 @ref{Configuration Commands, , Running Arbitrary Configuration
2053 Commands}.
2054 @end defmac
2056 Historically, the usage of @code{AC_OUTPUT} was somewhat different.
2057 @xref{Obsolete Macros}, for a description of the arguments that
2058 @code{AC_OUTPUT} used to support.
2061 If you run @command{make} in subdirectories, you should run it using the
2062 @command{make} variable @code{MAKE}.  Most versions of @command{make} set
2063 @code{MAKE} to the name of the @command{make} program plus any options it
2064 was given.  (But many do not include in it the values of any variables
2065 set on the command line, so those are not passed on automatically.)
2066 Some old versions of @command{make} do not set this variable.  The
2067 following macro allows you to use it even with those versions.
2069 @anchor{AC_PROG_MAKE_SET}
2070 @defmac AC_PROG_MAKE_SET
2071 @acindex{PROG_MAKE_SET}
2072 @ovindex SET_MAKE
2073 If the Make command, @code{$MAKE} if set or else @samp{make}, predefines
2074 @code{$(MAKE)}, define output variable @code{SET_MAKE} to be empty.
2075 Otherwise, define @code{SET_MAKE} to a macro definition that sets
2076 @code{$(MAKE)}, such as @samp{MAKE=make}.  Calls @code{AC_SUBST} for
2077 @code{SET_MAKE}.
2078 @end defmac
2080 If you use this macro, place a line like this in each @file{Makefile.in}
2081 that runs @command{MAKE} on other directories:
2083 @example
2084 @@SET_MAKE@@
2085 @end example
2089 @node Configuration Actions
2090 @section Performing Configuration Actions
2091 @cindex Configuration actions
2093 @file{configure} is designed so that it appears to do everything itself,
2094 but there is actually a hidden slave: @file{config.status}.
2095 @file{configure} is in charge of examining your system, but it is
2096 @file{config.status} that actually takes the proper actions based on the
2097 results of @file{configure}.  The most typical task of
2098 @file{config.status} is to @emph{instantiate} files.
2100 This section describes the common behavior of the four standard
2101 instantiating macros: @code{AC_CONFIG_FILES}, @code{AC_CONFIG_HEADERS},
2102 @code{AC_CONFIG_COMMANDS} and @code{AC_CONFIG_LINKS}.  They all
2103 have this prototype:
2105 @c FIXME: Can't use @ovar here, Texinfo 4.0 goes lunatic and emits something
2106 @c awful.
2107 @example
2108 AC_CONFIG_@var{ITEMS}(@var{tag}@dots{}, [@var{commands}], [@var{init-cmds}])
2109 @end example
2111 @noindent
2112 where the arguments are:
2114 @table @var
2115 @item tag@dots{}
2116 A blank-or-newline-separated list of tags, which are typically the names of
2117 the files to instantiate.
2119 You are encouraged to use literals as @var{tags}.  In particular, you
2120 should avoid
2122 @example
2123 @dots{} && my_foos="$my_foos fooo"
2124 @dots{} && my_foos="$my_foos foooo"
2125 AC_CONFIG_@var{ITEMS}([$my_foos])
2126 @end example
2128 @noindent
2129 and use this instead:
2131 @example
2132 @dots{} && AC_CONFIG_@var{ITEMS}([fooo])
2133 @dots{} && AC_CONFIG_@var{ITEMS}([foooo])
2134 @end example
2136 The macros @code{AC_CONFIG_FILES} and @code{AC_CONFIG_HEADERS} use
2137 special @var{tag} values: they may have the form @samp{@var{output}} or
2138 @samp{@var{output}:@var{inputs}}.  The file @var{output} is instantiated
2139 from its templates, @var{inputs} (defaulting to @samp{@var{output}.in}).
2141 @samp{AC_CONFIG_FILES([Makefile:boiler/top.mk:boiler/bot.mk)]},
2142 for example, asks for
2143 the creation of the file @file{Makefile} that contains the expansion of the
2144 output variables in the concatenation of @file{boiler/top.mk} and
2145 @file{boiler/bot.mk}.
2147 The special value @samp{-} might be used to denote the standard output
2148 when used in @var{output}, or the standard input when used in the
2149 @var{inputs}.  You most probably don't need to use this in
2150 @file{configure.ac}, but it is convenient when using the command line
2151 interface of @file{./config.status}, see @ref{config.status Invocation},
2152 for more details.
2154 The @var{inputs} may be absolute or relative file names.  In the latter
2155 case they are first looked for in the build tree, and then in the source
2156 tree.  Input files should be text files, and a line length below 2000
2157 bytes should be safe.
2159 @item commands
2160 Shell commands output literally into @file{config.status}, and
2161 associated with a tag that the user can use to tell @file{config.status}
2162 which commands to run.  The commands are run each time a @var{tag}
2163 request is given to @file{config.status}, typically each time the file
2164 @file{@var{tag}} is created.
2166 The variables set during the execution of @command{configure} are
2167 @emph{not} available here: you first need to set them via the
2168 @var{init-cmds}.  Nonetheless the following variables are precomputed:
2170 @table @code
2171 @item srcdir
2172 The name of the top source directory, assuming that the working
2173 directory is the top build directory.  This
2174 is what the @command{configure} option @option{--srcdir} sets.
2176 @item ac_top_srcdir
2177 The name of the top source directory, assuming that the working
2178 directory is the current build directory.
2181 @item ac_top_build_prefix
2182 The name of the top build directory, assuming that the working
2183 directory is the current build directory.
2184 It can be empty, or else ends with a slash, so that you may concatenate
2187 @item ac_srcdir
2188 The name of the corresponding source directory, assuming that the
2189 working directory is the current build directory.
2190 @end table
2192 @noindent
2193 The @dfn{current} directory refers to the directory (or
2194 pseudo-directory) containing the input part of @var{tags}.  For
2195 instance, running
2197 @example
2198 AC_CONFIG_COMMANDS([deep/dir/out:in/in.in], [@dots{}], [@dots{}])
2199 @end example
2201 @noindent
2202  with @option{--srcdir=../package} produces the following values:
2204 @example
2205 # Argument of --srcdir
2206 srcdir='../package'
2207 # Reversing deep/dir
2208 ac_top_build_prefix='../../'
2209 # Concatenation of $ac_top_build_prefix and srcdir
2210 ac_top_srcdir='../../../package'
2211 # Concatenation of $ac_top_srcdir and deep/dir
2212 ac_srcdir='../../../package/deep/dir'
2213 @end example
2215 @noindent
2216 independently of @samp{in/in.in}.
2218 @item init-cmds
2219 Shell commands output @emph{unquoted} near the beginning of
2220 @file{config.status}, and executed each time @file{config.status} runs
2221 (regardless of the tag).  Because they are unquoted, for example,
2222 @samp{$var} is output as the value of @code{var}.  @var{init-cmds}
2223 is typically used by @file{configure} to give @file{config.status} some
2224 variables it needs to run the @var{commands}.
2226 You should be extremely cautious in your variable names: all the
2227 @var{init-cmds} share the same name space and may overwrite each other
2228 in unpredictable ways.  Sorry@enddots{}
2229 @end table
2231 All these macros can be called multiple times, with different
2232 @var{tag} values, of course!
2235 @node Configuration Files
2236 @section Creating Configuration Files
2237 @cindex Creating configuration files
2238 @cindex Configuration file creation
2240 Be sure to read the previous section, @ref{Configuration Actions}.
2242 @anchor{AC_CONFIG_FILES}
2243 @defmac AC_CONFIG_FILES (@var{file}@dots{}, @ovar{cmds}, @ovar{init-cmds})
2244 @acindex{CONFIG_FILES}
2245 Make @code{AC_OUTPUT} create each @file{@var{file}} by copying an input
2246 file (by default @file{@var{file}.in}), substituting the output variable
2247 values.
2248 @c Before we used to have this feature, which was later rejected
2249 @c because it complicates the writing of makefiles:
2250 @c If the file would be unchanged, it is left untouched, to preserve
2251 @c timestamp.
2252 This macro is one of the instantiating macros; see @ref{Configuration
2253 Actions}.  @xref{Makefile Substitutions}, for more information on using
2254 output variables.  @xref{Setting Output Variables}, for more information
2255 on creating them.  This macro creates the directory that the file is in
2256 if it doesn't exist.  Usually, makefiles are created this way,
2257 but other files, such as @file{.gdbinit}, can be specified as well.
2259 Typical calls to @code{AC_CONFIG_FILES} look like this:
2261 @example
2262 AC_CONFIG_FILES([Makefile src/Makefile man/Makefile X/Imakefile])
2263 AC_CONFIG_FILES([autoconf], [chmod +x autoconf])
2264 @end example
2266 You can override an input file name by appending to @var{file} a
2267 colon-separated list of input files.  Examples:
2269 @example
2270 AC_CONFIG_FILES([Makefile:boiler/top.mk:boiler/bot.mk]
2271                 [lib/Makefile:boiler/lib.mk])
2272 @end example
2274 @noindent
2275 Doing this allows you to keep your file names acceptable to
2276 @acronym{DOS} variants, or
2277 to prepend and/or append boilerplate to the file.
2278 @end defmac
2282 @node Makefile Substitutions
2283 @section Substitutions in Makefiles
2284 @cindex Substitutions in makefiles
2285 @cindex Makefile substitutions
2287 Each subdirectory in a distribution that contains something to be
2288 compiled or installed should come with a file @file{Makefile.in}, from
2289 which @command{configure} creates a file @file{Makefile} in that directory.
2290 To create @file{Makefile}, @command{configure} performs a simple variable
2291 substitution, replacing occurrences of @samp{@@@var{variable}@@} in
2292 @file{Makefile.in} with the value that @command{configure} has determined
2293 for that variable.  Variables that are substituted into output files in
2294 this way are called @dfn{output variables}.  They are ordinary shell
2295 variables that are set in @command{configure}.  To make @command{configure}
2296 substitute a particular variable into the output files, the macro
2297 @code{AC_SUBST} must be called with that variable name as an argument.
2298 Any occurrences of @samp{@@@var{variable}@@} for other variables are
2299 left unchanged.  @xref{Setting Output Variables}, for more information
2300 on creating output variables with @code{AC_SUBST}.
2302 A software package that uses a @command{configure} script should be
2303 distributed with a file @file{Makefile.in}, but no makefile; that
2304 way, the user has to properly configure the package for the local system
2305 before compiling it.
2307 @xref{Makefile Conventions, , Makefile Conventions, standards, The
2308 @acronym{GNU} Coding Standards}, for more information on what to put in
2309 makefiles.
2311 @menu
2312 * Preset Output Variables::     Output variables that are always set
2313 * Installation Directory Variables::  Other preset output variables
2314 * Changed Directory Variables:: Warnings about @file{datarootdir}
2315 * Build Directories::           Supporting multiple concurrent compiles
2316 * Automatic Remaking::          Makefile rules for configuring
2317 @end menu
2319 @node Preset Output Variables
2320 @subsection Preset Output Variables
2321 @cindex Output variables
2323 Some output variables are preset by the Autoconf macros.  Some of the
2324 Autoconf macros set additional output variables, which are mentioned in
2325 the descriptions for those macros.  @xref{Output Variable Index}, for a
2326 complete list of output variables.  @xref{Installation Directory
2327 Variables}, for the list of the preset ones related to installation
2328 directories.  Below are listed the other preset ones.  They all are
2329 precious variables (@pxref{Setting Output Variables},
2330 @code{AC_ARG_VAR}).
2332 @c Just say no to ASCII sorting!  We're humans, not computers.
2333 @c These variables are listed as they would be in a dictionary:
2334 @c actor
2335 @c Actress
2336 @c actress
2338 @defvar CFLAGS
2339 @ovindex CFLAGS
2340 Debugging and optimization options for the C compiler.  If it is not set
2341 in the environment when @command{configure} runs, the default value is set
2342 when you call @code{AC_PROG_CC} (or empty if you don't).  @command{configure}
2343 uses this variable when compiling or linking programs to test for C features.
2345 If a compiler option affects only the behavior of the preprocessor
2346 (e.g., @option{-D @var{name}}), it should be put into @code{CPPFLAGS}
2347 instead.  If it affects only the linker (e.g., @option{-L
2348 @var{directory}}), it should be put into @code{LDFLAGS} instead.  If it
2349 affects only the compiler proper, @code{CFLAGS} is the natural home for
2350 it.  If an option affects multiple phases of the compiler, though,
2351 matters get tricky.  One approach to put such options directly into
2352 @code{CC}, e.g., @code{CC='gcc -m64'}.  Another is to put them into both
2353 @code{CPPFLAGS} and @code{LDFLAGS}, but not into @code{CFLAGS}.
2355 However, remember that some @file{Makefile} variables are reserved by
2356 the GNU Coding Standards for the use of the ``user''---the person
2357 building the package.  For instance, @code{CFLAGS} is one such variable.
2359 Sometimes package developers are tempted to set user variables such as
2360 @code{CFLAGS} because it appears to make their job easier.  However, the
2361 package itself should never set a user variable, particularly not to
2362 include switches that are required for proper compilation of the
2363 package.  Since these variables are documented as being for the package
2364 builder, that person rightfully expects to be able to override any of
2365 these variables at build time.  If the package developer needs to add
2366 switches without interfering with the user, the proper way to do that is
2367 to introduce an additional variable.  Automake makes this easy by
2368 introducing @code{AM_CFLAGS} (@pxref{Flag Variables Ordering, , ,
2369 automake, @acronym{GNU} Automake}), but the concept is the same even if
2370 Automake is not used.
2371 @end defvar
2373 @defvar configure_input
2374 @ovindex configure_input
2375 A comment saying that the file was generated automatically by
2376 @command{configure} and giving the name of the input file.
2377 @code{AC_OUTPUT} adds a comment line containing this variable to the top
2378 of every makefile it creates.  For other files, you should
2379 reference this variable in a comment at the top of each input file.  For
2380 example, an input shell script should begin like this:
2382 @example
2383 #!/bin/sh
2384 # @@configure_input@@
2385 @end example
2387 @noindent
2388 The presence of that line also reminds people editing the file that it
2389 needs to be processed by @command{configure} in order to be used.
2390 @end defvar
2392 @defvar CPPFLAGS
2393 @ovindex CPPFLAGS
2394 Preprocessor options for the C, C++, and Objective C preprocessors and
2395 compilers.  If
2396 it is not set in the environment when @command{configure} runs, the default
2397 value is empty.  @command{configure} uses this variable when preprocessing
2398 or compiling programs to test for C, C++, and Objective C features.
2400 This variable's contents should contain options like @option{-I},
2401 @option{-D}, and @option{-U} that affect only the behavior of the
2402 preprocessor.  Please see the explanation of @code{CFLAGS} for what you
2403 can do if an option affects other phases of the compiler as well.
2405 Currently, @command{configure} always links as part of a single
2406 invocation of the compiler that also preprocesses and compiles, so it
2407 uses this variable also when linking programs.  However, it is unwise to
2408 depend on this behavior because the @acronym{GNU} coding standards do
2409 not require it and many packages do not use @code{CPPFLAGS} when linking
2410 programs.
2412 @xref{Special Chars in Variables}, for limitations that @code{CPPFLAGS}
2413 might run into.
2414 @end defvar
2416 @defvar CXXFLAGS
2417 @ovindex CXXFLAGS
2418 Debugging and optimization options for the C++ compiler.  It acts like
2419 @code{CFLAGS}, but for C++ instead of C.
2420 @end defvar
2422 @defvar DEFS
2423 @ovindex DEFS
2424 @option{-D} options to pass to the C compiler.  If @code{AC_CONFIG_HEADERS}
2425 is called, @command{configure} replaces @samp{@@DEFS@@} with
2426 @option{-DHAVE_CONFIG_H} instead (@pxref{Configuration Headers}).  This
2427 variable is not defined while @command{configure} is performing its tests,
2428 only when creating the output files.  @xref{Setting Output Variables}, for
2429 how to check the results of previous tests.
2430 @end defvar
2432 @defvar ECHO_C
2433 @defvarx ECHO_N
2434 @defvarx ECHO_T
2435 @ovindex ECHO_C
2436 @ovindex ECHO_N
2437 @ovindex ECHO_T
2438 How does one suppress the trailing newline from @command{echo} for
2439 question-answer message pairs?  These variables provide a way:
2441 @example
2442 echo $ECHO_N "And the winner is... $ECHO_C"
2443 sleep 100000000000
2444 echo "$@{ECHO_T@}dead."
2445 @end example
2447 @noindent
2448 Some old and uncommon @command{echo} implementations offer no means to
2449 achieve this, in which case @code{ECHO_T} is set to tab.  You might not
2450 want to use it.
2451 @end defvar
2453 @defvar ERLCFLAGS
2454 @ovindex ERLCFLAGS
2455 Debugging and optimization options for the Erlang compiler.  If it is not set
2456 in the environment when @command{configure} runs, the default value is empty.
2457 @command{configure} uses this variable when compiling
2458 programs to test for Erlang features.
2459 @end defvar
2461 @defvar FCFLAGS
2462 @ovindex FCFLAGS
2463 Debugging and optimization options for the Fortran compiler.  If it
2464 is not set in the environment when @command{configure} runs, the default
2465 value is set when you call @code{AC_PROG_FC} (or empty if you don't).
2466 @command{configure} uses this variable when compiling or linking
2467 programs to test for Fortran features.
2468 @end defvar
2470 @defvar FFLAGS
2471 @ovindex FFLAGS
2472 Debugging and optimization options for the Fortran 77 compiler.  If it
2473 is not set in the environment when @command{configure} runs, the default
2474 value is set when you call @code{AC_PROG_F77} (or empty if you don't).
2475 @command{configure} uses this variable when compiling or linking
2476 programs to test for Fortran 77 features.
2477 @end defvar
2479 @defvar LDFLAGS
2480 @ovindex LDFLAGS
2481 Options for the linker.  If it is not set
2482 in the environment when @command{configure} runs, the default value is empty.
2483 @command{configure} uses this variable when linking programs to test for
2484 C, C++, Objective C, and Fortran features.
2486 This variable's contents should contain options like @option{-s} and
2487 @option{-L} that affect only the behavior of the linker.  Please see the
2488 explanation of @code{CFLAGS} for what you can do if an option also
2489 affects other phases of the compiler.
2491 Don't use this variable to pass library names
2492 (@option{-l}) to the linker; use @code{LIBS} instead.
2493 @end defvar
2495 @defvar LIBS
2496 @ovindex LIBS
2497 @option{-l} options to pass to the linker.  The default value is empty,
2498 but some Autoconf macros may prepend extra libraries to this variable if
2499 those libraries are found and provide necessary functions, see
2500 @ref{Libraries}.  @command{configure} uses this variable when linking
2501 programs to test for C, C++, and Fortran features.
2502 @end defvar
2504 @defvar OBJCFLAGS
2505 @ovindex OBJCFLAGS
2506 Debugging and optimization options for the Objective C compiler.  It
2507 acts like @code{CFLAGS}, but for Objective C instead of C.
2508 @end defvar
2510 @defvar builddir
2511 @ovindex builddir
2512 Rigorously equal to @samp{.}.  Added for symmetry only.
2513 @end defvar
2515 @defvar abs_builddir
2516 @ovindex abs_builddir
2517 Absolute name of @code{builddir}.
2518 @end defvar
2520 @defvar top_builddir
2521 @ovindex top_builddir
2522 The relative name of the top level of the current build tree.  In the
2523 top-level directory, this is the same as @code{builddir}.
2524 @end defvar
2526 @defvar top_build_prefix
2527 @ovindex top_build_prefix
2528 The relative name of the top level of the current build tree with final
2529 slash if nonemtpy.  This is the same as @code{top_builddir}, except that
2530 it contains zero or more runs of @code{../}, so it should not be
2531 appended with a slash for concatenation.  This helps for @command{make}
2532 implementations that otherwise do not treat @file{./file} and @file{file}
2533 as equal in the toplevel build directory.
2534 @end defvar
2536 @defvar abs_top_builddir
2537 @ovindex abs_top_builddir
2538 Absolute name of @code{top_builddir}.
2539 @end defvar
2541 @defvar srcdir
2542 @ovindex srcdir
2543 The name of the directory that contains the source code for
2544 that makefile.
2545 @end defvar
2547 @defvar abs_srcdir
2548 @ovindex abs_srcdir
2549 Absolute name of @code{srcdir}.
2550 @end defvar
2552 @defvar top_srcdir
2553 @ovindex top_srcdir
2554 The name of the top-level source code directory for the
2555 package.  In the top-level directory, this is the same as @code{srcdir}.
2556 @end defvar
2558 @defvar abs_top_srcdir
2559 @ovindex abs_top_srcdir
2560 Absolute name of @code{top_srcdir}.
2561 @end defvar
2563 @node Installation Directory Variables
2564 @subsection Installation Directory Variables
2565 @cindex Installation directories
2566 @cindex Directories, installation
2568 The following variables specify the directories for
2569 package installation, see @ref{Directory Variables, , Variables for
2570 Installation Directories, standards, The @acronym{GNU} Coding
2571 Standards}, for more information.  Each variable corresponds to an
2572 argument of @command{configure}; trailing slashes are stripped so that
2573 expressions such as @samp{$@{prefix@}/lib} expand with only one slash
2574 between directory names.  See the end of this section for
2575 details on when and how to use these variables.
2577 @defvar bindir
2578 @ovindex bindir
2579 The directory for installing executables that users run.
2580 @end defvar
2582 @defvar datadir
2583 @ovindex datadir
2584 The directory for installing idiosyncratic read-only
2585 architecture-independent data.
2586 @end defvar
2588 @defvar datarootdir
2589 @ovindex datarootdir
2590 The root of the directory tree for read-only architecture-independent
2591 data files.
2592 @end defvar
2594 @defvar docdir
2595 @ovindex docdir
2596 The directory for installing documentation files (other than Info and
2597 man).
2598 @end defvar
2600 @defvar dvidir
2601 @ovindex dvidir
2602 The directory for installing documentation files in DVI format.
2603 @end defvar
2605 @defvar exec_prefix
2606 @ovindex exec_prefix
2607 The installation prefix for architecture-dependent files.  By default
2608 it's the same as @var{prefix}.  You should avoid installing anything
2609 directly to @var{exec_prefix}.  However, the default value for
2610 directories containing architecture-dependent files should be relative
2611 to @var{exec_prefix}.
2612 @end defvar
2614 @defvar htmldir
2615 @ovindex htmldir
2616 The directory for installing HTML documentation.
2617 @end defvar
2619 @defvar includedir
2620 @ovindex includedir
2621 The directory for installing C header files.
2622 @end defvar
2624 @defvar infodir
2625 @ovindex infodir
2626 The directory for installing documentation in Info format.
2627 @end defvar
2629 @defvar libdir
2630 @ovindex libdir
2631 The directory for installing object code libraries.
2632 @end defvar
2634 @defvar libexecdir
2635 @ovindex libexecdir
2636 The directory for installing executables that other programs run.
2637 @end defvar
2639 @defvar localedir
2640 @ovindex localedir
2641 The directory for installing locale-dependent but
2642 architecture-independent data, such as message catalogs.  This directory
2643 usually has a subdirectory per locale.
2644 @end defvar
2646 @defvar localstatedir
2647 @ovindex localstatedir
2648 The directory for installing modifiable single-machine data.
2649 @end defvar
2651 @defvar mandir
2652 @ovindex mandir
2653 The top-level directory for installing documentation in man format.
2654 @end defvar
2656 @defvar oldincludedir
2657 @ovindex oldincludedir
2658 The directory for installing C header files for non-@acronym{GCC} compilers.
2659 @end defvar
2661 @defvar pdfdir
2662 @ovindex pdfdir
2663 The directory for installing PDF documentation.
2664 @end defvar
2666 @defvar prefix
2667 @ovindex prefix
2668 The common installation prefix for all files.  If @var{exec_prefix}
2669 is defined to a different value, @var{prefix} is used only for
2670 architecture-independent files.
2671 @end defvar
2673 @defvar psdir
2674 @ovindex psdir
2675 The directory for installing PostScript documentation.
2676 @end defvar
2678 @defvar sbindir
2679 @ovindex sbindir
2680 The directory for installing executables that system
2681 administrators run.
2682 @end defvar
2684 @defvar sharedstatedir
2685 @ovindex sharedstatedir
2686 The directory for installing modifiable architecture-independent data.
2687 @end defvar
2689 @defvar sysconfdir
2690 @ovindex sysconfdir
2691 The directory for installing read-only single-machine data.
2692 @end defvar
2695 Most of these variables have values that rely on @code{prefix} or
2696 @code{exec_prefix}.  It is deliberate that the directory output
2697 variables keep them unexpanded: typically @samp{@@datarootdir@@} is
2698 replaced by @samp{$@{prefix@}/share}, not @samp{/usr/local/share}, and
2699 @samp{@@datadir@@} is replaced by @samp{$@{datarootdir@}}.
2701 This behavior is mandated by the @acronym{GNU} coding standards, so that when
2702 the user runs:
2704 @table @samp
2705 @item make
2706 she can still specify a different prefix from the one specified to
2707 @command{configure}, in which case, if needed, the package should hard
2708 code dependencies corresponding to the make-specified prefix.
2710 @item make install
2711 she can specify a different installation location, in which case the
2712 package @emph{must} still depend on the location which was compiled in
2713 (i.e., never recompile when @samp{make install} is run).  This is an
2714 extremely important feature, as many people may decide to install all
2715 the files of a package grouped together, and then install links from
2716 the final locations to there.
2717 @end table
2719 In order to support these features, it is essential that
2720 @code{datarootdir} remains defined as @samp{$@{prefix@}/share},
2721 so that its value can be expanded based
2722 on the current value of @code{prefix}.
2724 A corollary is that you should not use these variables except in
2725 makefiles.  For instance, instead of trying to evaluate @code{datadir}
2726 in @file{configure} and hard-coding it in makefiles using
2727 e.g., @samp{AC_DEFINE_UNQUOTED([DATADIR], ["$datadir"], [Data directory.])},
2728 you should add
2729 @option{-DDATADIR='$(datadir)'} to your makefile's definition of
2730 @code{CPPFLAGS} (@code{AM_CPPFLAGS} if you are also using Automake).
2732 Similarly, you should not rely on @code{AC_CONFIG_FILES} to replace
2733 @code{bindir} and friends in your shell scripts and other files; instead,
2734 let @command{make} manage their replacement.  For instance Autoconf
2735 ships templates of its shell scripts ending with @samp{.in}, and uses a
2736 makefile snippet similar to the following to build scripts like
2737 @command{autoheader} and @command{autom4te}:
2739 @example
2740 @group
2741 edit = sed \
2742         -e 's|@@bindir[@@]|$(bindir)|g' \
2743         -e 's|@@pkgdatadir[@@]|$(pkgdatadir)|g' \
2744         -e 's|@@prefix[@@]|$(prefix)|g'
2745 @end group
2747 @group
2748 autoheader autom4te: Makefile
2749         rm -f $@@ $@@.tmp
2750         srcdir=''; \
2751           test -f ./$@@.in || srcdir=$(srcdir)/; \
2752           $(edit) $$@{srcdir@}$@@.in >$@@.tmp
2753         chmod +x $@@.tmp
2754         chmod a-w $@@.tmp
2755         mv $@@.tmp $@@
2756 @end group
2758 @group
2759 autoheader: $(srcdir)/autoheader.in
2760 autom4te: $(srcdir)/autom4te.in
2761 @end group
2762 @end example
2764 Some details are noteworthy:
2766 @table @asis
2767 @item @samp{@@bindir[@@]}
2768 The brackets prevent @command{configure} from replacing
2769 @samp{@@bindir@@} in the Sed expression itself.
2770 Brackets are preferable to a backslash here, since
2771 Posix says @samp{\@@} is not portable.
2773 @item @samp{$(bindir)}
2774 Don't use @samp{@@bindir@@}!  Use the matching makefile variable
2775 instead.
2777 @item @samp{$(pkgdatadir)}
2778 The example takes advantage of the variable @samp{$(pkgdatadir)}
2779 provided by Automake; it is equivalent to @samp{$(datadir)/$(PACKAGE)}.
2781 @item @samp{/}
2782 Don't use @samp{/} in the Sed expressions that replace file names since
2783 most likely the
2784 variables you use, such as @samp{$(bindir)}, contain @samp{/}.
2785 Use a shell metacharacter instead, such as @samp{|}.
2787 @item special characters
2788 File names, file name components, and the value of @code{VPATH} should
2789 not contain shell metacharacters or white
2790 space.  @xref{Special Chars in Variables}.
2792 @item dependency on @file{Makefile}
2793 Since @code{edit} uses values that depend on the configuration specific
2794 values (@code{prefix}, etc.)@: and not only on @code{VERSION} and so forth,
2795 the output depends on @file{Makefile}, not @file{configure.ac}.
2797 @item @samp{$@@}
2798 The main rule is generic, and uses @samp{$@@} extensively to
2799 avoid the need for multiple copies of the rule.
2801 @item Separated dependencies and single suffix rules
2802 You can't use them!  The above snippet cannot be (portably) rewritten
2805 @example
2806 autoconf autoheader: Makefile
2807 @group
2808 .in:
2809         rm -f $@@ $@@.tmp
2810         $(edit) $< >$@@.tmp
2811         chmod +x $@@.tmp
2812         mv $@@.tmp $@@
2813 @end group
2814 @end example
2816 @xref{Single Suffix Rules}, for details.
2818 @item @samp{$(srcdir)}
2819 Be sure to specify the name of the source directory,
2820 otherwise the package won't support separated builds.
2821 @end table
2823 For the more specific installation of Erlang libraries, the following variables
2824 are defined:
2826 @defvar ERLANG_INSTALL_LIB_DIR
2827 @ovindex ERLANG_INSTALL_LIB_DIR
2828 @acindex{ERLANG_SUBST_INSTALL_LIB_DIR}
2829 The common parent directory of Erlang library installation directories.
2830 This variable is set by calling the @code{AC_ERLANG_SUBST_INSTALL_LIB_DIR}
2831 macro in @file{configure.ac}.
2832 @end defvar
2834 @defvar ERLANG_INSTALL_LIB_DIR_@var{library}
2835 @ovindex ERLANG_INSTALL_LIB_DIR_@var{library}
2836 @acindex{ERLANG_SUBST_INSTALL_LIB_SUBDIR}
2837 The installation directory for Erlang library @var{library}.
2838 This variable is set by using the
2839 @samp{AC_ERLANG_SUBST_INSTALL_LIB_SUBDIR}
2840 macro in @file{configure.ac}.
2841 @end defvar
2843 @xref{Erlang Libraries}, for details.
2846 @node Changed Directory Variables
2847 @subsection Changed Directory Variables
2848 @cindex @file{datarootdir}
2850 In Autoconf 2.60, the set of directory variables has changed, and the
2851 defaults of some variables have been adjusted
2852 (@pxref{Installation Directory Variables}) to changes in the
2853 @acronym{GNU} Coding Standards.  Notably, @file{datadir}, @file{infodir}, and
2854 @file{mandir} are now expressed in terms of @file{datarootdir}.  If you are
2855 upgrading from an earlier Autoconf version, you may need to adjust your files
2856 to ensure that the directory variables are substituted correctly
2857 (@pxref{Defining Directories}), and that a definition of @file{datarootdir} is
2858 in place.  For example, in a @file{Makefile.in}, adding
2860 @example
2861 datarootdir = @@datarootdir@@
2862 @end example
2864 @noindent
2865 is usually sufficient.  If you use Automake to create @file{Makefile.in},
2866 it will add this for you.
2868 To help with the transition, Autoconf warns about files that seem to use
2869 @code{datarootdir} without defining it.  In some cases, it then expands
2870 the value of @code{$datarootdir} in substitutions of the directory
2871 variables.  The following example shows such a warning:
2873 @example
2874 $ @kbd{cat configure.ac}
2875 AC_INIT
2876 AC_CONFIG_FILES([Makefile])
2877 AC_OUTPUT
2878 $ @kbd{cat Makefile.in}
2879 prefix = @@prefix@@
2880 datadir = @@datadir@@
2881 $ @kbd{autoconf}
2882 $ @kbd{configure}
2883 configure: creating ./config.status
2884 config.status: creating Makefile
2885 config.status: WARNING:
2886                Makefile.in seems to ignore the --datarootdir setting
2887 $ @kbd{cat Makefile}
2888 prefix = /usr/local
2889 datadir = $@{prefix@}/share
2890 @end example
2892 Usually one can easily change the file to accommodate both older and newer
2893 Autoconf releases:
2895 @example
2896 $ @kbd{cat Makefile.in}
2897 prefix = @@prefix@@
2898 datarootdir = @@datarootdir@@
2899 datadir = @@datadir@@
2900 $ @kbd{configure}
2901 configure: creating ./config.status
2902 config.status: creating Makefile
2903 $ @kbd{cat Makefile}
2904 prefix = /usr/local
2905 datarootdir = $@{prefix@}/share
2906 datadir = $@{datarootdir@}
2907 @end example
2909 @acindex{DATAROOTDIR_CHECKED}
2910 In some cases, however, the checks may not be able to detect that a suitable
2911 initialization of @code{datarootdir} is in place, or they may fail to detect
2912 that such an initialization is necessary in the output file.  If, after
2913 auditing your package, there are still spurious @file{configure} warnings about
2914 @code{datarootdir}, you may add the line
2916 @example
2917 AC_DEFUN([AC_DATAROOTDIR_CHECKED])
2918 @end example
2920 @noindent
2921 to your @file{configure.ac} to disable the warnings.  This is an exception
2922 to the usual rule that you should not define a macro whose name begins with
2923 @code{AC_} (@pxref{Macro Names}).
2927 @node Build Directories
2928 @subsection Build Directories
2929 @cindex Build directories
2930 @cindex Directories, build
2932 You can support compiling a software package for several architectures
2933 simultaneously from the same copy of the source code.  The object files
2934 for each architecture are kept in their own directory.
2936 To support doing this, @command{make} uses the @code{VPATH} variable to
2937 find the files that are in the source directory.  @acronym{GNU} Make
2938 can do this.  Most other recent @command{make} programs can do this as
2939 well, though they may have difficulties and it is often simpler to
2940 recommend @acronym{GNU} @command{make} (@pxref{VPATH and Make}).  Older
2941 @command{make} programs do not support @code{VPATH}; when using them, the
2942 source code must be in the same directory as the object files.
2944 If you are using @acronym{GNU} Automake, the remaining details in this
2945 section are already covered for you, based on the contents of your
2946 @file{Makefile.am}.  But if you are using Autoconf in isolation, then
2947 supporting @code{VPATH} requires the following in your
2948 @file{Makefile.in}:
2950 @example
2951 srcdir = @@srcdir@@
2952 VPATH = @@srcdir@@
2953 @end example
2955 Do not set @code{VPATH} to the value of another variable, for example
2956 @samp{VPATH = $(srcdir)}, because some versions of @command{make} do not do
2957 variable substitutions on the value of @code{VPATH}.
2959 @command{configure} substitutes the correct value for @code{srcdir} when
2960 it produces @file{Makefile}.
2962 Do not use the @command{make} variable @code{$<}, which expands to the
2963 file name of the file in the source directory (found with @code{VPATH}),
2964 except in implicit rules.  (An implicit rule is one such as @samp{.c.o},
2965 which tells how to create a @file{.o} file from a @file{.c} file.)  Some
2966 versions of @command{make} do not set @code{$<} in explicit rules; they
2967 expand it to an empty value.
2969 Instead, Make command lines should always refer to source
2970 files by prefixing them with @samp{$(srcdir)/}.  For example:
2972 @example
2973 time.info: time.texinfo
2974         $(MAKEINFO) '$(srcdir)/time.texinfo'
2975 @end example
2977 @node Automatic Remaking
2978 @subsection Automatic Remaking
2979 @cindex Automatic remaking
2980 @cindex Remaking automatically
2982 You can put rules like the following in the top-level @file{Makefile.in}
2983 for a package to automatically update the configuration information when
2984 you change the configuration files.  This example includes all of the
2985 optional files, such as @file{aclocal.m4} and those related to
2986 configuration header files.  Omit from the @file{Makefile.in} rules for
2987 any of these files that your package does not use.
2989 The @samp{$(srcdir)/} prefix is included because of limitations in the
2990 @code{VPATH} mechanism.
2992 The @file{stamp-} files are necessary because the timestamps of
2993 @file{config.h.in} and @file{config.h} are not changed if remaking
2994 them does not change their contents.  This feature avoids unnecessary
2995 recompilation.  You should include the file @file{stamp-h.in} in your
2996 package's distribution, so that @command{make} considers
2997 @file{config.h.in} up to date.  Don't use @command{touch}
2998 (@pxref{touch, , Limitations of Usual Tools}); instead, use
2999 @command{echo} (using
3000 @command{date} would cause needless differences, hence @acronym{CVS}
3001 conflicts, etc.).
3003 @example
3004 @group
3005 $(srcdir)/configure: configure.ac aclocal.m4
3006         cd '$(srcdir)' && autoconf
3008 # autoheader might not change config.h.in, so touch a stamp file.
3009 $(srcdir)/config.h.in: stamp-h.in
3010 $(srcdir)/stamp-h.in: configure.ac aclocal.m4
3011         cd '$(srcdir)' && autoheader
3012         echo timestamp > '$(srcdir)/stamp-h.in'
3014 config.h: stamp-h
3015 stamp-h: config.h.in config.status
3016         ./config.status
3018 Makefile: Makefile.in config.status
3019         ./config.status
3021 config.status: configure
3022         ./config.status --recheck
3023 @end group
3024 @end example
3026 @noindent
3027 (Be careful if you copy these lines directly into your makefile, as you
3028 need to convert the indented lines to start with the tab character.)
3030 In addition, you should use
3032 @example
3033 AC_CONFIG_FILES([stamp-h], [echo timestamp > stamp-h])
3034 @end example
3036 @noindent
3037 so @file{config.status} ensures that @file{config.h} is considered up to
3038 date.  @xref{Output}, for more information about @code{AC_OUTPUT}.
3040 @xref{config.status Invocation}, for more examples of handling
3041 configuration-related dependencies.
3043 @node Configuration Headers
3044 @section Configuration Header Files
3045 @cindex Configuration Header
3046 @cindex @file{config.h}
3048 When a package contains more than a few tests that define C preprocessor
3049 symbols, the command lines to pass @option{-D} options to the compiler
3050 can get quite long.  This causes two problems.  One is that the
3051 @command{make} output is hard to visually scan for errors.  More
3052 seriously, the command lines can exceed the length limits of some
3053 operating systems.  As an alternative to passing @option{-D} options to
3054 the compiler, @command{configure} scripts can create a C header file
3055 containing @samp{#define} directives.  The @code{AC_CONFIG_HEADERS}
3056 macro selects this kind of output.  Though it can be called anywhere
3057 between @code{AC_INIT} and @code{AC_OUTPUT}, it is customary to call
3058 it right after @code{AC_INIT}.
3060 The package should @samp{#include} the configuration header file before
3061 any other header files, to prevent inconsistencies in declarations (for
3062 example, if it redefines @code{const}).
3064 To provide for VPATH builds, remember to pass the C compiler a @option{-I.}
3065 option (or @option{-I..}; whichever directory contains @file{config.h}).
3066 Even if you use @samp{#include "config.h"}, the preprocessor searches only
3067 the directory of the currently read file, i.e., the source directory, not
3068 the build directory.
3070 With the appropriate @option{-I} option, you can use
3071 @samp{#include <config.h>}.  Actually, it's a good habit to use it,
3072 because in the rare case when the source directory contains another
3073 @file{config.h}, the build directory should be searched first.
3076 @defmac AC_CONFIG_HEADERS (@var{header} @dots{}, @ovar{cmds}, @ovar{init-cmds})
3077 @acindex{CONFIG_HEADERS}
3078 @cvindex HAVE_CONFIG_H
3079 This macro is one of the instantiating macros; see @ref{Configuration
3080 Actions}.  Make @code{AC_OUTPUT} create the file(s) in the
3081 blank-or-newline-separated list @var{header} containing C preprocessor
3082 @code{#define} statements, and replace @samp{@@DEFS@@} in generated
3083 files with @option{-DHAVE_CONFIG_H} instead of the value of @code{DEFS}.
3084 The usual name for @var{header} is @file{config.h}.
3086 If @var{header} already exists and its contents are identical to what
3087 @code{AC_OUTPUT} would put in it, it is left alone.  Doing this allows
3088 making some changes in the configuration without needlessly causing
3089 object files that depend on the header file to be recompiled.
3091 Usually the input file is named @file{@var{header}.in}; however, you can
3092 override the input file name by appending to @var{header} a
3093 colon-separated list of input files.  For example, you might need to make
3094 the input file name acceptable to @acronym{DOS} variants:
3096 @example
3097 AC_CONFIG_HEADERS([config.h:config.hin])
3098 @end example
3100 @end defmac
3102 @defmac AH_HEADER
3103 @ahindex{HEADER}
3104 This macro is defined as the name of the first declared config header
3105 and undefined if no config headers have been declared up to this point.
3106 A third-party macro may, for example, require use of a config header
3107 without invoking AC_CONFIG_HEADERS twice, like this:
3109 @example
3110 AC_CONFIG_COMMANDS_PRE(
3111         [m4_ifndef([AH_HEADER], [AC_CONFIG_HEADERS([config.h])])])
3112 @end example
3114 @end defmac
3116 @xref{Configuration Actions}, for more details on @var{header}.
3118 @menu
3119 * Header Templates::            Input for the configuration headers
3120 * autoheader Invocation::       How to create configuration templates
3121 * Autoheader Macros::           How to specify CPP templates
3122 @end menu
3124 @node Header Templates
3125 @subsection Configuration Header Templates
3126 @cindex Configuration Header Template
3127 @cindex Header templates
3128 @cindex @file{config.h.in}
3130 Your distribution should contain a template file that looks as you want
3131 the final header file to look, including comments, with @code{#undef}
3132 statements which are used as hooks.  For example, suppose your
3133 @file{configure.ac} makes these calls:
3135 @example
3136 AC_CONFIG_HEADERS([conf.h])
3137 AC_CHECK_HEADERS([unistd.h])
3138 @end example
3140 @noindent
3141 Then you could have code like the following in @file{conf.h.in}.
3142 The @file{conf.h} created by @command{configure} defines @samp{HAVE_UNISTD_H}
3143 to 1, if and only if the system has @file{unistd.h}.
3145 @example
3146 @group
3147 /* Define as 1 if you have unistd.h.  */
3148 #undef HAVE_UNISTD_H
3149 @end group
3150 @end example
3152 The format of the template file is stricter than what the C preprocessor
3153 is required to accept.  A directive line should contain only whitespace,
3154 @samp{#undef}, and @samp{HAVE_UNISTD_H}.  The use of @samp{#define}
3155 instead of @samp{#undef}, or of comments on the same line as
3156 @samp{#undef}, is strongly discouraged.  Each hook should only be listed
3157 once.  Other preprocessor lines, such as @samp{#ifdef} or
3158 @samp{#include}, are copied verbatim from the template into the
3159 generated header.
3161 Since it is a tedious task to keep a template header up to date, you may
3162 use @command{autoheader} to generate it, see @ref{autoheader Invocation}.
3164 During the instantiation of the header, each @samp{#undef} line in the
3165 template file for each symbol defined by @samp{AC_DEFINE} is changed to an
3166 appropriate @samp{#define}. If the corresponding @samp{AC_DEFINE} has not
3167 been executed during the @command{configure} run, the @samp{#undef} line is
3168 commented out.  (This is important, e.g., for @samp{_POSIX_SOURCE}:
3169 on many systems, it can be implicitly defined by the compiler, and
3170 undefining it in the header would then break compilation of subsequent
3171 headers.)
3173 Currently, @emph{all} remaining @samp{#undef} lines in the header
3174 template are commented out, whether or not there was a corresponding
3175 @samp{AC_DEFINE} for the macro name; but this behavior is not guaranteed
3176 for future releases of Autoconf.
3178 Generally speaking, since you should not use @samp{#define}, and you
3179 cannot guarantee whether a @samp{#undef} directive in the header
3180 template will be converted to a @samp{#define} or commented out in the
3181 generated header file, the template file cannot be used for conditional
3182 definition effects.  Consequently, if you need to use the construct
3184 @example
3185 @group
3186 #ifdef THIS
3187 # define THAT
3188 #endif
3189 @end group
3190 @end example
3192 @noindent
3193 you must place it outside of the template.
3194 If you absolutely need to hook it to the config header itself, please put
3195 the directives to a separate file, and @samp{#include} that file from the
3196 config header template.  If you are using @command{autoheader}, you would
3197 probably use @samp{AH_BOTTOM} to append the @samp{#include} directive.
3200 @node autoheader Invocation
3201 @subsection Using @command{autoheader} to Create @file{config.h.in}
3202 @cindex @command{autoheader}
3204 The @command{autoheader} program can create a template file of C
3205 @samp{#define} statements for @command{configure} to use.
3206 It searches for the first invocation of @code{AC_CONFIG_HEADERS} in
3207 @file{configure} sources to determine the name of the template.
3208 (If the first call of @code{AC_CONFIG_HEADERS} specifies more than one
3209 input file name, @command{autoheader} uses the first one.)
3211 It is recommended that only one input file is used.  If you want to append
3212 a boilerplate code, it is preferable to use
3213 @samp{AH_BOTTOM([#include <conf_post.h>])}.
3214 File @file{conf_post.h} is not processed during the configuration then,
3215 which make things clearer.  Analogically, @code{AH_TOP} can be used to
3216 prepend a boilerplate code.
3218 In order to do its job, @command{autoheader} needs you to document all
3219 of the symbols that you might use.  Typically this is done via an
3220 @code{AC_DEFINE} or @code{AC_DEFINE_UNQUOTED} call whose first argument
3221 is a literal symbol and whose third argument describes the symbol
3222 (@pxref{Defining Symbols}).  Alternatively, you can use
3223 @code{AH_TEMPLATE} (@pxref{Autoheader Macros}), or you can supply a
3224 suitable input file for a subsequent configuration header file.
3225 Symbols defined by Autoconf's builtin tests are already documented properly;
3226 you need to document only those that you
3227 define yourself.
3229 You might wonder why @command{autoheader} is needed: after all, why
3230 would @command{configure} need to ``patch'' a @file{config.h.in} to
3231 produce a @file{config.h} instead of just creating @file{config.h} from
3232 scratch?  Well, when everything rocks, the answer is just that we are
3233 wasting our time maintaining @command{autoheader}: generating
3234 @file{config.h} directly is all that is needed.  When things go wrong,
3235 however, you'll be thankful for the existence of @command{autoheader}.
3237 The fact that the symbols are documented is important in order to
3238 @emph{check} that @file{config.h} makes sense.  The fact that there is a
3239 well-defined list of symbols that should be defined (or not) is
3240 also important for people who are porting packages to environments where
3241 @command{configure} cannot be run: they just have to @emph{fill in the
3242 blanks}.
3244 But let's come back to the point: the invocation of @command{autoheader}@dots{}
3246 If you give @command{autoheader} an argument, it uses that file instead
3247 of @file{configure.ac} and writes the header file to the standard output
3248 instead of to @file{config.h.in}.  If you give @command{autoheader} an
3249 argument of @option{-}, it reads the standard input instead of
3250 @file{configure.ac} and writes the header file to the standard output.
3252 @command{autoheader} accepts the following options:
3254 @table @option
3255 @item --help
3256 @itemx -h
3257 Print a summary of the command line options and exit.
3259 @item --version
3260 @itemx -V
3261 Print the version number of Autoconf and exit.
3263 @item --verbose
3264 @itemx -v
3265 Report processing steps.
3267 @item --debug
3268 @itemx -d
3269 Don't remove the temporary files.
3271 @item --force
3272 @itemx -f
3273 Remake the template file even if newer than its input files.
3275 @item --include=@var{dir}
3276 @itemx -I @var{dir}
3277 Append @var{dir} to the include path.  Multiple invocations accumulate.
3279 @item --prepend-include=@var{dir}
3280 @itemx -B @var{dir}
3281 Prepend @var{dir} to the include path.  Multiple invocations accumulate.
3283 @item --warnings=@var{category}
3284 @itemx -W @var{category}
3285 @evindex WARNINGS
3286 Report the warnings related to @var{category} (which can actually be a
3287 comma separated list).  Current categories include:
3289 @table @samp
3290 @item obsolete
3291 report the uses of obsolete constructs
3293 @item all
3294 report all the warnings
3296 @item none
3297 report none
3299 @item error
3300 treats warnings as errors
3302 @item no-@var{category}
3303 disable warnings falling into @var{category}
3304 @end table
3306 @end table
3310 @node Autoheader Macros
3311 @subsection Autoheader Macros
3312 @cindex Autoheader macros
3314 @command{autoheader} scans @file{configure.ac} and figures out which C
3315 preprocessor symbols it might define.  It knows how to generate
3316 templates for symbols defined by @code{AC_CHECK_HEADERS},
3317 @code{AC_CHECK_FUNCS} etc., but if you @code{AC_DEFINE} any additional
3318 symbol, you must define a template for it.  If there are missing
3319 templates, @command{autoheader} fails with an error message.
3321 The template for a @var{symbol} is created
3322 by @command{autoheader} from
3323 the @var{description} argument to an @code{AC_DEFINE};
3324 see @ref{Defining Symbols}.
3326 For special needs, you can use the following macros.
3329 @defmac AH_TEMPLATE (@var{key}, @var{description})
3330 @ahindex{TEMPLATE}
3331 Tell @command{autoheader} to generate a template for @var{key}.  This macro
3332 generates standard templates just like @code{AC_DEFINE} when a
3333 @var{description} is given.
3335 For example:
3337 @example
3338 AH_TEMPLATE([CRAY_STACKSEG_END],
3339             [Define to one of _getb67, GETB67, getb67
3340              for Cray-2 and Cray-YMP systems.  This
3341              function is required for alloca.c support
3342              on those systems.])
3343 @end example
3345 @noindent
3346 generates the following template, with the description properly
3347 justified.
3349 @example
3350 /* Define to one of _getb67, GETB67, getb67 for Cray-2 and
3351    Cray-YMP systems.  This function is required for alloca.c
3352    support on those systems.  */
3353 #undef CRAY_STACKSEG_END
3354 @end example
3355 @end defmac
3358 @defmac AH_VERBATIM (@var{key}, @var{template})
3359 @ahindex{VERBATIM}
3360 Tell @command{autoheader} to include the @var{template} as-is in the header
3361 template file.  This @var{template} is associated with the @var{key},
3362 which is used to sort all the different templates and guarantee their
3363 uniqueness.  It should be a symbol that can be defined via @code{AC_DEFINE}.
3364 @end defmac
3367 @defmac AH_TOP (@var{text})
3368 @ahindex{TOP}
3369 Include @var{text} at the top of the header template file.
3370 @end defmac
3373 @defmac AH_BOTTOM (@var{text})
3374 @ahindex{BOTTOM}
3375 Include @var{text} at the bottom of the header template file.
3376 @end defmac
3379 Please note that @var{text} gets included ``verbatim'' to the template file,
3380 not to the resulting config header, so it can easily get mangled when the
3381 template is processed.  There is rarely a need for something other than
3383 @example
3384 AH_BOTTOM([#include <custom.h>])
3385 @end example
3389 @node Configuration Commands
3390 @section Running Arbitrary Configuration Commands
3391 @cindex Configuration commands
3392 @cindex Commands for configuration
3394 You can execute arbitrary commands before, during, and after
3395 @file{config.status} is run.  The three following macros accumulate the
3396 commands to run when they are called multiple times.
3397 @code{AC_CONFIG_COMMANDS} replaces the obsolete macro
3398 @code{AC_OUTPUT_COMMANDS}; see @ref{Obsolete Macros}, for details.
3400 @anchor{AC_CONFIG_COMMANDS}
3401 @defmac AC_CONFIG_COMMANDS (@var{tag}@dots{}, @ovar{cmds}, @ovar{init-cmds})
3402 @acindex{CONFIG_COMMANDS}
3403 Specify additional shell commands to run at the end of
3404 @file{config.status}, and shell commands to initialize any variables
3405 from @command{configure}.  Associate the commands with @var{tag}.
3406 Since typically the @var{cmds} create a file, @var{tag} should
3407 naturally be the name of that file.  If needed, the directory hosting
3408 @var{tag} is created.  This macro is one of the instantiating macros;
3409 see @ref{Configuration Actions}.
3411 Here is an unrealistic example:
3412 @example
3413 fubar=42
3414 AC_CONFIG_COMMANDS([fubar],
3415                    [echo this is extra $fubar, and so on.],
3416                    [fubar=$fubar])
3417 @end example
3419 Here is a better one:
3420 @example
3421 AC_CONFIG_COMMANDS([timestamp], [date >timestamp])
3422 @end example
3423 @end defmac
3425 The following two macros look similar, but in fact they are not of the same
3426 breed: they are executed directly by @file{configure}, so you cannot use
3427 @file{config.status} to rerun them.
3429 @c Yet it is good to leave them here.  The user sees them together and
3430 @c decides which best fits their needs.
3432 @defmac AC_CONFIG_COMMANDS_PRE (@var{cmds})
3433 @acindex{CONFIG_COMMANDS_PRE}
3434 Execute the @var{cmds} right before creating @file{config.status}.
3436 This macro presents the last opportunity to call @code{AC_SUBST},
3437 @code{AC_DEFINE}, or @code{AC_CONFIG_@var{ITEMS}} macros.
3438 @end defmac
3440 @defmac AC_CONFIG_COMMANDS_POST (@var{cmds})
3441 @acindex{CONFIG_COMMANDS_POST}
3442 Execute the @var{cmds} right after creating @file{config.status}.
3443 @end defmac
3448 @node Configuration Links
3449 @section Creating Configuration Links
3450 @cindex Configuration links
3451 @cindex Links for configuration
3453 You may find it convenient to create links whose destinations depend upon
3454 results of tests.  One can use @code{AC_CONFIG_COMMANDS} but the
3455 creation of relative symbolic links can be delicate when the package is
3456 built in a directory different from the source directory.
3458 @anchor{AC_CONFIG_LINKS}
3459 @defmac AC_CONFIG_LINKS (@var{dest}:@var{source}@dots{}, @ovar{cmds}, @
3460   @ovar{init-cmds})
3461 @acindex{CONFIG_LINKS}
3462 @cindex Links
3463 Make @code{AC_OUTPUT} link each of the existing files @var{source} to
3464 the corresponding link name @var{dest}.  Makes a symbolic link if
3465 possible, otherwise a hard link if possible, otherwise a copy.  The
3466 @var{dest} and @var{source} names should be relative to the top level
3467 source or build directory.  This macro is one of the instantiating
3468 macros; see @ref{Configuration Actions}.
3470 For example, this call:
3472 @example
3473 AC_CONFIG_LINKS([host.h:config/$machine.h
3474                 object.h:config/$obj_format.h])
3475 @end example
3477 @noindent
3478 creates in the current directory @file{host.h} as a link to
3479 @file{@var{srcdir}/config/$machine.h}, and @file{object.h} as a
3480 link to @file{@var{srcdir}/config/$obj_format.h}.
3482 The tempting value @samp{.} for @var{dest} is invalid: it makes it
3483 impossible for @samp{config.status} to guess the links to establish.
3485 One can then run:
3486 @example
3487 ./config.status host.h object.h
3488 @end example
3489 @noindent
3490 to create the links.
3491 @end defmac
3495 @node Subdirectories
3496 @section Configuring Other Packages in Subdirectories
3497 @cindex Configure subdirectories
3498 @cindex Subdirectory configure
3500 In most situations, calling @code{AC_OUTPUT} is sufficient to produce
3501 makefiles in subdirectories.  However, @command{configure} scripts
3502 that control more than one independent package can use
3503 @code{AC_CONFIG_SUBDIRS} to run @command{configure} scripts for other
3504 packages in subdirectories.
3506 @defmac AC_CONFIG_SUBDIRS (@var{dir} @dots{})
3507 @acindex{CONFIG_SUBDIRS}
3508 @ovindex subdirs
3509 Make @code{AC_OUTPUT} run @command{configure} in each subdirectory
3510 @var{dir} in the given blank-or-newline-separated list.  Each @var{dir} should
3511 be a literal, i.e., please do not use:
3513 @example
3514 if test "x$package_foo_enabled" = xyes; then
3515   $my_subdirs="$my_subdirs foo"
3517 AC_CONFIG_SUBDIRS([$my_subdirs])
3518 @end example
3520 @noindent
3521 because this prevents @samp{./configure --help=recursive} from
3522 displaying the options of the package @code{foo}.  Instead, you should
3523 write:
3525 @example
3526 if test "x$package_foo_enabled" = xyes; then
3527   AC_CONFIG_SUBDIRS([foo])
3529 @end example
3531 If a given @var{dir} is not found, an error is reported: if the
3532 subdirectory is optional, write:
3534 @example
3535 if test -d "$srcdir/foo"; then
3536   AC_CONFIG_SUBDIRS([foo])
3538 @end example
3540 @c NB: Yes, below we mean configure.in, not configure.ac.
3541 If a given @var{dir} contains @command{configure.gnu}, it is run instead
3542 of @command{configure}.  This is for packages that might use a
3543 non-Autoconf script @command{Configure}, which can't be called through a
3544 wrapper @command{configure} since it would be the same file on
3545 case-insensitive file systems.  Likewise, if a @var{dir} contains
3546 @file{configure.in} but no @command{configure}, the Cygnus
3547 @command{configure} script found by @code{AC_CONFIG_AUX_DIR} is used.
3549 The subdirectory @command{configure} scripts are given the same command
3550 line options that were given to this @command{configure} script, with minor
3551 changes if needed, which include:
3553 @itemize @minus
3554 @item
3555 adjusting a relative name for the cache file;
3557 @item
3558 adjusting a relative name for the source directory;
3560 @item
3561 propagating the current value of @code{$prefix}, including if it was
3562 defaulted, and if the default values of the top level and of the subdirectory
3563 @file{configure} differ.
3564 @end itemize
3566 This macro also sets the output variable @code{subdirs} to the list of
3567 directories @samp{@var{dir} @dots{}}.  Make rules can use
3568 this variable to determine which subdirectories to recurse into.
3570 This macro may be called multiple times.
3571 @end defmac
3573 @node Default Prefix
3574 @section Default Prefix
3575 @cindex Install prefix
3576 @cindex Prefix for install
3578 By default, @command{configure} sets the prefix for files it installs to
3579 @file{/usr/local}.  The user of @command{configure} can select a different
3580 prefix using the @option{--prefix} and @option{--exec-prefix} options.
3581 There are two ways to change the default: when creating
3582 @command{configure}, and when running it.
3584 Some software packages might want to install in a directory other than
3585 @file{/usr/local} by default.  To accomplish that, use the
3586 @code{AC_PREFIX_DEFAULT} macro.
3588 @defmac AC_PREFIX_DEFAULT (@var{prefix})
3589 @acindex{PREFIX_DEFAULT}
3590 Set the default installation prefix to @var{prefix} instead of
3591 @file{/usr/local}.
3592 @end defmac
3594 It may be convenient for users to have @command{configure} guess the
3595 installation prefix from the location of a related program that they
3596 have already installed.  If you wish to do that, you can call
3597 @code{AC_PREFIX_PROGRAM}.
3599 @anchor{AC_PREFIX_PROGRAM}
3600 @defmac AC_PREFIX_PROGRAM (@var{program})
3601 @acindex{PREFIX_PROGRAM}
3602 If the user did not specify an installation prefix (using the
3603 @option{--prefix} option), guess a value for it by looking for
3604 @var{program} in @env{PATH}, the way the shell does.  If @var{program}
3605 is found, set the prefix to the parent of the directory containing
3606 @var{program}, else default the prefix as described above
3607 (@file{/usr/local} or @code{AC_PREFIX_DEFAULT}).  For example, if
3608 @var{program} is @code{gcc} and the @env{PATH} contains
3609 @file{/usr/local/gnu/bin/gcc}, set the prefix to @file{/usr/local/gnu}.
3610 @end defmac
3614 @c ======================================================== Existing tests
3616 @node Existing Tests
3617 @chapter Existing Tests
3619 These macros test for particular system features that packages might
3620 need or want to use.  If you need to test for a kind of feature that
3621 none of these macros check for, you can probably do it by calling
3622 primitive test macros with appropriate arguments (@pxref{Writing
3623 Tests}).
3625 These tests print messages telling the user which feature they're
3626 checking for, and what they find.  They cache their results for future
3627 @command{configure} runs (@pxref{Caching Results}).
3629 Some of these macros set output variables.  @xref{Makefile
3630 Substitutions}, for how to get their values.  The phrase ``define
3631 @var{name}'' is used below as a shorthand to mean ``define the C
3632 preprocessor symbol @var{name} to the value 1''.  @xref{Defining
3633 Symbols}, for how to get those symbol definitions into your program.
3635 @menu
3636 * Common Behavior::             Macros' standard schemes
3637 * Alternative Programs::        Selecting between alternative programs
3638 * Files::                       Checking for the existence of files
3639 * Libraries::                   Library archives that might be missing
3640 * Library Functions::           C library functions that might be missing
3641 * Header Files::                Header files that might be missing
3642 * Declarations::                Declarations that may be missing
3643 * Structures::                  Structures or members that might be missing
3644 * Types::                       Types that might be missing
3645 * Compilers and Preprocessors::  Checking for compiling programs
3646 * System Services::             Operating system services
3647 * Posix Variants::              Special kludges for specific Posix variants
3648 * Erlang Libraries::            Checking for the existence of Erlang libraries
3649 @end menu
3651 @node Common Behavior
3652 @section Common Behavior
3653 @cindex Common autoconf behavior
3655 Much effort has been expended to make Autoconf easy to learn.  The most
3656 obvious way to reach this goal is simply to enforce standard interfaces
3657 and behaviors, avoiding exceptions as much as possible.  Because of
3658 history and inertia, unfortunately, there are still too many exceptions
3659 in Autoconf; nevertheless, this section describes some of the common
3660 rules.
3662 @menu
3663 * Standard Symbols::            Symbols defined by the macros
3664 * Default Includes::            Includes used by the generic macros
3665 @end menu
3667 @node Standard Symbols
3668 @subsection Standard Symbols
3669 @cindex Standard symbols
3671 All the generic macros that @code{AC_DEFINE} a symbol as a result of
3672 their test transform their @var{argument} values to a standard alphabet.
3673 First, @var{argument} is converted to upper case and any asterisks
3674 (@samp{*}) are each converted to @samp{P}.  Any remaining characters
3675 that are not alphanumeric are converted to underscores.
3677 For instance,
3679 @example
3680 AC_CHECK_TYPES([struct $Expensive*])
3681 @end example
3683 @noindent
3684 defines the symbol @samp{HAVE_STRUCT__EXPENSIVEP} if the check
3685 succeeds.
3688 @node Default Includes
3689 @subsection Default Includes
3690 @cindex Default includes
3691 @cindex Includes, default
3693 Several tests depend upon a set of header files.  Since these headers
3694 are not universally available, tests actually have to provide a set of
3695 protected includes, such as:
3697 @example
3698 @group
3699 #ifdef TIME_WITH_SYS_TIME
3700 # include <sys/time.h>
3701 # include <time.h>
3702 #else
3703 # ifdef HAVE_SYS_TIME_H
3704 #  include <sys/time.h>
3705 # else
3706 #  include <time.h>
3707 # endif
3708 #endif
3709 @end group
3710 @end example
3712 @noindent
3713 Unless you know exactly what you are doing, you should avoid using
3714 unconditional includes, and check the existence of the headers you
3715 include beforehand (@pxref{Header Files}).
3717 Most generic macros use the following macro to provide the default set
3718 of includes:
3720 @defmac AC_INCLUDES_DEFAULT (@ovar{include-directives})
3721 @acindex{INCLUDES_DEFAULT}
3722 Expand to @var{include-directives} if defined, otherwise to:
3724 @example
3725 @group
3726 #include <stdio.h>
3727 #ifdef HAVE_SYS_TYPES_H
3728 # include <sys/types.h>
3729 #endif
3730 #ifdef HAVE_SYS_STAT_H
3731 # include <sys/stat.h>
3732 #endif
3733 #ifdef STDC_HEADERS
3734 # include <stdlib.h>
3735 # include <stddef.h>
3736 #else
3737 # ifdef HAVE_STDLIB_H
3738 #  include <stdlib.h>
3739 # endif
3740 #endif
3741 #ifdef HAVE_STRING_H
3742 # if !defined STDC_HEADERS && defined HAVE_MEMORY_H
3743 #  include <memory.h>
3744 # endif
3745 # include <string.h>
3746 #endif
3747 #ifdef HAVE_STRINGS_H
3748 # include <strings.h>
3749 #endif
3750 #ifdef HAVE_INTTYPES_H
3751 # include <inttypes.h>
3752 #endif
3753 #ifdef HAVE_STDINT_H
3754 # include <stdint.h>
3755 #endif
3756 #ifdef HAVE_UNISTD_H
3757 # include <unistd.h>
3758 #endif
3759 @end group
3760 @end example
3762 If the default includes are used, then check for the presence of these
3763 headers and their compatibility, i.e., you don't need to run
3764 @code{AC_HEADER_STDC}, nor check for @file{stdlib.h} etc.
3766 These headers are checked for in the same order as they are included.
3767 For instance, on some systems @file{string.h} and @file{strings.h} both
3768 exist, but conflict.  Then @code{HAVE_STRING_H} is defined, not
3769 @code{HAVE_STRINGS_H}.
3770 @end defmac
3772 @node Alternative Programs
3773 @section Alternative Programs
3774 @cindex Programs, checking
3776 These macros check for the presence or behavior of particular programs.
3777 They are used to choose between several alternative programs and to
3778 decide what to do once one has been chosen.  If there is no macro
3779 specifically defined to check for a program you need, and you don't need
3780 to check for any special properties of it, then you can use one of the
3781 general program-check macros.
3783 @menu
3784 * Particular Programs::         Special handling to find certain programs
3785 * Generic Programs::            How to find other programs
3786 @end menu
3788 @node Particular Programs
3789 @subsection Particular Program Checks
3791 These macros check for particular programs---whether they exist, and
3792 in some cases whether they support certain features.
3794 @defmac AC_PROG_AWK
3795 @acindex{PROG_AWK}
3796 @ovindex AWK
3797 Check for @code{gawk}, @code{mawk}, @code{nawk}, and @code{awk}, in that
3798 order, and set output variable @code{AWK} to the first one that is found.
3799 It tries @code{gawk} first because that is reported to be the
3800 best implementation.
3801 @end defmac
3803 @defmac AC_PROG_GREP
3804 @acindex{PROG_GREP}
3805 @ovindex GREP
3806 Look for the best available @code{grep} or @code{ggrep} that accepts the
3807 longest input lines possible, and that supports multiple @option{-e} options.
3808 Set the output variable @code{GREP} to whatever is chosen.
3809 @xref{grep, , Limitations of Usual Tools}, for more information about
3810 portability problems with the @command{grep} command family.
3811 @end defmac
3813 @defmac AC_PROG_EGREP
3814 @acindex{PROG_EGREP}
3815 @ovindex EGREP
3816 Check whether @code{$GREP -E} works, or else look for the best available
3817 @code{egrep} or @code{gegrep} that accepts the longest input lines possible.
3818 Set the output variable @code{EGREP} to whatever is chosen.
3819 @end defmac
3821 @defmac AC_PROG_FGREP
3822 @acindex{PROG_FGREP}
3823 @ovindex FGREP
3824 Check whether @code{$GREP -F} works, or else look for the best available
3825 @code{fgrep} or @code{gfgrep} that accepts the longest input lines possible.
3826 Set the output variable @code{FGREP} to whatever is chosen.
3827 @end defmac
3829 @defmac AC_PROG_INSTALL
3830 @acindex{PROG_INSTALL}
3831 @ovindex INSTALL
3832 @ovindex INSTALL_PROGRAM
3833 @ovindex INSTALL_DATA
3834 @ovindex INSTALL_SCRIPT
3835 Set output variable @code{INSTALL} to the name of a @acronym{BSD}-compatible
3836 @command{install} program, if one is found in the current @env{PATH}.
3837 Otherwise, set @code{INSTALL} to @samp{@var{dir}/install-sh -c},
3838 checking the directories specified to @code{AC_CONFIG_AUX_DIR} (or its
3839 default directories) to determine @var{dir} (@pxref{Output}).  Also set
3840 the variables @code{INSTALL_PROGRAM} and @code{INSTALL_SCRIPT} to
3841 @samp{$@{INSTALL@}} and @code{INSTALL_DATA} to @samp{$@{INSTALL@} -m 644}.
3843 @samp{@@INSTALL@@} is special, as its value may vary for different
3844 configuration files.
3846 This macro screens out various instances of @command{install} known not to
3847 work.  It prefers to find a C program rather than a shell script, for
3848 speed.  Instead of @file{install-sh}, it can also use @file{install.sh},
3849 but that name is obsolete because some @command{make} programs have a rule
3850 that creates @file{install} from it if there is no makefile.  Further, this
3851 macro requires @command{install} to be able to install multiple files into a
3852 target directory in a single invocation.
3854 Autoconf comes with a copy of @file{install-sh} that you can use.  If
3855 you use @code{AC_PROG_INSTALL}, you must include either
3856 @file{install-sh} or @file{install.sh} in your distribution; otherwise
3857 @command{configure} produces an error message saying it can't find
3858 them---even if the system you're on has a good @command{install} program.
3859 This check is a safety measure to prevent you from accidentally leaving
3860 that file out, which would prevent your package from installing on
3861 systems that don't have a @acronym{BSD}-compatible @command{install} program.
3863 If you need to use your own installation program because it has features
3864 not found in standard @command{install} programs, there is no reason to use
3865 @code{AC_PROG_INSTALL}; just put the file name of your program into your
3866 @file{Makefile.in} files.
3867 @end defmac
3869 @defmac AC_PROG_MKDIR_P
3870 @acindex{PROG_MKDIR_P}
3871 @ovindex MKDIR_P
3872 Set output variable @code{MKDIR_P} to a program that ensures that for
3873 each argument, a directory named by this argument exists, creating it
3874 and its parent directories if needed, and without race conditions when
3875 two instances of the program attempt to make the same directory at
3876 nearly the same time.
3878 This macro uses the @samp{mkdir -p} command if possible.  Otherwise, it
3879 falls back on invoking @command{install-sh} with the @option{-d} option,
3880 so your package should
3881 contain @file{install-sh} as described under @code{AC_PROG_INSTALL}.
3882 An @file{install-sh} file that predates Autoconf 2.60 or Automake 1.10
3883 is vulnerable to race conditions, so if you want to support parallel
3884 installs from
3885 different packages into the same directory you need to make sure you
3886 have an up-to-date @file{install-sh}.  In particular, be careful about
3887 using @samp{autoreconf -if} if your Automake predates Automake 1.10.
3889 This macro is related to the @code{AS_MKDIR_P} macro (@pxref{Programming
3890 in M4sh}), but it sets an output variable intended for use in other
3891 files, whereas @code{AS_MKDIR_P} is intended for use in scripts like
3892 @command{configure}.  Also, @code{AS_MKDIR_P} does not accept options,
3893 but @code{MKDIR_P} supports the @option{-m} option, e.g., a makefile
3894 might invoke @code{$(MKDIR_P) -m 0 dir} to create an inaccessible
3895 directory, and conversely a makefile should use @code{$(MKDIR_P) --
3896 $(FOO)} if @var{FOO} might yield a value that begins with @samp{-}.
3897 Finally, @code{AS_MKDIR_P} does not check for race condition
3898 vulnerability, whereas @code{AC_PROG_MKDIR_P} does.
3900 @samp{@@MKDIR_P@@} is special, as its value may vary for different
3901 configuration files.
3902 @end defmac
3904 @anchor{AC_PROG_LEX}
3905 @defmac AC_PROG_LEX
3906 @acindex{PROG_LEX}
3907 @ovindex LEX
3908 @ovindex LEXLIB
3909 @cvindex YYTEXT_POINTER
3910 @ovindex LEX_OUTPUT_ROOT
3911 If @code{flex} is found, set output variable @code{LEX} to @samp{flex}
3912 and @code{LEXLIB} to @option{-lfl}, if that library is in a standard
3913 place.  Otherwise set @code{LEX} to @samp{lex} and @code{LEXLIB} to
3914 @option{-ll}.
3916 Define @code{YYTEXT_POINTER} if @code{yytext} defaults to @samp{char *} instead
3917 of to @samp{char []}.  Also set output variable @code{LEX_OUTPUT_ROOT} to
3918 the base of the file name that the lexer generates; usually
3919 @file{lex.yy}, but sometimes something else.  These results vary
3920 according to whether @code{lex} or @code{flex} is being used.
3922 You are encouraged to use Flex in your sources, since it is both more
3923 pleasant to use than plain Lex and the C source it produces is portable.
3924 In order to ensure portability, however, you must either provide a
3925 function @code{yywrap} or, if you don't use it (e.g., your scanner has
3926 no @samp{#include}-like feature), simply include a @samp{%noyywrap}
3927 statement in the scanner's source.  Once this done, the scanner is
3928 portable (unless @emph{you} felt free to use nonportable constructs) and
3929 does not depend on any library.  In this case, and in this case only, it
3930 is suggested that you use this Autoconf snippet:
3932 @example
3933 AC_PROG_LEX
3934 if test "x$LEX" != xflex; then
3935   LEX="$SHELL $missing_dir/missing flex"
3936   AC_SUBST([LEX_OUTPUT_ROOT], [lex.yy])
3937   AC_SUBST([LEXLIB], [''])
3939 @end example
3941 The shell script @command{missing} can be found in the Automake
3942 distribution.
3944 To ensure backward compatibility, Automake's @code{AM_PROG_LEX} invokes
3945 (indirectly) this macro twice, which causes an annoying but benign
3946 ``@code{AC_PROG_LEX} invoked multiple times'' warning.  Future versions
3947 of Automake will fix this issue; meanwhile, just ignore this message.
3949 As part of running the test, this macro may delete any file in the
3950 configuration directory named @file{lex.yy.c} or @file{lexyy.c}.
3951 @end defmac
3953 @anchor{AC_PROG_LN_S}
3954 @defmac AC_PROG_LN_S
3955 @acindex{PROG_LN_S}
3956 @ovindex LN_S
3957 If @samp{ln -s} works on the current file system (the operating system
3958 and file system support symbolic links), set the output variable
3959 @code{LN_S} to @samp{ln -s}; otherwise, if @samp{ln} works, set
3960 @code{LN_S} to @samp{ln}, and otherwise set it to @samp{cp -p}.
3962 If you make a link in a directory other than the current directory, its
3963 meaning depends on whether @samp{ln} or @samp{ln -s} is used.  To safely
3964 create links using @samp{$(LN_S)}, either find out which form is used
3965 and adjust the arguments, or always invoke @code{ln} in the directory
3966 where the link is to be created.
3968 In other words, it does not work to do:
3969 @example
3970 $(LN_S) foo /x/bar
3971 @end example
3973 Instead, do:
3975 @example
3976 (cd /x && $(LN_S) foo bar)
3977 @end example
3978 @end defmac
3980 @defmac AC_PROG_RANLIB
3981 @acindex{PROG_RANLIB}
3982 @ovindex RANLIB
3983 Set output variable @code{RANLIB} to @samp{ranlib} if @code{ranlib}
3984 is found, and otherwise to @samp{:} (do nothing).
3985 @end defmac
3987 @defmac AC_PROG_SED
3988 @acindex{PROG_SED}
3989 @ovindex SED
3990 Set output variable @code{SED} to a Sed implementation that conforms to
3991 Posix and does not have arbitrary length limits.  Report an error if no
3992 acceptable Sed is found.  @xref{sed, , Limitations of Usual Tools}, for more
3993 information about portability problems with Sed.
3994 @end defmac
3996 @defmac AC_PROG_YACC
3997 @acindex{PROG_YACC}
3998 @ovindex YACC
3999 If @code{bison} is found, set output variable @code{YACC} to @samp{bison
4000 -y}.  Otherwise, if @code{byacc} is found, set @code{YACC} to
4001 @samp{byacc}.  Otherwise set @code{YACC} to @samp{yacc}.
4002 @end defmac
4004 @node Generic Programs
4005 @subsection Generic Program and File Checks
4007 These macros are used to find programs not covered by the ``particular''
4008 test macros.  If you need to check the behavior of a program as well as
4009 find out whether it is present, you have to write your own test for it
4010 (@pxref{Writing Tests}).  By default, these macros use the environment
4011 variable @env{PATH}.  If you need to check for a program that might not
4012 be in the user's @env{PATH}, you can pass a modified path to use
4013 instead, like this:
4015 @example
4016 AC_PATH_PROG([INETD], [inetd], [/usr/libexec/inetd],
4017              [$PATH$PATH_SEPARATOR/usr/libexec$PATH_SEPARATOR]dnl
4018 [/usr/sbin$PATH_SEPARATOR/usr/etc$PATH_SEPARATOR/etc])
4019 @end example
4021 You are strongly encouraged to declare the @var{variable} passed to
4022 @code{AC_CHECK_PROG} etc.@: as precious, @xref{Setting Output Variables},
4023 @code{AC_ARG_VAR}, for more details.
4025 @anchor{AC_CHECK_PROG}
4026 @defmac AC_CHECK_PROG (@var{variable}, @var{prog-to-check-for}, @
4027   @var{value-if-found}, @ovar{value-if-not-found}, @dvar{path, $PATH}, @
4028   @ovar{reject})
4029 @acindex{CHECK_PROG}
4030 Check whether program @var{prog-to-check-for} exists in @var{path}.  If
4031 it is found, set @var{variable} to @var{value-if-found}, otherwise to
4032 @var{value-if-not-found}, if given.  Always pass over @var{reject} (an
4033 absolute file name) even if it is the first found in the search path; in
4034 that case, set @var{variable} using the absolute file name of the
4035 @var{prog-to-check-for} found that is not @var{reject}.  If
4036 @var{variable} was already set, do nothing.  Calls @code{AC_SUBST} for
4037 @var{variable}.
4038 @end defmac
4040 @anchor{AC_CHECK_PROGS}
4041 @defmac AC_CHECK_PROGS (@var{variable}, @var{progs-to-check-for}, @
4042   @ovar{value-if-not-found}, @dvar{path, $PATH})
4043 @acindex{CHECK_PROGS}
4044 Check for each program in the blank-separated list
4045 @var{progs-to-check-for} existing in the @var{path}.  If one is found, set
4046 @var{variable} to the name of that program.  Otherwise, continue
4047 checking the next program in the list.  If none of the programs in the
4048 list are found, set @var{variable} to @var{value-if-not-found}; if
4049 @var{value-if-not-found} is not specified, the value of @var{variable}
4050 is not changed.  Calls @code{AC_SUBST} for @var{variable}.
4051 @end defmac
4053 @defmac AC_CHECK_TARGET_TOOL (@var{variable}, @var{prog-to-check-for}, @
4054   @ovar{value-if-not-found}, @dvar{path, $PATH})
4055 @acindex{CHECK_TARGET_TOOL}
4056 Like @code{AC_CHECK_PROG}, but first looks for @var{prog-to-check-for}
4057 with a prefix of the target type as determined by
4058 @code{AC_CANONICAL_TARGET}, followed by a dash (@pxref{Canonicalizing}).
4059 If the tool cannot be found with a prefix, and if the build and target
4060 types are equal, then it is also searched for without a prefix.
4062 As noted in @ref{Specifying Target Triplets}, the
4063 target is rarely specified, because most of the time it is the same
4064 as the host: it is the type of system for which any compiler tool in
4065 the package produces code.  What this macro looks for is,
4066 for example, @emph{a tool @r{(assembler, linker, etc.)}@: that the
4067 compiler driver @r{(@command{gcc} for the @acronym{GNU} C Compiler)}
4068 uses to produce objects, archives or executables}.
4069 @end defmac
4071 @defmac AC_CHECK_TOOL (@var{variable}, @var{prog-to-check-for}, @
4072   @ovar{value-if-not-found}, @dvar{path, $PATH})
4073 @acindex{CHECK_TOOL}
4074 Like @code{AC_CHECK_PROG}, but first looks for @var{prog-to-check-for}
4075 with a prefix of the host type as specified by @option{--host}, followed by a
4076 dash.  For example, if the user runs
4077 @samp{configure --build=x86_64-gnu --host=i386-gnu}, then this call:
4078 @example
4079 AC_CHECK_TOOL([RANLIB], [ranlib], [:])
4080 @end example
4081 @noindent
4082 sets @code{RANLIB} to @file{i386-gnu-ranlib} if that program exists in
4083 @var{path}, or otherwise to @samp{ranlib} if that program exists in
4084 @var{path}, or to @samp{:} if neither program exists.
4086 When cross-compiling, this macro will issue a warning if no program
4087 prefixed with the host type could be found.
4088 For more information, see @ref{Specifying Target Triplets}.
4089 @end defmac
4091 @defmac AC_CHECK_TARGET_TOOLS (@var{variable}, @var{progs-to-check-for}, @
4092   @ovar{value-if-not-found}, @dvar{path, $PATH})
4093 @acindex{CHECK_TARGET_TOOLS}
4094 Like @code{AC_CHECK_TARGET_TOOL}, each of the tools in the list
4095 @var{progs-to-check-for} are checked with a prefix of the target type as
4096 determined by @code{AC_CANONICAL_TARGET}, followed by a dash
4097 (@pxref{Canonicalizing}).  If none of the tools can be found with a
4098 prefix, and if the build and target types are equal, then the first one
4099 without a prefix is used.  If a tool is found, set @var{variable} to
4100 the name of that program.  If none of the tools in the list are found,
4101 set @var{variable} to @var{value-if-not-found}; if @var{value-if-not-found}
4102 is not specified, the value of @var{variable} is not changed.  Calls
4103 @code{AC_SUBST} for @var{variable}.
4104 @end defmac
4106 @defmac AC_CHECK_TOOLS (@var{variable}, @var{progs-to-check-for}, @
4107   @ovar{value-if-not-found}, @dvar{path, $PATH})
4108 @acindex{CHECK_TOOLS}
4109 Like @code{AC_CHECK_TOOL}, each of the tools in the list
4110 @var{progs-to-check-for} are checked with a prefix of the host type as
4111 determined by @code{AC_CANONICAL_HOST}, followed by a dash
4112 (@pxref{Canonicalizing}).  If none of the tools can be found with a
4113 prefix, then the first one without a prefix is used.  If a tool is found,
4114 set @var{variable} to the name of that program.  If none of the tools in
4115 the list are found, set @var{variable} to @var{value-if-not-found}; if
4116 @var{value-if-not-found} is not specified, the value of @var{variable}
4117 is not changed.  Calls @code{AC_SUBST} for @var{variable}.
4119 When cross-compiling, this macro will issue a warning if no program
4120 prefixed with the host type could be found.
4121 For more information, see @ref{Specifying Target Triplets}.
4122 @end defmac
4124 @anchor{AC_PATH_PROG}
4125 @defmac AC_PATH_PROG (@var{variable}, @var{prog-to-check-for}, @
4126   @ovar{value-if-not-found}, @dvar{path, $PATH})
4127 @acindex{PATH_PROG}
4128 Like @code{AC_CHECK_PROG}, but set @var{variable} to the absolute
4129 name of @var{prog-to-check-for} if found.
4130 @end defmac
4132 @anchor{AC_PATH_PROGS}
4133 @defmac AC_PATH_PROGS (@var{variable}, @var{progs-to-check-for}, @
4134   @ovar{value-if-not-found}, @dvar{path, $PATH})
4135 @acindex{PATH_PROGS}
4136 Like @code{AC_CHECK_PROGS}, but if any of @var{progs-to-check-for}
4137 are found, set @var{variable} to the absolute name of the program
4138 found.
4139 @end defmac
4141 @defmac AC_PATH_PROGS_FEATURE_CHECK (@var{variable}, @
4142   @var{progs-to-check-for}, @var{feature-test}, @
4143   @ovar{action-if-not-found}, @dvar{path, $PATH})
4144 @acindex{PATH_PROGS_FEATURE_CHECK}
4145 This macro was introduced in Autoconf 2.62.  If @var{variable} is not
4146 empty, then set the cache variable @code{$ac_cv_path_@var{variable}} to
4147 its value.  Otherwise, check for each program in the blank-separated
4148 list @var{progs-to-check-for} existing in @var{path}.  For each program
4149 found, execute @var{feature-test} with @code{$ac_path_@var{variable}}
4150 set to the absolute name of the candidate program.  If no invocation of
4151 @var{feature-test} sets the shell variable
4152 @code{$ac_cv_path_@var{variable}}, then @var{action-if-not-found} is
4153 executed.  @var{feature-test} will be run even when
4154 @code{ac_cv_path_@var{variable}} is set, to provide the ability to
4155 choose a better candidate found later in @var{path}; to accept the
4156 current setting and bypass all futher checks, @var{feature-test} can
4157 execute @code{ac_path_@var{variable}_found=:}.
4159 Note that this macro has some subtle differences from
4160 @code{AC_CHECK_PROGS}.  It is designed to be run inside
4161 @code{AC_CACHE_VAL}, therefore, it should have no side effects.  In
4162 particular, @var{variable} is not set to the final value of
4163 @code{ac_cv_path_@var{variable}}, nor is @code{AC_SUBST} automatically
4164 run.  Also, on failure, any action can be performed, whereas
4165 @code{AC_CHECK_PROGS} only performs
4166 @code{@var{variable}=@var{value-if-not-found}}.
4168 Here is an example, similar to what Autoconf uses in its own configure
4169 script.  It will search for an implementation of @command{m4} that
4170 supports the @code{indir} builtin, even if it goes by the name
4171 @command{gm4} or is not the first implementation on @env{PATH}.
4173 @example
4174 AC_CACHE_CHECK([for m4 that supports indir], [ac_cv_path_M4],
4175   [AC_PATH_PROGS_FEATURE_CHECK([M4], [m4 gm4],
4176     [[m4out=`echo 'changequote([,])indir([divnum])' | $ac_path_M4`
4177       test "x$m4out" = x0 \
4178       && ac_cv_path_M4=$ac_path_M4 ac_path_M4_found=:]],
4179     [AC_MSG_ERROR([could not find m4 that supports indir])])])
4180 AC_SUBST([M4], [$ac_cv_path_M4])
4181 @end example
4182 @end defmac
4184 @defmac AC_PATH_TARGET_TOOL (@var{variable}, @var{prog-to-check-for}, @
4185   @ovar{value-if-not-found}, @dvar{path, $PATH})
4186 @acindex{PATH_TARGET_TOOL}
4187 Like @code{AC_CHECK_TARGET_TOOL}, but set @var{variable} to the absolute
4188 name of the program if it is found.
4189 @end defmac
4191 @defmac AC_PATH_TOOL (@var{variable}, @var{prog-to-check-for}, @
4192   @ovar{value-if-not-found}, @dvar{path, $PATH})
4193 @acindex{PATH_TOOL}
4194 Like @code{AC_CHECK_TOOL}, but set @var{variable} to the absolute
4195 name of the program if it is found.
4197 When cross-compiling, this macro will issue a warning if no program
4198 prefixed with the host type could be found.
4199 For more information, see @ref{Specifying Target Triplets}.
4200 @end defmac
4203 @node Files
4204 @section Files
4205 @cindex File, checking
4207 You might also need to check for the existence of files.  Before using
4208 these macros, ask yourself whether a runtime test might not be a better
4209 solution.  Be aware that, like most Autoconf macros, they test a feature
4210 of the host machine, and therefore, they die when cross-compiling.
4212 @defmac AC_CHECK_FILE (@var{file}, @ovar{action-if-found}, @
4213   @ovar{action-if-not-found})
4214 @acindex{CHECK_FILE}
4215 Check whether file @var{file} exists on the native system.  If it is
4216 found, execute @var{action-if-found}, otherwise do
4217 @var{action-if-not-found}, if given.
4218 @end defmac
4220 @defmac AC_CHECK_FILES (@var{files}, @ovar{action-if-found}, @
4221   @ovar{action-if-not-found})
4222 @acindex{CHECK_FILES}
4223 Executes @code{AC_CHECK_FILE} once for each file listed in @var{files}.
4224 Additionally, defines @samp{HAVE_@var{file}} (@pxref{Standard Symbols})
4225 for each file found.
4226 @end defmac
4229 @node Libraries
4230 @section Library Files
4231 @cindex Library, checking
4233 The following macros check for the presence of certain C, C++, or Fortran
4234 library archive files.
4236 @anchor{AC_CHECK_LIB}
4237 @defmac AC_CHECK_LIB (@var{library}, @var{function}, @
4238   @ovar{action-if-found}, @ovar{action-if-not-found}, @ovar{other-libraries})
4239 @acindex{CHECK_LIB}
4240 Test whether the library @var{library} is available by trying to link
4241 a test program that calls function @var{function} with the library.
4242 @var{function} should be a function provided by the library.
4243 Use the base
4244 name of the library; e.g., to check for @option{-lmp}, use @samp{mp} as
4245 the @var{library} argument.
4247 @var{action-if-found} is a list of shell commands to run if the link
4248 with the library succeeds; @var{action-if-not-found} is a list of shell
4249 commands to run if the link fails.  If @var{action-if-found} is not
4250 specified, the default action prepends @option{-l@var{library}} to
4251 @code{LIBS} and defines @samp{HAVE_LIB@var{library}} (in all
4252 capitals).  This macro is intended to support building @code{LIBS} in
4253 a right-to-left (least-dependent to most-dependent) fashion such that
4254 library dependencies are satisfied as a natural side effect of
4255 consecutive tests.  Linkers are sensitive to library ordering
4256 so the order in which @code{LIBS} is generated is important to reliable
4257 detection of libraries.
4259 If linking with @var{library} results in unresolved symbols that would
4260 be resolved by linking with additional libraries, give those libraries
4261 as the @var{other-libraries} argument, separated by spaces:
4262 e.g., @option{-lXt -lX11}.  Otherwise, this macro fails to detect
4263 that @var{library} is present, because linking the test program
4264 always fails with unresolved symbols.  The @var{other-libraries} argument
4265 should be limited to cases where it is desirable to test for one library
4266 in the presence of another that is not already in @code{LIBS}.
4268 @code{AC_CHECK_LIB} requires some care in usage, and should be avoided
4269 in some common cases.  Many standard functions like @code{gethostbyname}
4270 appear in the standard C library on some hosts, and in special libraries
4271 like @code{nsl} on other hosts.  On some hosts the special libraries
4272 contain variant implementations that you may not want to use.  These
4273 days it is normally better to use @code{AC_SEARCH_LIBS([gethostbyname],
4274 [nsl])} instead of @code{AC_CHECK_LIB([nsl], [gethostbyname])}.
4275 @end defmac
4277 @anchor{AC_SEARCH_LIBS}
4278 @defmac AC_SEARCH_LIBS (@var{function}, @var{search-libs}, @
4279   @ovar{action-if-found}, @ovar{action-if-not-found}, @ovar{other-libraries})
4280 @acindex{SEARCH_LIBS}
4281 Search for a library defining @var{function} if it's not already
4282 available.  This equates to calling
4283 @samp{AC_LINK_IFELSE([AC_LANG_CALL([], [@var{function}])])} first with
4284 no libraries, then for each library listed in @var{search-libs}.
4286 Add @option{-l@var{library}} to @code{LIBS} for the first library found
4287 to contain @var{function}, and run @var{action-if-found}.  If the
4288 function is not found, run @var{action-if-not-found}.
4290 If linking with @var{library} results in unresolved symbols that would
4291 be resolved by linking with additional libraries, give those libraries
4292 as the @var{other-libraries} argument, separated by spaces:
4293 e.g., @option{-lXt -lX11}.  Otherwise, this macro fails to detect
4294 that @var{function} is present, because linking the test program
4295 always fails with unresolved symbols.
4296 @end defmac
4300 @node Library Functions
4301 @section Library Functions
4303 The following macros check for particular C library functions.
4304 If there is no macro specifically defined to check for a function you need,
4305 and you don't need to check for any special properties of
4306 it, then you can use one of the general function-check macros.
4308 @menu
4309 * Function Portability::        Pitfalls with usual functions
4310 * Particular Functions::        Special handling to find certain functions
4311 * Generic Functions::           How to find other functions
4312 @end menu
4314 @node Function Portability
4315 @subsection Portability of C Functions
4316 @cindex Portability of C functions
4317 @cindex C function portability
4319 Most usual functions can either be missing, or be buggy, or be limited
4320 on some architectures.  This section tries to make an inventory of these
4321 portability issues.  By definition, this list always requires
4322 additions.  Please help us keeping it as complete as possible.
4324 @table @asis
4325 @item @code{exit}
4326 @c @fuindex exit
4327 @prindex @code{exit}
4328 On ancient hosts, @code{exit} returned @code{int}.
4329 This is because @code{exit} predates @code{void}, and there was a long
4330 tradition of it returning @code{int}.
4332 On current hosts, the problem more likely is that @code{exit} is not
4333 declared, due to C++ problems of some sort or another.  For this reason
4334 we suggest that test programs not invoke @code{exit}, but return from
4335 @code{main} instead.
4337 @item @code{free}
4338 @c @fuindex free
4339 @prindex @code{free}
4340 The C standard says a call @code{free (NULL)} does nothing, but
4341 some old systems don't support this (e.g., NextStep).
4343 @item @code{isinf}
4344 @itemx @code{isnan}
4345 @c @fuindex isinf
4346 @c @fuindex isnan
4347 @prindex @code{isinf}
4348 @prindex @code{isnan}
4349 The C99 standard says that @code{isinf} and @code{isnan} are
4350 macros.  On some systems just macros are available
4351 (e.g., @acronym{HP-UX} and Solaris 10), on
4352 some systems both macros and functions (e.g., glibc 2.3.2), and on some
4353 systems only functions (e.g., IRIX 6 and Solaris 9).  In some cases
4354 these functions are declared in nonstandard headers like
4355 @code{<sunmath.h>} and defined in non-default libraries like
4356 @option{-lm} or @option{-lsunmath}.
4358 The C99 @code{isinf} and @code{isnan} macros work correctly with
4359 @code{long double} arguments, but pre-C99 systems that use functions
4360 typically assume @code{double} arguments.  On such a system,
4361 @code{isinf} incorrectly returns true for a finite @code{long double}
4362 argument that is outside the range of @code{double}.
4364 The best workaround for these issues is to use gnulib modules
4365 @code{isinf} and @code{isnan} (@pxref{Gnulib}).  But a lighter weight
4366 solution involves code like the following.
4368 @smallexample
4369 #include <math.h>
4371 #ifndef isnan
4372 # define isnan(x) \
4373     (sizeof (x) == sizeof (long double) ? isnan_ld (x) \
4374      : sizeof (x) == sizeof (double) ? isnan_d (x) \
4375      : isnan_f (x))
4376 static inline int isnan_f  (float       x) @{ return x != x; @}
4377 static inline int isnan_d  (double      x) @{ return x != x; @}
4378 static inline int isnan_ld (long double x) @{ return x != x; @}
4379 #endif
4381 #ifndef isinf
4382 # define isinf(x) \
4383     (sizeof (x) == sizeof (long double) ? isinf_ld (x) \
4384      : sizeof (x) == sizeof (double) ? isinf_d (x) \
4385      : isinf_f (x))
4386 static inline int isinf_f  (float       x)
4387 @{ return !isnan (x) && isnan (x - x); @}
4388 static inline int isinf_d  (double      x)
4389 @{ return !isnan (x) && isnan (x - x); @}
4390 static inline int isinf_ld (long double x)
4391 @{ return !isnan (x) && isnan (x - x); @}
4392 #endif
4393 @end smallexample
4395 Use @code{AC_C_INLINE} (@pxref{C Compiler}) so that this code works on
4396 compilers that lack the @code{inline} keyword.  Some optimizing
4397 compilers mishandle these definitions, but systems with that bug
4398 typically have many other floating point corner-case compliance problems
4399 anyway, so it's probably not worth worrying about.
4401 @item @code{malloc}
4402 @c @fuindex malloc
4403 @prindex @code{malloc}
4404 The C standard says a call @code{malloc (0)} is implementation
4405 dependent.  It can return either @code{NULL} or a new non-null pointer.
4406 The latter is more common (e.g., the @acronym{GNU} C Library) but is by
4407 no means universal.  @code{AC_FUNC_MALLOC}
4408 can be used to insist on non-@code{NULL} (@pxref{Particular Functions}).
4410 @item @code{putenv}
4411 @c @fuindex putenv
4412 @prindex @code{putenv}
4413 Posix prefers @code{setenv} to @code{putenv}; among other things,
4414 @code{putenv} is not required of all Posix implementations, but
4415 @code{setenv} is.
4417 Posix specifies that @code{putenv} puts the given string directly in
4418 @code{environ}, but some systems make a copy of it instead (e.g.,
4419 glibc 2.0, or @acronym{BSD}).  And when a copy is made, @code{unsetenv} might
4420 not free it, causing a memory leak (e.g., Free@acronym{BSD} 4).
4422 On some systems @code{putenv ("FOO")} removes @samp{FOO} from the
4423 environment, but this is not standard usage and it dumps core
4424 on some systems (e.g., AIX).
4426 On MinGW, a call @code{putenv ("FOO=")} removes @samp{FOO} from the
4427 environment, rather than inserting it with an empty value.
4429 @item @code{realloc}
4430 @c @fuindex realloc
4431 @prindex @code{realloc}
4432 The C standard says a call @code{realloc (NULL, size)} is equivalent
4433 to @code{malloc (size)}, but some old systems don't support this (e.g.,
4434 NextStep).
4436 @item @code{signal} handler
4437 @c @fuindex signal
4438 @prindex @code{signal}
4439 @prindex @code{sigaction}
4440 Normally @code{signal} takes a handler function with a return type of
4441 @code{void}, but some old systems required @code{int} instead.  Any
4442 actual @code{int} value returned is not used; this is only a
4443 difference in the function prototype demanded.
4445 All systems we know of in current use return @code{void}.  The
4446 @code{int} was to support K&R C, where of course @code{void} is not
4447 available.  The obsolete macro @code{AC_TYPE_SIGNAL}
4448 (@pxref{AC_TYPE_SIGNAL}) can be used to establish the correct type in
4449 all cases.
4451 In most cases, it is more robust to use @code{sigaction} when it is
4452 available, rather than @code{signal}.
4454 @item @code{snprintf}
4455 @c @fuindex snprintf
4456 @prindex @code{snprintf}
4457 @c @fuindex vsnprintf
4458 @prindex @code{vsnprintf}
4459 The C99 standard says that if the output array isn't big enough
4460 and if no other errors occur, @code{snprintf} and @code{vsnprintf}
4461 truncate the output and return the number of bytes that ought to have
4462 been produced.  Some older systems return the truncated length (e.g.,
4463 @acronym{GNU} C Library 2.0.x or @sc{irix} 6.5), some a negative value
4464 (e.g., earlier @acronym{GNU} C Library versions), and some the buffer
4465 length without truncation (e.g., 32-bit Solaris 7).  Also, some buggy
4466 older systems ignore the length and overrun the buffer (e.g., 64-bit
4467 Solaris 7).
4469 @item @code{sprintf}
4470 @c @fuindex sprintf
4471 @prindex @code{sprintf}
4472 @c @fuindex vsprintf
4473 @prindex @code{vsprintf}
4474 The C standard says @code{sprintf} and @code{vsprintf} return the
4475 number of bytes written.  On some ancient systems (SunOS 4 for
4476 instance) they return the buffer pointer instead, but these no
4477 longer need to be worried about.
4479 @item @code{sscanf}
4480 @c @fuindex sscanf
4481 @prindex @code{sscanf}
4482 On various old systems, e.g., @acronym{HP-UX} 9, @code{sscanf} requires
4483 that its
4484 input string be writable (though it doesn't actually change it).  This
4485 can be a problem when using @command{gcc} since it normally puts
4486 constant strings in read-only memory (@pxref{Incompatibilities,
4487 Incompatibilities of @acronym{GCC}, , gcc, Using and
4488 Porting the @acronym{GNU} Compiler Collection}).  Apparently in some cases even
4489 having format strings read-only can be a problem.
4491 @item @code{strerror_r}
4492 @c @fuindex strerror_r
4493 @prindex @code{strerror_r}
4494 Posix specifies that @code{strerror_r} returns an @code{int}, but many
4495 systems (e.g., @acronym{GNU} C Library version 2.2.4) provide a
4496 different version returning a @code{char *}.  @code{AC_FUNC_STRERROR_R}
4497 can detect which is in use (@pxref{Particular Functions}).
4499 @item @code{strnlen}
4500 @c @fuindex strnlen
4501 @prindex @code{strnlen}
4502 @acronym{AIX} 4.3 provides a broken version which produces the
4503 following results:
4505 @example
4506 strnlen ("foobar", 0) = 0
4507 strnlen ("foobar", 1) = 3
4508 strnlen ("foobar", 2) = 2
4509 strnlen ("foobar", 3) = 1
4510 strnlen ("foobar", 4) = 0
4511 strnlen ("foobar", 5) = 6
4512 strnlen ("foobar", 6) = 6
4513 strnlen ("foobar", 7) = 6
4514 strnlen ("foobar", 8) = 6
4515 strnlen ("foobar", 9) = 6
4516 @end example
4518 @item @code{sysconf}
4519 @c @fuindex sysconf
4520 @prindex @code{sysconf}
4521 @code{_SC_PAGESIZE} is standard, but some older systems (e.g., @acronym{HP-UX}
4522 9) have @code{_SC_PAGE_SIZE} instead.  This can be tested with
4523 @code{#ifdef}.
4525 @item @code{unlink}
4526 @c @fuindex unlink
4527 @prindex @code{unlink}
4528 The Posix spec says that @code{unlink} causes the given file to be
4529 removed only after there are no more open file handles for it.  Some
4530 non-Posix hosts have trouble with this requirement, though,
4531 and some @acronym{DOS} variants even corrupt the file system.
4533 @item @code{unsetenv}
4534 @c @fuindex unsetenv
4535 @prindex @code{unsetenv}
4536 On MinGW, @code{unsetenv} is not available, but a variable @samp{FOO}
4537 can be removed with a call @code{putenv ("FOO=")}, as described under
4538 @code{putenv} above.
4540 @item @code{va_copy}
4541 @c @fuindex va_copy
4542 @prindex @code{va_copy}
4543 The C99 standard provides @code{va_copy} for copying
4544 @code{va_list} variables.  It may be available in older environments
4545 too, though possibly as @code{__va_copy} (e.g., @command{gcc} in strict
4546 pre-C99 mode).  These can be tested with @code{#ifdef}.  A fallback to
4547 @code{memcpy (&dst, &src, sizeof (va_list))} gives maximum
4548 portability.
4550 @item @code{va_list}
4551 @c @fuindex va_list
4552 @prindex @code{va_list}
4553 @code{va_list} is not necessarily just a pointer.  It can be a
4554 @code{struct} (e.g., @command{gcc} on Alpha), which means @code{NULL} is
4555 not portable.  Or it can be an array (e.g., @command{gcc} in some
4556 PowerPC configurations), which means as a function parameter it can be
4557 effectively call-by-reference and library routines might modify the
4558 value back in the caller (e.g., @code{vsnprintf} in the @acronym{GNU} C Library
4559 2.1).
4561 @item Signed @code{>>}
4562 Normally the C @code{>>} right shift of a signed type replicates the
4563 high bit, giving a so-called ``arithmetic'' shift.  But care should be
4564 taken since Standard C doesn't require that behavior.  On those
4565 few processors without a native arithmetic shift (for instance Cray
4566 vector systems) zero bits may be shifted in, the same as a shift of an
4567 unsigned type.
4569 @item Integer @code{/}
4570 C divides signed integers by truncating their quotient toward zero,
4571 yielding the same result as Fortran.  However, before C99 the standard
4572 allowed C implementations to take the floor or ceiling of the quotient
4573 in some cases.  Hardly any implementations took advantage of this
4574 freedom, though, and it's probably not worth worrying about this issue
4575 nowadays.
4576 @end table
4579 @node Particular Functions
4580 @subsection Particular Function Checks
4581 @cindex Function, checking
4583 These macros check for particular C functions---whether they exist, and
4584 in some cases how they respond when given certain arguments.
4586 @anchor{AC_FUNC_ALLOCA}
4587 @defmac AC_FUNC_ALLOCA
4588 @acindex{FUNC_ALLOCA}
4589 @cvindex C_ALLOCA
4590 @cvindex HAVE_ALLOCA_H
4591 @ovindex ALLOCA
4592 @c @fuindex alloca
4593 @prindex @code{alloca}
4594 @hdrindex{alloca.h}
4595 Check how to get @code{alloca}.  Tries to get a builtin version by
4596 checking for @file{alloca.h} or the predefined C preprocessor macros
4597 @code{__GNUC__} and @code{_AIX}.  If this macro finds @file{alloca.h},
4598 it defines @code{HAVE_ALLOCA_H}.
4600 If those attempts fail, it looks for the function in the standard C
4601 library.  If any of those methods succeed, it defines
4602 @code{HAVE_ALLOCA}.  Otherwise, it sets the output variable
4603 @code{ALLOCA} to @samp{$@{LIBOBJDIR@}alloca.o} and defines
4604 @code{C_ALLOCA} (so programs can periodically call @samp{alloca (0)} to
4605 garbage collect).  This variable is separate from @code{LIBOBJS} so
4606 multiple programs can share the value of @code{ALLOCA} without needing
4607 to create an actual library, in case only some of them use the code in
4608 @code{LIBOBJS}.  The @samp{$@{LIBOBJDIR@}} prefix serves the same
4609 purpose as in @code{LIBOBJS} (@pxref{AC_LIBOBJ vs LIBOBJS}).
4611 This macro does not try to get @code{alloca} from the System V R3
4612 @file{libPW} or the System V R4 @file{libucb} because those libraries
4613 contain some incompatible functions that cause trouble.  Some versions
4614 do not even contain @code{alloca} or contain a buggy version.  If you
4615 still want to use their @code{alloca}, use @code{ar} to extract
4616 @file{alloca.o} from them instead of compiling @file{alloca.c}.
4618 Source files that use @code{alloca} should start with a piece of code
4619 like the following, to declare it properly.
4621 @example
4622 @group
4623 #ifdef HAVE_ALLOCA_H
4624 # include <alloca.h>
4625 #elif defined __GNUC__
4626 # define alloca __builtin_alloca
4627 #elif defined _AIX
4628 # define alloca __alloca
4629 #elif defined _MSC_VER
4630 # include <malloc.h>
4631 # define alloca _alloca
4632 #else
4633 # include <stddef.h>
4634 # ifdef  __cplusplus
4635 extern "C"
4636 # endif
4637 void *alloca (size_t);
4638 #endif
4639 @end group
4640 @end example
4641 @end defmac
4643 @defmac AC_FUNC_CHOWN
4644 @acindex{FUNC_CHOWN}
4645 @cvindex HAVE_CHOWN
4646 @c @fuindex chown
4647 @prindex @code{chown}
4648 If the @code{chown} function is available and works (in particular, it
4649 should accept @option{-1} for @code{uid} and @code{gid}), define
4650 @code{HAVE_CHOWN}.
4651 @end defmac
4653 @anchor{AC_FUNC_CLOSEDIR_VOID}
4654 @defmac AC_FUNC_CLOSEDIR_VOID
4655 @acindex{FUNC_CLOSEDIR_VOID}
4656 @cvindex CLOSEDIR_VOID
4657 @c @fuindex closedir
4658 @prindex @code{closedir}
4659 If the @code{closedir} function does not return a meaningful value,
4660 define @code{CLOSEDIR_VOID}.  Otherwise, callers ought to check its
4661 return value for an error indicator.
4663 Currently this test is implemented by running a test program.  When
4664 cross compiling the pessimistic assumption that @code{closedir} does not
4665 return a meaningful value is made.
4667 This macro is obsolescent, as @code{closedir} returns a meaningful value
4668 on current systems.  New programs need not use this macro.
4669 @end defmac
4671 @defmac AC_FUNC_ERROR_AT_LINE
4672 @acindex{FUNC_ERROR_AT_LINE}
4673 @c @fuindex error_at_line
4674 @prindex @code{error_at_line}
4675 If the @code{error_at_line} function is not found, require an
4676 @code{AC_LIBOBJ} replacement of @samp{error}.
4677 @end defmac
4679 @defmac AC_FUNC_FNMATCH
4680 @acindex{FUNC_FNMATCH}
4681 @c @fuindex fnmatch
4682 @prindex @code{fnmatch}
4683 If the @code{fnmatch} function conforms to Posix, define
4684 @code{HAVE_FNMATCH}.  Detect common implementation bugs, for example,
4685 the bugs in Solaris 2.4.
4687 Unlike the other specific
4688 @code{AC_FUNC} macros, @code{AC_FUNC_FNMATCH} does not replace a
4689 broken/missing @code{fnmatch}.  This is for historical reasons.
4690 See @code{AC_REPLACE_FNMATCH} below.
4692 This macro is obsolescent.  New programs should use Gnulib's
4693 @code{fnmatch-posix} module.  @xref{Gnulib}.
4694 @end defmac
4696 @defmac AC_FUNC_FNMATCH_GNU
4697 @acindex{FUNC_FNMATCH_GNU}
4698 @c @fuindex fnmatch
4699 @prindex @code{fnmatch}
4700 Behave like @code{AC_REPLACE_FNMATCH} (@emph{replace}) but also test
4701 whether @code{fnmatch} supports @acronym{GNU} extensions.  Detect common
4702 implementation bugs, for example, the bugs in the @acronym{GNU} C
4703 Library 2.1.
4705 This macro is obsolescent.  New programs should use Gnulib's
4706 @code{fnmatch-gnu} module.  @xref{Gnulib}.
4707 @end defmac
4709 @anchor{AC_FUNC_FORK}
4710 @defmac AC_FUNC_FORK
4711 @acindex{FUNC_FORK}
4712 @cvindex HAVE_VFORK_H
4713 @cvindex HAVE_WORKING_FORK
4714 @cvindex HAVE_WORKING_VFORK
4715 @cvindex vfork
4716 @c @fuindex fork
4717 @prindex @code{fork}
4718 @c @fuindex vfork
4719 @prindex @code{vfork}
4720 @hdrindex{vfork.h}
4721 This macro checks for the @code{fork} and @code{vfork} functions.  If a
4722 working @code{fork} is found, define @code{HAVE_WORKING_FORK}.  This macro
4723 checks whether @code{fork} is just a stub by trying to run it.
4725 If @file{vfork.h} is found, define @code{HAVE_VFORK_H}.  If a working
4726 @code{vfork} is found, define @code{HAVE_WORKING_VFORK}.  Otherwise,
4727 define @code{vfork} to be @code{fork} for backward compatibility with
4728 previous versions of @command{autoconf}.  This macro checks for several known
4729 errors in implementations of @code{vfork} and considers the system to not
4730 have a working @code{vfork} if it detects any of them.  It is not considered
4731 to be an implementation error if a child's invocation of @code{signal}
4732 modifies the parent's signal handler, since child processes rarely change
4733 their signal handlers.
4735 Since this macro defines @code{vfork} only for backward compatibility with
4736 previous versions of @command{autoconf} you're encouraged to define it
4737 yourself in new code:
4738 @example
4739 @group
4740 #ifndef HAVE_WORKING_VFORK
4741 # define vfork fork
4742 #endif
4743 @end group
4744 @end example
4745 @end defmac
4747 @defmac AC_FUNC_FSEEKO
4748 @acindex{FUNC_FSEEKO}
4749 @cvindex _LARGEFILE_SOURCE
4750 @cvindex HAVE_FSEEKO
4751 @c @fuindex fseeko
4752 @prindex @code{fseeko}
4753 @c @fuindex ftello
4754 @prindex @code{ftello}
4755 If the @code{fseeko} function is available, define @code{HAVE_FSEEKO}.
4756 Define @code{_LARGEFILE_SOURCE} if necessary to make the prototype
4757 visible on some systems (e.g., glibc 2.2).  Otherwise linkage problems
4758 may occur when compiling with @code{AC_SYS_LARGEFILE} on
4759 largefile-sensitive systems where @code{off_t} does not default to a
4760 64bit entity.  All systems with @code{fseeko} also supply @code{ftello}.
4761 @end defmac
4763 @defmac AC_FUNC_GETGROUPS
4764 @acindex{FUNC_GETGROUPS}
4765 @cvindex HAVE_GETGROUPS
4766 @ovindex GETGROUPS_LIBS
4767 @c @fuindex getgroups
4768 @prindex @code{getgroups}
4769 If the @code{getgroups} function is available and works (unlike on
4770 Ultrix 4.3, where @samp{getgroups (0, 0)} always fails), define
4771 @code{HAVE_GETGROUPS}.  Set @code{GETGROUPS_LIBS} to any libraries
4772 needed to get that function.  This macro runs @code{AC_TYPE_GETGROUPS}.
4773 @end defmac
4775 @anchor{AC_FUNC_GETLOADAVG}
4776 @defmac AC_FUNC_GETLOADAVG
4777 @acindex{FUNC_GETLOADAVG}
4778 @cvindex SVR4
4779 @cvindex DGUX
4780 @cvindex UMAX
4781 @cvindex UMAX4_3
4782 @cvindex HAVE_NLIST_H
4783 @cvindex NLIST_NAME_UNION
4784 @cvindex GETLOADAVG_PRIVILEGED
4785 @cvindex NEED_SETGID
4786 @cvindex C_GETLOADAVG
4787 @ovindex LIBOBJS
4788 @ovindex NEED_SETGID
4789 @ovindex KMEM_GROUP
4790 @ovindex GETLOADAVG_LIBS
4791 @c @fuindex getloadavg
4792 @prindex @code{getloadavg}
4793 Check how to get the system load averages.  To perform its tests
4794 properly, this macro needs the file @file{getloadavg.c}; therefore, be
4795 sure to set the @code{AC_LIBOBJ} replacement directory properly (see
4796 @ref{Generic Functions}, @code{AC_CONFIG_LIBOBJ_DIR}).
4798 If the system has the @code{getloadavg} function, define
4799 @code{HAVE_GETLOADAVG}, and set @code{GETLOADAVG_LIBS} to any libraries
4800 necessary to get that function.  Also add @code{GETLOADAVG_LIBS} to
4801 @code{LIBS}.  Otherwise, require an @code{AC_LIBOBJ} replacement for
4802 @samp{getloadavg} with source code in @file{@var{dir}/getloadavg.c}, and
4803 possibly define several other C preprocessor macros and output
4804 variables:
4806 @enumerate
4807 @item
4808 Define @code{C_GETLOADAVG}.
4810 @item
4811 Define @code{SVR4}, @code{DGUX}, @code{UMAX}, or @code{UMAX4_3} if on
4812 those systems.
4814 @item
4815 @hdrindex{nlist.h}
4816 If @file{nlist.h} is found, define @code{HAVE_NLIST_H}.
4818 @item
4819 If @samp{struct nlist} has an @samp{n_un.n_name} member, define
4820 @code{HAVE_STRUCT_NLIST_N_UN_N_NAME}.  The obsolete symbol
4821 @code{NLIST_NAME_UNION} is still defined, but do not depend upon it.
4823 @item
4824 Programs may need to be installed set-group-ID (or set-user-ID) for
4825 @code{getloadavg} to work.  In this case, define
4826 @code{GETLOADAVG_PRIVILEGED}, set the output variable @code{NEED_SETGID}
4827 to @samp{true} (and otherwise to @samp{false}), and set
4828 @code{KMEM_GROUP} to the name of the group that should own the installed
4829 program.
4830 @end enumerate
4832 The @code{AC_FUNC_GETLOADAVG} macro is obsolescent.  New programs should
4833 use Gnulib's @code{getloadavg} module.  @xref{Gnulib}.
4834 @end defmac
4836 @anchor{AC_FUNC_GETMNTENT}
4837 @defmac AC_FUNC_GETMNTENT
4838 @acindex{FUNC_GETMNTENT}
4839 @cvindex HAVE_GETMNTENT
4840 @c @fuindex getmntent
4841 @prindex @code{getmntent}
4842 Check for @code{getmntent} in the standard C library, and then in the
4843 @file{sun}, @file{seq}, and @file{gen} libraries, for @sc{unicos},
4844 @sc{irix} 4, @sc{ptx}, and UnixWare, respectively.  Then, if
4845 @code{getmntent} is available, define @code{HAVE_GETMNTENT}.
4846 @end defmac
4848 @defmac AC_FUNC_GETPGRP
4849 @acindex{FUNC_GETPGRP}
4850 @cvindex GETPGRP_VOID
4851 @c @fuindex getpgid
4852 @c @fuindex getpgrp
4853 @prindex @code{getpgid}
4854 @prindex @code{getpgrp}
4855 Define @code{GETPGRP_VOID} if it is an error to pass 0 to
4856 @code{getpgrp}; this is the Posix behavior.  On older @acronym{BSD}
4857 systems, you must pass 0 to @code{getpgrp}, as it takes an argument and
4858 behaves like Posix's @code{getpgid}.
4860 @example
4861 #ifdef GETPGRP_VOID
4862   pid = getpgrp ();
4863 #else
4864   pid = getpgrp (0);
4865 #endif
4866 @end example
4868 This macro does not check whether
4869 @code{getpgrp} exists at all; if you need to work in that situation,
4870 first call @code{AC_CHECK_FUNC} for @code{getpgrp}.
4872 This macro is obsolescent, as current systems have a @code{getpgrp}
4873 whose signature conforms to Posix.  New programs need not use this macro.
4874 @end defmac
4876 @defmac AC_FUNC_LSTAT_FOLLOWS_SLASHED_SYMLINK
4877 @acindex{FUNC_LSTAT_FOLLOWS_SLASHED_SYMLINK}
4878 @cvindex LSTAT_FOLLOWS_SLASHED_SYMLINK
4879 @c @fuindex lstat
4880 @prindex @code{lstat}
4881 If @file{link} is a symbolic link, then @code{lstat} should treat
4882 @file{link/} the same as @file{link/.}.  However, many older
4883 @code{lstat} implementations incorrectly ignore trailing slashes.
4885 It is safe to assume that if @code{lstat} incorrectly ignores
4886 trailing slashes, then other symbolic-link-aware functions like
4887 @code{unlink} also incorrectly ignore trailing slashes.
4889 If @code{lstat} behaves properly, define
4890 @code{LSTAT_FOLLOWS_SLASHED_SYMLINK}, otherwise require an
4891 @code{AC_LIBOBJ} replacement of @code{lstat}.
4892 @end defmac
4894 @defmac AC_FUNC_MALLOC
4895 @acindex{FUNC_MALLOC}
4896 @cvindex HAVE_MALLOC
4897 @cvindex malloc
4898 @c @fuindex malloc
4899 @prindex @code{malloc}
4900 If the @code{malloc} function is compatible with the @acronym{GNU} C
4901 library @code{malloc} (i.e., @samp{malloc (0)} returns a valid
4902 pointer), define @code{HAVE_MALLOC} to 1.  Otherwise define
4903 @code{HAVE_MALLOC} to 0, ask for an @code{AC_LIBOBJ} replacement for
4904 @samp{malloc}, and define @code{malloc} to @code{rpl_malloc} so that the
4905 native @code{malloc} is not used in the main project.
4907 Typically, the replacement file @file{malloc.c} should look like (note
4908 the @samp{#undef malloc}):
4910 @verbatim
4911 #include <config.h>
4912 #undef malloc
4914 #include <sys/types.h>
4916 void *malloc ();
4918 /* Allocate an N-byte block of memory from the heap.
4919    If N is zero, allocate a 1-byte block.  */
4921 void *
4922 rpl_malloc (size_t n)
4924   if (n == 0)
4925     n = 1;
4926   return malloc (n);
4928 @end verbatim
4929 @end defmac
4931 @defmac AC_FUNC_MEMCMP
4932 @acindex{FUNC_MEMCMP}
4933 @ovindex LIBOBJS
4934 @c @fuindex memcmp
4935 @prindex @code{memcmp}
4936 If the @code{memcmp} function is not available, or does not work on
4937 8-bit data (like the one on SunOS 4.1.3), or fails when comparing 16
4938 bytes or more and with at least one buffer not starting on a 4-byte
4939 boundary (such as the one on NeXT x86 OpenStep), require an
4940 @code{AC_LIBOBJ} replacement for @samp{memcmp}.
4942 This macro is obsolescent, as current systems have a working
4943 @code{memcmp}.  New programs need not use this macro.
4944 @end defmac
4946 @defmac AC_FUNC_MBRTOWC
4947 @acindex{FUNC_MBRTOWC}
4948 @cvindex HAVE_MBRTOWC
4949 @c @fuindex mbrtowc
4950 @prindex @code{mbrtowc}
4951 Define @code{HAVE_MBRTOWC} to 1 if the function @code{mbrtowc} and the
4952 type @code{mbstate_t} are properly declared.
4953 @end defmac
4955 @defmac AC_FUNC_MKTIME
4956 @acindex{FUNC_MKTIME}
4957 @ovindex LIBOBJS
4958 @c @fuindex mktime
4959 @prindex @code{mktime}
4960 If the @code{mktime} function is not available, or does not work
4961 correctly, require an @code{AC_LIBOBJ} replacement for @samp{mktime}.
4962 For the purposes of this test, @code{mktime} should conform to the
4963 Posix standard and should be the inverse of
4964 @code{localtime}.
4965 @end defmac
4967 @anchor{AC_FUNC_MMAP}
4968 @defmac AC_FUNC_MMAP
4969 @acindex{FUNC_MMAP}
4970 @cvindex HAVE_MMAP
4971 @c @fuindex mmap
4972 @prindex @code{mmap}
4973 If the @code{mmap} function exists and works correctly, define
4974 @code{HAVE_MMAP}.  This checks only private fixed mapping of already-mapped
4975 memory.
4976 @end defmac
4978 @defmac AC_FUNC_OBSTACK
4979 @acindex{FUNC_OBSTACK}
4980 @cvindex HAVE_OBSTACK
4981 @cindex obstack
4982 If the obstacks are found, define @code{HAVE_OBSTACK}, else require an
4983 @code{AC_LIBOBJ} replacement for @samp{obstack}.
4984 @end defmac
4986 @defmac AC_FUNC_REALLOC
4987 @acindex{FUNC_REALLOC}
4988 @cvindex HAVE_REALLOC
4989 @cvindex realloc
4990 @c @fuindex realloc
4991 @prindex @code{realloc}
4992 If the @code{realloc} function is compatible with the @acronym{GNU} C
4993 library @code{realloc} (i.e., @samp{realloc (NULL, 0)} returns a
4994 valid pointer), define @code{HAVE_REALLOC} to 1.  Otherwise define
4995 @code{HAVE_REALLOC} to 0, ask for an @code{AC_LIBOBJ} replacement for
4996 @samp{realloc}, and define @code{realloc} to @code{rpl_realloc} so that
4997 the native @code{realloc} is not used in the main project.  See
4998 @code{AC_FUNC_MALLOC} for details.
4999 @end defmac
5001 @defmac AC_FUNC_SELECT_ARGTYPES
5002 @acindex{FUNC_SELECT_ARGTYPES}
5003 @cvindex SELECT_TYPE_ARG1
5004 @cvindex SELECT_TYPE_ARG234
5005 @cvindex SELECT_TYPE_ARG5
5006 @c @fuindex select
5007 @prindex @code{select}
5008 Determines the correct type to be passed for each of the
5009 @code{select} function's arguments, and defines those types
5010 in @code{SELECT_TYPE_ARG1}, @code{SELECT_TYPE_ARG234}, and
5011 @code{SELECT_TYPE_ARG5} respectively.  @code{SELECT_TYPE_ARG1} defaults
5012 to @samp{int}, @code{SELECT_TYPE_ARG234} defaults to @samp{int *},
5013 and @code{SELECT_TYPE_ARG5} defaults to @samp{struct timeval *}.
5015 This macro is obsolescent, as current systems have a @code{select} whose
5016 signature conforms to Posix.  New programs need not use this macro.
5017 @end defmac
5019 @defmac AC_FUNC_SETPGRP
5020 @acindex{FUNC_SETPGRP}
5021 @cvindex SETPGRP_VOID
5022 @c @fuindex setpgrp
5023 @prindex @code{setpgrp}
5024 If @code{setpgrp} takes no argument (the Posix version), define
5025 @code{SETPGRP_VOID}.  Otherwise, it is the @acronym{BSD} version, which takes
5026 two process IDs as arguments.  This macro does not check whether
5027 @code{setpgrp} exists at all; if you need to work in that situation,
5028 first call @code{AC_CHECK_FUNC} for @code{setpgrp}.
5030 This macro is obsolescent, as current systems have a @code{setpgrp}
5031 whose signature conforms to Posix.  New programs need not use this macro.
5032 @end defmac
5034 @defmac AC_FUNC_STAT
5035 @defmacx AC_FUNC_LSTAT
5036 @acindex{FUNC_STAT}
5037 @acindex{FUNC_LSTAT}
5038 @cvindex HAVE_STAT_EMPTY_STRING_BUG
5039 @cvindex HAVE_LSTAT_EMPTY_STRING_BUG
5040 @c @fuindex stat
5041 @prindex @code{stat}
5042 @c @fuindex lstat
5043 @prindex @code{lstat}
5044 Determine whether @code{stat} or @code{lstat} have the bug that it
5045 succeeds when given the zero-length file name as argument.  The @code{stat}
5046 and @code{lstat} from SunOS 4.1.4 and the Hurd (as of 1998-11-01) do
5047 this.
5049 If it does, then define @code{HAVE_STAT_EMPTY_STRING_BUG} (or
5050 @code{HAVE_LSTAT_EMPTY_STRING_BUG}) and ask for an @code{AC_LIBOBJ}
5051 replacement of it.
5053 These macros are obsolescent, as no current systems have the bug.
5054 New programs need not use these macros.
5055 @end defmac
5057 @anchor{AC_FUNC_STRCOLL}
5058 @defmac AC_FUNC_STRCOLL
5059 @acindex{FUNC_STRCOLL}
5060 @cvindex HAVE_STRCOLL
5061 @c @fuindex strcoll
5062 @prindex @code{strcoll}
5063 If the @code{strcoll} function exists and works correctly, define
5064 @code{HAVE_STRCOLL}.  This does a bit more than
5065 @samp{AC_CHECK_FUNCS(strcoll)}, because some systems have incorrect
5066 definitions of @code{strcoll} that should not be used.
5067 @end defmac
5069 @defmac AC_FUNC_STRERROR_R
5070 @acindex{FUNC_STRERROR_R}
5071 @cvindex HAVE_STRERROR_R
5072 @cvindex HAVE_DECL_STRERROR_R
5073 @cvindex STRERROR_R_CHAR_P
5074 @c @fuindex strerror_r
5075 @prindex @code{strerror_r}
5076 If @code{strerror_r} is available, define @code{HAVE_STRERROR_R}, and if
5077 it is declared, define @code{HAVE_DECL_STRERROR_R}.  If it returns a
5078 @code{char *} message, define @code{STRERROR_R_CHAR_P}; otherwise it
5079 returns an @code{int} error number.  The Thread-Safe Functions option of
5080 Posix requires @code{strerror_r} to return @code{int}, but
5081 many systems (including, for example, version 2.2.4 of the @acronym{GNU} C
5082 Library) return a @code{char *} value that is not necessarily equal to
5083 the buffer argument.
5084 @end defmac
5086 @anchor{AC_FUNC_STRFTIME}
5087 @defmac AC_FUNC_STRFTIME
5088 @acindex{FUNC_STRFTIME}
5089 @cvindex HAVE_STRFTIME
5090 @c @fuindex strftime
5091 @prindex @code{strftime}
5092 Check for @code{strftime} in the @file{intl} library, for SCO Unix.
5093 Then, if @code{strftime} is available, define @code{HAVE_STRFTIME}.
5095 This macro is obsolescent, as no current systems require the @file{intl}
5096 library for @code{strftime}.  New programs need not use this macro.
5097 @end defmac
5099 @defmac AC_FUNC_STRTOD
5100 @acindex{FUNC_STRTOD}
5101 @ovindex POW_LIB
5102 @c @fuindex strtod
5103 @prindex @code{strtod}
5104 If the @code{strtod} function does not exist or doesn't work correctly,
5105 ask for an @code{AC_LIBOBJ} replacement of @samp{strtod}.  In this case,
5106 because @file{strtod.c} is likely to need @samp{pow}, set the output
5107 variable @code{POW_LIB} to the extra library needed.
5108 @end defmac
5110 @defmac AC_FUNC_STRTOLD
5111 @acindex{FUNC_STRTOLD}
5112 @cvindex HAVE_STRTOLD
5113 @prindex @code{strtold}
5114 If the @code{strtold} function exists and conforms to C99, define
5115 @code{HAVE_STRTOLD}.
5116 @end defmac
5118 @defmac AC_FUNC_STRNLEN
5119 @acindex{FUNC_STRNLEN}
5120 @cvindex HAVE_STRNLEN
5121 @c @fuindex strnlen
5122 @prindex @code{strnlen}
5123 If the @code{strnlen} function is not available, or is buggy (like the one
5124 from @acronym{AIX} 4.3), require an @code{AC_LIBOBJ} replacement for it.
5125 @end defmac
5127 @anchor{AC_FUNC_UTIME_NULL}
5128 @defmac AC_FUNC_UTIME_NULL
5129 @acindex{FUNC_UTIME_NULL}
5130 @cvindex HAVE_UTIME_NULL
5131 @c @fuindex utime
5132 @prindex @code{utime}
5133 If @samp{utime (@var{file}, NULL)} sets @var{file}'s timestamp to
5134 the present, define @code{HAVE_UTIME_NULL}.
5136 This macro is obsolescent, as all current systems have a @code{utime}
5137 that behaves this way.  New programs need not use this macro.
5138 @end defmac
5140 @anchor{AC_FUNC_VPRINTF}
5141 @defmac AC_FUNC_VPRINTF
5142 @acindex{FUNC_VPRINTF}
5143 @cvindex HAVE_VPRINTF
5144 @cvindex HAVE_DOPRNT
5145 @c @fuindex vprintf
5146 @prindex @code{vprintf}
5147 @c @fuindex vsprintf
5148 @prindex @code{vsprintf}
5149 If @code{vprintf} is found, define @code{HAVE_VPRINTF}.  Otherwise, if
5150 @code{_doprnt} is found, define @code{HAVE_DOPRNT}.  (If @code{vprintf}
5151 is available, you may assume that @code{vfprintf} and @code{vsprintf}
5152 are also available.)
5154 This macro is obsolescent, as all current systems have @code{vprintf}.
5155 New programs need not use this macro.
5156 @end defmac
5158 @defmac AC_REPLACE_FNMATCH
5159 @acindex{REPLACE_FNMATCH}
5160 @c @fuindex fnmatch
5161 @prindex @code{fnmatch}
5162 @hdrindex{fnmatch.h}
5163 If the @code{fnmatch} function does not conform to Posix (see
5164 @code{AC_FUNC_FNMATCH}), ask for its @code{AC_LIBOBJ} replacement.
5166 The files @file{fnmatch.c}, @file{fnmatch_loop.c}, and @file{fnmatch_.h}
5167 in the @code{AC_LIBOBJ} replacement directory are assumed to contain a
5168 copy of the source code of @acronym{GNU} @code{fnmatch}.  If necessary,
5169 this source code is compiled as an @code{AC_LIBOBJ} replacement, and the
5170 @file{fnmatch_.h} file is linked to @file{fnmatch.h} so that it can be
5171 included in place of the system @code{<fnmatch.h>}.
5173 This macro is obsolescent, as it assumes the use of particular source
5174 files.  New programs should use Gnulib's @code{fnmatch-posix} module,
5175 which provides this macro along with the source files.  @xref{Gnulib}.
5176 @end defmac
5180 @node Generic Functions
5181 @subsection Generic Function Checks
5183 These macros are used to find functions not covered by the ``particular''
5184 test macros.  If the functions might be in libraries other than the
5185 default C library, first call @code{AC_CHECK_LIB} for those libraries.
5186 If you need to check the behavior of a function as well as find out
5187 whether it is present, you have to write your own test for
5188 it (@pxref{Writing Tests}).
5190 @anchor{AC_CHECK_FUNC}
5191 @defmac AC_CHECK_FUNC (@var{function}, @ovar{action-if-found}, @
5192   @ovar{action-if-not-found})
5193 @acindex{CHECK_FUNC}
5194 If C function @var{function} is available, run shell commands
5195 @var{action-if-found}, otherwise @var{action-if-not-found}.  If you just
5196 want to define a symbol if the function is available, consider using
5197 @code{AC_CHECK_FUNCS} instead.  This macro checks for functions with C
5198 linkage even when @code{AC_LANG(C++)} has been called, since C is more
5199 standardized than C++.  (@pxref{Language Choice}, for more information
5200 about selecting the language for checks.)
5201 @end defmac
5203 @anchor{AC_CHECK_FUNCS}
5204 @defmac AC_CHECK_FUNCS (@var{function}@dots{}, @ovar{action-if-found}, @
5205   @ovar{action-if-not-found})
5206 @acindex{CHECK_FUNCS}
5207 @cvindex HAVE_@var{function}
5208 For each @var{function} enumerated in the blank-or-newline-separated argument
5209 list, define @code{HAVE_@var{function}} (in all capitals) if it is available.
5210 If @var{action-if-found} is given, it is additional shell code to
5211 execute when one of the functions is found.  You can give it a value of
5212 @samp{break} to break out of the loop on the first match.  If
5213 @var{action-if-not-found} is given, it is executed when one of the
5214 functions is not found.
5215 @end defmac
5217 @defmac AC_CHECK_FUNCS_ONCE (@var{function}@dots{})
5218 @acindex{CHECK_FUNCS_ONCE}
5219 @cvindex HAVE_@var{function}
5220 For each @var{function} enumerated in the blank-or-newline-separated argument
5221 list, define @code{HAVE_@var{function}} (in all capitals) if it is available.
5222 This is a once-only variant of @code{AC_CHECK_FUNCS}.  It generates the
5223 checking code at most once, so that @command{configure} is smaller and
5224 faster; but the checks cannot be conditionalized and are always done once,
5225 early during the @command{configure} run.
5226 @end defmac
5228 @sp 1
5230 Autoconf follows a philosophy that was formed over the years by those
5231 who have struggled for portability: isolate the portability issues in
5232 specific files, and then program as if you were in a Posix
5233 environment.  Some functions may be missing or unfixable, and your
5234 package must be ready to replace them.
5236 Suitable replacements for many such problem functions are available from
5237 Gnulib (@pxref{Gnulib}).
5239 @defmac AC_LIBOBJ (@var{function})
5240 @acindex{LIBOBJ}
5241 @ovindex LIBOBJS
5242 Specify that @samp{@var{function}.c} must be included in the executables
5243 to replace a missing or broken implementation of @var{function}.
5245 Technically, it adds @samp{@var{function}.$ac_objext} to the output
5246 variable @code{LIBOBJS} if it is not already in, and calls
5247 @code{AC_LIBSOURCE} for @samp{@var{function}.c}.  You should not
5248 directly change @code{LIBOBJS}, since this is not traceable.
5249 @end defmac
5251 @defmac AC_LIBSOURCE (@var{file})
5252 @acindex{LIBSOURCE}
5253 Specify that @var{file} might be needed to compile the project.  If you
5254 need to know what files might be needed by a @file{configure.ac}, you
5255 should trace @code{AC_LIBSOURCE}.  @var{file} must be a literal.
5257 This macro is called automatically from @code{AC_LIBOBJ}, but you must
5258 call it explicitly if you pass a shell variable to @code{AC_LIBOBJ}.  In
5259 that case, since shell variables cannot be traced statically, you must
5260 pass to @code{AC_LIBSOURCE} any possible files that the shell variable
5261 might cause @code{AC_LIBOBJ} to need.  For example, if you want to pass
5262 a variable @code{$foo_or_bar} to @code{AC_LIBOBJ} that holds either
5263 @code{"foo"} or @code{"bar"}, you should do:
5265 @example
5266 AC_LIBSOURCE([foo.c])
5267 AC_LIBSOURCE([bar.c])
5268 AC_LIBOBJ([$foo_or_bar])
5269 @end example
5271 @noindent
5272 There is usually a way to avoid this, however, and you are encouraged to
5273 simply call @code{AC_LIBOBJ} with literal arguments.
5275 Note that this macro replaces the obsolete @code{AC_LIBOBJ_DECL}, with
5276 slightly different semantics: the old macro took the function name,
5277 e.g., @code{foo}, as its argument rather than the file name.
5278 @end defmac
5280 @defmac AC_LIBSOURCES (@var{files})
5281 @acindex{LIBSOURCES}
5282 Like @code{AC_LIBSOURCE}, but accepts one or more @var{files} in a
5283 comma-separated M4 list.  Thus, the above example might be rewritten:
5285 @example
5286 AC_LIBSOURCES([foo.c, bar.c])
5287 AC_LIBOBJ([$foo_or_bar])
5288 @end example
5289 @end defmac
5291 @defmac AC_CONFIG_LIBOBJ_DIR (@var{directory})
5292 @acindex{CONFIG_LIBOBJ_DIR}
5293 Specify that @code{AC_LIBOBJ} replacement files are to be found in
5294 @var{directory}, a name relative to the top level of the
5295 source tree.  The replacement directory defaults to @file{.}, the top
5296 level directory, and the most typical value is @file{lib}, corresponding
5297 to @samp{AC_CONFIG_LIBOBJ_DIR([lib])}.
5299 @command{configure} might need to know the replacement directory for the
5300 following reasons: (i) some checks use the replacement files, (ii) some
5301 macros bypass broken system headers by installing links to the
5302 replacement headers (iii) when used in conjunction with Automake,
5303 within each makefile, @var{directory} is used as a relative path
5304 from @code{$(top_srcdir)} to each object named in @code{LIBOBJS} and
5305 @code{LTLIBOBJS}, etc.
5306 @end defmac
5308 @sp 1
5310 It is common to merely check for the existence of a function, and ask
5311 for its @code{AC_LIBOBJ} replacement if missing.  The following macro is
5312 a convenient shorthand.
5314 @defmac AC_REPLACE_FUNCS (@var{function}@dots{})
5315 @acindex{REPLACE_FUNCS}
5316 @cvindex HAVE_@var{function}
5317 @ovindex LIBOBJS
5318 Like @code{AC_CHECK_FUNCS}, but uses @samp{AC_LIBOBJ(@var{function})} as
5319 @var{action-if-not-found}.  You can declare your replacement function by
5320 enclosing the prototype in @samp{#ifndef HAVE_@var{function}}.  If the
5321 system has the function, it probably declares it in a header file you
5322 should be including, so you shouldn't redeclare it lest your declaration
5323 conflict.
5324 @end defmac
5326 @node Header Files
5327 @section Header Files
5328 @cindex Header, checking
5330 The following macros check for the presence of certain C header files.
5331 If there is no macro specifically defined to check for a header file you need,
5332 and you don't need to check for any special properties of
5333 it, then you can use one of the general header-file check macros.
5335 @menu
5336 * Header Portability::          Collected knowledge on common headers
5337 * Particular Headers::          Special handling to find certain headers
5338 * Generic Headers::             How to find other headers
5339 @end menu
5341 @node Header Portability
5342 @subsection Portability of Headers
5343 @cindex Portability of headers
5344 @cindex Header portability
5346 This section tries to collect knowledge about common headers, and the
5347 problems they cause.  By definition, this list always requires
5348 additions.  Please help us keeping it as complete as possible.
5350 @table @asis
5352 @item @file{limits.h}
5353 C99 says that @file{limits.h} defines @code{LLONG_MIN},
5354 @code{LLONG_MAX}, and @code{ULLONG_MAX}, but many almost-C99
5355 environments (e.g., default @acronym{GCC} 4.0.2 + glibc 2.4) do not
5356 define them.
5358 @item @file{inttypes.h} vs.@: @file{stdint.h}
5359 @hdrindex{inttypes.h}
5360 @hdrindex{stdint.h}
5361 The C99 standard says that @file{inttypes.h} includes
5362 @file{stdint.h}, so there's no need to include @file{stdint.h}
5363 separately in a standard environment.  Some implementations have
5364 @file{inttypes.h} but not @file{stdint.h} (e.g., Solaris 7), but we don't
5365 know of any implementation that has @file{stdint.h} but not
5366 @file{inttypes.h}.
5368 @item @file{linux/irda.h}
5369 @hdrindex{linux/irda.h}
5370 It requires @file{linux/types.h} and @file{sys/socket.h}.
5372 @item @file{linux/random.h}
5373 @hdrindex{linux/random.h}
5374 It requires @file{linux/types.h}.
5376 @item @file{net/if.h}
5377 @hdrindex{net/if.h}
5378 On Darwin, this file requires that @file{sys/socket.h} be included
5379 beforehand.  One should run:
5381 @example
5382 AC_CHECK_HEADERS([sys/socket.h])
5383 AC_CHECK_HEADERS([net/if.h], [], [],
5384 [#include <stdio.h>
5385 #ifdef STDC_HEADERS
5386 # include <stdlib.h>
5387 # include <stddef.h>
5388 #else
5389 # ifdef HAVE_STDLIB_H
5390 #  include <stdlib.h>
5391 # endif
5392 #endif
5393 #ifdef HAVE_SYS_SOCKET_H
5394 # include <sys/socket.h>
5395 #endif
5397 @end example
5399 @item @file{netinet/if_ether.h}
5400 @hdrindex{netinet/if_ether.h}
5401 On Darwin, this file requires that @file{stdio.h} and
5402 @file{sys/socket.h} be included beforehand.  One should run:
5404 @example
5405 AC_CHECK_HEADERS([sys/socket.h])
5406 AC_CHECK_HEADERS([netinet/if_ether.h], [], [],
5407 [#include <stdio.h>
5408 #ifdef STDC_HEADERS
5409 # include <stdlib.h>
5410 # include <stddef.h>
5411 #else
5412 # ifdef HAVE_STDLIB_H
5413 #  include <stdlib.h>
5414 # endif
5415 #endif
5416 #ifdef HAVE_SYS_SOCKET_H
5417 # include <sys/socket.h>
5418 #endif
5420 @end example
5422 @item @file{stdint.h}
5423 See above, item @file{inttypes.h} vs.@: @file{stdint.h}.
5425 @item @file{stdlib.h}
5426 @hdrindex{stdlib.h}
5427 On many systems (e.g., Darwin), @file{stdio.h} is a prerequisite.
5429 @item @file{sys/mount.h}
5430 @hdrindex{sys/mount.h}
5431 On Free@acronym{BSD} 4.8 on ia32 and using gcc version 2.95.4,
5432 @file{sys/params.h} is a prerequisite.
5434 @item @file{sys/ptem.h}
5435 @hdrindex{sys/ptem.h}
5436 On Solaris 8, @file{sys/stream.h} is a prerequisite.
5438 @item @file{sys/socket.h}
5439 @hdrindex{sys/socket.h}
5440 On Darwin, @file{stdlib.h} is a prerequisite.
5442 @item @file{sys/ucred.h}
5443 @hdrindex{sys/ucred.h}
5444 On Tru64 5.1, @file{sys/types.h} is a prerequisite.
5446 @item @file{X11/extensions/scrnsaver.h}
5447 @hdrindex{X11/extensions/scrnsaver.h}
5448 Using XFree86, this header requires @file{X11/Xlib.h}, which is probably
5449 so required that you might not even consider looking for it.
5451 @example
5452 AC_CHECK_HEADERS([X11/extensions/scrnsaver.h], [], [],
5453 [[#include <X11/Xlib.h>
5455 @end example
5456 @end table
5459 @node Particular Headers
5460 @subsection Particular Header Checks
5462 These macros check for particular system header files---whether they
5463 exist, and in some cases whether they declare certain symbols.
5465 @defmac AC_HEADER_ASSERT
5466 @acindex{HEADER_ASSERT}
5467 @cvindex NDEBUG
5468 @hdrindex{assert.h}
5469 Check whether to enable assertions in the style of @file{assert.h}.
5470 Assertions are enabled by default, but the user can override this by
5471 invoking @command{configure} with the @option{--disable-assert} option.
5472 @end defmac
5474 @anchor{AC_HEADER_DIRENT}
5475 @defmac AC_HEADER_DIRENT
5476 @acindex{HEADER_DIRENT}
5477 @cvindex HAVE_DIRENT_H
5478 @cvindex HAVE_NDIR_H
5479 @cvindex HAVE_SYS_DIR_H
5480 @cvindex HAVE_SYS_NDIR_H
5481 @hdrindex{dirent.h}
5482 @hdrindex{sys/ndir.h}
5483 @hdrindex{sys/dir.h}
5484 @hdrindex{ndir.h}
5485 Check for the following header files.  For the first one that is
5486 found and defines @samp{DIR}, define the listed C preprocessor macro:
5488 @multitable {@file{sys/ndir.h}} {@code{HAVE_SYS_NDIR_H}}
5489 @item @file{dirent.h}   @tab @code{HAVE_DIRENT_H}
5490 @item @file{sys/ndir.h} @tab @code{HAVE_SYS_NDIR_H}
5491 @item @file{sys/dir.h}  @tab @code{HAVE_SYS_DIR_H}
5492 @item @file{ndir.h}     @tab @code{HAVE_NDIR_H}
5493 @end multitable
5495 The directory-library declarations in your source code should look
5496 something like the following:
5498 @example
5499 @group
5500 #include <sys/types.h>
5501 #ifdef HAVE_DIRENT_H
5502 # include <dirent.h>
5503 # define NAMLEN(dirent) strlen ((dirent)->d_name)
5504 #else
5505 # define dirent direct
5506 # define NAMLEN(dirent) ((dirent)->d_namlen)
5507 # ifdef HAVE_SYS_NDIR_H
5508 #  include <sys/ndir.h>
5509 # endif
5510 # ifdef HAVE_SYS_DIR_H
5511 #  include <sys/dir.h>
5512 # endif
5513 # ifdef HAVE_NDIR_H
5514 #  include <ndir.h>
5515 # endif
5516 #endif
5517 @end group
5518 @end example
5520 Using the above declarations, the program would declare variables to be
5521 of type @code{struct dirent}, not @code{struct direct}, and would access
5522 the length of a directory entry name by passing a pointer to a
5523 @code{struct dirent} to the @code{NAMLEN} macro.
5525 This macro also checks for the SCO Xenix @file{dir} and @file{x} libraries.
5527 This macro is obsolescent, as all current systems with directory
5528 libraries have @code{<dirent.h>}.  New programs need not use this macro.
5530 Also see @code{AC_STRUCT_DIRENT_D_INO} and
5531 @code{AC_STRUCT_DIRENT_D_TYPE} (@pxref{Particular Structures}).
5532 @end defmac
5534 @anchor{AC_HEADER_MAJOR}
5535 @defmac AC_HEADER_MAJOR
5536 @acindex{HEADER_MAJOR}
5537 @cvindex MAJOR_IN_MKDEV
5538 @cvindex MAJOR_IN_SYSMACROS
5539 @hdrindex{sys/mkdev.h}
5540 @hdrindex{sys/sysmacros.h}
5541 If @file{sys/types.h} does not define @code{major}, @code{minor}, and
5542 @code{makedev}, but @file{sys/mkdev.h} does, define
5543 @code{MAJOR_IN_MKDEV}; otherwise, if @file{sys/sysmacros.h} does, define
5544 @code{MAJOR_IN_SYSMACROS}.
5545 @end defmac
5547 @defmac AC_HEADER_RESOLV
5548 @acindex{HEADER_RESOLV}
5549 @cvindex HAVE_RESOLV_H
5550 @hdrindex{resolv.h}
5551 Checks for header @file{resolv.h}, checking for prerequisites first.
5552 To properly use @file{resolv.h}, your code should contain something like
5553 the following:
5555 @verbatim
5556 #ifdef HAVE_SYS_TYPES_H
5557 #  include <sys/types.h>
5558 #endif
5559 #ifdef HAVE_NETINET_IN_H
5560 #  include <netinet/in.h>   /* inet_ functions / structs */
5561 #endif
5562 #ifdef HAVE_ARPA_NAMESER_H
5563 #  include <arpa/nameser.h> /* DNS HEADER struct */
5564 #endif
5565 #ifdef HAVE_NETDB_H
5566 #  include <netdb.h>
5567 #endif
5568 #include <resolv.h>
5569 @end verbatim
5570 @end defmac
5572 @anchor{AC_HEADER_STAT}
5573 @defmac AC_HEADER_STAT
5574 @acindex{HEADER_STAT}
5575 @cvindex STAT_MACROS_BROKEN
5576 @hdrindex{sys/stat.h}
5577 If the macros @code{S_ISDIR}, @code{S_ISREG}, etc.@: defined in
5578 @file{sys/stat.h} do not work properly (returning false positives),
5579 define @code{STAT_MACROS_BROKEN}.  This is the case on Tektronix UTekV,
5580 Amdahl UTS and Motorola System V/88.
5582 This macro is obsolescent, as no current systems have the bug.
5583 New programs need not use this macro.
5584 @end defmac
5586 @defmac AC_HEADER_STDBOOL
5587 @acindex{HEADER_STDBOOL}
5588 @cvindex HAVE_STDBOOL_H
5589 @cvindex HAVE__BOOL
5590 @hdrindex{stdbool.h}
5591 @hdrindex{system.h}
5592 If @file{stdbool.h} exists and conforms to C99, define
5593 @code{HAVE_STDBOOL_H} to 1; if the type @code{_Bool} is defined, define
5594 @code{HAVE__BOOL} to 1.  To fulfill the C99 requirements, your
5595 @file{system.h} could contain the following code:
5597 @verbatim
5598 #ifdef HAVE_STDBOOL_H
5599 # include <stdbool.h>
5600 #else
5601 # ifndef HAVE__BOOL
5602 #  ifdef __cplusplus
5603 typedef bool _Bool;
5604 #  else
5605 #   define _Bool signed char
5606 #  endif
5607 # endif
5608 # define bool _Bool
5609 # define false 0
5610 # define true 1
5611 # define __bool_true_false_are_defined 1
5612 #endif
5613 @end verbatim
5615 Alternatively you can use the @samp{stdbool} package of Gnulib
5616 (@pxref{Gnulib}); it packages the above code into a replacement header
5617 and contains a few other bells and whistles.
5619 @end defmac
5621 @anchor{AC_HEADER_STDC}
5622 @defmac AC_HEADER_STDC
5623 @acindex{HEADER_STDC}
5624 @cvindex STDC_HEADERS
5625 @hdrindex{stdlib.h}
5626 @hdrindex{stdarg.h}
5627 @hdrindex{string.h}
5628 @hdrindex{float.h}
5629 @hdrindex{ctype.h}
5630 Define @code{STDC_HEADERS} if the system has C header files
5631 conforming to @acronym{ANSI} C89 (@acronym{ISO} C90).
5632 Specifically, this macro checks for @file{stdlib.h}, @file{stdarg.h},
5633 @file{string.h}, and @file{float.h}; if the system has those, it
5634 probably has the rest of the C89 header files.  This macro also
5635 checks whether @file{string.h} declares @code{memchr} (and thus
5636 presumably the other @code{mem} functions), whether @file{stdlib.h}
5637 declare @code{free} (and thus presumably @code{malloc} and other related
5638 functions), and whether the @file{ctype.h} macros work on characters
5639 with the high bit set, as the C standard requires.
5641 If you use this macro, your code can refer to @code{STDC_HEADERS} to
5642 determine whether the system has conforming header files (and probably C
5643 library functions).
5645 This macro is obsolescent, as current systems have conforming header
5646 files.  New programs need not use this macro.
5648 @hdrindex{string.h}
5649 @hdrindex{strings.h}
5650 Nowadays @file{string.h} is part of the C standard and declares functions like
5651 @code{strcpy}, and @file{strings.h} is standardized by Posix and declares
5652 @acronym{BSD} functions like @code{bcopy}; but
5653 historically, string functions were a major sticking point in this area.
5654 If you still want to worry about portability to ancient systems without
5655 standard headers, there is so much variation
5656 that it is probably easier to declare the functions you use than to
5657 figure out exactly what the system header files declare.  Some ancient systems
5658 contained a mix of functions from the C standard and from @acronym{BSD};
5659 some were mostly standard but lacked @samp{memmove}; some defined the
5660 @acronym{BSD} functions as macros in @file{string.h} or
5661 @file{strings.h}; some had only the @acronym{BSD} functions but
5662 @file{string.h}; some declared the memory functions in @file{memory.h},
5663 some in @file{string.h}; etc.  It is probably sufficient to check for
5664 one string function and one memory function; if the library had the
5665 standard versions of those then it probably had most of the others.
5666 If you put the following in @file{configure.ac}:
5668 @example
5669 # This example is obsolescent.
5670 # Nowadays you can omit these macro calls.
5671 AC_HEADER_STDC
5672 AC_CHECK_FUNCS([strchr memcpy])
5673 @end example
5675 @noindent
5676 then, in your code, you can use declarations like this:
5678 @example
5679 @group
5680 /* This example is obsolescent.
5681    Nowadays you can just #include <string.h>.  */
5682 #ifdef STDC_HEADERS
5683 # include <string.h>
5684 #else
5685 # ifndef HAVE_STRCHR
5686 #  define strchr index
5687 #  define strrchr rindex
5688 # endif
5689 char *strchr (), *strrchr ();
5690 # ifndef HAVE_MEMCPY
5691 #  define memcpy(d, s, n) bcopy ((s), (d), (n))
5692 #  define memmove(d, s, n) bcopy ((s), (d), (n))
5693 # endif
5694 #endif
5695 @end group
5696 @end example
5698 @noindent
5699 If you use a function like @code{memchr}, @code{memset}, @code{strtok},
5700 or @code{strspn}, which have no @acronym{BSD} equivalent, then macros don't
5701 suffice to port to ancient hosts; you must provide an implementation of
5702 each function.  An easy
5703 way to incorporate your implementations only when needed (since the ones
5704 in system C libraries may be hand optimized) is to, taking @code{memchr}
5705 for example, put it in @file{memchr.c} and use
5706 @samp{AC_REPLACE_FUNCS([memchr])}.
5707 @end defmac
5709 @defmac AC_HEADER_SYS_WAIT
5710 @acindex{HEADER_SYS_WAIT}
5711 @cvindex HAVE_SYS_WAIT_H
5712 @hdrindex{sys/wait.h}
5713 If @file{sys/wait.h} exists and is compatible with Posix, define
5714 @code{HAVE_SYS_WAIT_H}.  Incompatibility can occur if @file{sys/wait.h}
5715 does not exist, or if it uses the old @acronym{BSD} @code{union wait} instead
5716 of @code{int} to store a status value.  If @file{sys/wait.h} is not
5717 Posix compatible, then instead of including it, define the
5718 Posix macros with their usual interpretations.  Here is an
5719 example:
5721 @example
5722 @group
5723 #include <sys/types.h>
5724 #ifdef HAVE_SYS_WAIT_H
5725 # include <sys/wait.h>
5726 #endif
5727 #ifndef WEXITSTATUS
5728 # define WEXITSTATUS(stat_val) ((unsigned int) (stat_val) >> 8)
5729 #endif
5730 #ifndef WIFEXITED
5731 # define WIFEXITED(stat_val) (((stat_val) & 255) == 0)
5732 #endif
5733 @end group
5734 @end example
5736 @noindent
5737 This macro is obsolescent, as current systems are compatible with Posix.
5738 New programs need not use this macro.
5739 @end defmac
5741 @cvindex _POSIX_VERSION
5742 @hdrindex{unistd.h}
5743 @code{_POSIX_VERSION} is defined when @file{unistd.h} is included on
5744 Posix systems.  If there is no @file{unistd.h}, it is definitely
5745 not a Posix system.  However, some non-Posix systems do
5746 have @file{unistd.h}.
5748 The way to check whether the system supports Posix is:
5750 @example
5751 @group
5752 #ifdef HAVE_UNISTD_H
5753 # include <sys/types.h>
5754 # include <unistd.h>
5755 #endif
5757 #ifdef _POSIX_VERSION
5758 /* Code for Posix systems.  */
5759 #endif
5760 @end group
5761 @end example
5763 @anchor{AC_HEADER_TIME}
5764 @defmac AC_HEADER_TIME
5765 @acindex{HEADER_TIME}
5766 @cvindex TIME_WITH_SYS_TIME
5767 @hdrindex{time.h}
5768 @hdrindex{sys/time.h}
5769 If a program may include both @file{time.h} and @file{sys/time.h},
5770 define @code{TIME_WITH_SYS_TIME}.  On some ancient systems,
5771 @file{sys/time.h} included @file{time.h}, but @file{time.h} was not
5772 protected against multiple inclusion, so programs could not explicitly
5773 include both files.  This macro is useful in programs that use, for
5774 example, @code{struct timeval} as well as
5775 @code{struct tm}.  It is best used in conjunction with
5776 @code{HAVE_SYS_TIME_H}, which can be checked for using
5777 @code{AC_CHECK_HEADERS([sys/time.h])}.
5779 @example
5780 @group
5781 #ifdef TIME_WITH_SYS_TIME
5782 # include <sys/time.h>
5783 # include <time.h>
5784 #else
5785 # ifdef HAVE_SYS_TIME_H
5786 #  include <sys/time.h>
5787 # else
5788 #  include <time.h>
5789 # endif
5790 #endif
5791 @end group
5792 @end example
5794 @noindent
5795 This macro is obsolescent, as current systems can include both files
5796 when they exist.  New programs need not use this macro.
5797 @end defmac
5800 @defmac AC_HEADER_TIOCGWINSZ
5801 @acindex{HEADER_TIOCGWINSZ}
5802 @cvindex GWINSZ_IN_SYS_IOCTL
5803 @hdrindex{sys/ioctl.h}
5804 @hdrindex{termios.h}
5805 @c FIXME: I need clarifications from Jim.
5806 If the use of @code{TIOCGWINSZ} requires @file{<sys/ioctl.h>}, then
5807 define @code{GWINSZ_IN_SYS_IOCTL}.  Otherwise @code{TIOCGWINSZ} can be
5808 found in @file{<termios.h>}.
5810 Use:
5812 @example
5813 @group
5814 #ifdef HAVE_TERMIOS_H
5815 # include <termios.h>
5816 #endif
5818 #ifdef GWINSZ_IN_SYS_IOCTL
5819 # include <sys/ioctl.h>
5820 #endif
5821 @end group
5822 @end example
5823 @end defmac
5825 @node Generic Headers
5826 @subsection Generic Header Checks
5828 These macros are used to find system header files not covered by the
5829 ``particular'' test macros.  If you need to check the contents of a header
5830 as well as find out whether it is present, you have to write your own
5831 test for it (@pxref{Writing Tests}).
5833 @anchor{AC_CHECK_HEADER}
5834 @defmac AC_CHECK_HEADER (@var{header-file}, @ovar{action-if-found}, @
5835   @ovar{action-if-not-found}, @ovar{includes})
5836 @acindex{CHECK_HEADER}
5837 If the system header file @var{header-file} is compilable, execute shell
5838 commands @var{action-if-found}, otherwise execute
5839 @var{action-if-not-found}.  If you just want to define a symbol if the
5840 header file is available, consider using @code{AC_CHECK_HEADERS}
5841 instead.
5843 @var{includes} is decoded to determine the appropriate include
5844 directives.  If omitted or empty, @file{configure} will check for both header
5845 existence (with the preprocessor) and usability (with the compiler),
5846 using @code{AC_INCLUDES_DEFAULT} for the compile test.  If
5847 there is a discrepancy between the results, a warning is issued to the
5848 user, and the compiler results are favored (@pxref{Present But
5849 Cannot Be Compiled}).  In general, favoring the compiler results means
5850 that a header will be treated as not found even though the file exists,
5851 because you did not provide enough prerequisites.
5853 Providing a non-empty @var{includes} argument allows the code to provide
5854 any prerequisites prior to including the header under test; it is common
5855 to use the argument @code{AC_INCLUDES_DEFAULT} (@pxref{Default
5856 Includes}).  With an explicit fourth argument, no preprocessor test is
5857 needed.  As a special case, an @var{includes} of exactly @samp{-}
5858 triggers the older preprocessor check, which merely determines existence
5859 of the file in the preprocessor search path; this should only be used as
5860 a last resort (it is safer to determine the actual prerequisites and
5861 perform a compiler check, or else use @code{AC_PREPROC_IFELSE} to make
5862 it obvious that only a preprocessor check is desired).
5863 @end defmac
5865 @anchor{AC_CHECK_HEADERS}
5866 @defmac AC_CHECK_HEADERS (@var{header-file}@dots{}, @
5867   @ovar{action-if-found}, @ovar{action-if-not-found}, @
5868   @ovar{includes})
5869 @acindex{CHECK_HEADERS}
5870 @cvindex HAVE_@var{header}
5871 For each given system header file @var{header-file} in the
5872 blank-separated argument list that exists, define
5873 @code{HAVE_@var{header-file}} (in all capitals).  If @var{action-if-found}
5874 is given, it is additional shell code to execute when one of the header
5875 files is found.  You can give it a value of @samp{break} to break out of
5876 the loop on the first match.  If @var{action-if-not-found} is given, it
5877 is executed when one of the header files is not found.
5879 @var{includes} is interpreted as in @code{AC_CHECK_HEADER}, in order to
5880 choose the set of preprocessor directives supplied before the header
5881 under test.
5882 @end defmac
5884 Previous versions of Autoconf merely checked whether the header was
5885 accepted by the preprocessor.  This was changed because the old test was
5886 inappropriate for typical uses.  Headers are typically used to compile,
5887 not merely to preprocess, and the old behavior sometimes accepted
5888 headers that clashed at compile-time (@pxref{Present But Cannot Be
5889 Compiled}).  If you need to check whether a header is preprocessable,
5890 you can use @code{AC_PREPROC_IFELSE} (@pxref{Running the Preprocessor}).
5892 Actually requiring a header to compile improves the robustness of the
5893 test, but it also requires
5894 that you make sure that headers that must be included before the
5895 @var{header-file} be part of the @var{includes}, (@pxref{Default
5896 Includes}).  If looking for @file{bar.h}, which requires that
5897 @file{foo.h} be included before if it exists, we suggest the following
5898 scheme:
5900 @verbatim
5901 AC_CHECK_HEADERS([foo.h])
5902 AC_CHECK_HEADERS([bar.h], [], [],
5903 [#ifdef HAVE_FOO_H
5904 # include <foo.h>
5905 #endif
5907 @end verbatim
5909 The following variant generates smaller, faster @command{configure}
5910 files if you do not need the full power of @code{AC_CHECK_HEADERS}.
5912 @defmac AC_CHECK_HEADERS_ONCE (@var{header-file}@dots{})
5913 @acindex{CHECK_HEADERS_ONCE}
5914 @cvindex HAVE_@var{header}
5915 For each given system header file @var{header-file} in the
5916 blank-separated argument list that exists, define
5917 @code{HAVE_@var{header-file}} (in all capitals).
5918 This is a once-only variant of @code{AC_CHECK_HEADERS}.  It generates the
5919 checking code at most once, so that @command{configure} is smaller and
5920 faster; but the checks cannot be conditionalized and are always done once,
5921 early during the @command{configure} run.  Thus, this macro is only safe
5922 for checking headers that do not have prerequisites beyond what
5923 @code{AC_INCLUDES_DEFAULT} provides.
5924 @end defmac
5926 @node Declarations
5927 @section Declarations
5928 @cindex Declaration, checking
5930 The following macros check for the declaration of variables and
5931 functions.  If there is no macro specifically defined to check for a
5932 symbol you need, then you can use the general macros (@pxref{Generic
5933 Declarations}) or, for more complex tests, you may use
5934 @code{AC_COMPILE_IFELSE} (@pxref{Running the Compiler}).
5936 @menu
5937 * Particular Declarations::     Macros to check for certain declarations
5938 * Generic Declarations::        How to find other declarations
5939 @end menu
5941 @node Particular Declarations
5942 @subsection Particular Declaration Checks
5944 There are no specific macros for declarations.
5946 @node Generic Declarations
5947 @subsection Generic Declaration Checks
5949 These macros are used to find declarations not covered by the ``particular''
5950 test macros.
5952 @defmac AC_CHECK_DECL (@var{symbol}, @ovar{action-if-found}, @
5953   @ovar{action-if-not-found}, @dvar{includes, AC_INCLUDES_DEFAULT})
5954 @acindex{CHECK_DECL}
5955 If @var{symbol} (a function, variable, or constant) is not declared in
5956 @var{includes} and a declaration is needed, run the shell commands
5957 @var{action-if-not-found}, otherwise @var{action-if-found}.
5958 @var{includes} is a series of include directives, defaulting to
5959 @code{AC_INCLUDES_DEFAULT} (@pxref{Default Includes}), which are used
5960 prior to the declaration under test.
5962 This macro actually tests whether @var{symbol} is defined as a macro or
5963 can be used as an r-value, not whether it is really declared, because it
5964 is much safer to avoid
5965 introducing extra declarations when they are not needed.
5966 @end defmac
5968 @anchor{AC_CHECK_DECLS}
5969 @defmac AC_CHECK_DECLS (@var{symbols}, @ovar{action-if-found}, @
5970   @ovar{action-if-not-found}, @dvar{includes, AC_INCLUDES_DEFAULT})
5971 @acindex{CHECK_DECLS}
5972 @cvindex HAVE_DECL_@var{symbol}
5973 For each of the @var{symbols} (@emph{comma}-separated list), define
5974 @code{HAVE_DECL_@var{symbol}} (in all capitals) to @samp{1} if
5975 @var{symbol} is declared, otherwise to @samp{0}.  If
5976 @var{action-if-not-found} is given, it is additional shell code to
5977 execute when one of the function declarations is needed, otherwise
5978 @var{action-if-found} is executed.
5980 @var{includes} is a series of include directives, defaulting to
5981 @code{AC_INCLUDES_DEFAULT} (@pxref{Default Includes}), which are used
5982 prior to the declarations under test.
5984 This macro uses an M4 list as first argument:
5985 @example
5986 AC_CHECK_DECLS([strdup])
5987 AC_CHECK_DECLS([strlen])
5988 AC_CHECK_DECLS([malloc, realloc, calloc, free])
5989 AC_CHECK_DECLS([j0], [], [], [[#include <math.h>]])
5990 @end example
5992 Unlike the other @samp{AC_CHECK_*S} macros, when a @var{symbol} is not
5993 declared, @code{HAVE_DECL_@var{symbol}} is defined to @samp{0} instead
5994 of leaving @code{HAVE_DECL_@var{symbol}} undeclared.  When you are
5995 @emph{sure} that the check was performed, use
5996 @code{HAVE_DECL_@var{symbol}} in @code{#if}:
5998 @example
5999 #if !HAVE_DECL_SYMBOL
6000 extern char *symbol;
6001 #endif
6002 @end example
6004 @noindent
6005 If the test may have not been performed, however, because it is safer
6006 @emph{not} to declare a symbol than to use a declaration that conflicts
6007 with the system's one, you should use:
6009 @example
6010 #if defined HAVE_DECL_MALLOC && !HAVE_DECL_MALLOC
6011 void *malloc (size_t *s);
6012 #endif
6013 @end example
6015 @noindent
6016 You fall into the second category only in extreme situations: either
6017 your files may be used without being configured, or they are used during
6018 the configuration.  In most cases the traditional approach is enough.
6019 @end defmac
6021 @defmac AC_CHECK_DECLS_ONCE (@var{symbols})
6022 @acindex{CHECK_DECLS_ONCE}
6023 @cvindex HAVE_DECL_@var{symbol}
6024 For each of the @var{symbols} (@emph{comma}-separated list), define
6025 @code{HAVE_DECL_@var{symbol}} (in all capitals) to @samp{1} if
6026 @var{symbol} is declared in the default include files, otherwise to
6027 @samp{0}.  This is a once-only variant of @code{AC_CHECK_DECLS}.  It
6028 generates the checking code at most once, so that @command{configure} is
6029 smaller and faster; but the checks cannot be conditionalized and are
6030 always done once, early during the @command{configure} run.
6031 @end defmac
6034 @node Structures
6035 @section Structures
6036 @cindex Structure, checking
6038 The following macros check for the presence of certain members in C
6039 structures.  If there is no macro specifically defined to check for a
6040 member you need, then you can use the general structure-member macros
6041 (@pxref{Generic Structures}) or, for more complex tests, you may use
6042 @code{AC_COMPILE_IFELSE} (@pxref{Running the Compiler}).
6044 @menu
6045 * Particular Structures::       Macros to check for certain structure members
6046 * Generic Structures::          How to find other structure members
6047 @end menu
6049 @node Particular Structures
6050 @subsection Particular Structure Checks
6052 The following macros check for certain structures or structure members.
6054 @defmac AC_STRUCT_DIRENT_D_INO
6055 @acindex{STRUCT_DIRENT_D_INO}
6056 @cvindex HAVE_STRUCT_DIRENT_D_INO
6057 Perform all the actions of @code{AC_HEADER_DIRENT} (@pxref{Particular
6058 Headers}).  Then, if @code{struct dirent} contains a @code{d_ino}
6059 member, define @code{HAVE_STRUCT_DIRENT_D_INO}.
6061 @code{HAVE_STRUCT_DIRENT_D_INO} indicates only the presence of
6062 @code{d_ino}, not whether its contents are always reliable.
6063 Traditionally, a zero @code{d_ino} indicated a deleted directory entry,
6064 though current systems hide this detail from the user and never return
6065 zero @code{d_ino} values.
6066 Many current systems report an incorrect @code{d_ino} for a directory
6067 entry that is a mount point.
6068 @end defmac
6070 @defmac AC_STRUCT_DIRENT_D_TYPE
6071 @acindex{STRUCT_DIRENT_D_TYPE}
6072 @cvindex HAVE_STRUCT_DIRENT_D_TYPE
6073 Perform all the actions of @code{AC_HEADER_DIRENT} (@pxref{Particular
6074 Headers}).  Then, if @code{struct dirent} contains a @code{d_type}
6075 member, define @code{HAVE_STRUCT_DIRENT_D_TYPE}.
6076 @end defmac
6078 @anchor{AC_STRUCT_ST_BLOCKS}
6079 @defmac AC_STRUCT_ST_BLOCKS
6080 @acindex{STRUCT_ST_BLOCKS}
6081 @cvindex HAVE_STRUCT_STAT_ST_BLOCKS
6082 @cvindex HAVE_ST_BLOCKS
6083 @ovindex LIBOBJS
6084 If @code{struct stat} contains an @code{st_blocks} member, define
6085 @code{HAVE_STRUCT_STAT_ST_BLOCKS}.  Otherwise, require an
6086 @code{AC_LIBOBJ} replacement of @samp{fileblocks}.  The former name,
6087 @code{HAVE_ST_BLOCKS} is to be avoided, as its support will cease in the
6088 future.
6089 @end defmac
6091 @defmac AC_STRUCT_TM
6092 @acindex{STRUCT_TM}
6093 @cvindex TM_IN_SYS_TIME
6094 @hdrindex{time.h}
6095 @hdrindex{sys/time.h}
6096 If @file{time.h} does not define @code{struct tm}, define
6097 @code{TM_IN_SYS_TIME}, which means that including @file{sys/time.h}
6098 had better define @code{struct tm}.
6100 This macro is obsolescent, as @file{time.h} defines @code{struct tm} in
6101 current systems.  New programs need not use this macro.
6102 @end defmac
6104 @anchor{AC_STRUCT_TIMEZONE}
6105 @defmac AC_STRUCT_TIMEZONE
6106 @acindex{STRUCT_TIMEZONE}
6107 @cvindex HAVE_DECL_TZNAME
6108 @cvindex HAVE_STRUCT_TM_TM_ZONE
6109 @cvindex HAVE_TM_ZONE
6110 @cvindex HAVE_TZNAME
6111 Figure out how to get the current timezone.  If @code{struct tm} has a
6112 @code{tm_zone} member, define @code{HAVE_STRUCT_TM_TM_ZONE} (and the
6113 obsoleted @code{HAVE_TM_ZONE}).  Otherwise, if the external array
6114 @code{tzname} is found, define @code{HAVE_TZNAME}; if it is declared,
6115 define @code{HAVE_DECL_TZNAME}.
6116 @end defmac
6118 @node Generic Structures
6119 @subsection Generic Structure Checks
6121 These macros are used to find structure members not covered by the
6122 ``particular'' test macros.
6124 @defmac AC_CHECK_MEMBER (@var{aggregate}.@var{member}, @
6125   @ovar{action-if-found}, @ovar{action-if-not-found}, @
6126   @dvar{includes, AC_INCLUDES_DEFAULT})
6127 @acindex{CHECK_MEMBER}
6128 Check whether @var{member} is a member of the aggregate @var{aggregate}.
6129 If no @var{includes} are specified, the default includes are used
6130 (@pxref{Default Includes}).
6132 @example
6133 AC_CHECK_MEMBER([struct passwd.pw_gecos], [],
6134                 [AC_MSG_ERROR([We need `passwd.pw_gecos'!])],
6135                 [[#include <pwd.h>]])
6136 @end example
6138 You can use this macro for submembers:
6140 @example
6141 AC_CHECK_MEMBER(struct top.middle.bot)
6142 @end example
6143 @end defmac
6145 @anchor{AC_CHECK_MEMBERS}
6146 @defmac AC_CHECK_MEMBERS (@var{members}, @ovar{action-if-found}, @
6147   @ovar{action-if-not-found}, @dvar{includes, AC_INCLUDES_DEFAULT})
6148 @acindex{CHECK_MEMBERS}
6149 @cvindex HAVE_@var{aggregate}_@var{member}
6150 Check for the existence of each @samp{@var{aggregate}.@var{member}} of
6151 @var{members} using the previous macro.  When @var{member} belongs to
6152 @var{aggregate}, define @code{HAVE_@var{aggregate}_@var{member}} (in all
6153 capitals, with spaces and dots replaced by underscores).  If
6154 @var{action-if-found} is given, it is executed for each of the found
6155 members.  If @var{action-if-not-found} is given, it is executed for each
6156 of the members that could not be found.
6158 @var{includes} is a series of include directives, defaulting to
6159 @code{AC_INCLUDES_DEFAULT} (@pxref{Default Includes}), which are used
6160 prior to the members under test.
6162 This macro uses M4 lists:
6163 @example
6164 AC_CHECK_MEMBERS([struct stat.st_rdev, struct stat.st_blksize])
6165 @end example
6166 @end defmac
6169 @node Types
6170 @section Types
6171 @cindex Types
6172 @cindex C types
6174 The following macros check for C types, either builtin or typedefs.  If
6175 there is no macro specifically defined to check for a type you need, and
6176 you don't need to check for any special properties of it, then you can
6177 use a general type-check macro.
6179 @menu
6180 * Particular Types::            Special handling to find certain types
6181 * Generic Types::               How to find other types
6182 @end menu
6184 @node Particular Types
6185 @subsection Particular Type Checks
6187 @hdrindex{sys/types.h}
6188 @hdrindex{stdlib.h}
6189 @hdrindex{stdint.h}
6190 @hdrindex{inttypes.h}
6191 These macros check for particular C types in @file{sys/types.h},
6192 @file{stdlib.h}, @file{stdint.h}, @file{inttypes.h} and others, if they
6193 exist.
6195 The Gnulib @code{stdint} module is an alternate way to define many of
6196 these symbols; it is useful if you prefer your code to assume a
6197 C99-or-better environment.  @xref{Gnulib}.
6199 @anchor{AC_TYPE_GETGROUPS}
6200 @defmac AC_TYPE_GETGROUPS
6201 @acindex{TYPE_GETGROUPS}
6202 @cvindex GETGROUPS_T
6203 Define @code{GETGROUPS_T} to be whichever of @code{gid_t} or @code{int}
6204 is the base type of the array argument to @code{getgroups}.
6205 @end defmac
6207 @defmac AC_TYPE_INT8_T
6208 @acindex{TYPE_INT8_T}
6209 @cvindex HAVE_INT8_T
6210 @cvindex int8_t
6211 If @file{stdint.h} or @file{inttypes.h} does not define the type
6212 @code{int8_t}, define @code{int8_t} to a signed
6213 integer type that is exactly 8 bits wide and that uses two's complement
6214 representation, if such a type exists.
6215 If you are worried about porting to hosts that lack such a type, you can
6216 use the results of this macro in C89-or-later code as follows:
6218 @example
6219 #if HAVE_STDINT_H
6220 # include <stdint.h>
6221 #endif
6222 #if defined INT8_MAX || defined int8_t
6223  @emph{code using int8_t}
6224 #else
6225  @emph{complicated alternative using >8-bit 'signed char'}
6226 #endif
6227 @end example
6228 @end defmac
6230 @defmac AC_TYPE_INT16_T
6231 @acindex{TYPE_INT16_T}
6232 @cvindex HAVE_INT16_T
6233 @cvindex int16_t
6234 This is like @code{AC_TYPE_INT8_T}, except for 16-bit integers.
6235 @end defmac
6237 @defmac AC_TYPE_INT32_T
6238 @acindex{TYPE_INT32_T}
6239 @cvindex HAVE_INT32_T
6240 @cvindex int32_t
6241 This is like @code{AC_TYPE_INT8_T}, except for 32-bit integers.
6242 @end defmac
6244 @defmac AC_TYPE_INT64_T
6245 @acindex{TYPE_INT64_T}
6246 @cvindex HAVE_INT64_T
6247 @cvindex int64_t
6248 This is like @code{AC_TYPE_INT8_T}, except for 64-bit integers.
6249 @end defmac
6251 @defmac AC_TYPE_INTMAX_T
6252 @acindex{TYPE_INTMAX_T}
6253 @cvindex HAVE_INTMAX_T
6254 @cvindex intmax_t
6255 If @file{stdint.h} or @file{inttypes.h} defines the type @code{intmax_t},
6256 define @code{HAVE_INTMAX_T}.  Otherwise, define @code{intmax_t} to the
6257 widest signed integer type.
6258 @end defmac
6260 @defmac AC_TYPE_INTPTR_T
6261 @acindex{TYPE_INTPTR_T}
6262 @cvindex HAVE_INTPTR_T
6263 @cvindex intptr_t
6264 If @file{stdint.h} or @file{inttypes.h} defines the type @code{intptr_t},
6265 define @code{HAVE_INTPTR_T}.  Otherwise, define @code{intptr_t} to a
6266 signed integer type wide enough to hold a pointer, if such a type
6267 exists.
6268 @end defmac
6270 @defmac AC_TYPE_LONG_DOUBLE
6271 @acindex{TYPE_LONG_DOUBLE}
6272 @cvindex HAVE_LONG_DOUBLE
6273 If the C compiler supports a working @code{long double} type, define
6274 @code{HAVE_LONG_DOUBLE}.  The @code{long double} type might have the
6275 same range and precision as @code{double}.
6277 This macro is obsolescent, as current C compilers support @code{long
6278 double}.  New programs need not use this macro.
6279 @end defmac
6281 @defmac AC_TYPE_LONG_DOUBLE_WIDER
6282 @acindex{TYPE_LONG_DOUBLE_WIDER}
6283 @cvindex HAVE_LONG_DOUBLE_WIDER
6284 If the C compiler supports a working @code{long double} type with more
6285 range or precision than the @code{double} type, define
6286 @code{HAVE_LONG_DOUBLE_WIDER}.
6287 @end defmac
6289 @defmac AC_TYPE_LONG_LONG_INT
6290 @acindex{TYPE_LONG_LONG_INT}
6291 @cvindex HAVE_LONG_LONG_INT
6292 If the C compiler supports a working @code{long long int} type, define
6293 @code{HAVE_LONG_LONG_INT}.  However, this test does not test
6294 @code{long long int} values in preprocessor @code{#if} expressions,
6295 because too many compilers mishandle such expressions.
6296 @xref{Preprocessor Arithmetic}.
6297 @end defmac
6299 @defmac AC_TYPE_MBSTATE_T
6300 @acindex{TYPE_MBSTATE_T}
6301 @cvindex mbstate_t
6302 @hdrindex{wchar.h}
6303 Define @code{HAVE_MBSTATE_T} if @code{<wchar.h>} declares the
6304 @code{mbstate_t} type.  Also, define @code{mbstate_t} to be a type if
6305 @code{<wchar.h>} does not declare it.
6306 @end defmac
6308 @anchor{AC_TYPE_MODE_T}
6309 @defmac AC_TYPE_MODE_T
6310 @acindex{TYPE_MODE_T}
6311 @cvindex mode_t
6312 Define @code{mode_t} to a suitable type, if standard headers do not
6313 define it.
6314 @end defmac
6316 @anchor{AC_TYPE_OFF_T}
6317 @defmac AC_TYPE_OFF_T
6318 @acindex{TYPE_OFF_T}
6319 @cvindex off_t
6320 Define @code{off_t} to a suitable type, if standard headers do not
6321 define it.
6322 @end defmac
6324 @anchor{AC_TYPE_PID_T}
6325 @defmac AC_TYPE_PID_T
6326 @acindex{TYPE_PID_T}
6327 @cvindex pid_t
6328 Define @code{pid_t} to a suitable type, if standard headers do not
6329 define it.
6330 @end defmac
6332 @anchor{AC_TYPE_SIZE_T}
6333 @defmac AC_TYPE_SIZE_T
6334 @acindex{TYPE_SIZE_T}
6335 @cvindex size_t
6336 Define @code{size_t} to a suitable type, if standard headers do not
6337 define it.
6338 @end defmac
6340 @defmac AC_TYPE_SSIZE_T
6341 @acindex{TYPE_SSIZE_T}
6342 @cvindex ssize_t
6343 Define @code{ssize_t} to a suitable type, if standard headers do not
6344 define it.
6345 @end defmac
6347 @anchor{AC_TYPE_UID_T}
6348 @defmac AC_TYPE_UID_T
6349 @acindex{TYPE_UID_T}
6350 @cvindex uid_t
6351 @cvindex gid_t
6352 Define @code{uid_t} and @code{gid_t} to suitable types, if standard
6353 headers do not define them.
6354 @end defmac
6356 @defmac AC_TYPE_UINT8_T
6357 @acindex{TYPE_UINT8_T}
6358 @cvindex HAVE_UINT8_T
6359 @cvindex uint8_t
6360 If @file{stdint.h} or @file{inttypes.h} does not define the type
6361 @code{uint8_t}, define @code{uint8_t} to an
6362 unsigned integer type that is exactly 8 bits wide, if such a type
6363 exists.
6364 This is like @code{AC_TYPE_INT8_T}, except for unsigned integers.
6365 @end defmac
6367 @defmac AC_TYPE_UINT16_T
6368 @acindex{TYPE_UINT16_T}
6369 @cvindex HAVE_UINT16_T
6370 @cvindex uint16_t
6371 This is like @code{AC_TYPE_UINT8_T}, except for 16-bit integers.
6372 @end defmac
6374 @defmac AC_TYPE_UINT32_T
6375 @acindex{TYPE_UINT32_T}
6376 @cvindex HAVE_UINT32_T
6377 @cvindex uint32_t
6378 This is like @code{AC_TYPE_UINT8_T}, except for 32-bit integers.
6379 @end defmac
6381 @defmac AC_TYPE_UINT64_T
6382 @acindex{TYPE_UINT64_T}
6383 @cvindex HAVE_UINT64_T
6384 @cvindex uint64_t
6385 This is like @code{AC_TYPE_UINT8_T}, except for 64-bit integers.
6386 @end defmac
6388 @defmac AC_TYPE_UINTMAX_T
6389 @acindex{TYPE_UINTMAX_T}
6390 @cvindex HAVE_UINTMAX_T
6391 @cvindex uintmax_t
6392 If @file{stdint.h} or @file{inttypes.h} defines the type @code{uintmax_t},
6393 define @code{HAVE_UINTMAX_T}.  Otherwise, define @code{uintmax_t} to the
6394 widest unsigned integer type.
6395 @end defmac
6397 @defmac AC_TYPE_UINTPTR_T
6398 @acindex{TYPE_UINTPTR_T}
6399 @cvindex HAVE_UINTPTR_T
6400 @cvindex uintptr_t
6401 If @file{stdint.h} or @file{inttypes.h} defines the type @code{uintptr_t},
6402 define @code{HAVE_UINTPTR_T}.  Otherwise, define @code{uintptr_t} to an
6403 unsigned integer type wide enough to hold a pointer, if such a type
6404 exists.
6405 @end defmac
6407 @defmac AC_TYPE_UNSIGNED_LONG_LONG_INT
6408 @acindex{TYPE_UNSIGNED_LONG_LONG_INT}
6409 @cvindex HAVE_UNSIGNED_LONG_LONG_INT
6410 If the C compiler supports a working @code{unsigned long long int} type,
6411 define @code{HAVE_UNSIGNED_LONG_LONG_INT}.  However, this test does not test
6412 @code{unsigned long long int} values in preprocessor @code{#if} expressions,
6413 because too many compilers mishandle such expressions.
6414 @xref{Preprocessor Arithmetic}.
6415 @end defmac
6417 @node Generic Types
6418 @subsection Generic Type Checks
6420 These macros are used to check for types not covered by the ``particular''
6421 test macros.
6423 @defmac AC_CHECK_TYPE (@var{type}, @ovar{action-if-found}, @
6424   @ovar{action-if-not-found}, @dvar{includes, AC_INCLUDES_DEFAULT})
6425 @acindex{CHECK_TYPE}
6426 Check whether @var{type} is defined.  It may be a compiler builtin type
6427 or defined by the @var{includes}.  @var{includes} is a series of include
6428 directives, defaulting to @code{AC_INCLUDES_DEFAULT} (@pxref{Default
6429 Includes}), which are used prior to the type under test.
6431 In C, @var{type} must be a type-name, so that the expression @samp{sizeof
6432 (@var{type})} is valid (but @samp{sizeof ((@var{type}))} is not).  The
6433 same test is applied when compiling for C++, which means that in C++
6434 @var{type} should be a type-id and should not be an anonymous
6435 @samp{struct} or @samp{union}.
6436 @end defmac
6439 @defmac AC_CHECK_TYPES (@var{types}, @ovar{action-if-found}, @
6440   @ovar{action-if-not-found}, @dvar{includes, AC_INCLUDES_DEFAULT})
6441 @acindex{CHECK_TYPES}
6442 @cvindex HAVE_@var{type}
6443 For each @var{type} of the @var{types} that is defined, define
6444 @code{HAVE_@var{type}} (in all capitals).  Each @var{type} must follow
6445 the rules of @code{AC_CHECK_TYPE}.  If no @var{includes} are
6446 specified, the default includes are used (@pxref{Default Includes}).  If
6447 @var{action-if-found} is given, it is additional shell code to execute
6448 when one of the types is found.  If @var{action-if-not-found} is given,
6449 it is executed when one of the types is not found.
6451 This macro uses M4 lists:
6452 @example
6453 AC_CHECK_TYPES([ptrdiff_t])
6454 AC_CHECK_TYPES([unsigned long long int, uintmax_t])
6455 AC_CHECK_TYPES([float_t], [], [], [[#include <math.h>]])
6456 @end example
6458 @end defmac
6460 Autoconf, up to 2.13, used to provide to another version of
6461 @code{AC_CHECK_TYPE}, broken by design.  In order to keep backward
6462 compatibility, a simple heuristic, quite safe but not totally, is
6463 implemented.  In case of doubt, read the documentation of the former
6464 @code{AC_CHECK_TYPE}, see @ref{Obsolete Macros}.
6467 @node Compilers and Preprocessors
6468 @section Compilers and Preprocessors
6469 @cindex Compilers
6470 @cindex Preprocessors
6472 @ovindex EXEEXT
6473 All the tests for compilers (@code{AC_PROG_CC}, @code{AC_PROG_CXX},
6474 @code{AC_PROG_F77}) define the output variable @code{EXEEXT} based on
6475 the output of the compiler, typically to the empty string if
6476 Posix and @samp{.exe} if a @acronym{DOS} variant.
6478 @ovindex OBJEXT
6479 They also define the output variable @code{OBJEXT} based on the
6480 output of the compiler, after @file{.c} files have been excluded, typically
6481 to @samp{o} if Posix, @samp{obj} if a @acronym{DOS} variant.
6483 If the compiler being used does not produce executables, the tests fail.  If
6484 the executables can't be run, and cross-compilation is not enabled, they
6485 fail too.  @xref{Manual Configuration}, for more on support for cross
6486 compiling.
6488 @menu
6489 * Specific Compiler Characteristics::  Some portability issues
6490 * Generic Compiler Characteristics::  Language independent tests and features
6491 * C Compiler::                  Checking its characteristics
6492 * C++ Compiler::                Likewise
6493 * Objective C Compiler::        Likewise
6494 * Erlang Compiler and Interpreter::  Likewise
6495 * Fortran Compiler::            Likewise
6496 @end menu
6498 @node Specific Compiler Characteristics
6499 @subsection Specific Compiler Characteristics
6501 Some compilers exhibit different behaviors.
6503 @table @asis
6504 @item Static/Dynamic Expressions
6505 Autoconf relies on a trick to extract one bit of information from the C
6506 compiler: using negative array sizes.  For instance the following
6507 excerpt of a C source demonstrates how to test whether @samp{int} objects are 4
6508 bytes wide:
6510 @example
6511 static int test_array[sizeof (int) == 4 ? 1 : -1];
6512 @end example
6514 @noindent
6515 To our knowledge, there is a single compiler that does not support this
6516 trick: the @acronym{HP} C compilers (the real ones, not only the
6517 ``bundled'') on @acronym{HP-UX} 11.00.
6518 They incorrectly reject the above program with the diagnostic
6519 ``Variable-length arrays cannot have static storage.''
6520 This bug comes from @acronym{HP} compilers' mishandling of @code{sizeof (int)},
6521 not from the @code{? 1 : -1}, and
6522 Autoconf works around this problem by casting @code{sizeof (int)} to
6523 @code{long int} before comparing it.
6524 @end table
6526 @node Generic Compiler Characteristics
6527 @subsection Generic Compiler Characteristics
6529 @anchor{AC_CHECK_SIZEOF}
6530 @defmac AC_CHECK_SIZEOF (@var{type-or-expr}, @ovar{unused}, @
6531   @dvar{includes, AC_INCLUDES_DEFAULT})
6532 @acindex{CHECK_SIZEOF}
6533 @cvindex SIZEOF_@var{type-or-expr}
6534 Define @code{SIZEOF_@var{type-or-expr}} (@pxref{Standard Symbols}) to be
6535 the size in bytes of @var{type-or-expr}, which may be either a type or
6536 an expression returning a value that has a size.  If the expression
6537 @samp{sizeof (@var{type-or-expr})} is invalid, the result is 0.
6538 @var{includes} is a series of include directives, defaulting to
6539 @code{AC_INCLUDES_DEFAULT} (@pxref{Default Includes}), which are used
6540 prior to the expression under test.
6542 This macro now works even when cross-compiling.  The @var{unused}
6543 argument was used when cross-compiling.
6545 For example, the call
6547 @example
6548 AC_CHECK_SIZEOF([int *])
6549 @end example
6551 @noindent
6552 defines @code{SIZEOF_INT_P} to be 8 on DEC Alpha AXP systems.
6553 @end defmac
6555 @defmac AC_CHECK_ALIGNOF (@var{type}, @dvar{includes, AC_INCLUDES_DEFAULT})
6556 @acindex{CHECK_ALIGNOF}
6557 @cvindex ALIGNOF_@var{type}
6558 Define @code{ALIGNOF_@var{type}} (@pxref{Standard Symbols}) to be the
6559 alignment in bytes of @var{type}.  @samp{@var{type} y;} must be valid as
6560 a structure member declaration.  If @samp{type} is unknown, the result
6561 is 0.  If no @var{includes} are specified, the default includes are used
6562 (@pxref{Default Includes}).
6563 @end defmac
6565 @defmac AC_COMPUTE_INT (@var{var}, @var{expression}, @
6566   @dvar{includes, AC_INCLUDES_DEFAULT}, @ovar{action-if-fails})
6567 @acindex{COMPUTE_INT}
6568 Store into the shell variable @var{var} the value of the integer
6569 @var{expression}.  The
6570 value should fit in an initializer in a C variable of type @code{signed
6571 long}.  To support cross compilation (in which case, the macro only works on
6572 hosts that use twos-complement arithmetic), it should be possible to evaluate
6573 the expression at compile-time.  If no @var{includes} are specified, the
6574 default includes are used (@pxref{Default Includes}).
6576 Execute @var{action-if-fails} if the value cannot be determined correctly.
6577 @end defmac
6579 @defmac AC_LANG_WERROR
6580 @acindex{LANG_WERROR}
6581 Normally Autoconf ignores warnings generated by the compiler, linker, and
6582 preprocessor.  If this macro is used, warnings count as fatal
6583 errors for the current language.  This macro is useful when the
6584 results of configuration are used where warnings are unacceptable; for
6585 instance, if parts of a program are built with the @acronym{GCC}
6586 @option{-Werror}
6587 option.  If the whole program is built using @option{-Werror} it is
6588 often simpler to put @option{-Werror} in the compiler flags (@code{CFLAGS},
6589 etc.).
6590 @end defmac
6592 @defmac AC_OPENMP
6593 @acindex{OPENMP}
6594 @cvindex _OPENMP
6595 @ovindex OPENMP_CFLAGS
6596 @ovindex OPENMP_CXXFLAGS
6597 @ovindex OPENMP_FFLAGS
6598 @ovindex OPENMP_FCFLAGS
6599 OpenMP (@url{http://@/www.openmp.org/}) specifies extensions of C, C++,
6600 and Fortran that simplify optimization of shared memory parallelism,
6601 which is a common problem on multicore CPUs.
6603 If the current language is C, the macro @code{AC_OPENMP} sets the
6604 variable @code{OPENMP_CFLAGS} to the C compiler flags needed for
6605 supporting OpenMP@.  @code{OPENMP_CFLAGS} is set to empty if the
6606 compiler already supports OpenMP, if it has no way to activate OpenMP
6607 support, or if the user rejects OpenMP support by invoking
6608 @samp{configure} with the @samp{--disable-openmp} option.
6610 @code{OPENMP_CFLAGS} needs to be used when compiling programs, when
6611 preprocessing program source, and when linking programs.  Therefore you
6612 need to add @code{$(OPENMP_CFLAGS)} to the @code{CFLAGS} of C programs
6613 that use OpenMP@.  If you preprocess OpenMP-specific C code, you also
6614 need to add @code{$(OPENMP_CFLAGS)} to @code{CPPFLAGS}.  The presence of
6615 OpenMP support is revealed at compile time by the preprocessor macro
6616 @code{_OPENMP}.
6618 Linking a program with @code{OPENMP_CFLAGS} typically adds one more
6619 shared library to the program's dependencies, so its use is recommended
6620 only on programs that actually require OpenMP.
6622 If the current language is C++, @code{AC_OPENMP} sets the variable
6623 @code{OPENMP_CXXFLAGS}, suitably for the C++ compiler.  The same remarks
6624 hold as for C.
6626 If the current language is Fortran 77 or Fortran, @code{AC_OPENMP} sets
6627 the variable @code{OPENMP_FFLAGS} or @code{OPENMP_FCFLAGS},
6628 respectively.  Similar remarks as for C hold, except that
6629 @code{CPPFLAGS} is not used for Fortran, and no preprocessor macro
6630 signals OpenMP support.
6632 For portability, it is best to avoid spaces between @samp{#} and
6633 @samp{pragma omp}.  That is, write @samp{#pragma omp}, not
6634 @samp{# pragma omp}.  The Sun WorkShop 6.2 C compiler chokes on the
6635 latter.
6636 @end defmac
6638 @node C Compiler
6639 @subsection C Compiler Characteristics
6641 The following macros provide ways to find and exercise a C Compiler.
6642 There are a few constructs that ought to be avoided, but do not deserve
6643 being checked for, since they can easily be worked around.
6645 @table @asis
6646 @item Don't use lines containing solitary backslashes
6647 They tickle a bug in the @acronym{HP-UX} C compiler (checked on
6648 @acronym{HP-UX} 10.20,
6649 11.00, and 11i).  When given the following source:
6651 @example
6652 #ifdef __STDC__
6654 * A comment with backslash-newlines in it.  %@{ %@} *\
6657 char str[] = "\\
6658 " A string with backslash-newlines in it %@{ %@} \\
6660 char apostrophe = '\\
6664 #endif
6665 @end example
6667 @noindent
6668 the compiler incorrectly fails with the diagnostics ``Non-terminating
6669 comment at end of file'' and ``Missing @samp{#endif} at end of file.''
6670 Removing the lines with solitary backslashes solves the problem.
6672 @item Don't compile several files at once if output matters to you
6673 Some compilers, such as @acronym{HP}'s, report names of files being
6674 compiled when given more than one file operand.  For instance:
6676 @example
6677 $ @kbd{cc a.c b.c}
6678 a.c:
6679 b.c:
6680 @end example
6682 @noindent
6683 This can cause problems if you observe the output of the compiler to
6684 detect failures.  Invoking @samp{cc -c a.c && cc -c b.c && cc -o c a.o
6685 b.o} solves the issue.
6687 @item Don't rely on @code{#error} failing
6688 The @sc{irix} C compiler does not fail when #error is preprocessed; it
6689 simply emits a diagnostic and continues, exiting successfully.  So,
6690 instead of an error directive like @code{#error "Unsupported word size"}
6691 it is more portable to use an invalid directive like @code{#Unsupported
6692 word size} in Autoconf tests.  In ordinary source code, @code{#error} is
6693 OK, since installers with inadequate compilers like @sc{irix} can simply
6694 examine these compilers' diagnostic output.
6696 @item Don't rely on correct @code{#line} support
6697 On Solaris, @command{c89} (at least Sun C 5.3 through 5.8)
6698 diagnoses @code{#line} directives whose line
6699 numbers are greater than 32767.  Nothing in Posix
6700 makes this invalid.  That is why Autoconf stopped issuing
6701 @code{#line} directives.
6702 @end table
6704 @defmac AC_PROG_CC (@ovar{compiler-search-list})
6705 @acindex{PROG_CC}
6706 @ovindex CC
6707 @ovindex CFLAGS
6708 Determine a C compiler to use.  If @code{CC} is not already set in the
6709 environment, check for @code{gcc} and @code{cc}, then for other C
6710 compilers.  Set output variable @code{CC} to the name of the compiler
6711 found.
6713 This macro may, however, be invoked with an optional first argument
6714 which, if specified, must be a blank-separated list of C compilers to
6715 search for.  This just gives the user an opportunity to specify an
6716 alternative search list for the C compiler.  For example, if you didn't
6717 like the default order, then you could invoke @code{AC_PROG_CC} like
6718 this:
6720 @example
6721 AC_PROG_CC([gcc cl cc])
6722 @end example
6724 If the C compiler does not handle function prototypes correctly by
6725 default, try to add an option to output variable @code{CC} to make it
6726 so.  This macro tries various options that select standard-conformance
6727 modes on various systems.
6729 After calling this macro you can check whether the C compiler has been
6730 set to accept @acronym{ANSI} C89 (@acronym{ISO} C90); if not, the shell
6731 variable
6732 @code{ac_cv_prog_cc_c89} is set to @samp{no}.  See also
6733 @code{AC_C_PROTOTYPES} below.
6735 If using the @acronym{GNU} C compiler, set shell variable @code{GCC} to
6736 @samp{yes}.  If output variable @code{CFLAGS} was not already set, set
6737 it to @option{-g -O2} for the @acronym{GNU} C compiler (@option{-O2} on systems
6738 where @acronym{GCC} does not accept @option{-g}), or @option{-g} for
6739 other compilers.
6741 Many Autoconf macros use a compiler, and thus call
6742 @samp{AC_REQUIRE([AC_PROG_CC])} to ensure that the compiler has been
6743 determined before the body of the outermost @code{AC_DEFUN} macro.
6744 Although @code{AC_PROG_CC} is safe to directly expand multiple times, it
6745 performs certain checks (such as the proper value of @env{EXEEXT}) only
6746 on the first invocation.  Therefore, care must be used when invoking
6747 this macro from within another macro rather than at the top level
6748 (@pxref{Expanded Before Required}).
6749 @end defmac
6751 @anchor{AC_PROG_CC_C_O}
6752 @defmac AC_PROG_CC_C_O
6753 @acindex{PROG_CC_C_O}
6754 @cvindex NO_MINUS_C_MINUS_O
6755 If the C compiler does not accept the @option{-c} and @option{-o} options
6756 simultaneously, define @code{NO_MINUS_C_MINUS_O}.  This macro actually
6757 tests both the compiler found by @code{AC_PROG_CC}, and, if different,
6758 the first @code{cc} in the path.  The test fails if one fails.  This
6759 macro was created for @acronym{GNU} Make to choose the default C compilation
6760 rule.
6761 @end defmac
6764 @defmac AC_PROG_CPP
6765 @acindex{PROG_CPP}
6766 @ovindex CPP
6767 Set output variable @code{CPP} to a command that runs the
6768 C preprocessor.  If @samp{$CC -E} doesn't work, @file{/lib/cpp} is used.
6769 It is only portable to run @code{CPP} on files with a @file{.c}
6770 extension.
6772 Some preprocessors don't indicate missing include files by the error
6773 status.  For such preprocessors an internal variable is set that causes
6774 other macros to check the standard error from the preprocessor and
6775 consider the test failed if any warnings have been reported.
6776 For most preprocessors, though, warnings do not cause include-file
6777 tests to fail unless @code{AC_PROG_CPP_WERROR} is also specified.
6778 @end defmac
6780 @defmac AC_PROG_CPP_WERROR
6781 @acindex{PROG_CPP_WERROR}
6782 @ovindex CPP
6783 This acts like @code{AC_PROG_CPP}, except it treats warnings from the
6784 preprocessor as errors even if the preprocessor exit status indicates
6785 success.  This is useful for avoiding headers that generate mandatory
6786 warnings, such as deprecation notices.
6787 @end defmac
6790 The following macros check for C compiler or machine architecture
6791 features.  To check for characteristics not listed here, use
6792 @code{AC_COMPILE_IFELSE} (@pxref{Running the Compiler}) or
6793 @code{AC_RUN_IFELSE} (@pxref{Runtime}).
6795 @defmac AC_PROG_CC_STDC
6796 @acindex{PROG_CC_STDC}
6797 If the C compiler cannot compile @acronym{ISO} Standard C (currently
6798 C99), try to add an option to output variable @code{CC} to make it work.
6799 If the compiler does not support C99, fall back to supporting
6800 @acronym{ANSI} C89 (@acronym{ISO} C90).
6802 After calling this macro you can check whether the C compiler has been
6803 set to accept Standard C; if not, the shell variable
6804 @code{ac_cv_prog_cc_stdc} is set to @samp{no}.
6805 @end defmac
6807 @defmac AC_PROG_CC_C89
6808 @acindex{PROG_CC_C89}
6809 If the C compiler is not in @acronym{ANSI} C89 (@acronym{ISO} C90) mode by
6810 default, try to add an option to output variable @code{CC} to make it
6811 so.  This macro tries various options that select @acronym{ANSI} C89 on
6812 some system or another, preferring extended functionality modes over
6813 strict conformance modes.  It considers the compiler to be in
6814 @acronym{ANSI} C89 mode if it handles function prototypes correctly.
6816 After calling this macro you can check whether the C compiler has been
6817 set to accept @acronym{ANSI} C89; if not, the shell variable
6818 @code{ac_cv_prog_cc_c89} is set to @samp{no}.
6820 This macro is called automatically by @code{AC_PROG_CC}.
6821 @end defmac
6823 @defmac AC_PROG_CC_C99
6824 @acindex{PROG_CC_C99}
6825 If the C compiler is not in C99 mode by default, try to add an
6826 option to output variable @code{CC} to make it so.  This macro tries
6827 various options that select C99 on some system or another, preferring
6828 extended functionality modes over strict conformance modes.  It
6829 considers the compiler to be in C99 mode if it handles @code{_Bool},
6830 @code{//} comments, flexible array members, @code{inline}, signed and
6831 unsigned @code{long long int}, mixed code and declarations, named
6832 initialization of structs,
6833 @code{restrict}, @code{va_copy}, varargs macros, variable declarations
6834 in @code{for} loops, and variable length arrays.
6836 After calling this macro you can check whether the C compiler has been
6837 set to accept C99; if not, the shell variable
6838 @code{ac_cv_prog_cc_c99} is set to @samp{no}.
6839 @end defmac
6841 @defmac AC_C_BACKSLASH_A
6842 @acindex{C_BACKSLASH_A}
6843 @cvindex HAVE_C_BACKSLASH_A
6844 Define @samp{HAVE_C_BACKSLASH_A} to 1 if the C compiler understands
6845 @samp{\a}.
6847 This macro is obsolescent, as current C compilers understand @samp{\a}.
6848 New programs need not use this macro.
6849 @end defmac
6851 @anchor{AC_C_BIGENDIAN}
6852 @defmac AC_C_BIGENDIAN (@ovar{action-if-true}, @ovar{action-if-false}, @
6853   @ovar{action-if-unknown}, @ovar{action-if-universal})
6854 @acindex{C_BIGENDIAN}
6855 @cvindex WORDS_BIGENDIAN
6856 @cindex Endianness
6857 If words are stored with the most significant byte first (like Motorola
6858 and SPARC CPUs), execute @var{action-if-true}.  If words are stored with
6859 the least significant byte first (like Intel and VAX CPUs), execute
6860 @var{action-if-false}.
6862 This macro runs a test-case if endianness cannot be determined from the
6863 system header files.  When cross-compiling, the test-case is not run but
6864 grep'ed for some magic values.  @var{action-if-unknown} is executed if
6865 the latter case fails to determine the byte sex of the host system.
6867 In some cases a single run of a compiler can generate code for multiple
6868 architectures.  This can happen, for example, when generating Mac OS X
6869 universal binary files, which work on both PowerPC and Intel
6870 architectures.  In this case, the different variants might be for
6871 different architectures whose endiannesses differ.  If
6872 @command{configure} detects this, it executes @var{action-if-universal}
6873 instead of @var{action-if-unknown}.
6875 The default for @var{action-if-true} is to define
6876 @samp{WORDS_BIGENDIAN}.  The default for @var{action-if-false} is to do
6877 nothing.  The default for @var{action-if-unknown} is to
6878 abort configure and tell the installer how to bypass this test.
6879 And finally, the default for @var{action-if-universal} is to ensure that
6880 @samp{WORDS_BIGENDIAN} is defined if and only if a universal build is
6881 detected and the current code is big-endian; this default works only if
6882 @command{autoheader} is used (@pxref{autoheader Invocation}).
6884 If you use this macro without specifying @var{action-if-universal}, you
6885 should also use @code{AC_CONFIG_HEADERS}; otherwise
6886 @samp{WORDS_BIGENDIAN} may be set incorrectly for Mac OS X universal
6887 binary files.
6888 @end defmac
6890 @anchor{AC_C_CONST}
6891 @defmac AC_C_CONST
6892 @acindex{C_CONST}
6893 @cvindex const
6894 If the C compiler does not fully support the @code{const} keyword,
6895 define @code{const} to be empty.  Some C compilers that do
6896 not define @code{__STDC__} do support @code{const}; some compilers that
6897 define @code{__STDC__} do not completely support @code{const}.  Programs
6898 can simply use @code{const} as if every C compiler supported it; for
6899 those that don't, the makefile or configuration header file
6900 defines it as empty.
6902 Occasionally installers use a C++ compiler to compile C code, typically
6903 because they lack a C compiler.  This causes problems with @code{const},
6904 because C and C++ treat @code{const} differently.  For example:
6906 @example
6907 const int foo;
6908 @end example
6910 @noindent
6911 is valid in C but not in C++.  These differences unfortunately cannot be
6912 papered over by defining @code{const} to be empty.
6914 If @command{autoconf} detects this situation, it leaves @code{const} alone,
6915 as this generally yields better results in practice.  However, using a
6916 C++ compiler to compile C code is not recommended or supported, and
6917 installers who run into trouble in this area should get a C compiler
6918 like @acronym{GCC} to compile their C code.
6920 This macro is obsolescent, as current C compilers support @code{const}.
6921 New programs need not use this macro.
6922 @end defmac
6924 @defmac AC_C_RESTRICT
6925 @acindex{C_RESTRICT}
6926 @cvindex restrict
6927 If the C compiler recognizes a variant spelling for the @code{restrict}
6928 keyword (@code{__restrict}, @code{__restrict__}, or @code{_Restrict}),
6929 then define @code{restrict} to that; this is more likely to do the right
6930 thing with compilers that support language variants where plain
6931 @code{restrict} is not a keyword.  Otherwise, if the C compiler
6932 recognizes the @code{restrict} keyword, don't do anything.
6933 Otherwise, define @code{restrict} to be empty.
6934 Thus, programs may simply use @code{restrict} as if every C compiler
6935 supported it; for those that do not, the makefile
6936 or configuration header defines it away.
6938 Although support in C++ for the @code{restrict} keyword is not
6939 required, several C++ compilers do accept the keyword.
6940 This macro works for them, too.
6941 @end defmac
6943 @defmac AC_C_VOLATILE
6944 @acindex{C_VOLATILE}
6945 @cvindex volatile
6946 If the C compiler does not understand the keyword @code{volatile},
6947 define @code{volatile} to be empty.  Programs can simply use
6948 @code{volatile} as if every C compiler supported it; for those that do
6949 not, the makefile or configuration header defines it as
6950 empty.
6952 If the correctness of your program depends on the semantics of
6953 @code{volatile}, simply defining it to be empty does, in a sense, break
6954 your code.  However, given that the compiler does not support
6955 @code{volatile}, you are at its mercy anyway.  At least your
6956 program compiles, when it wouldn't before.
6957 @xref{Volatile Objects}, for more about @code{volatile}.
6959 In general, the @code{volatile} keyword is a standard C feature, so
6960 you might expect that @code{volatile} is available only when
6961 @code{__STDC__} is defined.  However, Ultrix 4.3's native compiler does
6962 support volatile, but does not define @code{__STDC__}.
6964 This macro is obsolescent, as current C compilers support @code{volatile}.
6965 New programs need not use this macro.
6966 @end defmac
6968 @anchor{AC_C_INLINE}
6969 @defmac AC_C_INLINE
6970 @acindex{C_INLINE}
6971 @cvindex inline
6972 If the C compiler supports the keyword @code{inline}, do nothing.
6973 Otherwise define @code{inline} to @code{__inline__} or @code{__inline}
6974 if it accepts one of those, otherwise define @code{inline} to be empty.
6975 @end defmac
6977 @anchor{AC_C_CHAR_UNSIGNED}
6978 @defmac AC_C_CHAR_UNSIGNED
6979 @acindex{C_CHAR_UNSIGNED}
6980 @cvindex __CHAR_UNSIGNED__
6981 If the C type @code{char} is unsigned, define @code{__CHAR_UNSIGNED__},
6982 unless the C compiler predefines it.
6984 These days, using this macro is not necessary.  The same information can
6985 be determined by this portable alternative, thus avoiding the use of
6986 preprocessor macros in the namespace reserved for the implementation.
6988 @example
6989 #include <limits.h>
6990 #if CHAR_MIN == 0
6991 # define CHAR_UNSIGNED 1
6992 #endif
6993 @end example
6994 @end defmac
6996 @defmac AC_C_STRINGIZE
6997 @acindex{C_STRINGIZE}
6998 @cvindex HAVE_STRINGIZE
6999 If the C preprocessor supports the stringizing operator, define
7000 @code{HAVE_STRINGIZE}.  The stringizing operator is @samp{#} and is
7001 found in macros such as this:
7003 @example
7004 #define x(y) #y
7005 @end example
7007 This macro is obsolescent, as current C compilers support the
7008 stringizing operator.  New programs need not use this macro.
7009 @end defmac
7011 @defmac AC_C_FLEXIBLE_ARRAY_MEMBER
7012 @acindex{C_FLEXIBLE_ARRAY_MEMBER}
7013 @cvindex FLEXIBLE_ARRAY_MEMBER
7014 If the C compiler supports flexible array members, define
7015 @code{FLEXIBLE_ARRAY_MEMBER} to nothing; otherwise define it to 1.
7016 That way, a declaration like this:
7018 @example
7019 struct s
7020   @{
7021     size_t n_vals;
7022     double val[FLEXIBLE_ARRAY_MEMBER];
7023   @};
7024 @end example
7026 @noindent
7027 will let applications use the ``struct hack'' even with compilers that
7028 do not support flexible array members.  To allocate and use such an
7029 object, you can use code like this:
7031 @example
7032 size_t i;
7033 size_t n = compute_value_count ();
7034 struct s *p =
7035    malloc (offsetof (struct s, val)
7036            + n * sizeof (double));
7037 p->n_vals = n;
7038 for (i = 0; i < n; i++)
7039   p->val[i] = compute_value (i);
7040 @end example
7041 @end defmac
7043 @defmac AC_C_VARARRAYS
7044 @acindex{C_VARARRAYS}
7045 @cvindex HAVE_C_VARARRAYS
7046 If the C compiler supports variable-length arrays, define
7047 @code{HAVE_C_VARARRAYS}.  A variable-length array is an array of automatic
7048 storage duration whose length is determined at run time, when the array
7049 is declared.
7050 @end defmac
7052 @defmac AC_C_TYPEOF
7053 @acindex{C_TYPEOF}
7054 @cvindex HAVE_TYPEOF
7055 @cvindex typeof
7056 If the C compiler supports @acronym{GCC}'s @code{typeof} syntax either
7057 directly or
7058 through a different spelling of the keyword (e.g., @code{__typeof__}),
7059 define @code{HAVE_TYPEOF}.  If the support is available only through a
7060 different spelling, define @code{typeof} to that spelling.
7061 @end defmac
7063 @defmac AC_C_PROTOTYPES
7064 @acindex{C_PROTOTYPES}
7065 @cvindex PROTOTYPES
7066 @cvindex __PROTOTYPES
7067 @cvindex PARAMS
7068 If function prototypes are understood by the compiler (as determined by
7069 @code{AC_PROG_CC}), define @code{PROTOTYPES} and @code{__PROTOTYPES}.
7070 Defining @code{__PROTOTYPES} is for the benefit of
7071 header files that cannot use macros that infringe on user name space.
7073 This macro is obsolescent, as current C compilers support prototypes.
7074 New programs need not use this macro.
7075 @end defmac
7077 @anchor{AC_PROG_GCC_TRADITIONAL}
7078 @defmac AC_PROG_GCC_TRADITIONAL
7079 @acindex{PROG_GCC_TRADITIONAL}
7080 @ovindex CC
7081 Add @option{-traditional} to output variable @code{CC} if using the
7082 @acronym{GNU} C compiler and @code{ioctl} does not work properly without
7083 @option{-traditional}.  That usually happens when the fixed header files
7084 have not been installed on an old system.
7086 This macro is obsolescent, since current versions of the @acronym{GNU} C
7087 compiler fix the header files automatically when installed.
7088 @end defmac
7091 @node C++ Compiler
7092 @subsection C++ Compiler Characteristics
7095 @defmac AC_PROG_CXX (@ovar{compiler-search-list})
7096 @acindex{PROG_CXX}
7097 @ovindex CXX
7098 @ovindex CXXFLAGS
7099 Determine a C++ compiler to use.  Check whether the environment variable
7100 @code{CXX} or @code{CCC} (in that order) is set; if so, then set output
7101 variable @code{CXX} to its value.
7103 Otherwise, if the macro is invoked without an argument, then search for
7104 a C++ compiler under the likely names (first @code{g++} and @code{c++}
7105 then other names).  If none of those checks succeed, then as a last
7106 resort set @code{CXX} to @code{g++}.
7108 This macro may, however, be invoked with an optional first argument
7109 which, if specified, must be a blank-separated list of C++ compilers to
7110 search for.  This just gives the user an opportunity to specify an
7111 alternative search list for the C++ compiler.  For example, if you
7112 didn't like the default order, then you could invoke @code{AC_PROG_CXX}
7113 like this:
7115 @example
7116 AC_PROG_CXX([gcc cl KCC CC cxx cc++ xlC aCC c++ g++])
7117 @end example
7119 If using the @acronym{GNU} C++ compiler, set shell variable @code{GXX} to
7120 @samp{yes}.  If output variable @code{CXXFLAGS} was not already set, set
7121 it to @option{-g -O2} for the @acronym{GNU} C++ compiler (@option{-O2} on
7122 systems where G++ does not accept @option{-g}), or @option{-g} for other
7123 compilers.
7124 @end defmac
7126 @defmac AC_PROG_CXXCPP
7127 @acindex{PROG_CXXCPP}
7128 @ovindex CXXCPP
7129 Set output variable @code{CXXCPP} to a command that runs the C++
7130 preprocessor.  If @samp{$CXX -E} doesn't work, @file{/lib/cpp} is used.
7131 It is portable to run @code{CXXCPP} only on files with a @file{.c},
7132 @file{.C}, @file{.cc}, or @file{.cpp} extension.
7134 Some preprocessors don't indicate missing include files by the error
7135 status.  For such preprocessors an internal variable is set that causes
7136 other macros to check the standard error from the preprocessor and
7137 consider the test failed if any warnings have been reported.  However,
7138 it is not known whether such broken preprocessors exist for C++.
7139 @end defmac
7141 @defmac AC_PROG_CXX_C_O
7142 @acindex{PROG_CXX_C_O}
7143 @cvindex CXX_NO_MINUS_C_MINUS_O
7144 Test whether the C++ compiler accepts the options @option{-c} and
7145 @option{-o} simultaneously, and define @code{CXX_NO_MINUS_C_MINUS_O},
7146 if it does not.
7147 @end defmac
7150 @node Objective C Compiler
7151 @subsection Objective C Compiler Characteristics
7154 @defmac AC_PROG_OBJC (@ovar{compiler-search-list})
7155 @acindex{PROG_OBJC}
7156 @ovindex OBJC
7157 @ovindex OBJCFLAGS
7158 Determine an Objective C compiler to use.  If @code{OBJC} is not already
7159 set in the environment, check for Objective C compilers.  Set output
7160 variable @code{OBJC} to the name of the compiler found.
7162 This macro may, however, be invoked with an optional first argument
7163 which, if specified, must be a blank-separated list of Objective C compilers to
7164 search for.  This just gives the user an opportunity to specify an
7165 alternative search list for the Objective C compiler.  For example, if you
7166 didn't like the default order, then you could invoke @code{AC_PROG_OBJC}
7167 like this:
7169 @example
7170 AC_PROG_OBJC([gcc objcc objc])
7171 @end example
7173 If using the @acronym{GNU} Objective C compiler, set shell variable
7174 @code{GOBJC} to @samp{yes}.  If output variable @code{OBJCFLAGS} was not
7175 already set, set it to @option{-g -O2} for the @acronym{GNU} Objective C
7176 compiler (@option{-O2} on systems where @command{gcc} does not accept
7177 @option{-g}), or @option{-g} for other compilers.
7178 @end defmac
7180 @defmac AC_PROG_OBJCPP
7181 @acindex{PROG_OBJCPP}
7182 @ovindex OBJCPP
7183 Set output variable @code{OBJCPP} to a command that runs the Objective C
7184 preprocessor.  If @samp{$OBJC -E} doesn't work, @file{/lib/cpp} is used.
7185 @end defmac
7188 @node Erlang Compiler and Interpreter
7189 @subsection Erlang Compiler and Interpreter Characteristics
7190 @cindex Erlang
7192 Autoconf defines the following macros for determining paths to the essential
7193 Erlang/OTP programs:
7195 @defmac AC_ERLANG_PATH_ERLC (@ovar{value-if-not-found}, @dvar{path, $PATH})
7196 @acindex{ERLANG_PATH_ERLC}
7197 @ovindex ERLC
7198 @ovindex ERLCFLAGS
7199 Determine an Erlang compiler to use.  If @code{ERLC} is not already set in the
7200 environment, check for @command{erlc}.  Set output variable @code{ERLC} to the
7201 complete path of the compiler command found.  In addition, if @code{ERLCFLAGS}
7202 is not set in the environment, set it to an empty value.
7204 The two optional arguments have the same meaning as the two last arguments of
7205 macro @code{AC_PROG_PATH} for looking for the @command{erlc} program.  For
7206 example, to look for @command{erlc} only in the @file{/usr/lib/erlang/bin}
7207 directory:
7209 @example
7210 AC_ERLANG_PATH_ERLC([not found], [/usr/lib/erlang/bin])
7211 @end example
7212 @end defmac
7214 @defmac AC_ERLANG_NEED_ERLC (@dvar{path, $PATH})
7215 @acindex{ERLANG_NEED_ERLC}
7216 A simplified variant of the @code{AC_ERLANG_PATH_ERLC} macro, that prints an
7217 error message and exits the @command{configure} script if the @command{erlc}
7218 program is not found.
7219 @end defmac
7221 @defmac AC_ERLANG_PATH_ERL (@ovar{value-if-not-found}, @dvar{path, $PATH})
7222 @acindex{ERLANG_PATH_ERL}
7223 @ovindex ERL
7224 Determine an Erlang interpreter to use.  If @code{ERL} is not already
7225 set in the
7226 environment, check for @command{erl}.  Set output variable @code{ERL} to the
7227 complete path of the interpreter command found.
7229 The two optional arguments have the same meaning as the two last arguments of
7230 macro @code{AC_PROG_PATH} for looking for the @command{erl} program.  For
7231 example, to look for @command{erl} only in the @file{/usr/lib/erlang/bin}
7232 directory:
7234 @example
7235 AC_ERLANG_PATH_ERL([not found], [/usr/lib/erlang/bin])
7236 @end example
7237 @end defmac
7239 @defmac AC_ERLANG_NEED_ERL (@dvar{path, $PATH})
7240 @acindex{ERLANG_NEED_ERL}
7241 A simplified variant of the @code{AC_ERLANG_PATH_ERL} macro, that prints an
7242 error message and exits the @command{configure} script if the @command{erl}
7243 program is not found.
7244 @end defmac
7247 @node Fortran Compiler
7248 @subsection Fortran Compiler Characteristics
7249 @cindex Fortran
7250 @cindex F77
7252 The Autoconf Fortran support is divided into two categories: legacy
7253 Fortran 77 macros (@code{F77}), and modern Fortran macros (@code{FC}).
7254 The former are intended for traditional Fortran 77 code, and have output
7255 variables like @code{F77}, @code{FFLAGS}, and @code{FLIBS}.  The latter
7256 are for newer programs that can (or must) compile under the newer
7257 Fortran standards, and have output variables like @code{FC},
7258 @code{FCFLAGS}, and @code{FCLIBS}.
7260 Except for two new macros @code{AC_FC_SRCEXT} and
7261 @code{AC_FC_FREEFORM} (see below), the @code{FC} and @code{F77} macros
7262 behave almost identically, and so they are documented together in this
7263 section.
7266 @defmac AC_PROG_F77 (@ovar{compiler-search-list})
7267 @acindex{PROG_F77}
7268 @ovindex F77
7269 @ovindex FFLAGS
7270 Determine a Fortran 77 compiler to use.  If @code{F77} is not already
7271 set in the environment, then check for @code{g77} and @code{f77}, and
7272 then some other names.  Set the output variable @code{F77} to the name
7273 of the compiler found.
7275 This macro may, however, be invoked with an optional first argument
7276 which, if specified, must be a blank-separated list of Fortran 77
7277 compilers to search for.  This just gives the user an opportunity to
7278 specify an alternative search list for the Fortran 77 compiler.  For
7279 example, if you didn't like the default order, then you could invoke
7280 @code{AC_PROG_F77} like this:
7282 @example
7283 AC_PROG_F77([fl32 f77 fort77 xlf g77 f90 xlf90])
7284 @end example
7286 If using @code{g77} (the @acronym{GNU} Fortran 77 compiler), then
7287 set the shell variable @code{G77} to @samp{yes}.
7288 If the output variable @code{FFLAGS} was not already set in the
7289 environment, then set it to @option{-g -02} for @code{g77} (or @option{-O2}
7290 where @code{g77} does not accept @option{-g}).  Otherwise, set
7291 @code{FFLAGS} to @option{-g} for all other Fortran 77 compilers.
7292 @end defmac
7294 @defmac AC_PROG_FC (@ovar{compiler-search-list}, @ovar{dialect})
7295 @acindex{PROG_FC}
7296 @ovindex FC
7297 @ovindex FCFLAGS
7298 Determine a Fortran compiler to use.  If @code{FC} is not already set in
7299 the environment, then @code{dialect} is a hint to indicate what Fortran
7300 dialect to search for; the default is to search for the newest available
7301 dialect.  Set the output variable @code{FC} to the name of the compiler
7302 found.
7304 By default, newer dialects are preferred over older dialects, but if
7305 @code{dialect} is specified then older dialects are preferred starting
7306 with the specified dialect.  @code{dialect} can currently be one of
7307 Fortran 77, Fortran 90, or Fortran 95.  However, this is only a hint of
7308 which compiler @emph{name} to prefer (e.g., @code{f90} or @code{f95}),
7309 and no attempt is made to guarantee that a particular language standard
7310 is actually supported.  Thus, it is preferable that you avoid the
7311 @code{dialect} option, and use AC_PROG_FC only for code compatible with
7312 the latest Fortran standard.
7314 This macro may, alternatively, be invoked with an optional first argument
7315 which, if specified, must be a blank-separated list of Fortran
7316 compilers to search for, just as in @code{AC_PROG_F77}.
7318 If the output variable @code{FCFLAGS} was not already set in the
7319 environment, then set it to @option{-g -02} for @acronym{GNU} @code{g77} (or
7320 @option{-O2} where @code{g77} does not accept @option{-g}).  Otherwise,
7321 set @code{FCFLAGS} to @option{-g} for all other Fortran compilers.
7322 @end defmac
7324 @defmac AC_PROG_F77_C_O
7325 @defmacx AC_PROG_FC_C_O
7326 @acindex{PROG_F77_C_O}
7327 @acindex{PROG_FC_C_O}
7328 @cvindex F77_NO_MINUS_C_MINUS_O
7329 @cvindex FC_NO_MINUS_C_MINUS_O
7330 Test whether the Fortran compiler accepts the options @option{-c} and
7331 @option{-o} simultaneously, and define @code{F77_NO_MINUS_C_MINUS_O} or
7332 @code{FC_NO_MINUS_C_MINUS_O}, respectively, if it does not.
7333 @end defmac
7335 The following macros check for Fortran compiler characteristics.
7336 To check for characteristics not listed here, use
7337 @code{AC_COMPILE_IFELSE} (@pxref{Running the Compiler}) or
7338 @code{AC_RUN_IFELSE} (@pxref{Runtime}), making sure to first set the
7339 current language to Fortran 77 or Fortran via @code{AC_LANG([Fortran 77])}
7340 or @code{AC_LANG(Fortran)} (@pxref{Language Choice}).
7343 @defmac AC_F77_LIBRARY_LDFLAGS
7344 @defmacx AC_FC_LIBRARY_LDFLAGS
7345 @acindex{F77_LIBRARY_LDFLAGS}
7346 @ovindex FLIBS
7347 @acindex{FC_LIBRARY_LDFLAGS}
7348 @ovindex FCLIBS
7349 Determine the linker flags (e.g., @option{-L} and @option{-l}) for the
7350 @dfn{Fortran intrinsic and runtime libraries} that are required to
7351 successfully link a Fortran program or shared library.  The output
7352 variable @code{FLIBS} or @code{FCLIBS} is set to these flags (which
7353 should be included after @code{LIBS} when linking).
7355 This macro is intended to be used in those situations when it is
7356 necessary to mix, e.g., C++ and Fortran source code in a single
7357 program or shared library (@pxref{Mixing Fortran 77 With C and C++, , ,
7358 automake, @acronym{GNU} Automake}).
7360 For example, if object files from a C++ and Fortran compiler must be
7361 linked together, then the C++ compiler/linker must be used for linking
7362 (since special C++-ish things need to happen at link time like calling
7363 global constructors, instantiating templates, enabling exception
7364 support, etc.).
7366 However, the Fortran intrinsic and runtime libraries must be linked in
7367 as well, but the C++ compiler/linker doesn't know by default how to add
7368 these Fortran 77 libraries.  Hence, this macro was created to determine
7369 these Fortran libraries.
7371 The macros @code{AC_F77_DUMMY_MAIN} and @code{AC_FC_DUMMY_MAIN} or
7372 @code{AC_F77_MAIN} and @code{AC_FC_MAIN} are probably also necessary to
7373 link C/C++ with Fortran; see below.
7374 @end defmac
7376 @defmac AC_F77_DUMMY_MAIN (@ovar{action-if-found}, @ovar{action-if-not-found})
7377 @defmacx AC_FC_DUMMY_MAIN (@ovar{action-if-found}, @ovar{action-if-not-found})
7378 @acindex{F77_DUMMY_MAIN}
7379 @cvindex F77_DUMMY_MAIN
7380 With many compilers, the Fortran libraries detected by
7381 @code{AC_F77_LIBRARY_LDFLAGS} or @code{AC_FC_LIBRARY_LDFLAGS} provide
7382 their own @code{main} entry function that initializes things like
7383 Fortran I/O, and which then calls a user-provided entry function named
7384 (say) @code{MAIN__} to run the user's program.  The
7385 @code{AC_F77_DUMMY_MAIN} and @code{AC_FC_DUMMY_MAIN} or
7386 @code{AC_F77_MAIN} and @code{AC_FC_MAIN} macros figure out how to deal with
7387 this interaction.
7389 When using Fortran for purely numerical functions (no I/O, etc.)@: often
7390 one prefers to provide one's own @code{main} and skip the Fortran
7391 library initializations.  In this case, however, one may still need to
7392 provide a dummy @code{MAIN__} routine in order to prevent linking errors
7393 on some systems.  @code{AC_F77_DUMMY_MAIN} or @code{AC_FC_DUMMY_MAIN}
7394 detects whether any such routine is @emph{required} for linking, and
7395 what its name is; the shell variable @code{F77_DUMMY_MAIN} or
7396 @code{FC_DUMMY_MAIN} holds this name, @code{unknown} when no solution
7397 was found, and @code{none} when no such dummy main is needed.
7399 By default, @var{action-if-found} defines @code{F77_DUMMY_MAIN} or
7400 @code{FC_DUMMY_MAIN} to the name of this routine (e.g., @code{MAIN__})
7401 @emph{if} it is required.  @var{action-if-not-found} defaults to
7402 exiting with an error.
7404 In order to link with Fortran routines, the user's C/C++ program should
7405 then include the following code to define the dummy main if it is
7406 needed:
7408 @example
7409 #ifdef F77_DUMMY_MAIN
7410 #  ifdef __cplusplus
7411      extern "C"
7412 #  endif
7413    int F77_DUMMY_MAIN() @{ return 1; @}
7414 #endif
7415 @end example
7417 (Replace @code{F77} with @code{FC} for Fortran instead of Fortran 77.)
7419 Note that this macro is called automatically from @code{AC_F77_WRAPPERS}
7420 or @code{AC_FC_WRAPPERS}; there is generally no need to call it
7421 explicitly unless one wants to change the default actions.
7422 @end defmac
7424 @defmac AC_F77_MAIN
7425 @defmacx AC_FC_MAIN
7426 @acindex{F77_MAIN}
7427 @cvindex F77_MAIN
7428 @acindex{FC_MAIN}
7429 @cvindex FC_MAIN
7430 As discussed above, many Fortran libraries allow you to provide an entry
7431 point called (say) @code{MAIN__} instead of the usual @code{main}, which
7432 is then called by a @code{main} function in the Fortran libraries that
7433 initializes things like Fortran I/O@.  The
7434 @code{AC_F77_MAIN} and @code{AC_FC_MAIN} macros detect whether it is
7435 @emph{possible} to utilize such an alternate main function, and defines
7436 @code{F77_MAIN} and @code{FC_MAIN} to the name of the function.  (If no
7437 alternate main function name is found, @code{F77_MAIN} and @code{FC_MAIN} are
7438 simply defined to @code{main}.)
7440 Thus, when calling Fortran routines from C that perform things like I/O,
7441 one should use this macro and declare the "main" function like so:
7443 @example
7444 #ifdef __cplusplus
7445   extern "C"
7446 #endif
7447 int F77_MAIN(int argc, char *argv[]);
7448 @end example
7450 (Again, replace @code{F77} with @code{FC} for Fortran instead of Fortran 77.)
7451 @end defmac
7453 @defmac AC_F77_WRAPPERS
7454 @defmacx AC_FC_WRAPPERS
7455 @acindex{F77_WRAPPERS}
7456 @cvindex F77_FUNC
7457 @cvindex F77_FUNC_
7458 @acindex{FC_WRAPPERS}
7459 @cvindex FC_FUNC
7460 @cvindex FC_FUNC_
7461 Defines C macros @code{F77_FUNC (name, NAME)}, @code{FC_FUNC (name, NAME)},
7462 @code{F77_FUNC_(name, NAME)}, and @code{FC_FUNC_(name, NAME)} to properly
7463 mangle the names of C/C++ identifiers, and identifiers with underscores,
7464 respectively, so that they match the name-mangling scheme used by the
7465 Fortran compiler.
7467 Fortran is case-insensitive, and in order to achieve this the Fortran
7468 compiler converts all identifiers into a canonical case and format.  To
7469 call a Fortran subroutine from C or to write a C function that is
7470 callable from Fortran, the C program must explicitly use identifiers in
7471 the format expected by the Fortran compiler.  In order to do this, one
7472 simply wraps all C identifiers in one of the macros provided by
7473 @code{AC_F77_WRAPPERS} or @code{AC_FC_WRAPPERS}.  For example, suppose
7474 you have the following Fortran 77 subroutine:
7476 @example
7477       subroutine foobar (x, y)
7478       double precision x, y
7479       y = 3.14159 * x
7480       return
7481       end
7482 @end example
7484 You would then declare its prototype in C or C++ as:
7486 @example
7487 #define FOOBAR_F77 F77_FUNC (foobar, FOOBAR)
7488 #ifdef __cplusplus
7489 extern "C"  /* prevent C++ name mangling */
7490 #endif
7491 void FOOBAR_F77(double *x, double *y);
7492 @end example
7494 Note that we pass both the lowercase and uppercase versions of the
7495 function name to @code{F77_FUNC} so that it can select the right one.
7496 Note also that all parameters to Fortran 77 routines are passed as
7497 pointers (@pxref{Mixing Fortran 77 With C and C++, , , automake, @acronym{GNU}
7498 Automake}).
7500 (Replace @code{F77} with @code{FC} for Fortran instead of Fortran 77.)
7502 Although Autoconf tries to be intelligent about detecting the
7503 name-mangling scheme of the Fortran compiler, there may be Fortran
7504 compilers that it doesn't support yet.  In this case, the above code
7505 generates a compile-time error, but some other behavior
7506 (e.g., disabling Fortran-related features) can be induced by checking
7507 whether @code{F77_FUNC} or @code{FC_FUNC} is defined.
7509 Now, to call that routine from a C program, we would do something like:
7511 @example
7513     double x = 2.7183, y;
7514     FOOBAR_F77 (&x, &y);
7516 @end example
7518 If the Fortran identifier contains an underscore (e.g., @code{foo_bar}),
7519 you should use @code{F77_FUNC_} or @code{FC_FUNC_} instead of
7520 @code{F77_FUNC} or @code{FC_FUNC} (with the same arguments).  This is
7521 because some Fortran compilers mangle names differently if they contain
7522 an underscore.
7523 @end defmac
7525 @defmac AC_F77_FUNC (@var{name}, @ovar{shellvar})
7526 @defmacx AC_FC_FUNC (@var{name}, @ovar{shellvar})
7527 @acindex{F77_FUNC}
7528 @acindex{FC_FUNC}
7529 Given an identifier @var{name}, set the shell variable @var{shellvar} to
7530 hold the mangled version @var{name} according to the rules of the
7531 Fortran linker (see also @code{AC_F77_WRAPPERS} or
7532 @code{AC_FC_WRAPPERS}).  @var{shellvar} is optional; if it is not
7533 supplied, the shell variable is simply @var{name}.  The purpose of
7534 this macro is to give the caller a way to access the name-mangling
7535 information other than through the C preprocessor as above, for example,
7536 to call Fortran routines from some language other than C/C++.
7537 @end defmac
7539 @defmac AC_FC_SRCEXT (@var{ext}, @ovar{action-if-success}, @
7540   @ovar{action-if-failure})
7541 @acindex{FC_SRCEXT}
7542 By default, the @code{FC} macros perform their tests using a @file{.f}
7543 extension for source-code files.  Some compilers, however, only enable
7544 newer language features for appropriately named files, e.g., Fortran 90
7545 features only for @file{.f90} files.  On the other hand, some other
7546 compilers expect all source files to end in @file{.f} and require
7547 special flags to support other file name extensions.  The
7548 @code{AC_FC_SRCEXT} macro deals with both of these issues.
7550 The @code{AC_FC_SRCEXT} tries to get the @code{FC} compiler to accept files
7551 ending with the extension .@var{ext} (i.e., @var{ext} does @emph{not}
7552 contain the dot).  If any special compiler flags are needed for this, it
7553 stores them in the output variable @code{FCFLAGS_}@var{ext}.  This
7554 extension and these flags are then used for all subsequent @code{FC} tests
7555 (until @code{AC_FC_SRCEXT} is called again).
7557 For example, you would use @code{AC_FC_SRCEXT(f90)} to employ the
7558 @file{.f90} extension in future tests, and it would set the
7559 @code{FCFLAGS_f90} output variable with any extra flags that are needed
7560 to compile such files.
7562 The @code{FCFLAGS_}@var{ext} can @emph{not} be simply absorbed into
7563 @code{FCFLAGS}, for two reasons based on the limitations of some
7564 compilers.  First, only one @code{FCFLAGS_}@var{ext} can be used at a
7565 time, so files with different extensions must be compiled separately.
7566 Second, @code{FCFLAGS_}@var{ext} must appear @emph{immediately} before
7567 the source-code file name when compiling.  So, continuing the example
7568 above, you might compile a @file{foo.f90} file in your makefile with the
7569 command:
7571 @example
7572 foo.o: foo.f90
7573      $(FC) -c $(FCFLAGS) $(FCFLAGS_f90) '$(srcdir)/foo.f90'
7574 @end example
7576 If @code{AC_FC_SRCEXT} succeeds in compiling files with the @var{ext}
7577 extension, it calls @var{action-if-success} (defaults to nothing).  If
7578 it fails, and cannot find a way to make the @code{FC} compiler accept such
7579 files, it calls @var{action-if-failure} (defaults to exiting with an
7580 error message).
7582 @end defmac
7584 @defmac AC_FC_FREEFORM (@ovar{action-if-success}, @ovar{action-if-failure})
7585 @acindex{FC_FREEFORM}
7587 The @code{AC_FC_FREEFORM} tries to ensure that the Fortran compiler
7588 (@code{$FC}) allows free-format source code (as opposed to the older
7589 fixed-format style from Fortran 77).  If necessary, it may add some
7590 additional flags to @code{FCFLAGS}.
7592 This macro is most important if you are using the default @file{.f}
7593 extension, since many compilers interpret this extension as indicating
7594 fixed-format source unless an additional flag is supplied.  If you
7595 specify a different extension with @code{AC_FC_SRCEXT}, such as
7596 @file{.f90} or @file{.f95}, then @code{AC_FC_FREEFORM} ordinarily
7597 succeeds without modifying @code{FCFLAGS}.
7599 If @code{AC_FC_FREEFORM} succeeds in compiling free-form source, it
7600 calls @var{action-if-success} (defaults to nothing).  If it fails, it
7601 calls @var{action-if-failure} (defaults to exiting with an error
7602 message).
7603 @end defmac
7605 @node System Services
7606 @section System Services
7608 The following macros check for operating system services or capabilities.
7610 @anchor{AC_PATH_X}
7611 @defmac AC_PATH_X
7612 @acindex{PATH_X}
7613 @evindex XMKMF
7614 @cindex X Window System
7615 Try to locate the X Window System include files and libraries.  If the
7616 user gave the command line options @option{--x-includes=@var{dir}} and
7617 @option{--x-libraries=@var{dir}}, use those directories.
7619 If either or both were not given, get the missing values by running
7620 @code{xmkmf} (or an executable pointed to by the @code{XMKMF}
7621 environment variable) on a trivial @file{Imakefile} and examining the
7622 makefile that it produces.  Setting @code{XMKMF} to @samp{false}
7623 disables this method.
7625 If this method fails to find the X Window System, @command{configure}
7626 looks for the files in several directories where they often reside.
7627 If either method is successful, set the shell variables
7628 @code{x_includes} and @code{x_libraries} to their locations, unless they
7629 are in directories the compiler searches by default.
7631 If both methods fail, or the user gave the command line option
7632 @option{--without-x}, set the shell variable @code{no_x} to @samp{yes};
7633 otherwise set it to the empty string.
7634 @end defmac
7636 @anchor{AC_PATH_XTRA}
7637 @defmac AC_PATH_XTRA
7638 @acindex{PATH_XTRA}
7639 @ovindex X_CFLAGS
7640 @ovindex X_LIBS
7641 @ovindex X_EXTRA_LIBS
7642 @ovindex X_PRE_LIBS
7643 @cvindex X_DISPLAY_MISSING
7644 An enhanced version of @code{AC_PATH_X}.  It adds the C compiler flags
7645 that X needs to output variable @code{X_CFLAGS}, and the X linker flags
7646 to @code{X_LIBS}.  Define @code{X_DISPLAY_MISSING} if X is not
7647 available.
7649 This macro also checks for special libraries that some systems need in
7650 order to compile X programs.  It adds any that the system needs to
7651 output variable @code{X_EXTRA_LIBS}.  And it checks for special X11R6
7652 libraries that need to be linked with before @option{-lX11}, and adds
7653 any found to the output variable @code{X_PRE_LIBS}.
7655 @c This is an incomplete kludge.  Make a real way to do it.
7656 @c If you need to check for other X functions or libraries yourself, then
7657 @c after calling this macro, add the contents of @code{X_EXTRA_LIBS} to
7658 @c @code{LIBS} temporarily, like this: (FIXME - add example)
7659 @end defmac
7661 @anchor{AC_SYS_INTERPRETER}
7662 @defmac AC_SYS_INTERPRETER
7663 @acindex{SYS_INTERPRETER}
7664 Check whether the system supports starting scripts with a line of the
7665 form @samp{#!/bin/sh} to select the interpreter to use for the script.
7666 After running this macro, shell code in @file{configure.ac} can check
7667 the shell variable @code{interpval}; it is set to @samp{yes}
7668 if the system supports @samp{#!}, @samp{no} if not.
7669 @end defmac
7671 @defmac AC_SYS_LARGEFILE
7672 @acindex{SYS_LARGEFILE}
7673 @cvindex _FILE_OFFSET_BITS
7674 @cvindex _LARGE_FILES
7675 @ovindex CC
7676 @cindex Large file support
7677 @cindex LFS
7678 Arrange for 64-bit file offsets, known as
7679 @uref{http://@/www.unix-systems@/.org/@/version2/@/whatsnew/@/lfs20mar.html,
7680 large-file support}.  On some hosts, one must use special compiler
7681 options to build programs that can access large files.  Append any such
7682 options to the output variable @code{CC}.  Define
7683 @code{_FILE_OFFSET_BITS} and @code{_LARGE_FILES} if necessary.
7685 Large-file support can be disabled by configuring with the
7686 @option{--disable-largefile} option.
7688 If you use this macro, check that your program works even when
7689 @code{off_t} is wider than @code{long int}, since this is common when
7690 large-file support is enabled.  For example, it is not correct to print
7691 an arbitrary @code{off_t} value @code{X} with @code{printf ("%ld",
7692 (long int) X)}.
7694 The LFS introduced the @code{fseeko} and @code{ftello} functions to
7695 replace their C counterparts @code{fseek} and @code{ftell} that do not
7696 use @code{off_t}.  Take care to use @code{AC_FUNC_FSEEKO} to make their
7697 prototypes available when using them and large-file support is
7698 enabled.
7699 @end defmac
7701 @anchor{AC_SYS_LONG_FILE_NAMES}
7702 @defmac AC_SYS_LONG_FILE_NAMES
7703 @acindex{SYS_LONG_FILE_NAMES}
7704 @cvindex HAVE_LONG_FILE_NAMES
7705 If the system supports file names longer than 14 characters, define
7706 @code{HAVE_LONG_FILE_NAMES}.
7707 @end defmac
7709 @defmac AC_SYS_POSIX_TERMIOS
7710 @acindex{SYS_POSIX_TERMIOS}
7711 @cindex Posix termios headers
7712 @cindex termios Posix headers
7713 Check to see if the Posix termios headers and functions are available on the
7714 system.  If so, set the shell variable @code{ac_cv_sys_posix_termios} to
7715 @samp{yes}.  If not, set the variable to @samp{no}.
7716 @end defmac
7718 @node Posix Variants
7719 @section Posix Variants
7721 The following macro makes it possible to use features of Posix that are
7722 extensions to C, as well as platform extensions not defined by Posix.
7724 @anchor{AC_USE_SYSTEM_EXTENSIONS}
7725 @defmac AC_USE_SYSTEM_EXTENSIONS
7726 @acindex{USE_SYSTEM_EXTENSIONS}
7727 @cvindex _ALL_SOURCE
7728 @cvindex _GNU_SOURCE
7729 @cvindex _MINIX
7730 @cvindex _POSIX_1_SOURCE
7731 @cvindex _POSIX_PTHREAD_SEMANTICS
7732 @cvindex _POSIX_SOURCE
7733 @cvindex _TANDEM_SOURCE
7734 @cvindex __EXTENSIONS__
7735 This macro was introduced in Autoconf 2.60.  If possible, enable
7736 extensions to C or Posix on hosts that normally disable the extensions,
7737 typically due to standards-conformance namespace issues.  This should be
7738 called before any macros that run the C compiler.  The following
7739 preprocessor macros are defined where appropriate:
7741 @table @code
7742 @item _GNU_SOURCE
7743 Enable extensions on @acronym{GNU}/Linux.
7744 @item __EXTENSIONS__
7745 Enable general extensions on Solaris.
7746 @item _POSIX_PTHREAD_SEMANTICS
7747 Enable threading extensions on Solaris.
7748 @item _TANDEM_SOURCE
7749 Enable extensions for the @acronym{HP} NonStop platform.
7750 @item _ALL_SOURCE
7751 Enable extensions for @acronym{AIX} 3, and for Interix.
7752 @item _POSIX_SOURCE
7753 Enable Posix functions for Minix.
7754 @item _POSIX_1_SOURCE
7755 Enable additional Posix functions for Minix.
7756 @item _MINIX
7757 Identify Minix platform.  This particular preprocessor macro is
7758 obsolescent, and may be removed in a future release of Autoconf.
7759 @end table
7760 @end defmac
7763 @node Erlang Libraries
7764 @section Erlang Libraries
7765 @cindex Erlang, Library, checking
7767 The following macros check for an installation of Erlang/OTP, and for the
7768 presence of certain Erlang libraries.  All those macros require the
7769 configuration of an Erlang interpreter and an Erlang compiler
7770 (@pxref{Erlang Compiler and Interpreter}).
7772 @defmac AC_ERLANG_SUBST_ROOT_DIR
7773 @acindex{ERLANG_SUBST_ROOT_DIR}
7774 @ovindex ERLANG_ROOT_DIR
7776 Set the output variable @code{ERLANG_ROOT_DIR} to the path to the base
7777 directory in which Erlang/OTP is installed (as returned by Erlang's
7778 @code{code:root_dir/0} function).  The result of this test is cached if
7779 caching is enabled when running @command{configure}.
7780 @end defmac
7782 @defmac AC_ERLANG_SUBST_LIB_DIR
7783 @acindex{ERLANG_SUBST_LIB_DIR}
7784 @ovindex ERLANG_LIB_DIR
7786 Set the output variable @code{ERLANG_LIB_DIR} to the path of the library
7787 directory of Erlang/OTP (as returned by Erlang's
7788 @code{code:lib_dir/0} function), which subdirectories each contain an installed
7789 Erlang/OTP library.  The result of this test is cached if caching is enabled
7790 when running @command{configure}.
7791 @end defmac
7793 @defmac AC_ERLANG_CHECK_LIB (@var{library}, @ovar{action-if-found}, @
7794   @ovar{action-if-not-found})
7795 @acindex{ERLANG_CHECK_LIB}
7796 @ovindex ERLANG_LIB_DIR_@var{library}
7797 @ovindex ERLANG_LIB_VER_@var{library}
7799 Test whether the Erlang/OTP library @var{library} is installed by
7800 calling Erlang's @code{code:lib_dir/1} function.  The result of this
7801 test is cached if caching is enabled when running @command{configure}.
7802 @var{action-if-found} is a list of shell commands to run if the library
7803 is installed; @var{action-if-not-found} is a list of shell commands to
7804 run if it is not.  Additionally, if the library is installed, the output
7805 variable @samp{ERLANG_LIB_DIR_@var{library}} is set to the path to the
7806 library installation directory, and the output variable
7807 @samp{ERLANG_LIB_VER_@var{library}} is set to the version number that is
7808 part of the subdirectory name, if it is in the standard form
7809 (@code{@var{library}-@var{version}}).  If the directory name does not
7810 have a version part, @samp{ERLANG_LIB_VER_@var{library}} is set to the
7811 empty string.  If the library is not installed,
7812 @samp{ERLANG_LIB_DIR_@var{library}} and
7813 @samp{ERLANG_LIB_VER_@var{library}} are set to @code{"not found"}.  For
7814 example, to check if library @code{stdlib} is installed:
7816 @example
7817 AC_ERLANG_CHECK_LIB([stdlib],
7818   [echo "stdlib version \"$ERLANG_LIB_VER_stdlib\""
7819    echo "is installed in \"$ERLANG_LIB_DIR_stdlib\""],
7820   [AC_MSG_ERROR([stdlib was not found!])])
7821 @end example
7822 @end defmac
7824 In addition to the above macros, which test installed Erlang libraries, the
7825 following macros determine the paths to the directories into which newly built
7826 Erlang libraries are to be installed:
7828 @defmac AC_ERLANG_SUBST_INSTALL_LIB_DIR
7829 @acindex{ERLANG_SUBST_INSTALL_LIB_DIR}
7830 @ovindex ERLANG_INSTALL_LIB_DIR
7832 Set the @code{ERLANG_INSTALL_LIB_DIR} output variable to the directory into
7833 which every built Erlang library should be installed in a separate
7834 subdirectory.
7835 If this variable is not set in the environment when @command{configure} runs,
7836 its default value is @code{$ERLANG_LIB_DIR}, which value is set by the
7837 @code{AC_ERLANG_SUBST_LIB_DIR} macro.
7838 @end defmac
7840 @defmac AC_ERLANG_SUBST_INSTALL_LIB_SUBDIR (@var{library}, @var{version})
7841 @acindex{ERLANG_SUBST_INSTALL_LIB_SUBDIR}
7842 @ovindex ERLANG_INSTALL_LIB_DIR_@var{library}
7844 Set the @samp{ERLANG_INSTALL_LIB_DIR_@var{library}} output variable to the
7845 directory into which the built Erlang library @var{library} version
7846 @var{version} should be installed.  If this variable is not set in the
7847 environment when @command{configure} runs, its default value is
7848 @samp{$ERLANG_INSTALL_LIB_DIR/@var{library}-@var{version}}, the value of the
7849 @code{ERLANG_INSTALL_LIB_DIR} variable being set by the
7850 @code{AC_ERLANG_SUBST_INSTALL_LIB_DIR} macro.
7851 @end defmac
7857 @c ========================================================= Writing Tests
7859 @node Writing Tests
7860 @chapter Writing Tests
7862 If the existing feature tests don't do something you need, you have to
7863 write new ones.  These macros are the building blocks.  They provide
7864 ways for other macros to check whether various kinds of features are
7865 available and report the results.
7867 This chapter contains some suggestions and some of the reasons why the
7868 existing tests are written the way they are.  You can also learn a lot
7869 about how to write Autoconf tests by looking at the existing ones.  If
7870 something goes wrong in one or more of the Autoconf tests, this
7871 information can help you understand the assumptions behind them, which
7872 might help you figure out how to best solve the problem.
7874 These macros check the output of the compiler system of the current
7875 language (@pxref{Language Choice}).  They do not cache the results of
7876 their tests for future use (@pxref{Caching Results}), because they don't
7877 know enough about the information they are checking for to generate a
7878 cache variable name.  They also do not print any messages, for the same
7879 reason.  The checks for particular kinds of features call these macros
7880 and do cache their results and print messages about what they're
7881 checking for.
7883 When you write a feature test that could be applicable to more than one
7884 software package, the best thing to do is encapsulate it in a new macro.
7885 @xref{Writing Autoconf Macros}, for how to do that.
7887 @menu
7888 * Language Choice::             Selecting which language to use for testing
7889 * Writing Test Programs::       Forging source files for compilers
7890 * Running the Preprocessor::    Detecting preprocessor symbols
7891 * Running the Compiler::        Detecting language or header features
7892 * Running the Linker::          Detecting library features
7893 * Runtime::                     Testing for runtime features
7894 * Systemology::                 A zoology of operating systems
7895 * Multiple Cases::              Tests for several possible values
7896 @end menu
7898 @node Language Choice
7899 @section Language Choice
7900 @cindex Language
7902 Autoconf-generated @command{configure} scripts check for the C compiler and
7903 its features by default.  Packages that use other programming languages
7904 (maybe more than one, e.g., C and C++) need to test features of the
7905 compilers for the respective languages.  The following macros determine
7906 which programming language is used in the subsequent tests in
7907 @file{configure.ac}.
7909 @anchor{AC_LANG}
7910 @defmac AC_LANG (@var{language})
7911 Do compilation tests using the compiler, preprocessor, and file
7912 extensions for the specified @var{language}.
7914 Supported languages are:
7916 @table @samp
7917 @item C
7918 Do compilation tests using @code{CC} and @code{CPP} and use extension
7919 @file{.c} for test programs.  Use compilation flags: @code{CPPFLAGS} with
7920 @code{CPP}, and both @code{CPPFLAGS} and @code{CFLAGS} with @code{CC}.
7922 @item C++
7923 Do compilation tests using @code{CXX} and @code{CXXCPP} and use
7924 extension @file{.C} for test programs.  Use compilation flags:
7925 @code{CPPFLAGS} with @code{CXXCPP}, and both @code{CPPFLAGS} and
7926 @code{CXXFLAGS} with @code{CXX}.
7928 @item Fortran 77
7929 Do compilation tests using @code{F77} and use extension @file{.f} for
7930 test programs.  Use compilation flags: @code{FFLAGS}.
7932 @item Fortran
7933 Do compilation tests using @code{FC} and use extension @file{.f} (or
7934 whatever has been set by @code{AC_FC_SRCEXT}) for test programs.  Use
7935 compilation flags: @code{FCFLAGS}.
7937 @item Erlang
7938 @ovindex ERLC
7939 @ovindex ERL
7940 @ovindex ERLCFLAGS
7941 Compile and execute tests using @code{ERLC} and @code{ERL} and use extension
7942 @file{.erl} for test Erlang modules.  Use compilation flags: @code{ERLCFLAGS}.
7944 @item Objective C
7945 Do compilation tests using @code{OBJC} and @code{OBJCPP} and use
7946 extension @file{.m} for test programs.  Use compilation flags:
7947 @code{CPPFLAGS} with @code{OBJCPP}, and both @code{CPPFLAGS} and
7948 @code{OBJCFLAGS} with @code{OBJC}.
7949 @end table
7950 @end defmac
7952 @anchor{AC_LANG_PUSH}
7953 @defmac AC_LANG_PUSH (@var{language})
7954 @acindex{LANG_PUSH}
7955 Remember the current language (as set by @code{AC_LANG}) on a stack, and
7956 then select the @var{language}.  Use this macro and @code{AC_LANG_POP}
7957 in macros that need to temporarily switch to a particular language.
7958 @end defmac
7960 @defmac AC_LANG_POP (@ovar{language})
7961 @acindex{LANG_POP}
7962 Select the language that is saved on the top of the stack, as set by
7963 @code{AC_LANG_PUSH}, and remove it from the stack.
7965 If given, @var{language} specifies the language we just @emph{quit}.  It
7966 is a good idea to specify it when it's known (which should be the
7967 case@dots{}), since Autoconf detects inconsistencies.
7969 @example
7970 AC_LANG_PUSH([Fortran 77])
7971 # Perform some tests on Fortran 77.
7972 # @dots{}
7973 AC_LANG_POP([Fortran 77])
7974 @end example
7975 @end defmac
7977 @defmac AC_LANG_ASSERT (@var{language})
7978 @acindex{LANG_ASSERT} Check statically that the current language is
7979 @var{language}.  You should use this in your language specific macros
7980 to avoid that they be called with an inappropriate language.
7982 This macro runs only at @command{autoconf} time, and incurs no cost at
7983 @command{configure} time.  Sadly enough and because Autoconf is a two
7984 layer language @footnote{Because M4 is not aware of Sh code,
7985 especially conditionals, some optimizations that look nice statically
7986 may produce incorrect results at runtime.}, the macros
7987 @code{AC_LANG_PUSH} and @code{AC_LANG_POP} cannot be ``optimizing'',
7988 therefore as much as possible you ought to avoid using them to wrap
7989 your code, rather, require from the user to run the macro with a
7990 correct current language, and check it with @code{AC_LANG_ASSERT}.
7991 And anyway, that may help the user understand she is running a Fortran
7992 macro while expecting a result about her Fortran 77 compiler@enddots{}
7993 @end defmac
7996 @defmac AC_REQUIRE_CPP
7997 @acindex{REQUIRE_CPP}
7998 Ensure that whichever preprocessor would currently be used for tests has
7999 been found.  Calls @code{AC_REQUIRE} (@pxref{Prerequisite Macros}) with an
8000 argument of either @code{AC_PROG_CPP} or @code{AC_PROG_CXXCPP},
8001 depending on which language is current.
8002 @end defmac
8005 @node Writing Test Programs
8006 @section Writing Test Programs
8008 Autoconf tests follow a common scheme: feed some program with some
8009 input, and most of the time, feed a compiler with some source file.
8010 This section is dedicated to these source samples.
8012 @menu
8013 * Guidelines::                  General rules for writing test programs
8014 * Test Functions::              Avoiding pitfalls in test programs
8015 * Generating Sources::          Source program boilerplate
8016 @end menu
8018 @node Guidelines
8019 @subsection Guidelines for Test Programs
8021 The most important rule to follow when writing testing samples is:
8023 @center @emph{Look for realism.}
8025 This motto means that testing samples must be written with the same
8026 strictness as real programs are written.  In particular, you should
8027 avoid ``shortcuts'' and simplifications.
8029 Don't just play with the preprocessor if you want to prepare a
8030 compilation.  For instance, using @command{cpp} to check whether a header is
8031 functional might let your @command{configure} accept a header which
8032 causes some @emph{compiler} error.  Do not hesitate to check a header with
8033 other headers included before, especially required headers.
8035 Make sure the symbols you use are properly defined, i.e., refrain for
8036 simply declaring a function yourself instead of including the proper
8037 header.
8039 Test programs should not write to standard output.  They
8040 should exit with status 0 if the test succeeds, and with status 1
8041 otherwise, so that success
8042 can be distinguished easily from a core dump or other failure;
8043 segmentation violations and other failures produce a nonzero exit
8044 status.  Unless you arrange for @code{exit} to be declared, test
8045 programs should @code{return}, not @code{exit}, from @code{main},
8046 because on many systems @code{exit} is not declared by default.
8048 Test programs can use @code{#if} or @code{#ifdef} to check the values of
8049 preprocessor macros defined by tests that have already run.  For
8050 example, if you call @code{AC_HEADER_STDBOOL}, then later on in
8051 @file{configure.ac} you can have a test program that includes
8052 @file{stdbool.h} conditionally:
8054 @example
8055 @group
8056 #ifdef HAVE_STDBOOL_H
8057 # include <stdbool.h>
8058 #endif
8059 @end group
8060 @end example
8062 Both @code{#if HAVE_STDBOOL_H} and @code{#ifdef HAVE_STDBOOL_H} will
8063 work with any standard C compiler.  Some developers prefer @code{#if}
8064 because it is easier to read, while others prefer @code{#ifdef} because
8065 it avoids diagnostics with picky compilers like @acronym{GCC} with the
8066 @option{-Wundef} option.
8068 If a test program needs to use or create a data file, give it a name
8069 that starts with @file{conftest}, such as @file{conftest.data}.  The
8070 @command{configure} script cleans up by running @samp{rm -f -r conftest*}
8071 after running test programs and if the script is interrupted.
8073 @node Test Functions
8074 @subsection Test Functions
8076 These days it's safe to assume support for function prototypes
8077 (introduced in C89).
8079 Functions that test programs declare should also be conditionalized for
8080 C++, which requires @samp{extern "C"} prototypes.  Make sure to not
8081 include any header files containing clashing prototypes.
8083 @example
8084 #ifdef __cplusplus
8085 extern "C"
8086 #endif
8087 void *valloc (size_t);
8088 @end example
8090 If a test program calls a function with invalid parameters (just to see
8091 whether it exists), organize the program to ensure that it never invokes
8092 that function.  You can do this by calling it in another function that is
8093 never invoked.  You can't do it by putting it after a call to
8094 @code{exit}, because @acronym{GCC} version 2 knows that @code{exit}
8095 never returns
8096 and optimizes out any code that follows it in the same block.
8098 If you include any header files, be sure to call the functions
8099 relevant to them with the correct number of arguments, even if they are
8100 just 0, to avoid compilation errors due to prototypes.  @acronym{GCC}
8101 version 2
8102 has internal prototypes for several functions that it automatically
8103 inlines; for example, @code{memcpy}.  To avoid errors when checking for
8104 them, either pass them the correct number of arguments or redeclare them
8105 with a different return type (such as @code{char}).
8108 @node Generating Sources
8109 @subsection Generating Sources
8111 Autoconf provides a set of macros that can be used to generate test
8112 source files.  They are written to be language generic, i.e., they
8113 actually depend on the current language (@pxref{Language Choice}) to
8114 ``format'' the output properly.
8117 @defmac AC_LANG_CONFTEST (@var{source})
8118 @acindex{LANG_CONFTEST}
8119 Save the @var{source} text in the current test source file:
8120 @file{conftest.@var{extension}} where the @var{extension} depends on the
8121 current language.
8123 Note that the @var{source} is evaluated exactly once, like regular
8124 Autoconf macro arguments, and therefore (i) you may pass a macro
8125 invocation, (ii) if not, be sure to double quote if needed.
8126 @end defmac
8128 @defmac AC_LANG_SOURCE (@var{source})
8129 @acindex{LANG_SOURCE}
8130 Expands into the @var{source}, with the definition of
8131 all the @code{AC_DEFINE} performed so far.
8132 @end defmac
8134 For instance executing (observe the double quotation!):
8136 @example
8137 AC_INIT([Hello], [1.0], [bug-hello@@example.org])
8138 AC_DEFINE([HELLO_WORLD], ["Hello, World\n"],
8139   [Greetings string.])
8140 AC_LANG(C)
8141 AC_LANG_CONFTEST(
8142    [AC_LANG_SOURCE([[const char hw[] = "Hello, World\n";]])])
8143 gcc -E -dD -o - conftest.c
8144 @end example
8146 @noindent
8147 results in:
8149 @example
8150 @dots{}
8151 # 1 "conftest.c"
8153 #define PACKAGE_NAME "Hello"
8154 #define PACKAGE_TARNAME "hello"
8155 #define PACKAGE_VERSION "1.0"
8156 #define PACKAGE_STRING "Hello 1.0"
8157 #define PACKAGE_BUGREPORT "bug-hello@@example.org"
8158 #define HELLO_WORLD "Hello, World\n"
8160 const char hw[] = "Hello, World\n";
8161 @end example
8163 When the test language is Fortran or Erlang, the @code{AC_DEFINE} definitions
8164 are not automatically translated into constants in the source code by this
8165 macro.
8167 @defmac AC_LANG_PROGRAM (@var{prologue}, @var{body})
8168 @acindex{LANG_PROGRAM}
8169 Expands into a source file which consists of the @var{prologue}, and
8170 then @var{body} as body of the main function (e.g., @code{main} in
8171 C).  Since it uses @code{AC_LANG_SOURCE}, the features of the latter are
8172 available.
8173 @end defmac
8175 For instance:
8177 @example
8178 AC_INIT([Hello], [1.0], [bug-hello@@example.org])
8179 AC_DEFINE([HELLO_WORLD], ["Hello, World\n"],
8180   [Greetings string.])
8181 AC_LANG_CONFTEST(
8182 [AC_LANG_PROGRAM([[const char hw[] = "Hello, World\n";]],
8183                  [[fputs (hw, stdout);]])])
8184 gcc -E -dD -o - conftest.c
8185 @end example
8187 @noindent
8188 results in:
8190 @example
8191 @dots{}
8192 # 1 "conftest.c"
8194 #define PACKAGE_NAME "Hello"
8195 #define PACKAGE_TARNAME "hello"
8196 #define PACKAGE_VERSION "1.0"
8197 #define PACKAGE_STRING "Hello 1.0"
8198 #define PACKAGE_BUGREPORT "bug-hello@@example.org"
8199 #define HELLO_WORLD "Hello, World\n"
8201 const char hw[] = "Hello, World\n";
8203 main ()
8205 fputs (hw, stdout);
8206   ;
8207   return 0;
8209 @end example
8211 In Erlang tests, the created source file is that of an Erlang module called
8212 @code{conftest} (@file{conftest.erl}).  This module defines and exports
8213 at least
8214 one @code{start/0} function, which is called to perform the test.  The
8215 @var{prologue} is optional code that is inserted between the module header and
8216 the @code{start/0} function definition.  @var{body} is the body of the
8217 @code{start/0} function without the final period (@pxref{Runtime}, about
8218 constraints on this function's behavior).
8220 For instance:
8222 @example
8223 AC_INIT([Hello], [1.0], [bug-hello@@example.org])
8224 AC_LANG(Erlang)
8225 AC_LANG_CONFTEST(
8226 [AC_LANG_PROGRAM([[-define(HELLO_WORLD, "Hello, world!").]],
8227                  [[io:format("~s~n", [?HELLO_WORLD])]])])
8228 cat conftest.erl
8229 @end example
8231 @noindent
8232 results in:
8234 @example
8235 -module(conftest).
8236 -export([start/0]).
8237 -define(HELLO_WORLD, "Hello, world!").
8238 start() ->
8239 io:format("~s~n", [?HELLO_WORLD])
8241 @end example
8243 @defmac AC_LANG_CALL (@var{prologue}, @var{function})
8244 @acindex{LANG_CALL}
8245 Expands into a source file which consists of the @var{prologue}, and
8246 then a call to the @var{function} as body of the main function (e.g.,
8247 @code{main} in C).  Since it uses @code{AC_LANG_PROGRAM}, the feature
8248 of the latter are available.
8250 This function will probably be replaced in the future by a version
8251 which would enable specifying the arguments.  The use of this macro is
8252 not encouraged, as it violates strongly the typing system.
8254 This macro cannot be used for Erlang tests.
8255 @end defmac
8257 @defmac AC_LANG_FUNC_LINK_TRY (@var{function})
8258 @acindex{LANG_FUNC_LINK_TRY}
8259 Expands into a source file which uses the @var{function} in the body of
8260 the main function (e.g., @code{main} in C).  Since it uses
8261 @code{AC_LANG_PROGRAM}, the features of the latter are available.
8263 As @code{AC_LANG_CALL}, this macro is documented only for completeness.
8264 It is considered to be severely broken, and in the future will be
8265 removed in favor of actual function calls (with properly typed
8266 arguments).
8268 This macro cannot be used for Erlang tests.
8269 @end defmac
8271 @node Running the Preprocessor
8272 @section Running the Preprocessor
8274 Sometimes one might need to run the preprocessor on some source file.
8275 @emph{Usually it is a bad idea}, as you typically need to @emph{compile}
8276 your project, not merely run the preprocessor on it; therefore you
8277 certainly want to run the compiler, not the preprocessor.  Resist the
8278 temptation of following the easiest path.
8280 Nevertheless, if you need to run the preprocessor, then use
8281 @code{AC_PREPROC_IFELSE}.
8283 The macros described in this section cannot be used for tests in Erlang or
8284 Fortran, since those languages require no preprocessor.
8286 @anchor{AC_PREPROC_IFELSE}
8287 @defmac AC_PREPROC_IFELSE (@var{input}, @ovar{action-if-true}, @
8288   @ovar{action-if-false})
8289 @acindex{PREPROC_IFELSE}
8290 Run the preprocessor of the current language (@pxref{Language Choice})
8291 on the @var{input}, run the shell commands @var{action-if-true} on
8292 success, @var{action-if-false} otherwise.  The @var{input} can be made
8293 by @code{AC_LANG_PROGRAM} and friends.
8295 This macro uses @code{CPPFLAGS}, but not @code{CFLAGS}, because
8296 @option{-g}, @option{-O}, etc.@: are not valid options to many C
8297 preprocessors.
8299 It is customary to report unexpected failures with
8300 @code{AC_MSG_FAILURE}.
8301 @end defmac
8303 For instance:
8305 @example
8306 AC_INIT([Hello], [1.0], [bug-hello@@example.org])
8307 AC_DEFINE([HELLO_WORLD], ["Hello, World\n"],
8308   [Greetings string.])
8309 AC_PREPROC_IFELSE(
8310    [AC_LANG_PROGRAM([[const char hw[] = "Hello, World\n";]],
8311                     [[fputs (hw, stdout);]])],
8312    [AC_MSG_RESULT([OK])],
8313    [AC_MSG_FAILURE([unexpected preprocessor failure])])
8314 @end example
8316 @noindent
8317 results in:
8319 @example
8320 checking for gcc... gcc
8321 checking for C compiler default output file name... a.out
8322 checking whether the C compiler works... yes
8323 checking whether we are cross compiling... no
8324 checking for suffix of executables...
8325 checking for suffix of object files... o
8326 checking whether we are using the GNU C compiler... yes
8327 checking whether gcc accepts -g... yes
8328 checking for gcc option to accept ISO C89... none needed
8329 checking how to run the C preprocessor... gcc -E
8331 @end example
8333 @sp 1
8335 The macro @code{AC_TRY_CPP} (@pxref{Obsolete Macros}) used to play the
8336 role of @code{AC_PREPROC_IFELSE}, but double quotes its argument, making
8337 it impossible to use it to elaborate sources.  You are encouraged to
8338 get rid of your old use of the macro @code{AC_TRY_CPP} in favor of
8339 @code{AC_PREPROC_IFELSE}, but, in the first place, are you sure you need
8340 to run the @emph{preprocessor} and not the compiler?
8342 @anchor{AC_EGREP_HEADER}
8343 @defmac AC_EGREP_HEADER (@var{pattern}, @var{header-file}, @
8344   @var{action-if-found}, @ovar{action-if-not-found})
8345 @acindex{EGREP_HEADER}
8346 If the output of running the preprocessor on the system header file
8347 @var{header-file} matches the extended regular expression
8348 @var{pattern}, execute shell commands @var{action-if-found}, otherwise
8349 execute @var{action-if-not-found}.
8350 @end defmac
8352 @anchor{AC_EGREP_CPP}
8353 @defmac AC_EGREP_CPP (@var{pattern}, @var{program}, @
8354   @ovar{action-if-found}, @ovar{action-if-not-found})
8355 @acindex{EGREP_CPP}
8356 @var{program} is the text of a C or C++ program, on which shell
8357 variable, back quote, and backslash substitutions are performed.  If the
8358 output of running the preprocessor on @var{program} matches the
8359 extended regular expression @var{pattern}, execute shell commands
8360 @var{action-if-found}, otherwise execute @var{action-if-not-found}.
8361 @end defmac
8365 @node Running the Compiler
8366 @section Running the Compiler
8368 To check for a syntax feature of the current language's (@pxref{Language
8369 Choice}) compiler, such as whether it recognizes a certain keyword, or
8370 simply to try some library feature, use @code{AC_COMPILE_IFELSE} to try
8371 to compile a small program that uses that feature.
8373 @defmac AC_COMPILE_IFELSE (@var{input}, @ovar{action-if-true}, @
8374   @ovar{action-if-false})
8375 @acindex{COMPILE_IFELSE}
8376 Run the compiler and compilation flags of the current language
8377 (@pxref{Language Choice}) on the @var{input}, run the shell commands
8378 @var{action-if-true} on success, @var{action-if-false} otherwise.  The
8379 @var{input} can be made by @code{AC_LANG_PROGRAM} and friends.
8381 It is customary to report unexpected failures with
8382 @code{AC_MSG_FAILURE}.  This macro does not try to link; use
8383 @code{AC_LINK_IFELSE} if you need to do that (@pxref{Running the
8384 Linker}).
8386 This macro uses @code{AC_REQUIRE} for the compiler associated with the
8387 current language, which means that if the compiler has not yet been
8388 determined, the compiler determination will be made prior to the body of
8389 the outermust @code{AC_DEFUN} macro that triggered this macro to
8390 expand (@pxref{Expanded Before Required}).
8391 @end defmac
8393 @ovindex ERL
8394 For tests in Erlang, the @var{input} must be the source code of a module named
8395 @code{conftest}.  @code{AC_COMPILE_IFELSE} generates a @file{conftest.beam}
8396 file that can be interpreted by the Erlang virtual machine (@code{ERL}).  It is
8397 recommended to use @code{AC_LANG_PROGRAM} to specify the test program,
8398 to ensure that the Erlang module has the right name.
8400 @node Running the Linker
8401 @section Running the Linker
8403 To check for a library, a function, or a global variable, Autoconf
8404 @command{configure} scripts try to compile and link a small program that
8405 uses it.  This is unlike Metaconfig, which by default uses @code{nm} or
8406 @code{ar} on the C library to try to figure out which functions are
8407 available.  Trying to link with the function is usually a more reliable
8408 approach because it avoids dealing with the variations in the options
8409 and output formats of @code{nm} and @code{ar} and in the location of the
8410 standard libraries.  It also allows configuring for cross-compilation or
8411 checking a function's runtime behavior if needed.  On the other hand,
8412 it can be slower than scanning the libraries once, but accuracy is more
8413 important than speed.
8415 @code{AC_LINK_IFELSE} is used to compile test programs to test for
8416 functions and global variables.  It is also used by @code{AC_CHECK_LIB}
8417 to check for libraries (@pxref{Libraries}), by adding the library being
8418 checked for to @code{LIBS} temporarily and trying to link a small
8419 program.
8421 @anchor{AC_LINK_IFELSE}
8422 @defmac AC_LINK_IFELSE (@var{input}, @ovar{action-if-true}, @
8423   @ovar{action-if-false})
8424 @acindex{LINK_IFELSE}
8425 Run the compiler (and compilation flags) and the linker of the current
8426 language (@pxref{Language Choice}) on the @var{input}, run the shell
8427 commands @var{action-if-true} on success, @var{action-if-false}
8428 otherwise.  The @var{input} can be made by @code{AC_LANG_PROGRAM} and
8429 friends.
8431 @code{LDFLAGS} and @code{LIBS} are used for linking, in addition to the
8432 current compilation flags.
8434 It is customary to report unexpected failures with
8435 @code{AC_MSG_FAILURE}.  This macro does not try to execute the program;
8436 use @code{AC_RUN_IFELSE} if you need to do that (@pxref{Runtime}).
8437 @end defmac
8439 The @code{AC_LINK_IFELSE} macro cannot be used for Erlang tests, since Erlang
8440 programs are interpreted and do not require linking.
8444 @node Runtime
8445 @section Checking Runtime Behavior
8447 Sometimes you need to find out how a system performs at runtime, such
8448 as whether a given function has a certain capability or bug.  If you
8449 can, make such checks when your program runs instead of when it is
8450 configured.  You can check for things like the machine's endianness when
8451 your program initializes itself.
8453 If you really need to test for a runtime behavior while configuring,
8454 you can write a test program to determine the result, and compile and
8455 run it using @code{AC_RUN_IFELSE}.  Avoid running test programs if
8456 possible, because this prevents people from configuring your package for
8457 cross-compiling.
8459 @anchor{AC_RUN_IFELSE}
8460 @defmac AC_RUN_IFELSE (@var{input}, @ovar{action-if-true}, @
8461   @ovar{action-if-false}, @ovar{action-if-cross-compiling})
8462 @acindex{RUN_IFELSE}
8463 If @var{program} compiles and links successfully and returns an exit
8464 status of 0 when executed, run shell commands @var{action-if-true}.
8465 Otherwise, run shell commands @var{action-if-false}.
8467 The @var{input} can be made by @code{AC_LANG_PROGRAM} and friends.
8468 @code{LDFLAGS} and @code{LIBS} are used for linking, in addition to the
8469 compilation flags of the current language (@pxref{Language Choice}).
8471 If the compiler being used does not produce executables that run on the
8472 system where @command{configure} is being run, then the test program is
8473 not run.  If the optional shell commands @var{action-if-cross-compiling}
8474 are given, they are run instead.  Otherwise, @command{configure} prints
8475 an error message and exits.
8477 In the @var{action-if-false} section, the failing exit status is
8478 available in the shell variable @samp{$?}.  This exit status might be
8479 that of a failed compilation, or it might be that of a failed program
8480 execution.
8482 It is customary to report unexpected failures with
8483 @code{AC_MSG_FAILURE}.
8484 @end defmac
8486 Try to provide a pessimistic default value to use when cross-compiling
8487 makes runtime tests impossible.  You do this by passing the optional
8488 last argument to @code{AC_RUN_IFELSE}.  @command{autoconf} prints a
8489 warning message when creating @command{configure} each time it
8490 encounters a call to @code{AC_RUN_IFELSE} with no
8491 @var{action-if-cross-compiling} argument given.  You may ignore the
8492 warning, though users cannot configure your package for
8493 cross-compiling.  A few of the macros distributed with Autoconf produce
8494 this warning message.
8496 To configure for cross-compiling you can also choose a value for those
8497 parameters based on the canonical system name (@pxref{Manual
8498 Configuration}).  Alternatively, set up a test results cache file with
8499 the correct values for the host system (@pxref{Caching Results}).
8501 @ovindex cross_compiling
8502 To provide a default for calls of @code{AC_RUN_IFELSE} that are embedded
8503 in other macros, including a few of the ones that come with Autoconf,
8504 you can test whether the shell variable @code{cross_compiling} is set to
8505 @samp{yes}, and then use an alternate method to get the results instead
8506 of calling the macros.
8508 It is also permissible to temporarily assign to @code{cross_compiling}
8509 in order to force tests to behave as though they are in a
8510 cross-compilation environment, particularly since this provides a way to
8511 test your @var{action-if-cross-compiling} even when you are not using a
8512 cross-compiler.
8514 @example
8515 # We temporarily set cross-compile mode to force AC_COMPUTE_INT
8516 # to use the slow link-only method
8517 save_cross_compiling=$cross_compiling
8518 cross_compiling=yes
8519 AC_COMPUTE_INT([@dots{}])
8520 cross_compiling=$save_cross_compiling
8521 @end example
8523 A C or C++ runtime test should be portable.
8524 @xref{Portable C and C++}.
8526 Erlang tests must exit themselves the Erlang VM by calling the @code{halt/1}
8527 function: the given status code is used to determine the success of the test
8528 (status is @code{0}) or its failure (status is different than @code{0}), as
8529 explained above.  It must be noted that data output through the standard output
8530 (e.g., using @code{io:format/2}) may be truncated when halting the VM.
8531 Therefore, if a test must output configuration information, it is recommended
8532 to create and to output data into the temporary file named @file{conftest.out},
8533 using the functions of module @code{file}.  The @code{conftest.out} file is
8534 automatically deleted by the @code{AC_RUN_IFELSE} macro.  For instance, a
8535 simplified implementation of Autoconf's @code{AC_ERLANG_SUBST_LIB_DIR}
8536 macro is:
8538 @example
8539 AC_INIT([LibdirTest], [1.0], [bug-libdirtest@@example.org])
8540 AC_ERLANG_NEED_ERL
8541 AC_LANG(Erlang)
8542 AC_RUN_IFELSE(
8543   [AC_LANG_PROGRAM([], [dnl
8544     file:write_file("conftest.out", code:lib_dir()),
8545     halt(0)])],
8546   [echo "code:lib_dir() returned: `cat conftest.out`"],
8547   [AC_MSG_FAILURE([test Erlang program execution failed])])
8548 @end example
8551 @node Systemology
8552 @section Systemology
8553 @cindex Systemology
8555 This section aims at presenting some systems and pointers to
8556 documentation.  It may help you addressing particular problems reported
8557 by users.
8559 @uref{http://@/www.opengroup.org/@/susv3, Posix-conforming systems} are
8560 derived from the @uref{http://@/www.bell-labs.com/@/history/@/unix/, Unix
8561 operating system}.
8563 The @uref{http://@/bhami.com/@/rosetta.html, Rosetta Stone for Unix}
8564 contains a table correlating the features of various Posix-conforming
8565 systems.  @uref{http://@/www.levenez.com/@/unix/, Unix History} is a
8566 simplified diagram of how many Unix systems were derived from each
8567 other.
8569 @uref{http://@/heirloom.sourceforge.net/, The Heirloom Project}
8570 provides some variants of traditional implementations of Unix utilities.
8572 @table @asis
8573 @item Darwin
8574 @cindex Darwin
8575 Darwin is also known as Mac OS X@.  Beware that the file system @emph{can} be
8576 case-preserving, but case insensitive.  This can cause nasty problems,
8577 since for instance the installation attempt for a package having an
8578 @file{INSTALL} file can result in @samp{make install} report that
8579 nothing was to be done!
8581 That's all dependent on whether the file system is a UFS (case
8582 sensitive) or HFS+ (case preserving).  By default Apple wants you to
8583 install the OS on HFS+.  Unfortunately, there are some pieces of
8584 software which really need to be built on UFS@.  We may want to rebuild
8585 Darwin to have both UFS and HFS+ available (and put the /local/build
8586 tree on the UFS).
8588 @item @acronym{QNX} 4.25
8589 @cindex @acronym{QNX} 4.25
8590 @c FIXME: Please, if you feel like writing something more precise,
8591 @c it'd be great.  In particular, I can't understand the difference with
8592 @c QNX Neutrino.
8593 @acronym{QNX} is a realtime operating system running on Intel architecture
8594 meant to be scalable from the small embedded systems to the hundred
8595 processor super-computer.  It claims to be Posix certified.  More
8596 information is available on the
8597 @uref{http://@/www.qnx.com/, @acronym{QNX} home page}.
8599 @item Tru64
8600 @cindex Tru64
8601 @uref{http://@/h30097.www3.hp.com/@/docs/,
8602 Documentation of several versions of Tru64} is available in different
8603 formats.
8605 @item Unix version 7
8606 @cindex Unix version 7
8607 @cindex V7
8608 Officially this was called the ``Seventh Edition'' of ``the @sc{unix}
8609 time-sharing system'' but we use the more-common name ``Unix version 7''.
8610 Documentation is available in the
8611 @uref{http://@/plan9.bell-labs.com/@/7thEdMan/, Unix Seventh Edition Manual}.
8612 Previous versions of Unix are called ``Unix version 6'', etc., but
8613 they were not as widely used.
8614 @end table
8617 @node Multiple Cases
8618 @section Multiple Cases
8620 Some operations are accomplished in several possible ways, depending on
8621 the OS variant.  Checking for them essentially requires a ``case
8622 statement''.  Autoconf does not directly provide one; however, it is
8623 easy to simulate by using a shell variable to keep track of whether a
8624 way to perform the operation has been found yet.
8626 Here is an example that uses the shell variable @code{fstype} to keep
8627 track of whether the remaining cases need to be checked.  Note that
8628 since the value of @code{fstype} is under our control, we don't have to
8629 use the longer @samp{test "x$fstype" = xno}.
8631 @example
8632 @group
8633 AC_MSG_CHECKING([how to get file system type])
8634 fstype=no
8635 # The order of these tests is important.
8636 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <sys/statvfs.h>
8637 #include <sys/fstyp.h>]])],
8638                   [AC_DEFINE([FSTYPE_STATVFS], [1],
8639                      [Define if statvfs exists.])
8640                    fstype=SVR4])
8641 if test $fstype = no; then
8642   AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <sys/statfs.h>
8643 #include <sys/fstyp.h>]])],
8644                   [AC_DEFINE([FSTYPE_USG_STATFS], [1],
8645                      [Define if USG statfs.])
8646                    fstype=SVR3])
8648 if test $fstype = no; then
8649   AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <sys/statfs.h>
8650 #include <sys/vmount.h>]])]),
8651                   [AC_DEFINE([FSTYPE_AIX_STATFS], [1],
8652                      [Define if AIX statfs.])
8653                    fstype=AIX])
8655 # (more cases omitted here)
8656 AC_MSG_RESULT([$fstype])
8657 @end group
8658 @end example
8660 @c ====================================================== Results of Tests.
8662 @node Results
8663 @chapter Results of Tests
8665 Once @command{configure} has determined whether a feature exists, what can
8666 it do to record that information?  There are four sorts of things it can
8667 do: define a C preprocessor symbol, set a variable in the output files,
8668 save the result in a cache file for future @command{configure} runs, and
8669 print a message letting the user know the result of the test.
8671 @menu
8672 * Defining Symbols::            Defining C preprocessor symbols
8673 * Setting Output Variables::    Replacing variables in output files
8674 * Special Chars in Variables::  Characters to beware of in variables
8675 * Caching Results::             Speeding up subsequent @command{configure} runs
8676 * Printing Messages::           Notifying @command{configure} users
8677 @end menu
8679 @node Defining Symbols
8680 @section Defining C Preprocessor Symbols
8682 A common action to take in response to a feature test is to define a C
8683 preprocessor symbol indicating the results of the test.  That is done by
8684 calling @code{AC_DEFINE} or @code{AC_DEFINE_UNQUOTED}.
8686 By default, @code{AC_OUTPUT} places the symbols defined by these macros
8687 into the output variable @code{DEFS}, which contains an option
8688 @option{-D@var{symbol}=@var{value}} for each symbol defined.  Unlike in
8689 Autoconf version 1, there is no variable @code{DEFS} defined while
8690 @command{configure} is running.  To check whether Autoconf macros have
8691 already defined a certain C preprocessor symbol, test the value of the
8692 appropriate cache variable, as in this example:
8694 @example
8695 AC_CHECK_FUNC([vprintf], [AC_DEFINE([HAVE_VPRINTF], [1],
8696                           [Define if vprintf exists.])])
8697 if test "x$ac_cv_func_vprintf" != xyes; then
8698   AC_CHECK_FUNC([_doprnt], [AC_DEFINE([HAVE_DOPRNT], [1],
8699                             [Define if _doprnt exists.])])
8701 @end example
8703 If @code{AC_CONFIG_HEADERS} has been called, then instead of creating
8704 @code{DEFS}, @code{AC_OUTPUT} creates a header file by substituting the
8705 correct values into @code{#define} statements in a template file.
8706 @xref{Configuration Headers}, for more information about this kind of
8707 output.
8709 @defmac AC_DEFINE (@var{variable}, @var{value}, @ovar{description})
8710 @defmacx AC_DEFINE (@var{variable})
8711 @cvindex @var{variable}
8712 @acindex{DEFINE}
8713 Define @var{variable} to @var{value} (verbatim), by defining a C
8714 preprocessor macro for @var{variable}.  @var{variable} should be a C
8715 identifier, optionally suffixed by a parenthesized argument list to
8716 define a C preprocessor macro with arguments.  The macro argument list,
8717 if present, should be a comma-separated list of C identifiers, possibly
8718 terminated by an ellipsis @samp{...} if C99 syntax is employed.
8719 @var{variable} should not contain comments, white space, trigraphs,
8720 backslash-newlines, universal character names, or non-@acronym{ASCII}
8721 characters.
8723 @var{value} may contain backslash-escaped newlines, which will be
8724 preserved if you use @code{AC_CONFIG_HEADERS} but flattened if passed
8725 via @code{@@DEFS@@} (with no effect on the compilation, since the
8726 preprocessor sees only one line in the first place).  @var{value} should
8727 not contain raw newlines.  If you are not using
8728 @code{AC_CONFIG_HEADERS}, @var{value} should not contain any @samp{#}
8729 characters, as @command{make} tends to eat them.  To use a shell
8730 variable, use @code{AC_DEFINE_UNQUOTED} instead.
8732 @var{description} is only useful if you are using
8733 @code{AC_CONFIG_HEADERS}.  In this case, @var{description} is put into
8734 the generated @file{config.h.in} as the comment before the macro define.
8735 The following example defines the C preprocessor variable
8736 @code{EQUATION} to be the string constant @samp{"$a > $b"}:
8738 @example
8739 AC_DEFINE([EQUATION], ["$a > $b"],
8740   [Equation string.])
8741 @end example
8743 If neither @var{value} nor @var{description} are given, then
8744 @var{value} defaults to 1 instead of to the empty string.  This is for
8745 backwards compatibility with older versions of Autoconf, but this usage
8746 is obsolescent and may be withdrawn in future versions of Autoconf.
8748 If the @var{variable} is a literal string, it is passed to
8749 @code{m4_pattern_allow} (@pxref{Forbidden Patterns}).
8751 If multiple @code{AC_DEFINE} statements are executed for the same
8752 @var{variable} name (not counting any parenthesized argument list),
8753 the last one wins.
8754 @end defmac
8756 @defmac AC_DEFINE_UNQUOTED (@var{variable}, @var{value}, @ovar{description})
8757 @defmacx AC_DEFINE_UNQUOTED (@var{variable})
8758 @acindex{DEFINE_UNQUOTED}
8759 @cvindex @var{variable}
8760 Like @code{AC_DEFINE}, but three shell expansions are
8761 performed---once---on @var{variable} and @var{value}: variable expansion
8762 (@samp{$}), command substitution (@samp{`}), and backslash escaping
8763 (@samp{\}).  Single and double quote characters in the value have no
8764 special meaning.  Use this macro instead of @code{AC_DEFINE} when
8765 @var{variable} or @var{value} is a shell variable.  Examples:
8767 @example
8768 AC_DEFINE_UNQUOTED([config_machfile], ["$machfile"],
8769   [Configuration machine file.])
8770 AC_DEFINE_UNQUOTED([GETGROUPS_T], [$ac_cv_type_getgroups],
8771   [getgroups return type.])
8772 AC_DEFINE_UNQUOTED([$ac_tr_hdr], [1],
8773   [Translated header name.])
8774 @end example
8775 @end defmac
8777 Due to a syntactical bizarreness of the Bourne shell, do not use
8778 semicolons to separate @code{AC_DEFINE} or @code{AC_DEFINE_UNQUOTED}
8779 calls from other macro calls or shell code; that can cause syntax errors
8780 in the resulting @command{configure} script.  Use either blanks or
8781 newlines.  That is, do this:
8783 @example
8784 AC_CHECK_HEADER([elf.h],
8785   [AC_DEFINE([SVR4], [1], [System V Release 4]) LIBS="-lelf $LIBS"])
8786 @end example
8788 @noindent
8789 or this:
8791 @example
8792 AC_CHECK_HEADER([elf.h],
8793   [AC_DEFINE([SVR4], [1], [System V Release 4])
8794    LIBS="-lelf $LIBS"])
8795 @end example
8797 @noindent
8798 instead of this:
8800 @example
8801 AC_CHECK_HEADER([elf.h],
8802   [AC_DEFINE([SVR4], [1], [System V Release 4]); LIBS="-lelf $LIBS"])
8803 @end example
8805 @node Setting Output Variables
8806 @section Setting Output Variables
8807 @cindex Output variables
8809 Another way to record the results of tests is to set @dfn{output
8810 variables}, which are shell variables whose values are substituted into
8811 files that @command{configure} outputs.  The two macros below create new
8812 output variables.  @xref{Preset Output Variables}, for a list of output
8813 variables that are always available.
8815 @defmac AC_SUBST (@var{variable}, @ovar{value})
8816 @acindex{SUBST}
8817 Create an output variable from a shell variable.  Make @code{AC_OUTPUT}
8818 substitute the variable @var{variable} into output files (typically one
8819 or more makefiles).  This means that @code{AC_OUTPUT}
8820 replaces instances of @samp{@@@var{variable}@@} in input files with the
8821 value that the shell variable @var{variable} has when @code{AC_OUTPUT}
8822 is called.  The value can contain any non-@code{NUL} character, including
8823 newline.  If you are using Automake 1.11 or newer, for newlines in values
8824 you might want to consider using @code{AM_SUBST_NOTMAKE} to prevent
8825 @command{automake} from adding a line @code{@var{variable} =
8826 @@@var{variable}@@} to the @file{Makefile.in} files (@pxref{Optional, ,
8827 Automake, automake, Other things Automake recognizes}).
8829 Variable occurrences should not overlap: e.g., an input file should
8830 not contain @samp{@@@var{var1}@@@var{var2}@@} if @var{var1} and @var{var2}
8831 are variable names.
8832 The substituted value is not rescanned for more output variables;
8833 occurrences of @samp{@@@var{variable}@@} in the value are inserted
8834 literally into the output file.  (The algorithm uses the special marker
8835 @code{|#_!!_#|} internally, so neither the substituted value nor the
8836 output file may contain @code{|#_!!_#|}.)
8838 If @var{value} is given, in addition assign it to @var{variable}.
8840 The string @var{variable} is passed to @code{m4_pattern_allow}
8841 (@pxref{Forbidden Patterns}).
8842 @end defmac
8844 @defmac AC_SUBST_FILE (@var{variable})
8845 @acindex{SUBST_FILE}
8846 Another way to create an output variable from a shell variable.  Make
8847 @code{AC_OUTPUT} insert (without substitutions) the contents of the file
8848 named by shell variable @var{variable} into output files.  This means
8849 that @code{AC_OUTPUT} replaces instances of
8850 @samp{@@@var{variable}@@} in output files (such as @file{Makefile.in})
8851 with the contents of the file that the shell variable @var{variable}
8852 names when @code{AC_OUTPUT} is called.  Set the variable to
8853 @file{/dev/null} for cases that do not have a file to insert.
8854 This substitution occurs only when the @samp{@@@var{variable}@@} is on a
8855 line by itself, optionally surrounded by spaces and tabs.  The
8856 substitution replaces the whole line, including the spaces, tabs, and
8857 the terminating newline.
8859 This macro is useful for inserting makefile fragments containing
8860 special dependencies or other @command{make} directives for particular host
8861 or target types into makefiles.  For example, @file{configure.ac}
8862 could contain:
8864 @example
8865 AC_SUBST_FILE([host_frag])
8866 host_frag=$srcdir/conf/sun4.mh
8867 @end example
8869 @noindent
8870 and then a @file{Makefile.in} could contain:
8872 @example
8873 @@host_frag@@
8874 @end example
8876 The string @var{variable} is passed to @code{m4_pattern_allow}
8877 (@pxref{Forbidden Patterns}).
8878 @end defmac
8880 @cindex Precious Variable
8881 @cindex Variable, Precious
8882 Running @command{configure} in varying environments can be extremely
8883 dangerous.  If for instance the user runs @samp{CC=bizarre-cc
8884 ./configure}, then the cache, @file{config.h}, and many other output
8885 files depend upon @command{bizarre-cc} being the C compiler.  If
8886 for some reason the user runs @command{./configure} again, or if it is
8887 run via @samp{./config.status --recheck}, (@xref{Automatic Remaking},
8888 and @pxref{config.status Invocation}), then the configuration can be
8889 inconsistent, composed of results depending upon two different
8890 compilers.
8892 Environment variables that affect this situation, such as @samp{CC}
8893 above, are called @dfn{precious variables}, and can be declared as such
8894 by @code{AC_ARG_VAR}.
8896 @defmac AC_ARG_VAR (@var{variable}, @var{description})
8897 @acindex{ARG_VAR}
8898 Declare @var{variable} is a precious variable, and include its
8899 @var{description} in the variable section of @samp{./configure --help}.
8901 Being precious means that
8902 @itemize @minus
8903 @item
8904 @var{variable} is substituted via @code{AC_SUBST}.
8906 @item
8907 The value of @var{variable} when @command{configure} was launched is
8908 saved in the cache, including if it was not specified on the command
8909 line but via the environment.  Indeed, while @command{configure} can
8910 notice the definition of @code{CC} in @samp{./configure CC=bizarre-cc},
8911 it is impossible to notice it in @samp{CC=bizarre-cc ./configure},
8912 which, unfortunately, is what most users do.
8914 We emphasize that it is the @emph{initial} value of @var{variable} which
8915 is saved, not that found during the execution of @command{configure}.
8916 Indeed, specifying @samp{./configure FOO=foo} and letting
8917 @samp{./configure} guess that @code{FOO} is @code{foo} can be two
8918 different things.
8920 @item
8921 @var{variable} is checked for consistency between two
8922 @command{configure} runs.  For instance:
8924 @example
8925 $ @kbd{./configure --silent --config-cache}
8926 $ @kbd{CC=cc ./configure --silent --config-cache}
8927 configure: error: `CC' was not set in the previous run
8928 configure: error: changes in the environment can compromise \
8929 the build
8930 configure: error: run `make distclean' and/or \
8931 `rm config.cache' and start over
8932 @end example
8934 @noindent
8935 and similarly if the variable is unset, or if its content is changed.
8936 If the content has white space changes only, then the error is degraded
8937 to a warning only, but the old value is reused.
8939 @item
8940 @var{variable} is kept during automatic reconfiguration
8941 (@pxref{config.status Invocation}) as if it had been passed as a command
8942 line argument, including when no cache is used:
8944 @example
8945 $ @kbd{CC=/usr/bin/cc ./configure var=raboof --silent}
8946 $ @kbd{./config.status --recheck}
8947 running CONFIG_SHELL=/bin/sh /bin/sh ./configure var=raboof \
8948   CC=/usr/bin/cc  --no-create --no-recursion
8949 @end example
8950 @end itemize
8951 @end defmac
8953 @node Special Chars in Variables
8954 @section Special Characters in Output Variables
8955 @cindex Output variables, special characters in
8957 Many output variables are intended to be evaluated both by
8958 @command{make} and by the shell.  Some characters are expanded
8959 differently in these two contexts, so to avoid confusion these
8960 variables' values should not contain any of the following characters:
8962 @example
8963 " # $ & ' ( ) * ; < > ? [ \ ^ ` |
8964 @end example
8966 Also, these variables' values should neither contain newlines, nor start
8967 with @samp{~}, nor contain white space or @samp{:} immediately followed
8968 by @samp{~}.  The values can contain nonempty sequences of white space
8969 characters like tabs and spaces, but each such sequence might
8970 arbitrarily be replaced by a single space during substitution.
8972 These restrictions apply both to the values that @command{configure}
8973 computes, and to the values set directly by the user.  For example, the
8974 following invocations of @command{configure} are problematic, since they
8975 attempt to use special characters within @code{CPPFLAGS} and white space
8976 within @code{$(srcdir)}:
8978 @example
8979 CPPFLAGS='-DOUCH="&\"#$*?"' '../My Source/ouch-1.0/configure'
8981 '../My Source/ouch-1.0/configure' CPPFLAGS='-DOUCH="&\"#$*?"'
8982 @end example
8984 @node Caching Results
8985 @section Caching Results
8986 @cindex Cache
8988 To avoid checking for the same features repeatedly in various
8989 @command{configure} scripts (or in repeated runs of one script),
8990 @command{configure} can optionally save the results of many checks in a
8991 @dfn{cache file} (@pxref{Cache Files}).  If a @command{configure} script
8992 runs with caching enabled and finds a cache file, it reads the results
8993 of previous runs from the cache and avoids rerunning those checks.  As a
8994 result, @command{configure} can then run much faster than if it had to
8995 perform all of the checks every time.
8997 @defmac AC_CACHE_VAL (@var{cache-id}, @var{commands-to-set-it})
8998 @acindex{CACHE_VAL}
8999 Ensure that the results of the check identified by @var{cache-id} are
9000 available.  If the results of the check were in the cache file that was
9001 read, and @command{configure} was not given the @option{--quiet} or
9002 @option{--silent} option, print a message saying that the result was
9003 cached; otherwise, run the shell commands @var{commands-to-set-it}.  If
9004 the shell commands are run to determine the value, the value is
9005 saved in the cache file just before @command{configure} creates its output
9006 files.  @xref{Cache Variable Names}, for how to choose the name of the
9007 @var{cache-id} variable.
9009 The @var{commands-to-set-it} @emph{must have no side effects} except for
9010 setting the variable @var{cache-id}, see below.
9011 @end defmac
9013 @defmac AC_CACHE_CHECK (@var{message}, @var{cache-id}, @
9014   @var{commands-to-set-it})
9015 @acindex{CACHE_CHECK}
9016 A wrapper for @code{AC_CACHE_VAL} that takes care of printing the
9017 messages.  This macro provides a convenient shorthand for the most
9018 common way to use these macros.  It calls @code{AC_MSG_CHECKING} for
9019 @var{message}, then @code{AC_CACHE_VAL} with the @var{cache-id} and
9020 @var{commands} arguments, and @code{AC_MSG_RESULT} with @var{cache-id}.
9022 The @var{commands-to-set-it} @emph{must have no side effects} except for
9023 setting the variable @var{cache-id}, see below.
9024 @end defmac
9026 It is common to find buggy macros using @code{AC_CACHE_VAL} or
9027 @code{AC_CACHE_CHECK}, because people are tempted to call
9028 @code{AC_DEFINE} in the @var{commands-to-set-it}.  Instead, the code that
9029 @emph{follows} the call to @code{AC_CACHE_VAL} should call
9030 @code{AC_DEFINE}, by examining the value of the cache variable.  For
9031 instance, the following macro is broken:
9033 @example
9034 @group
9035 AC_DEFUN([AC_SHELL_TRUE],
9036 [AC_CACHE_CHECK([whether true(1) works], [my_cv_shell_true_works],
9037                 [my_cv_shell_true_works=no
9038                  (true) 2>/dev/null && my_cv_shell_true_works=yes
9039                  if test "x$my_cv_shell_true_works" = xyes; then
9040                    AC_DEFINE([TRUE_WORKS], [1],
9041                              [Define if `true(1)' works properly.])
9042                  fi])
9044 @end group
9045 @end example
9047 @noindent
9048 This fails if the cache is enabled: the second time this macro is run,
9049 @code{TRUE_WORKS} @emph{will not be defined}.  The proper implementation
9052 @example
9053 @group
9054 AC_DEFUN([AC_SHELL_TRUE],
9055 [AC_CACHE_CHECK([whether true(1) works], [my_cv_shell_true_works],
9056                 [my_cv_shell_true_works=no
9057                  (true) 2>/dev/null && my_cv_shell_true_works=yes])
9058  if test "x$my_cv_shell_true_works" = xyes; then
9059    AC_DEFINE([TRUE_WORKS], [1],
9060              [Define if `true(1)' works properly.])
9061  fi
9063 @end group
9064 @end example
9066 Also, @var{commands-to-set-it} should not print any messages, for
9067 example with @code{AC_MSG_CHECKING}; do that before calling
9068 @code{AC_CACHE_VAL}, so the messages are printed regardless of whether
9069 the results of the check are retrieved from the cache or determined by
9070 running the shell commands.
9072 @menu
9073 * Cache Variable Names::        Shell variables used in caches
9074 * Cache Files::                 Files @command{configure} uses for caching
9075 * Cache Checkpointing::         Loading and saving the cache file
9076 @end menu
9078 @node Cache Variable Names
9079 @subsection Cache Variable Names
9080 @cindex Cache variable
9082 The names of cache variables should have the following format:
9084 @example
9085 @var{package-prefix}_cv_@var{value-type}_@var{specific-value}_@ovar{additional-options}
9086 @end example
9088 @noindent
9089 for example, @samp{ac_cv_header_stat_broken} or
9090 @samp{ac_cv_prog_gcc_traditional}.  The parts of the variable name are:
9092 @table @asis
9093 @item @var{package-prefix}
9094 An abbreviation for your package or organization; the same prefix you
9095 begin local Autoconf macros with, except lowercase by convention.
9096 For cache values used by the distributed Autoconf macros, this value is
9097 @samp{ac}.
9099 @item @code{_cv_}
9100 Indicates that this shell variable is a cache value.  This string
9101 @emph{must} be present in the variable name, including the leading
9102 underscore.
9104 @item @var{value-type}
9105 A convention for classifying cache values, to produce a rational naming
9106 system.  The values used in Autoconf are listed in @ref{Macro Names}.
9108 @item @var{specific-value}
9109 Which member of the class of cache values this test applies to.
9110 For example, which function (@samp{alloca}), program (@samp{gcc}), or
9111 output variable (@samp{INSTALL}).
9113 @item @var{additional-options}
9114 Any particular behavior of the specific member that this test applies to.
9115 For example, @samp{broken} or @samp{set}.  This part of the name may
9116 be omitted if it does not apply.
9117 @end table
9119 The values assigned to cache variables may not contain newlines.
9120 Usually, their values are Boolean (@samp{yes} or @samp{no}) or the
9121 names of files or functions; so this is not an important restriction.
9123 @node Cache Files
9124 @subsection Cache Files
9126 A cache file is a shell script that caches the results of configure
9127 tests run on one system so they can be shared between configure scripts
9128 and configure runs.  It is not useful on other systems.  If its contents
9129 are invalid for some reason, the user may delete or edit it.
9131 By default, @command{configure} uses no cache file,
9132 to avoid problems caused by accidental
9133 use of stale cache files.
9135 To enable caching, @command{configure} accepts @option{--config-cache} (or
9136 @option{-C}) to cache results in the file @file{config.cache}.
9137 Alternatively, @option{--cache-file=@var{file}} specifies that
9138 @var{file} be the cache file.  The cache file is created if it does not
9139 exist already.  When @command{configure} calls @command{configure} scripts in
9140 subdirectories, it uses the @option{--cache-file} argument so that they
9141 share the same cache.  @xref{Subdirectories}, for information on
9142 configuring subdirectories with the @code{AC_CONFIG_SUBDIRS} macro.
9144 @file{config.status} only pays attention to the cache file if it is
9145 given the @option{--recheck} option, which makes it rerun
9146 @command{configure}.
9148 It is wrong to try to distribute cache files for particular system types.
9149 There is too much room for error in doing that, and too much
9150 administrative overhead in maintaining them.  For any features that
9151 can't be guessed automatically, use the standard method of the canonical
9152 system type and linking files (@pxref{Manual Configuration}).
9154 The site initialization script can specify a site-wide cache file to
9155 use, instead of the usual per-program cache.  In this case, the cache
9156 file gradually accumulates information whenever someone runs a new
9157 @command{configure} script.  (Running @command{configure} merges the new cache
9158 results with the existing cache file.)  This may cause problems,
9159 however, if the system configuration (e.g., the installed libraries or
9160 compilers) changes and the stale cache file is not deleted.
9162 @node Cache Checkpointing
9163 @subsection Cache Checkpointing
9165 If your configure script, or a macro called from @file{configure.ac}, happens
9166 to abort the configure process, it may be useful to checkpoint the cache
9167 a few times at key points using @code{AC_CACHE_SAVE}.  Doing so
9168 reduces the amount of time it takes to rerun the configure script with
9169 (hopefully) the error that caused the previous abort corrected.
9171 @c FIXME: Do we really want to document this guy?
9172 @defmac AC_CACHE_LOAD
9173 @acindex{CACHE_LOAD}
9174 Loads values from existing cache file, or creates a new cache file if a
9175 cache file is not found.  Called automatically from @code{AC_INIT}.
9176 @end defmac
9178 @defmac AC_CACHE_SAVE
9179 @acindex{CACHE_SAVE}
9180 Flushes all cached values to the cache file.  Called automatically from
9181 @code{AC_OUTPUT}, but it can be quite useful to call
9182 @code{AC_CACHE_SAVE} at key points in @file{configure.ac}.
9183 @end defmac
9185 For instance:
9187 @example
9188 @r{ @dots{} AC_INIT, etc. @dots{}}
9189 @group
9190 # Checks for programs.
9191 AC_PROG_CC
9192 AC_PROG_AWK
9193 @r{ @dots{} more program checks @dots{}}
9194 AC_CACHE_SAVE
9195 @end group
9197 @group
9198 # Checks for libraries.
9199 AC_CHECK_LIB([nsl], [gethostbyname])
9200 AC_CHECK_LIB([socket], [connect])
9201 @r{ @dots{} more lib checks @dots{}}
9202 AC_CACHE_SAVE
9203 @end group
9205 @group
9206 # Might abort@dots{}
9207 AM_PATH_GTK([1.0.2], [], [AC_MSG_ERROR([GTK not in path])])
9208 AM_PATH_GTKMM([0.9.5], [], [AC_MSG_ERROR([GTK not in path])])
9209 @end group
9210 @r{ @dots{} AC_OUTPUT, etc. @dots{}}
9211 @end example
9213 @node Printing Messages
9214 @section Printing Messages
9215 @cindex Messages, from @command{configure}
9217 @command{configure} scripts need to give users running them several kinds
9218 of information.  The following macros print messages in ways appropriate
9219 for each kind.  The arguments to all of them get enclosed in shell
9220 double quotes, so the shell performs variable and back-quote
9221 substitution on them.
9223 These macros are all wrappers around the @command{echo} shell command.
9224 They direct output to the appropriate file descriptor (@pxref{File
9225 Descriptor Macros}).
9226 @command{configure} scripts should rarely need to run @command{echo} directly
9227 to print messages for the user.  Using these macros makes it easy to
9228 change how and when each kind of message is printed; such changes need
9229 only be made to the macro definitions and all the callers change
9230 automatically.
9232 To diagnose static issues, i.e., when @command{autoconf} is run, see
9233 @ref{Diagnostic Macros}.
9235 @defmac AC_MSG_CHECKING (@var{feature-description})
9236 @acindex{MSG_CHECKING}
9237 Notify the user that @command{configure} is checking for a particular
9238 feature.  This macro prints a message that starts with @samp{checking }
9239 and ends with @samp{...} and no newline.  It must be followed by a call
9240 to @code{AC_MSG_RESULT} to print the result of the check and the
9241 newline.  The @var{feature-description} should be something like
9242 @samp{whether the Fortran compiler accepts C++ comments} or @samp{for
9243 c89}.
9245 This macro prints nothing if @command{configure} is run with the
9246 @option{--quiet} or @option{--silent} option.
9247 @end defmac
9249 @anchor{AC_MSG_RESULT}
9250 @defmac AC_MSG_RESULT (@var{result-description})
9251 @acindex{MSG_RESULT}
9252 Notify the user of the results of a check.  @var{result-description} is
9253 almost always the value of the cache variable for the check, typically
9254 @samp{yes}, @samp{no}, or a file name.  This macro should follow a call
9255 to @code{AC_MSG_CHECKING}, and the @var{result-description} should be
9256 the completion of the message printed by the call to
9257 @code{AC_MSG_CHECKING}.
9259 This macro prints nothing if @command{configure} is run with the
9260 @option{--quiet} or @option{--silent} option.
9261 @end defmac
9263 @anchor{AC_MSG_NOTICE}
9264 @defmac AC_MSG_NOTICE (@var{message})
9265 @acindex{MSG_NOTICE}
9266 Deliver the @var{message} to the user.  It is useful mainly to print a
9267 general description of the overall purpose of a group of feature checks,
9268 e.g.,
9270 @example
9271 AC_MSG_NOTICE([checking if stack overflow is detectable])
9272 @end example
9274 This macro prints nothing if @command{configure} is run with the
9275 @option{--quiet} or @option{--silent} option.
9276 @end defmac
9278 @anchor{AC_MSG_ERROR}
9279 @defmac AC_MSG_ERROR (@var{error-description}, @dvar{exit-status, $?/1})
9280 @acindex{MSG_ERROR}
9281 Notify the user of an error that prevents @command{configure} from
9282 completing.  This macro prints an error message to the standard error
9283 output and exits @command{configure} with @var{exit-status} (@samp{$?}
9284 by default, except that @samp{0} is converted to @samp{1}).
9285 @var{error-description} should be something like @samp{invalid value
9286 $HOME for \$HOME}.
9288 The @var{error-description} should start with a lower-case letter, and
9289 ``cannot'' is preferred to ``can't''.
9290 @end defmac
9292 @defmac AC_MSG_FAILURE (@var{error-description}, @ovar{exit-status})
9293 @acindex{MSG_FAILURE}
9294 This @code{AC_MSG_ERROR} wrapper notifies the user of an error that
9295 prevents @command{configure} from completing @emph{and} that additional
9296 details are provided in @file{config.log}.  This is typically used when
9297 abnormal results are found during a compilation.
9298 @end defmac
9300 @anchor{AC_MSG_WARN}
9301 @defmac AC_MSG_WARN (@var{problem-description})
9302 @acindex{MSG_WARN}
9303 Notify the @command{configure} user of a possible problem.  This macro
9304 prints the message to the standard error output; @command{configure}
9305 continues running afterward, so macros that call @code{AC_MSG_WARN} should
9306 provide a default (back-up) behavior for the situations they warn about.
9307 @var{problem-description} should be something like @samp{ln -s seems to
9308 make hard links}.
9309 @end defmac
9313 @c ====================================================== Programming in M4.
9315 @node Programming in M4
9316 @chapter Programming in M4
9317 @cindex M4
9319 Autoconf is written on top of two layers: @dfn{M4sugar}, which provides
9320 convenient macros for pure M4 programming, and @dfn{M4sh}, which
9321 provides macros dedicated to shell script generation.
9323 As of this version of Autoconf, these two layers still contain
9324 experimental macros, whose interface might change in the future.  As a
9325 matter of fact, @emph{anything that is not documented must not be used}.
9327 @menu
9328 * M4 Quotation::                Protecting macros from unwanted expansion
9329 * Using autom4te::              The Autoconf executables backbone
9330 * Programming in M4sugar::      Convenient pure M4 macros
9331 @end menu
9333 @node M4 Quotation
9334 @section M4 Quotation
9335 @cindex M4 quotation
9336 @cindex quotation
9338 The most common problem with existing macros is an improper quotation.
9339 This section, which users of Autoconf can skip, but which macro writers
9340 @emph{must} read, first justifies the quotation scheme that was chosen
9341 for Autoconf and then ends with a rule of thumb.  Understanding the
9342 former helps one to follow the latter.
9344 @menu
9345 * Active Characters::           Characters that change the behavior of M4
9346 * One Macro Call::              Quotation and one macro call
9347 * Quoting and Parameters::      M4 vs. shell parameters
9348 * Quotation and Nested Macros::  Macros calling macros
9349 * Changequote is Evil::         Worse than INTERCAL: M4 + changequote
9350 * Quadrigraphs::                Another way to escape special characters
9351 * Balancing Parentheses::       Dealing with unbalanced parentheses
9352 * Quotation Rule Of Thumb::     One parenthesis, one quote
9353 @end menu
9355 @node Active Characters
9356 @subsection Active Characters
9358 To fully understand where proper quotation is important, you first need
9359 to know what the special characters are in Autoconf: @samp{#} introduces
9360 a comment inside which no macro expansion is performed, @samp{,}
9361 separates arguments, @samp{[} and @samp{]} are the quotes themselves,
9362 @samp{(} and @samp{)} (which M4 tries to match by pairs), and finally
9363 @samp{$} inside a macro definition.
9365 In order to understand the delicate case of macro calls, we first have
9366 to present some obvious failures.  Below they are ``obvious-ified'',
9367 but when you find them in real life, they are usually in disguise.
9369 Comments, introduced by a hash and running up to the newline, are opaque
9370 tokens to the top level: active characters are turned off, and there is
9371 no macro expansion:
9373 @example
9374 # define([def], ine)
9375 @result{}# define([def], ine)
9376 @end example
9378 Each time there can be a macro expansion, there is a quotation
9379 expansion, i.e., one level of quotes is stripped:
9381 @example
9382 int tab[10];
9383 @result{}int tab10;
9384 [int tab[10];]
9385 @result{}int tab[10];
9386 @end example
9388 Without this in mind, the reader might try hopelessly to use her macro
9389 @code{array}:
9391 @example
9392 define([array], [int tab[10];])
9393 array
9394 @result{}int tab10;
9395 [array]
9396 @result{}array
9397 @end example
9399 @noindent
9400 How can you correctly output the intended results@footnote{Using
9401 @code{defn}.}?
9404 @node One Macro Call
9405 @subsection One Macro Call
9407 Let's proceed on the interaction between active characters and macros
9408 with this small macro, which just returns its first argument:
9410 @example
9411 define([car], [$1])
9412 @end example
9414 @noindent
9415 The two pairs of quotes above are not part of the arguments of
9416 @code{define}; rather, they are understood by the top level when it
9417 tries to find the arguments of @code{define}.  Therefore, assuming
9418 @code{car} is not already defined, it is equivalent to write:
9420 @example
9421 define(car, $1)
9422 @end example
9424 @noindent
9425 But, while it is acceptable for a @file{configure.ac} to avoid unnecessary
9426 quotes, it is bad practice for Autoconf macros which must both be more
9427 robust and also advocate perfect style.
9429 At the top level, there are only two possibilities: either you
9430 quote or you don't:
9432 @example
9433 car(foo, bar, baz)
9434 @result{}foo
9435 [car(foo, bar, baz)]
9436 @result{}car(foo, bar, baz)
9437 @end example
9439 Let's pay attention to the special characters:
9441 @example
9442 car(#)
9443 @error{}EOF in argument list
9444 @end example
9446 The closing parenthesis is hidden in the comment; with a hypothetical
9447 quoting, the top level understood it this way:
9449 @example
9450 car([#)]
9451 @end example
9453 @noindent
9454 Proper quotation, of course, fixes the problem:
9456 @example
9457 car([#])
9458 @result{}#
9459 @end example
9461 Here are more examples:
9463 @example
9464 car(foo, bar)
9465 @result{}foo
9466 car([foo, bar])
9467 @result{}foo, bar
9468 car((foo, bar))
9469 @result{}(foo, bar)
9470 car([(foo], [bar)])
9471 @result{}(foo
9472 define([a], [b])
9473 @result{}
9474 car(a)
9475 @result{}b
9476 car([a])
9477 @result{}b
9478 car([[a]])
9479 @result{}a
9480 car([[[a]]])
9481 @result{}[a]
9482 @end example
9484 @node Quoting and Parameters
9485 @subsection Quoting and Parameters
9487 When M4 encounters @samp{$} within a macro definition, followed
9488 immediately by a character it recognizes (@samp{0}@dots{}@samp{9},
9489 @samp{#}, @samp{@@}, or @samp{*}), it will perform M4 parameter
9490 expansion.  This happens regardless of how many layers of quotes the
9491 parameter expansion is nested within, or even if it occurs in text that
9492 will be rescanned as a comment.
9494 @example
9495 define([none], [$1])
9496 @result{}
9497 define([one], [[$1]])
9498 @result{}
9499 define([two], [[[$1]]])
9500 @result{}
9501 define([comment], [# $1])
9502 @result{}
9503 define([active], [ACTIVE])
9504 @result{}
9505 none([active])
9506 @result{}ACTIVE
9507 one([active])
9508 @result{}active
9509 two([active])
9510 @result{}[active]
9511 comment([active])
9512 @result{}# active
9513 @end example
9515 On the other hand, since autoconf generates shell code, you often want
9516 to output shell variable expansion, rather than performing M4 parameter
9517 expansion.  To do this, you must use M4 quoting to separate the @samp{$}
9518 from the next character in the definition of your macro.  If the macro
9519 definition occurs in single-quoted text, then insert another level of
9520 quoting; if the usage is already inside a double-quoted string, then
9521 split it into concatenated strings.
9523 @example
9524 define([single], [a single-quoted $[]1 definition])
9525 @result{}
9526 define([double], [[a double-quoted $][1 definition]])
9527 @result{}
9528 single
9529 @result{}a single-quoted $1 definition
9530 double
9531 @result{}a double-quoted $1 definition
9532 @end example
9534 Posix states that M4 implementations are free to provide implementation
9535 extensions when @samp{$@{} is encountered in a macro definition.
9536 Autoconf reserves the longer sequence @samp{$@{@{} for use with planned
9537 extensions that will be available in the future @acronym{GNU} M4 2.0,
9538 but guarantees that all other instances of @samp{$@{} will be output
9539 literally.  Therefore, this idiom can also be used to output shell code
9540 parameter references:
9542 @example
9543 define([first], [$@{1@}])first
9544 @result{}$@{1@}
9545 @end example
9547 Posix also states that @samp{$11} should expand to the first parameter
9548 concatenated with a literal @samp{1}, although some versions of
9549 @acronym{GNU} M4 expand the eleventh parameter instead.  For
9550 portability, you should only use single-digit M4 parameter expansion.
9552 With this in mind, we can explore the cases where macros invoke
9553 macros@enddots{}
9555 @node Quotation and Nested Macros
9556 @subsection Quotation and Nested Macros
9558 The examples below use the following macros:
9560 @example
9561 define([car], [$1])
9562 define([active], [ACT, IVE])
9563 define([array], [int tab[10]])
9564 @end example
9566 Each additional embedded macro call introduces other possible
9567 interesting quotations:
9569 @example
9570 car(active)
9571 @result{}ACT
9572 car([active])
9573 @result{}ACT, IVE
9574 car([[active]])
9575 @result{}active
9576 @end example
9578 In the first case, the top level looks for the arguments of @code{car},
9579 and finds @samp{active}.  Because M4 evaluates its arguments
9580 before applying the macro, @samp{active} is expanded, which results in:
9582 @example
9583 car(ACT, IVE)
9584 @result{}ACT
9585 @end example
9587 @noindent
9588 In the second case, the top level gives @samp{active} as first and only
9589 argument of @code{car}, which results in:
9591 @example
9592 active
9593 @result{}ACT, IVE
9594 @end example
9596 @noindent
9597 i.e., the argument is evaluated @emph{after} the macro that invokes it.
9598 In the third case, @code{car} receives @samp{[active]}, which results in:
9600 @example
9601 [active]
9602 @result{}active
9603 @end example
9605 @noindent
9606 exactly as we already saw above.
9608 The example above, applied to a more realistic example, gives:
9610 @example
9611 car(int tab[10];)
9612 @result{}int tab10;
9613 car([int tab[10];])
9614 @result{}int tab10;
9615 car([[int tab[10];]])
9616 @result{}int tab[10];
9617 @end example
9619 @noindent
9620 Huh?  The first case is easily understood, but why is the second wrong,
9621 and the third right?  To understand that, you must know that after
9622 M4 expands a macro, the resulting text is immediately subjected
9623 to macro expansion and quote removal.  This means that the quote removal
9624 occurs twice---first before the argument is passed to the @code{car}
9625 macro, and second after the @code{car} macro expands to the first
9626 argument.
9628 As the author of the Autoconf macro @code{car}, you then consider it to
9629 be incorrect that your users have to double-quote the arguments of
9630 @code{car}, so you ``fix'' your macro.  Let's call it @code{qar} for
9631 quoted car:
9633 @example
9634 define([qar], [[$1]])
9635 @end example
9637 @noindent
9638 and check that @code{qar} is properly fixed:
9640 @example
9641 qar([int tab[10];])
9642 @result{}int tab[10];
9643 @end example
9645 @noindent
9646 Ahhh!  That's much better.
9648 But note what you've done: now that the result of @code{qar} is always
9649 a literal string, the only time a user can use nested macros is if she
9650 relies on an @emph{unquoted} macro call:
9652 @example
9653 qar(active)
9654 @result{}ACT
9655 qar([active])
9656 @result{}active
9657 @end example
9659 @noindent
9660 leaving no way for her to reproduce what she used to do with @code{car}:
9662 @example
9663 car([active])
9664 @result{}ACT, IVE
9665 @end example
9667 @noindent
9668 Worse yet: she wants to use a macro that produces a set of @code{cpp}
9669 macros:
9671 @example
9672 define([my_includes], [#include <stdio.h>])
9673 car([my_includes])
9674 @result{}#include <stdio.h>
9675 qar(my_includes)
9676 @error{}EOF in argument list
9677 @end example
9679 This macro, @code{qar}, because it double quotes its arguments, forces
9680 its users to leave their macro calls unquoted, which is dangerous.
9681 Commas and other active symbols are interpreted by M4 before
9682 they are given to the macro, often not in the way the users expect.
9683 Also, because @code{qar} behaves differently from the other macros,
9684 it's an exception that should be avoided in Autoconf.
9686 @node Changequote is Evil
9687 @subsection @code{changequote} is Evil
9688 @cindex @code{changequote}
9690 The temptation is often high to bypass proper quotation, in particular
9691 when it's late at night.  Then, many experienced Autoconf hackers
9692 finally surrender to the dark side of the force and use the ultimate
9693 weapon: @code{changequote}.
9695 The M4 builtin @code{changequote} belongs to a set of primitives that
9696 allow one to adjust the syntax of the language to adjust it to one's
9697 needs.  For instance, by default M4 uses @samp{`} and @samp{'} as
9698 quotes, but in the context of shell programming (and actually of most
9699 programming languages), that's about the worst choice one can make:
9700 because of strings and back-quoted expressions in shell code (such as
9701 @samp{'this'} and @samp{`that`}), and because of literal characters in usual
9702 programming languages (as in @samp{'0'}), there are many unbalanced
9703 @samp{`} and @samp{'}.  Proper M4 quotation then becomes a nightmare, if
9704 not impossible.  In order to make M4 useful in such a context, its
9705 designers have equipped it with @code{changequote}, which makes it
9706 possible to choose another pair of quotes.  M4sugar, M4sh, Autoconf, and
9707 Autotest all have chosen to use @samp{[} and @samp{]}.  Not especially
9708 because they are unlikely characters, but @emph{because they are
9709 characters unlikely to be unbalanced}.
9711 There are other magic primitives, such as @code{changecom} to specify
9712 what syntactic forms are comments (it is common to see
9713 @samp{changecom(<!--, -->)} when M4 is used to produce HTML pages),
9714 @code{changeword} and @code{changesyntax} to change other syntactic
9715 details (such as the character to denote the @var{n}th argument, @samp{$} by
9716 default, the parentheses around arguments, etc.).
9718 These primitives are really meant to make M4 more useful for specific
9719 domains: they should be considered like command line options:
9720 @option{--quotes}, @option{--comments}, @option{--words}, and
9721 @option{--syntax}.  Nevertheless, they are implemented as M4 builtins, as
9722 it makes M4 libraries self contained (no need for additional options).
9724 There lies the problem@enddots{}
9726 @sp 1
9728 The problem is that it is then tempting to use them in the middle of an
9729 M4 script, as opposed to its initialization.  This, if not carefully
9730 thought out, can lead to disastrous effects: @emph{you are changing the
9731 language in the middle of the execution}.  Changing and restoring the
9732 syntax is often not enough: if you happened to invoke macros in between,
9733 these macros are lost, as the current syntax is probably not
9734 the one they were implemented with.
9736 @c FIXME: I've been looking for a short, real case example, but I
9737 @c lost them all :(
9740 @node Quadrigraphs
9741 @subsection Quadrigraphs
9742 @cindex quadrigraphs
9743 @cindex @samp{@@S|@@}
9744 @cindex @samp{@@&t@@}
9745 @c Info cannot handle `:' in index entries.
9746 @c @cindex @samp{@@<:@@}
9747 @c @cindex @samp{@@:>@@}
9748 @c @cindex @samp{@@%:@@}
9749 @c @cindex @samp{@@@{:@@}
9750 @c @cindex @samp{@@:@}@@}
9752 When writing an Autoconf macro you may occasionally need to generate
9753 special characters that are difficult to express with the standard
9754 Autoconf quoting rules.  For example, you may need to output the regular
9755 expression @samp{[^[]}, which matches any character other than @samp{[}.
9756 This expression contains unbalanced brackets so it cannot be put easily
9757 into an M4 macro.
9759 Additionally, there are a few m4sugar macros (such as @code{m4_split}
9760 and @code{m4_expand}) which internally use special markers in addition
9761 to the regular quoting characters.  If the arguments to these macros
9762 contain the literal strings @samp{-=<@{(} or @samp{)@}>=-}, the macros
9763 might behave incorrectly.
9765 You can work around these problems by using one of the following
9766 @dfn{quadrigraphs}:
9768 @table @samp
9769 @item @@<:@@
9770 @samp{[}
9771 @item @@:>@@
9772 @samp{]}
9773 @item @@S|@@
9774 @samp{$}
9775 @item @@%:@@
9776 @samp{#}
9777 @item @@@{:@@
9778 @samp{(}
9779 @item @@:@}@@
9780 @samp{)}
9781 @item @@&t@@
9782 Expands to nothing.
9783 @end table
9785 Quadrigraphs are replaced at a late stage of the translation process,
9786 after @command{m4} is run, so they do not get in the way of M4 quoting.
9787 For example, the string @samp{^@@<:@@}, independently of its quotation,
9788 appears as @samp{^[} in the output.
9790 The empty quadrigraph can be used:
9792 @itemize @minus
9793 @item to mark trailing spaces explicitly
9795 Trailing spaces are smashed by @command{autom4te}.  This is a feature.
9797 @item to produce quadrigraphs and other strings reserved by m4sugar
9799 For instance @samp{@@<@@&t@@:@@} produces @samp{@@<:@@}.  For a more
9800 contrived example:
9802 @example
9803 m4_define([a], [A])m4_define([b], [B])m4_define([c], [C])dnl
9804 m4_split([a )@}>=- b -=<@{( c])
9805 @result{}[a], [], [B], [], [c]
9806 m4_split([a )@}@@&t@@>=- b -=<@@&t@@@{( c])
9807 @result{}[a], [)@}>=-], [b], [-=<@{(], [c]
9808 @end example
9810 @item to escape @emph{occurrences} of forbidden patterns
9812 For instance you might want to mention @code{AC_FOO} in a comment, while
9813 still being sure that @command{autom4te} still catches unexpanded
9814 @samp{AC_*}.  Then write @samp{AC@@&t@@_FOO}.
9815 @end itemize
9817 The name @samp{@@&t@@} was suggested by Paul Eggert:
9819 @quotation
9820 I should give some credit to the @samp{@@&t@@} pun.  The @samp{&} is my
9821 own invention, but the @samp{t} came from the source code of the
9822 @sc{algol68c} compiler, written by Steve Bourne (of Bourne shell fame),
9823 and which used @samp{mt} to denote the empty string.  In C, it would
9824 have looked like something like:
9826 @example
9827 char const mt[] = "";
9828 @end example
9830 @noindent
9831 but of course the source code was written in Algol 68.
9833 I don't know where he got @samp{mt} from: it could have been his own
9834 invention, and I suppose it could have been a common pun around the
9835 Cambridge University computer lab at the time.
9836 @end quotation
9839 @node Balancing Parentheses
9840 @subsection Dealing with unbalanced parentheses
9841 @cindex balancing parentheses
9842 @cindex parentheses, balancing
9843 @cindex unbalanced parentheses, managing
9845 One of the pitfalls of portable shell programming is that @command{case}
9846 statements require unbalanced parentheses (@pxref{case, , Limitations of
9847 Shell Builtins}).  With syntax highlighting
9848 editors, the presence of unbalanced @samp{)} can interfere with editors
9849 that perform syntax highlighting of macro contents based on finding the
9850 matching @samp{(}.  Another concern is how much editing must be done
9851 when transferring code snippets between shell scripts and macro
9852 definitions.  But most importantly, the presence of unbalanced
9853 parentheses can introduce expansion bugs.
9855 For an example, here is an underquoted attempt to use the macro
9856 @code{my_case}, which happens to expand to a portable @command{case}
9857 statement:
9859 @example
9860 AC_DEFUN([my_case],
9861 [case $file_name in
9862   *.c) echo "C source code";;
9863 esac])
9864 AS_IF(:, my_case)
9865 @end example
9867 @noindent
9868 In the above example, the @code{AS_IF} call underquotes its arguments.
9869 As a result, the unbalanced @samp{)} generated by the premature
9870 expansion of @code{my_case} results in expanding @code{AS_IF} with a
9871 truncated parameter, and the expansion is syntactically invalid:
9873 @example
9874 if :; then
9875   case $file_name in
9876   *.c
9877 fi echo "C source code";;
9878 esac)
9879 @end example
9881 If nothing else, this should emphasize the importance of the quoting
9882 arguments to macro calls.  On the other hand, there are several
9883 variations for defining @code{my_case} to be more robust, even when used
9884 without proper quoting, each with some benefits and some drawbacks.
9886 @itemize @w{}
9887 @item Creative literal shell comment
9888 @example
9889 AC_DEFUN([my_case],
9890 [case $file_name in #(
9891   *.c) echo "C source code";;
9892 esac])
9893 @end example
9894 @noindent
9895 This version provides balanced parentheses to several editors, and can
9896 be copied and pasted into a terminal as is.  Unfortunately, it is still
9897 unbalanced as an Autoconf argument, since @samp{#(} is an M4 comment
9898 that masks the normal properties of @samp{(}.
9900 @item Quadrigraph shell comment
9901 @example
9902 AC_DEFUN([my_case],
9903 [case $file_name in @@%:@@(
9904   *.c) echo "C source code";;
9905 esac])
9906 @end example
9907 @noindent
9908 This version provides balanced parentheses to even more editors, and can
9909 be used as a balanced Autoconf argument.  Unfortunately, it requires
9910 some editing before it can be copied and pasted into a terminal, and the
9911 use of the quadrigraph @samp{@@%:@@} for @samp{#} reduces readability.
9913 @item Quoting just the parenthesis
9914 @example
9915 AC_DEFUN([my_case],
9916 [case $file_name in
9917   *.c[)] echo "C source code";;
9918 esac])
9919 @end example
9920 @noindent
9921 This version quotes the @samp{)}, so that it can be used as a balanced
9922 Autoconf argument.  As written, this is not balanced to an editor, but
9923 it can be coupled with @samp{[#(]} to meet that need, too.  However, it
9924 still requires some edits before it can be copied and pasted into a
9925 terminal.
9927 @item Double-quoting the entire statement
9928 @example
9929 AC_DEFUN([my_case],
9930 [[case $file_name in #(
9931   *.c) echo "C source code";;
9932 esac]])
9933 @end example
9934 @noindent
9935 Since the entire macro is double-quoted, there is no problem with using
9936 this as an Autoconf argument; and since the double-quoting is over the
9937 entire statement, this code can be easily copied and pasted into a
9938 terminal.  However, the double quoting prevents the expansion of any
9939 macros inside the case statement, which may cause its own set of
9940 problems.
9942 @item Using @code{AS_CASE}
9943 @example
9944 AC_DEFUN([my_case],
9945 [AS_CASE([$file_name],
9946   [*.c], [echo "C source code"])])
9947 @end example
9948 @noindent
9949 This version avoids the balancing issue altogether, by relying on
9950 @code{AS_CASE} (@pxref{Common Shell Constructs}); it also allows for the
9951 expansion of @code{AC_REQUIRE} to occur prior to the entire case
9952 statement, rather than within a branch of the case statement that might
9953 not be taken.  However, the abstraction comes with a penalty that it is
9954 no longer a quick copy, paste, and edit to get back to shell code.
9955 @end itemize
9958 @node Quotation Rule Of Thumb
9959 @subsection Quotation Rule Of Thumb
9961 To conclude, the quotation rule of thumb is:
9963 @center @emph{One pair of quotes per pair of parentheses.}
9965 Never over-quote, never under-quote, in particular in the definition of
9966 macros.  In the few places where the macros need to use brackets
9967 (usually in C program text or regular expressions), properly quote
9968 @emph{the arguments}!
9970 It is common to read Autoconf programs with snippets like:
9972 @example
9973 AC_TRY_LINK(
9974 changequote(<<, >>)dnl
9975 <<#include <time.h>
9976 #ifndef tzname /* For SGI.  */
9977 extern char *tzname[]; /* RS6000 and others reject char **tzname.  */
9978 #endif>>,
9979 changequote([, ])dnl
9980 [atoi (*tzname);], ac_cv_var_tzname=yes, ac_cv_var_tzname=no)
9981 @end example
9983 @noindent
9984 which is incredibly useless since @code{AC_TRY_LINK} is @emph{already}
9985 double quoting, so you just need:
9987 @example
9988 AC_TRY_LINK(
9989 [#include <time.h>
9990 #ifndef tzname /* For SGI.  */
9991 extern char *tzname[]; /* RS6000 and others reject char **tzname.  */
9992 #endif],
9993             [atoi (*tzname);],
9994             [ac_cv_var_tzname=yes],
9995             [ac_cv_var_tzname=no])
9996 @end example
9998 @noindent
9999 The M4-fluent reader might note that these two examples are rigorously
10000 equivalent, since M4 swallows both the @samp{changequote(<<, >>)}
10001 and @samp{<<} @samp{>>} when it @dfn{collects} the arguments: these
10002 quotes are not part of the arguments!
10004 Simplified, the example above is just doing this:
10006 @example
10007 changequote(<<, >>)dnl
10008 <<[]>>
10009 changequote([, ])dnl
10010 @end example
10012 @noindent
10013 instead of simply:
10015 @example
10016 [[]]
10017 @end example
10019 With macros that do not double quote their arguments (which is the
10020 rule), double-quote the (risky) literals:
10022 @example
10023 AC_LINK_IFELSE([AC_LANG_PROGRAM(
10024 [[#include <time.h>
10025 #ifndef tzname /* For SGI.  */
10026 extern char *tzname[]; /* RS6000 and others reject char **tzname.  */
10027 #endif]],
10028                                 [atoi (*tzname);])],
10029                [ac_cv_var_tzname=yes],
10030                [ac_cv_var_tzname=no])
10031 @end example
10033 Please note that the macro @code{AC_TRY_LINK} is obsolete, so you really
10034 should be using @code{AC_LINK_IFELSE} instead.
10036 @xref{Quadrigraphs}, for what to do if you run into a hopeless case
10037 where quoting does not suffice.
10039 When you create a @command{configure} script using newly written macros,
10040 examine it carefully to check whether you need to add more quotes in
10041 your macros.  If one or more words have disappeared in the M4
10042 output, you need more quotes.  When in doubt, quote.
10044 However, it's also possible to put on too many layers of quotes.  If
10045 this happens, the resulting @command{configure} script may contain
10046 unexpanded macros.  The @command{autoconf} program checks for this problem
10047 by looking for the string @samp{AC_} in @file{configure}.  However, this
10048 heuristic does not work in general: for example, it does not catch
10049 overquoting in @code{AC_DEFINE} descriptions.
10052 @c ---------------------------------------- Using autom4te
10054 @node Using autom4te
10055 @section Using @command{autom4te}
10057 The Autoconf suite, including M4sugar, M4sh, and Autotest, in addition
10058 to Autoconf per se, heavily rely on M4.  All these different uses
10059 revealed common needs factored into a layer over M4:
10060 @command{autom4te}@footnote{
10062 Yet another great name from Lars J. Aas.
10066 @command{autom4te} is a preprocessor that is like @command{m4}.
10067 It supports M4 extensions designed for use in tools like Autoconf.
10069 @menu
10070 * autom4te Invocation::         A @acronym{GNU} M4 wrapper
10071 * Customizing autom4te::        Customizing the Autoconf package
10072 @end menu
10074 @node autom4te Invocation
10075 @subsection Invoking @command{autom4te}
10077 The command line arguments are modeled after M4's:
10079 @example
10080 autom4te @var{options} @var{files}
10081 @end example
10083 @noindent
10084 @evindex M4
10085 where the @var{files} are directly passed to @command{m4}.  By default,
10086 @acronym{GNU} M4 is found during configuration, but the environment
10087 variable
10088 @env{M4} can be set to tell @command{autom4te} where to look.  In addition
10089 to the regular expansion, it handles the replacement of the quadrigraphs
10090 (@pxref{Quadrigraphs}), and of @samp{__oline__}, the current line in the
10091 output.  It supports an extended syntax for the @var{files}:
10093 @table @file
10094 @item @var{file}.m4f
10095 This file is an M4 frozen file.  Note that @emph{all the previous files
10096 are ignored}.  See the option @option{--melt} for the rationale.
10098 @item @var{file}?
10099 If found in the library path, the @var{file} is included for expansion,
10100 otherwise it is ignored instead of triggering a failure.
10101 @end table
10103 @sp 1
10105 Of course, it supports the Autoconf common subset of options:
10107 @table @option
10108 @item --help
10109 @itemx -h
10110 Print a summary of the command line options and exit.
10112 @item --version
10113 @itemx -V
10114 Print the version number of Autoconf and exit.
10116 @item --verbose
10117 @itemx -v
10118 Report processing steps.
10120 @item --debug
10121 @itemx -d
10122 Don't remove the temporary files and be even more verbose.
10124 @item --include=@var{dir}
10125 @itemx -I @var{dir}
10126 Also look for input files in @var{dir}.  Multiple invocations
10127 accumulate.
10129 @item --output=@var{file}
10130 @itemx -o @var{file}
10131 Save output (script or trace) to @var{file}.  The file @option{-} stands
10132 for the standard output.
10133 @end table
10135 @sp 1
10137 As an extension of @command{m4}, it includes the following options:
10139 @table @option
10140 @item --warnings=@var{category}
10141 @itemx -W @var{category}
10142 @evindex WARNINGS
10143 @c FIXME: Point to the M4sugar macros, not Autoconf's.
10144 Report the warnings related to @var{category} (which can actually be a
10145 comma separated list).  @xref{Reporting Messages}, macro
10146 @code{AC_DIAGNOSE}, for a comprehensive list of categories.  Special
10147 values include:
10149 @table @samp
10150 @item all
10151 report all the warnings
10153 @item none
10154 report none
10156 @item error
10157 treats warnings as errors
10159 @item no-@var{category}
10160 disable warnings falling into @var{category}
10161 @end table
10163 Warnings about @samp{syntax} are enabled by default, and the environment
10164 variable @env{WARNINGS}, a comma separated list of categories, is
10165 honored.  @samp{autom4te -W @var{category}} actually
10166 behaves as if you had run:
10168 @example
10169 autom4te --warnings=syntax,$WARNINGS,@var{category}
10170 @end example
10172 @noindent
10173 For example, if you want to disable defaults and @env{WARNINGS}
10174 of @command{autom4te}, but enable the warnings about obsolete
10175 constructs, you would use @option{-W none,obsolete}.
10177 @cindex Back trace
10178 @cindex Macro invocation stack
10179 @command{autom4te} displays a back trace for errors, but not for
10180 warnings; if you want them, just pass @option{-W error}.
10182 @item --melt
10183 @itemx -M
10184 Do not use frozen files.  Any argument @code{@var{file}.m4f} is
10185 replaced by @code{@var{file}.m4}.  This helps tracing the macros which
10186 are executed only when the files are frozen, typically
10187 @code{m4_define}.  For instance, running:
10189 @example
10190 autom4te --melt 1.m4 2.m4f 3.m4 4.m4f input.m4
10191 @end example
10193 @noindent
10194 is roughly equivalent to running:
10196 @example
10197 m4 1.m4 2.m4 3.m4 4.m4 input.m4
10198 @end example
10200 @noindent
10201 while
10203 @example
10204 autom4te 1.m4 2.m4f 3.m4 4.m4f input.m4
10205 @end example
10207 @noindent
10208 is equivalent to:
10210 @example
10211 m4 --reload-state=4.m4f input.m4
10212 @end example
10214 @item --freeze
10215 @itemx -F
10216 Produce a frozen state file.  @command{autom4te} freezing is stricter
10217 than M4's: it must produce no warnings, and no output other than empty
10218 lines (a line with white space is @emph{not} empty) and comments
10219 (starting with @samp{#}).  Unlike @command{m4}'s similarly-named option,
10220 this option takes no argument:
10222 @example
10223 autom4te 1.m4 2.m4 3.m4 --freeze --output=3.m4f
10224 @end example
10226 @noindent
10227 corresponds to
10229 @example
10230 m4 1.m4 2.m4 3.m4 --freeze-state=3.m4f
10231 @end example
10233 @item --mode=@var{octal-mode}
10234 @itemx -m @var{octal-mode}
10235 Set the mode of the non-traces output to @var{octal-mode}; by default
10236 @samp{0666}.
10237 @end table
10239 @sp 1
10241 @cindex @file{autom4te.cache}
10242 As another additional feature over @command{m4}, @command{autom4te}
10243 caches its results.  @acronym{GNU} M4 is able to produce a regular
10244 output and traces at the same time.  Traces are heavily used in the
10245 @acronym{GNU} Build System: @command{autoheader} uses them to build
10246 @file{config.h.in}, @command{autoreconf} to determine what
10247 @acronym{GNU} Build System components are used, @command{automake} to
10248 ``parse'' @file{configure.ac} etc.  To avoid recomputation,
10249 traces are cached while performing regular expansion,
10250 and conversely.  This cache is (actually, the caches are) stored in
10251 the directory @file{autom4te.cache}.  @emph{It can safely be removed}
10252 at any moment (especially if for some reason @command{autom4te}
10253 considers it trashed).
10255 @table @option
10256 @item --cache=@var{directory}
10257 @itemx -C @var{directory}
10258 Specify the name of the directory where the result should be cached.
10259 Passing an empty value disables caching.  Be sure to pass a relative
10260 file name, as for the time being, global caches are not supported.
10262 @item --no-cache
10263 Don't cache the results.
10265 @item --force
10266 @itemx -f
10267 If a cache is used, consider it obsolete (but update it anyway).
10268 @end table
10270 @sp 1
10272 Because traces are so important to the @acronym{GNU} Build System,
10273 @command{autom4te} provides high level tracing features as compared to
10274 M4, and helps exploiting the cache:
10276 @table @option
10277 @item --trace=@var{macro}[:@var{format}]
10278 @itemx -t @var{macro}[:@var{format}]
10279 Trace the invocations of @var{macro} according to the @var{format}.
10280 Multiple @option{--trace} arguments can be used to list several macros.
10281 Multiple @option{--trace} arguments for a single macro are not
10282 cumulative; instead, you should just make @var{format} as long as
10283 needed.
10285 The @var{format} is a regular string, with newlines if desired, and
10286 several special escape codes.  It defaults to @samp{$f:$l:$n:$%}.  It can
10287 use the following special escapes:
10289 @table @samp
10290 @item $$
10291 The character @samp{$}.
10293 @item $f
10294 The file name from which @var{macro} is called.
10296 @item $l
10297 The line number from which @var{macro} is called.
10299 @item $d
10300 The depth of the @var{macro} call.  This is an M4 technical detail that
10301 you probably don't want to know about.
10303 @item $n
10304 The name of the @var{macro}.
10306 @item $@var{num}
10307 The @var{num}th argument of the call to @var{macro}.
10309 @item $@@
10310 @itemx $@var{sep}@@
10311 @itemx $@{@var{separator}@}@@
10312 All the arguments passed to @var{macro}, separated by the character
10313 @var{sep} or the string @var{separator} (@samp{,} by default).  Each
10314 argument is quoted, i.e., enclosed in a pair of square brackets.
10316 @item $*
10317 @itemx $@var{sep}*
10318 @itemx $@{@var{separator}@}*
10319 As above, but the arguments are not quoted.
10321 @item $%
10322 @itemx $@var{sep}%
10323 @itemx $@{@var{separator}@}%
10324 As above, but the arguments are not quoted, all new line characters in
10325 the arguments are smashed, and the default separator is @samp{:}.
10327 The escape @samp{$%} produces single-line trace outputs (unless you put
10328 newlines in the @samp{separator}), while @samp{$@@} and @samp{$*} do
10329 not.
10330 @end table
10332 @xref{autoconf Invocation}, for examples of trace uses.
10334 @item --preselect=@var{macro}
10335 @itemx -p @var{macro}
10336 Cache the traces of @var{macro}, but do not enable traces.  This is
10337 especially important to save CPU cycles in the future.  For instance,
10338 when invoked, @command{autoconf} preselects all the macros that
10339 @command{autoheader}, @command{automake}, @command{autoreconf}, etc.,
10340 trace, so that running @command{m4} is not needed to trace them: the
10341 cache suffices.  This results in a huge speed-up.
10342 @end table
10344 @sp 1
10346 @cindex Autom4te Library
10347 Finally, @command{autom4te} introduces the concept of @dfn{Autom4te
10348 libraries}.  They consists in a powerful yet extremely simple feature:
10349 sets of combined command line arguments:
10351 @table @option
10352 @item --language=@var{language}
10353 @itemx -l @var{language}
10354 Use the @var{language} Autom4te library.  Current languages include:
10356 @table @code
10357 @item M4sugar
10358 create M4sugar output.
10360 @item M4sh
10361 create M4sh executable shell scripts.
10363 @item Autotest
10364 create Autotest executable test suites.
10366 @item Autoconf-without-aclocal-m4
10367 create Autoconf executable configure scripts without
10368 reading @file{aclocal.m4}.
10370 @item Autoconf
10371 create Autoconf executable configure scripts.  This language inherits
10372 all the characteristics of @code{Autoconf-without-aclocal-m4} and
10373 additionally reads @file{aclocal.m4}.
10374 @end table
10376 @item --prepend-include=@var{dir}
10377 @itemx -B @var{dir}
10378 Prepend directory @var{dir} to the search path.  This is used to include
10379 the language-specific files before any third-party macros.
10381 @end table
10383 @cindex @file{autom4te.cfg}
10384 As an example, if Autoconf is installed in its default location,
10385 @file{/usr/local}, the command @samp{autom4te -l m4sugar foo.m4} is
10386 strictly equivalent to the command:
10388 @example
10389 autom4te --prepend-include /usr/local/share/autoconf \
10390   m4sugar/m4sugar.m4f --warnings syntax foo.m4
10391 @end example
10393 @noindent
10394 Recursive expansion applies here: the command @samp{autom4te -l m4sh foo.m4}
10395 is the same as @samp{autom4te --language M4sugar m4sugar/m4sh.m4f
10396 foo.m4}, i.e.:
10398 @example
10399 autom4te --prepend-include /usr/local/share/autoconf \
10400   m4sugar/m4sugar.m4f m4sugar/m4sh.m4f --mode 777 foo.m4
10401 @end example
10403 @noindent
10404 The definition of the languages is stored in @file{autom4te.cfg}.
10406 @node Customizing autom4te
10407 @subsection Customizing @command{autom4te}
10409 One can customize @command{autom4te} via @file{~/.autom4te.cfg} (i.e.,
10410 as found in the user home directory), and @file{./.autom4te.cfg} (i.e.,
10411 as found in the directory from which @command{autom4te} is run).  The
10412 order is first reading @file{autom4te.cfg}, then @file{~/.autom4te.cfg},
10413 then @file{./.autom4te.cfg}, and finally the command line arguments.
10415 In these text files, comments are introduced with @code{#}, and empty
10416 lines are ignored.  Customization is performed on a per-language basis,
10417 wrapped in between a @samp{begin-language: "@var{language}"},
10418 @samp{end-language: "@var{language}"} pair.
10420 Customizing a language stands for appending options (@pxref{autom4te
10421 Invocation}) to the current definition of the language.  Options, and
10422 more generally arguments, are introduced by @samp{args:
10423 @var{arguments}}.  You may use the traditional shell syntax to quote the
10424 @var{arguments}.
10426 As an example, to disable Autoconf caches (@file{autom4te.cache})
10427 globally, include the following lines in @file{~/.autom4te.cfg}:
10429 @verbatim
10430 ## ------------------ ##
10431 ## User Preferences.  ##
10432 ## ------------------ ##
10434 begin-language: "Autoconf-without-aclocal-m4"
10435 args: --no-cache
10436 end-language: "Autoconf-without-aclocal-m4"
10437 @end verbatim
10440 @node Programming in M4sugar
10441 @section Programming in M4sugar
10443 @cindex M4sugar
10444 M4 by itself provides only a small, but sufficient, set of all-purpose
10445 macros.  M4sugar introduces additional generic macros.  Its name was
10446 coined by Lars J. Aas: ``Readability And Greater Understanding Stands 4
10447 M4sugar''.
10449 M4sugar reserves the macro namespace @samp{^_m4_} for internal use, and
10450 the macro namespace @samp{^m4_} for M4sugar macros.  You should not
10451 define your own macros into these namespaces.
10453 @menu
10454 * Redefined M4 Macros::         M4 builtins changed in M4sugar
10455 * Diagnostic Macros::           Diagnostic messages from M4sugar
10456 * Diversion support::           Diversions in M4sugar
10457 * Conditional constructs::      Conditions in M4
10458 * Looping constructs::          Iteration in M4
10459 * Evaluation Macros::           More quotation and evaluation control
10460 * Text processing Macros::      String manipulation in M4
10461 * Number processing Macros::    Arithmetic computation in M4
10462 * Set manipulation Macros::     Set manipulation in M4
10463 * Forbidden Patterns::          Catching unexpanded macros
10464 @end menu
10466 @node Redefined M4 Macros
10467 @subsection Redefined M4 Macros
10469 @msindex{builtin}
10470 @msindex{changecom}
10471 @msindex{changequote}
10472 @msindex{debugfile}
10473 @msindex{debugmode}
10474 @msindex{decr}
10475 @msindex{define}
10476 @msindex{divnum}
10477 @msindex{errprint}
10478 @msindex{esyscmd}
10479 @msindex{eval}
10480 @msindex{format}
10481 @msindex{ifdef}
10482 @msindex{incr}
10483 @msindex{index}
10484 @msindex{indir}
10485 @msindex{len}
10486 @msindex{pushdef}
10487 @msindex{shift}
10488 @msindex{substr}
10489 @msindex{syscmd}
10490 @msindex{sysval}
10491 @msindex{traceoff}
10492 @msindex{traceon}
10493 @msindex{translit}
10494 With a few exceptions, all the M4 native macros are moved in the
10495 @samp{m4_} pseudo-namespace, e.g., M4sugar renames @code{define} as
10496 @code{m4_define} etc.
10498 The list of macros unchanged from M4, except for their name, is:
10499 @itemize @minus
10500 @item m4_builtin
10501 @item m4_changecom
10502 @item m4_changequote
10503 @item m4_debugfile
10504 @item m4_debugmode
10505 @item m4_decr
10506 @item m4_define
10507 @item m4_divnum
10508 @item m4_errprint
10509 @item m4_esyscmd
10510 @item m4_eval
10511 @item m4_format
10512 @item m4_ifdef
10513 @item m4_incr
10514 @item m4_index
10515 @item m4_indir
10516 @item m4_len
10517 @item m4_pushdef
10518 @item m4_shift
10519 @item m4_substr
10520 @item m4_syscmd
10521 @item m4_sysval
10522 @item m4_traceoff
10523 @item m4_traceon
10524 @item m4_translit
10525 @end itemize
10527 Some M4 macros are redefined, and are slightly incompatible with their
10528 native equivalent.
10530 @defmac __file__
10531 @defmacx __line__
10532 @MSindex __file__
10533 @MSindex __line__
10534 All M4 macros starting with @samp{__} retain their original name: for
10535 example, no @code{m4__file__} is defined.
10536 @end defmac
10538 @defmac __oline__
10539 @MSindex __oline__
10540 This is not technically a macro, but a feature of Autom4te.  The
10541 sequence @code{__oline__} can be used similarly to the other m4sugar
10542 location macros, but rather than expanding to the location of the input
10543 file, it is translated to the line number where it appears in the output
10544 file after all other M4 expansions.
10545 @end defmac
10547 @defmac dnl
10548 @MSindex dnl
10549 This macro kept its original name: no @code{m4_dnl} is defined.
10550 @end defmac
10552 @defmac m4_bpatsubst (@var{string}, @var{regexp}, @ovar{replacement})
10553 @msindex{bpatsubst}
10554 This macro corresponds to @code{patsubst}.  The name @code{m4_patsubst}
10555 is kept for future versions of M4sugar, once @acronym{GNU} M4 2.0 is
10556 released and supports extended regular expression syntax.
10557 @end defmac
10559 @defmac m4_bregexp (@var{string}, @var{regexp}, @ovar{replacement})
10560 @msindex{bregexp}
10561 This macro corresponds to @code{regexp}.  The name @code{m4_regexp}
10562 is kept for future versions of M4sugar, once @acronym{GNU} M4 2.0 is
10563 released and supports extended regular expression syntax.
10564 @end defmac
10566 @defmac m4_copy (@var{source}, @var{dest})
10567 @defmacx m4_rename (@var{source}, @var{dest})
10568 @msindex{copy}
10569 @msindex{rename}
10570 These macros aren't directly builtins, but are closely related to
10571 @code{m4_pushdef} and @code{m4_defn}.  They both ensures that @var{dest}
10572 is undefined, then proceed to copy the entire pushdef stack of
10573 definitions of @var{source}.  @code{m4_copy} preserves the source, while
10574 @code{m4_rename} undefines the original macro name.
10576 Note that attempting to invoke a renamed macro might not work, since the
10577 macro may have a dependence on helper macros accessed via composition of
10578 @samp{$0} but that were not also renamed; likewise, other macros may
10579 have a hard-coded dependence on @var{source} and could break if
10580 @var{source} has been deleted.  On the other hand, it is always safe to
10581 rename a macro to temporarily move it out of the way, then rename it
10582 back later to restore original semantics.
10583 @end defmac
10585 @defmac m4_defn (@var{macro}@dots{})
10586 @msindex{defn}
10587 This macro fails if @var{macro} is not defined, even when using older
10588 versions of M4 that did not warn.  See @code{m4_undefine}.
10589 Unfortunately, in order to support these older versions of M4, there are
10590 some situations involving unbalanced quotes where concatenating multiple
10591 macros together will work in newer M4 but not in m4sugar; use
10592 quadrigraphs to work around this.
10593 @end defmac
10595 @defmac m4_divert (@var{diversion})
10596 @msindex{divert}
10597 M4sugar relies heavily on diversions, so rather than behaving as a
10598 primitive, @code{m4_divert} behaves like:
10599 @example
10600 m4_divert_pop()m4_divert_push([@var{diversion}])
10601 @end example
10602 @noindent
10603 @xref{Diversion support}, for more details about the use of the
10604 diversion stack.
10605 @end defmac
10607 @defmac m4_dumpdef (@var{name}@dots{})
10608 @defmacx m4_dumpdefs (@var{name}@dots{})
10609 @msindex{dumpdef}
10610 @msindex{dumpdefs}
10611 @code{m4_dumpdef} is like the M4 builtin, except that this version
10612 requires at least one argument, output always goes to standard error
10613 rather than the current debug file, no sorting is done on multiple
10614 arguments, and an error is issued if any
10615 @var{name} is undefined.  @code{m4_dumpdefs} is a convenience macro that
10616 calls @code{m4_dumpdef} for all of the
10617 @code{m4_pushdef} stack of definitions, starting with the current, and
10618 silently does nothing if @var{name} is undefined.
10620 Unfortunately, due to a limitation in M4 1.4.x, any macro defined as a
10621 builtin is output as the empty string.  This behavior is rectified by
10622 using M4 1.6 or newer.  However, this behavior difference means that
10623 @code{m4_dumpdef} should only be used while developing m4sugar macros,
10624 and never in the final published form of a macro.
10625 @end defmac
10627 @defmac m4_esyscmd_s (@var{command})
10628 @msindex{esyscmd_s}
10629 Like @code{m4_esyscmd}, this macro expands to the result of running
10630 @var{command} in a shell.  The difference is that any trailing newlines
10631 are removed, so that the output behaves more like shell command
10632 substitution.
10633 @end defmac
10635 @defmac m4_exit (@var{exit-status})
10636 @msindex{exit}
10637 This macro corresponds to @code{m4exit}.
10638 @end defmac
10640 @defmac m4_if (@var{comment})
10641 @defmacx m4_if (@var{string-1}, @var{string-2}, @var{equal}, @ovar{not-equal})
10642 @defmacx m4_if (@var{string-1}, @var{string-2}, @var{equal-1}, @
10643   @var{string-3}, @var{string-4}, @var{equal-2}, @dots{}, @ovar{not-equal})
10644 @msindex{if}
10645 This macro corresponds to @code{ifelse}.  @var{string-1} and
10646 @var{string-2} are compared literally, so usually one of the two
10647 arguments is passed unquoted.  @xref{Conditional constructs}, for more
10648 conditional idioms.
10649 @end defmac
10651 @defmac m4_include (@var{file})
10652 @defmacx m4_sinclude (@var{file})
10653 @msindex{include}
10654 @msindex{sinclude}
10655 Like the M4 builtins, but warn against multiple inclusions of @var{file}.
10656 @end defmac
10658 @defmac m4_mkstemp (@var{template})
10659 @defmacx m4_maketemp (@var{template})
10660 @msindex{maketemp}
10661 @msindex{mkstemp}
10662 Posix requires @code{maketemp} to replace the trailing @samp{X}
10663 characters in @var{template} with the process id, without regards to the
10664 existence of a file by that name, but this a security hole.  When this
10665 was pointed out to the Posix folks, they agreed to invent a new macro
10666 @code{mkstemp} that always creates a uniquely named file, but not all
10667 versions of @acronym{GNU} M4 support the new macro.  In M4sugar,
10668 @code{m4_maketemp} and @code{m4_mkstemp} are synonyms for each other,
10669 and both have the secure semantics regardless of which macro the
10670 underlying M4 provides.
10671 @end defmac
10673 @defmac m4_popdef (@var{macro}@dots{})
10674 @msindex{popdef}
10675 This macro fails if @var{macro} is not defined, even when using older
10676 versions of M4 that did not warn.  See @code{m4_undefine}.
10677 @end defmac
10679 @defmac m4_undefine (@var{macro}@dots{})
10680 @msindex{undefine}
10681 This macro fails if @var{macro} is not defined, even when using older
10682 versions of M4 that did not warn.  Use
10684 @example
10685 m4_ifdef([@var{macro}], [m4_undefine([@var{macro}])])
10686 @end example
10688 @noindent
10689 if you are not sure whether @var{macro} is defined.
10690 @end defmac
10692 @defmac m4_undivert (@var{diversion}@dots{})
10693 @msindex{undivert}
10694 Unlike the M4 builtin, at least one @var{diversion} must be specified.
10695 Also, since the M4sugar diversion stack prefers named
10696 diversions, the use of @code{m4_undivert} to include files is risky.
10697 @xref{Diversion support}, for more details about the use of the
10698 diversion stack.
10699 @end defmac
10701 @defmac m4_wrap (@var{text})
10702 @defmacx m4_wrap_lifo (@var{text})
10703 @msindex{wrap}
10704 @msindex{wrap_lifo}
10705 These macros correspond to @code{m4wrap}.  Posix requires arguments of
10706 multiple wrap calls to be reprocessed at @acronym{EOF} in the same order
10707 as the original calls (first-in, first-out).  @acronym{GNU} M4 versions
10708 through 1.4.10, however, reprocess them in reverse order (last-in,
10709 first-out).  Both orders are useful, therefore, you can rely on
10710 @code{m4_wrap} to provide FIFO semantics and @code{m4_wrap_lifo} for
10711 LIFO semantics, regardless of the underlying @acronym{GNU} M4 version.
10713 Unlike the @acronym{GNU} M4 builtin, these macros only recognize one
10714 argument, and avoid token pasting between consecutive invocations.  On
10715 the other hand, nested calls to @code{m4_wrap} from within wrapped text
10716 work just as in the builtin.
10717 @end defmac
10720 @node Diagnostic Macros
10721 @subsection Diagnostic messages from M4sugar
10722 @cindex Messages, from @command{M4sugar}
10724 When macros statically diagnose abnormal situations, benign or fatal,
10725 they should report them using these macros.  For issuing dynamic issues,
10726 i.e., when @command{configure} is run, see @ref{Printing Messages}.
10728 @defmac m4_assert (@var{expression}, @dvar{exit-status, 1})
10729 @msindex{assert}
10730 Assert that the arithmetic @var{expression} evaluates to non-zero.
10731 Otherwise, issue a fatal error, and exit @command{autom4te} with
10732 @var{exit-status}.
10733 @end defmac
10735 @defmac m4_errprintn (@var{message})
10736 @msindex{errprintn}
10737 Similar to the builtin @code{m4_errprint}, except that a newline is
10738 guaranteed after @var{message}.
10739 @end defmac
10741 @anchor{m4_fatal}
10742 @defmac m4_fatal (@var{message})
10743 @msindex{fatal}
10744 Report a severe error @var{message} prefixed with the current location,
10745 and have @command{autom4te} die.
10746 @end defmac
10748 @defmac m4_location
10749 @msindex{location}
10750 Useful as a prefix in a message line.  Short for:
10751 @example
10752 __file__:__line__
10753 @end example
10754 @end defmac
10756 @anchor{m4_warn}
10757 @defmac m4_warn (@var{category}, @var{message})
10758 @msindex{warn}
10759 Report @var{message} as a warning (or as an error if requested by the
10760 user) if warnings of the @var{category} are turned on.  If the message
10761 is emitted, it is prefixed with the current location, and followed by a
10762 call trace of all macros defined via @code{AC_DEFUN} used to get to the
10763 current expansion.  You are encouraged to use standard categories, which
10764 currently include:
10766 @table @samp
10767 @item all
10768 messages that don't fall into one of the following categories.  Use of an
10769 empty @var{category} is equivalent.
10771 @item cross
10772 related to cross compilation issues.
10774 @item obsolete
10775 use of an obsolete construct.
10777 @item syntax
10778 dubious syntactic constructs, incorrectly ordered macro calls.
10779 @end table
10780 @end defmac
10783 @node Diversion support
10784 @subsection Diversion support
10786 M4sugar makes heavy use of diversions, because it is often the case that
10787 text that must appear early in the output is not discovered until late
10788 in the input.  Additionally, some of the topological sorting algorithms
10789 used in resolving macro dependencies use diversions.  However, most
10790 macros should not need to change diversions directly, but rather rely on
10791 higher-level M4sugar macros to manage diversions transparently.
10793 In the rare case that it is necessary to write a macro that explicitly
10794 outputs text to a different diversion, it is important to be aware of an
10795 M4 limitation regarding diversions: text only goes to a diversion if it
10796 is not part of argument collection.  Therefore, any macro that changes
10797 the current diversion cannot be used as an unquoted argument to another
10798 macro, but must be expanded at the top level.  The macro
10799 @code{m4_expand} will diagnose any attempt to change diversions, since
10800 it is generally useful only as an argument to another macro.  The
10801 following example shows what happens when diversion manipulation is
10802 attempted within macro arguments:
10804 @example
10805 m4_do([normal text]
10806 m4_divert_push([KILL])unwanted[]m4_divert_pop([KILL])
10807 [m4_divert_push([KILL])discarded[]m4_divert_pop([KILL])])dnl
10808 @result{}normal text
10809 @result{}unwanted
10810 @end example
10812 @noindent
10813 Notice that the unquoted text @code{unwanted} is output, even though it
10814 was processed while the current diversion was @code{KILL}, because it
10815 was collected as part of the argument to @code{m4_do}.  However, the
10816 text @code{discarded} disappeared as desired, because the diversion
10817 changes were single-quoted, and were not expanded until the top-level
10818 rescan of the output of @code{m4_do}.
10820 To make diversion management easier, M4sugar uses the concept of named
10821 diversions.  Rather than using diversion numbers directly, it is nicer
10822 to associate a name with each diversion; the diversion number associated
10823 with a particular diversion name is an implementation detail, so you
10824 should only use diversion names.  In general, you should not output text
10825 to a named diversion until after calling the appropriate initialization
10826 routine for your language (@code{m4_init}, @code{AS_INIT},
10827 @code{AT_INIT}, @dots{}), although there are some exceptions documented
10828 below.
10830 M4sugar defines two named diversions.
10831 @table @code
10832 @item KILL
10833 Text written to this diversion is discarded.  This is the default
10834 diversion once M4sugar is initialized.
10835 @item GROW
10836 This diversion is used behind the scenes by topological sorting macros,
10837 such as @code{AC_REQUIRE}.
10838 @end table
10840 M4sh adds several more named diversions.
10841 @table @code
10842 @item BINSH
10843 This diversion is reserved for the @samp{#!} interpreter line.
10844 @item HEADER-REVISION
10845 This diversion holds text from @code{AC_REVISION}.
10846 @item HEADER-COMMENT
10847 This diversion holds comments about the purpose of a file.
10848 @item HEADER-COPYRIGHT
10849 This diversion is managed by @code{AC_COPYRIGHT}.
10850 @item M4SH-SANITIZE
10851 This diversion contains M4sh sanitization code, used to ensure M4sh is
10852 executing in a reasonable shell environment.
10853 @item M4SH-INIT
10854 This diversion contains M4sh initialization code, initializing variables
10855 that are required by other M4sh macros.
10856 @item BODY
10857 This diversion contains the body of the shell code, and is the default
10858 diversion once M4sh is initialized.
10859 @end table
10861 Autotest inherits diversions from M4sh, and changes the default
10862 diversion from @code{BODY} back to @code{KILL}.  It also adds several
10863 more named diversions, with the following subset designed for developer
10864 use.
10865 @table @code
10866 @item PREPARE_TESTS
10867 This diversion contains initialization sequences which are executed
10868 after @file{atconfig} and @file{atlocal}, and after all command line
10869 arguments have been parsed, but prior to running any tests.  It can be
10870 used to set up state that is required across all tests.  This diversion
10871 will work even before @code{AT_INIT}.
10872 @end table
10874 For now, the named diversions of Autoconf and Autoheader, and the
10875 remaining diversions of Autotest, are not documented.  In other words,
10876 intentionally outputting text into an undocumented diversion is subject
10877 to breakage in a future release of Autoconf.
10879 @defmac m4_cleardivert (@var{diversion}@dots{})
10880 @msindex{cleardivert}
10881 Permanently discard any text that has been diverted into
10882 @var{diversion}.
10883 @end defmac
10885 @defmac m4_divert_once (@var{diversion}, @ovar{content})
10886 @msindex{divert_once}
10887 Similar to @code{m4_divert_text}, except that @var{content} is only
10888 output to @var{diversion} if this is the first time that
10889 @code{m4_divert_once} has been called with its particular arguments.
10890 @end defmac
10892 @defmac m4_divert_pop (@ovar{diversion})
10893 @msindex{divert_pop}
10894 If provided, check that the current diversion is indeed @var{diversion}.
10895 Then change to the diversion located earlier on the stack, giving an
10896 error if an attempt is made to pop beyond the initial m4sugar diversion
10897 of @code{KILL}.
10898 @end defmac
10900 @defmac m4_divert_push (@var{diversion})
10901 @msindex{divert_push}
10902 Remember the former diversion on the diversion stack, and output
10903 subsequent text into @var{diversion}.  M4sugar maintains a diversion
10904 stack, and issues an error if there is not a matching pop for every
10905 push.
10906 @end defmac
10908 @defmac m4_divert_text (@var{diversion}, @ovar{content})
10909 @msindex{divert_text}
10910 Output @var{content} and a newline into @var{diversion}, without
10911 affecting the current diversion.  Shorthand for:
10912 @example
10913 m4_divert_push([@var{diversion}])@var{content}
10914 m4_divert_pop([@var{diversion}])dnl
10915 @end example
10916 @end defmac
10918 @defmac m4_init
10919 @msindex{init}
10920 Initialize the M4sugar environment, setting up the default named
10921 diversion to be @code{KILL}.
10922 @end defmac
10924 @node Conditional constructs
10925 @subsection Conditional constructs
10927 The following macros provide additional conditional constructs as
10928 convenience wrappers around @code{m4_if}.
10930 @defmac m4_bmatch (@var{string}, @var{regex-1}, @var{value-1}, @
10931   @ovar{regex-2}, @ovar{value-2}, @dots{}, @ovar{default})
10932 @msindex{bmatch}
10933 The string @var{string} is repeatedly compared against a series of
10934 @var{regex} arguments; if a match is found, the expansion is the
10935 corresponding @var{value}, otherwise, the macro moves on to the next
10936 @var{regex}.  If no @var{regex} match, then the result is the optional
10937 @var{default}, or nothing.
10938 @end defmac
10940 @defmac m4_bpatsubsts (@var{string}, @var{regex-1}, @var{subst-1}, @
10941   @ovar{regex-2}, @ovar{subst-2}, @dots{})
10942 @msindex{bpatsubsts}
10943 The string @var{string} is altered by @var{regex-1} and @var{subst-1},
10944 as if by:
10945 @example
10946 m4_bpatsubst([[@var{string}]], [@var{regex}], [@var{subst}])
10947 @end example
10949 @noindent
10950 The result of the substitution is then passed through the next set of
10951 @var{regex} and @var{subst}, and so forth.  An empty @var{subst} implies
10952 deletion of any matched portions in the current string.  Note that this
10953 macro over-quotes @var{string}; this behavior is intentional, so that
10954 the result of each step of the recursion remains as a quoted string.
10955 However, it means that anchors (@samp{^} and @samp{$} in the @var{regex}
10956 will line up with the extra quotations, and not the characters of the
10957 original string.  The overquoting is removed after the final
10958 substitution.
10959 @end defmac
10961 @defmac m4_case (@var{string}, @var{value-1}, @var{if-value-1}, @
10962   @ovar{value-2}, @ovar{if-value-2}, @dots{}, @ovar{default})
10963 @msindex{case}
10964 Test @var{string} against multiple @var{value} possibilities, resulting
10965 in the first @var{if-value} for a match, or in the optional
10966 @var{default}.  This is shorthand for:
10967 @example
10968 m4_if([@var{string}], [@var{value-1}], [@var{if-value-1}],
10969       [@var{string}], [@var{value-2}], [@var{if-value-2}], @dots{},
10970       [@var{default}])
10971 @end example
10972 @end defmac
10974 @defmac m4_cond (@var{test-1}, @var{value-1}, @var{if-value-1}, @
10975   @ovar{test-2}, @ovar{value-2}, @ovar{if-value-2}, @dots{}, @ovar{default})
10976 @msindex{cond}
10977 This macro was introduced in Autoconf 2.62.  Similar to @code{m4_if},
10978 except that each @var{test} is expanded only when it is encountered.
10979 This is useful for short-circuiting expensive tests; while @code{m4_if}
10980 requires all its strings to be expanded up front before doing
10981 comparisons, @code{m4_cond} only expands a @var{test} when all earlier
10982 tests have failed.
10984 For an example, these two sequences give the same result, but in the
10985 case where @samp{$1} does not contain a backslash, the @code{m4_cond}
10986 version only expands @code{m4_index} once, instead of five times, for
10987 faster computation if this is a common case for @samp{$1}.  Notice that
10988 every third argument is unquoted for @code{m4_if}, and quoted for
10989 @code{m4_cond}:
10991 @example
10992 m4_if(m4_index([$1], [\]), [-1], [$2],
10993       m4_eval(m4_index([$1], [\\]) >= 0), [1], [$2],
10994       m4_eval(m4_index([$1], [\$]) >= 0), [1], [$2],
10995       m4_eval(m4_index([$1], [\`]) >= 0), [1], [$3],
10996       m4_eval(m4_index([$1], [\"]) >= 0), [1], [$3],
10997       [$2])
10998 m4_cond([m4_index([$1], [\])], [-1], [$2],
10999         [m4_eval(m4_index([$1], [\\]) >= 0)], [1], [$2],
11000         [m4_eval(m4_index([$1], [\$]) >= 0)], [1], [$2],
11001         [m4_eval(m4_index([$1], [\`]) >= 0)], [1], [$3],
11002         [m4_eval(m4_index([$1], [\"]) >= 0)], [1], [$3],
11003         [$2])
11004 @end example
11005 @end defmac
11007 @defmac m4_default (@var{expr-1}, @var{expr-2})
11008 @defmacx m4_default_quoted (@var{expr-1}, @var{expr-2})
11009 @defmacx m4_default_nblank (@var{expr-1}, @ovar{expr-2})
11010 @defmacx m4_default_nblank_quoted (@var{expr-1}, @ovar{expr-2})
11011 @msindex{default}
11012 @msindex{default_quoted}
11013 @msindex{default_nblank}
11014 @msindex{default_nblank_quoted}
11015 If @var{expr-1} contains text, use it.  Otherwise, select @var{expr-2}.
11016 @code{m4_default} expands the result, while @code{m4_default_quoted}
11017 does not.  Useful for providing a fixed default if the expression that
11018 results in @var{expr-1} would otherwise be empty.  The difference
11019 between @code{m4_default} and @code{m4_default_nblank} is whether an
11020 argument consisting of just blanks (space, tab, newline) is
11021 significant.  When using the expanding versions, note that an argument
11022 may contain text but still expand to an empty string.
11024 @example
11025 m4_define([active], [ACTIVE])dnl
11026 m4_define([empty], [])dnl
11027 m4_define([demo1], [m4_default([$1], [$2])])dnl
11028 m4_define([demo2], [m4_default_quoted([$1], [$2])])dnl
11029 m4_define([demo3], [m4_default_nblank([$1], [$2])])dnl
11030 m4_define([demo4], [m4_default_nblank_quoted([$1], [$2])])dnl
11031 demo1([active], [default])
11032 @result{}ACTIVE
11033 demo1([], [active])
11034 @result{}ACTIVE
11035 demo1([empty], [text])
11036 @result{}
11037 -demo1([ ], [active])-
11038 @result{}- -
11039 demo2([active], [default])
11040 @result{}active
11041 demo2([], [active])
11042 @result{}active
11043 demo2([empty], [text])
11044 @result{}empty
11045 -demo2([ ], [active])-
11046 @result{}- -
11047 demo3([active], [default])
11048 @result{}ACTIVE
11049 demo3([], [active])
11050 @result{}ACTIVE
11051 demo3([empty], [text])
11052 @result{}
11053 -demo3([ ], [active])-
11054 @result{}-ACTIVE-
11055 demo4([active], [default])
11056 @result{}active
11057 demo4([], [active])
11058 @result{}active
11059 demo4([empty], [text])
11060 @result{}empty
11061 -demo4([ ], [active])-
11062 @result{}-active-
11063 @end example
11064 @end defmac
11066 @defmac m4_ifblank (@var{cond}, @ovar{if-blank}, @ovar{if-text})
11067 @defmacx m4_ifnblank (@var{cond}, @ovar{if-text}, @ovar{if-blank})
11068 @msindex{ifblank}
11069 @msindex{ifnblank}
11070 If @var{cond} is empty or consists only of blanks (space, tab, newline),
11071 then expand @var{if-blank}; otherwise, expand @var{if-text}.  Two
11072 variants exist, in order to make it easier to select the correct logical
11073 sense when using only two parameters.  Note that this is more efficient
11074 than the equivalent behavior of:
11075 @example
11076 m4_ifval(m4_normalize([@var{cond}]), @var{if-text}, @var{if-cond})
11077 @end example
11078 @end defmac
11080 @defmac m4_ifndef (@var{macro}, @var{if-not-defined}, @ovar{if-defined})
11081 @msindex{ifndef}
11082 This is shorthand for:
11083 @example
11084 m4_ifdef([@var{macro}], [@var{if-defined}], [@var{if-not-defined}])
11085 @end example
11086 @end defmac
11088 @defmac m4_ifset (@var{macro}, @ovar{if-true}, @ovar{if-false})
11089 @msindex{ifset}
11090 If @var{macro} is undefined, or is defined as the empty string, expand
11091 to @var{if-false}.  Otherwise, expands to @var{if-true}.  Similar to:
11092 @example
11093 m4_ifval(m4_defn([@var{macro}]), [@var{if-true}], [@var{if-false}])
11094 @end example
11095 @noindent
11096 except that it is not an error if @var{macro} is undefined.
11097 @end defmac
11099 @defmac m4_ifval (@var{cond}, @ovar{if-true}, @ovar{if-false})
11100 @msindex{ifval}
11101 Expands to @var{if-true} if @var{cond} is not empty, otherwise to
11102 @var{if-false}.  This is shorthand for:
11103 @example
11104 m4_if([@var{cond}], [], [@var{if-true}], [@var{if-false}])
11105 @end example
11106 @end defmac
11108 @defmac m4_ifvaln (@var{cond}, @ovar{if-true}, @ovar{if-false})
11109 @msindex{ifvaln}
11110 Similar to @code{m4_ifval}, except guarantee that a newline is present
11111 after any non-empty expansion.  Often followed by @code{dnl}.
11112 @end defmac
11114 @defmac m4_n (@var{text})
11115 @msindex{n}
11116 Expand to @var{text}, and add a newline if @var{text} is not empty.
11117 Often followed by @code{dnl}.
11118 @end defmac
11121 @node Looping constructs
11122 @subsection Looping constructs
11124 The following macros are useful in implementing recursive algorithms in
11125 M4, including loop operations.  An M4 list is formed by quoting a list
11126 of quoted elements; generally the lists are comma-separated, although
11127 @code{m4_foreach_w} is whitespace-separated.  For example, the list
11128 @samp{[[a], [b,c]]} contains two elements: @samp{[a]} and @samp{[b,c]}.
11129 It is common to see lists with unquoted elements when those elements are
11130 not likely to be macro names, as in @samp{[fputc_unlocked,
11131 fgetc_unlocked]}.
11133 Although not generally recommended, it is possible for quoted lists to
11134 have side effects; all side effects are expanded only once, and prior to
11135 visiting any list element.  On the other hand, the fact that unquoted
11136 macros are expanded exactly once means that macros without side effects
11137 can be used to generate lists.  For example,
11139 @example
11140 m4_foreach([i], [[1], [2], [3]m4_errprintn([hi])], [i])
11141 @error{}hi
11142 @result{}123
11143 m4_define([list], [[1], [2], [3]])
11144 @result{}
11145 m4_foreach([i], [list], [i])
11146 @result{}123
11147 @end example
11149 @defmac m4_argn (@var{n}, @ovar{arg}@dots{})
11150 @msindex{argn}
11151 Extracts argument @var{n} (larger than 0) from the remaining arguments.
11152 If there are too few arguments, the empty string is used.  For any
11153 @var{n} besides 1, this is more efficient than the similar
11154 @samp{m4_car(m4_shiftn([@var{n}], [], [@var{arg}@dots{}]))}.
11155 @end defmac
11157 @defmac m4_car (@var{arg}@dots{})
11158 @msindex{car}
11159 Expands to the quoted first @var{arg}.  Can be used with @code{m4_cdr}
11160 to recursively iterate
11161 through a list.  Generally, when using quoted lists of quoted elements,
11162 @code{m4_car} should be called without any extra quotes.
11163 @end defmac
11165 @defmac m4_cdr (@var{arg}@dots{})
11166 @msindex{cdr}
11167 Expands to a quoted list of all but the first @var{arg}, or the empty
11168 string if there was only one argument.  Generally, when using quoted
11169 lists of quoted elements, @code{m4_cdr} should be called without any
11170 extra quotes.
11172 For example, this is a simple implementation of @code{m4_map}; note how
11173 each iteration checks for the end of recursion, then merely applies the
11174 first argument to the first element of the list, then repeats with the
11175 rest of the list.  (The actual implementation in M4sugar is a bit more
11176 involved, to gain some speed and share code with @code{m4_map_sep}, and
11177 also to avoid expanding side effects in @samp{$2} twice).
11178 @example
11179 m4_define([m4_map], [m4_ifval([$2],
11180   [m4_apply([$1], m4_car($2))[]$0([$1], m4_cdr($2))])])dnl
11181 m4_map([ m4_eval], [[[1]], [[1+1]], [[10],[16]]])
11182 @result{} 1 2 a
11183 @end example
11184 @end defmac
11186 @defmac m4_for (@var{var}, @var{first}, @var{last}, @ovar{step}, @
11187   @var{expression})
11188 @msindex{for}
11189 Loop over the numeric values between @var{first} and @var{last}
11190 including bounds by increments of @var{step}.  For each iteration,
11191 expand @var{expression} with the numeric value assigned to @var{var}.
11192 If @var{step} is omitted, it defaults to @samp{1} or @samp{-1} depending
11193 on the order of the limits.  If given, @var{step} has to match this
11194 order.  The number of iterations is determined independently from
11195 definition of @var{var}; iteration cannot be short-circuited or
11196 lengthened by modifying @var{var} from within @var{expression}.
11197 @end defmac
11199 @defmac m4_foreach (@var{var}, @var{list}, @var{expression})
11200 @msindex{foreach}
11201 Loop over the comma-separated M4 list @var{list}, assigning each value
11202 to @var{var}, and expand @var{expression}.  The following example
11203 outputs two lines:
11205 @example
11206 m4_foreach([myvar], [[foo], [bar, baz]],
11207            [echo myvar
11208 ])dnl
11209 @result{}echo foo
11210 @result{}echo bar, baz
11211 @end example
11213 Note that for some forms of @var{expression}, it may be faster to use
11214 @code{m4_map_args}.
11215 @end defmac
11217 @anchor{m4_foreach_w}
11218 @defmac m4_foreach_w (@var{var}, @var{list}, @var{expression})
11219 @msindex{foreach_w}
11220 Loop over the white-space-separated list @var{list}, assigning each value
11221 to @var{var}, and expand @var{expression}.  If @var{var} is only
11222 referenced once in @var{expression}, it is more efficient to use
11223 @code{m4_map_args_w}.
11225 The deprecated macro @code{AC_FOREACH} is an alias of
11226 @code{m4_foreach_w}.
11227 @end defmac
11229 @defmac m4_map (@var{macro}, @var{list})
11230 @defmacx m4_mapall (@var{macro}, @var{list})
11231 @defmacx m4_map_sep (@var{macro}, @var{separator}, @var{list})
11232 @defmacx m4_mapall_sep (@var{macro}, @var{separator}, @var{list})
11233 @msindex{map}
11234 @msindex{mapall}
11235 @msindex{map_sep}
11236 @msindex{mapall_sep}
11237 Loop over the comma separated quoted list of argument descriptions in
11238 @var{list}, and invoke @var{macro} with the arguments.  An argument
11239 description is in turn a comma-separated quoted list of quoted elements,
11240 suitable for @code{m4_apply}.  The macros @code{m4_map} and
11241 @code{m4_map_sep} ignore empty argument descriptions, while
11242 @code{m4_mapall} and @code{m4_mapall_sep} invoke @var{macro} with no
11243 arguments.  The macros @code{m4_map_sep} and @code{m4_mapall_sep}
11244 additionally expand @var{separator} between invocations of @var{macro}.
11246 Note that @var{separator} is expanded, unlike in @code{m4_join}.  When
11247 separating output with commas, this means that the map result can be
11248 used as a series of arguments, by using a single-quoted comma as
11249 @var{separator}, or as a single string, by using a double-quoted comma.
11251 @example
11252 m4_map([m4_count], [])
11253 @result{}
11254 m4_map([ m4_count], [[],
11255                      [[1]],
11256                      [[1], [2]]])
11257 @result{} 1 2
11258 m4_mapall([ m4_count], [[],
11259                         [[1]],
11260                         [[1], [2]]])
11261 @result{} 0 1 2
11262 m4_map_sep([m4_eval], [,], [[[1+2]],
11263                             [[10], [16]]])
11264 @result{}3,a
11265 m4_map_sep([m4_echo], [,], [[[a]], [[b]]])
11266 @result{}a,b
11267 m4_count(m4_map_sep([m4_echo], [,], [[[a]], [[b]]]))
11268 @result{}2
11269 m4_map_sep([m4_echo], [[,]], [[[a]], [[b]]])
11270 @result{}a,b
11271 m4_count(m4_map_sep([m4_echo], [[,]], [[[a]], [[b]]]))
11272 @result{}1
11273 @end example
11274 @end defmac
11276 @defmac m4_map_args (@var{macro}, @var{arg}@dots{})
11277 @msindex{map_args}
11278 Repeatedly invoke @var{macro} with each successive @var{arg} as its only
11279 argument.  In the following example, three solutions are presented with
11280 the same expansion; the solution using @code{m4_map_args} is the most
11281 efficient.
11282 @example
11283 m4_define([active], [ACTIVE])dnl
11284 m4_foreach([var], [[plain], [active]], [ m4_echo(m4_defn([var]))])
11285 @result{} plain active
11286 m4_map([ m4_echo], [[[plain]], [[active]]])
11287 @result{} plain active
11288 m4_map_args([ m4_echo], [plain], [active])
11289 @result{} plain active
11290 @end example
11292 In cases where it is useful to operate on additional parameters besides
11293 the list elements, the macro @code{m4_curry} can be used in @var{macro}
11294 to supply the argument currying necessary to generate the desired
11295 argument list.  In the following example, @code{list_add_n} is more
11296 efficient than @code{list_add_x}.  On the other hand, using
11297 @code{m4_map_args_sep} can be even more efficient.
11299 @example
11300 m4_define([list], [[1], [2], [3]])dnl
11301 m4_define([add], [m4_eval(([$1]) + ([$2]))])dnl
11302 dnl list_add_n(N, ARG...)
11303 dnl Output a list consisting of each ARG added to N
11304 m4_define([list_add_n],
11305 [m4_shift(m4_map_args([,m4_curry([add], [$1])], m4_shift($@@)))])dnl
11306 list_add_n([1], list)
11307 @result{}2,3,4
11308 list_add_n([2], list)
11309 @result{}3,4,5
11310 m4_define([list_add_x],
11311 [m4_shift(m4_foreach([var], m4_dquote(m4_shift($@@)),
11312   [,add([$1],m4_defn([var]))]))])dnl
11313 list_add_x([1], list)
11314 @result{}2,3,4
11315 @end example
11316 @end defmac
11318 @defmac m4_map_args_pair (@var{macro}, @dvar{macro-end, macro}, @
11319   @var{arg}@dots{})
11320 @msindex{map_args_pair}
11321 For every pair of arguments @var{arg}, invoke @var{macro} with two
11322 arguments.  If there is an odd number of arguments, invoke
11323 @var{macro-end}, which defaults to @var{macro}, with the remaining
11324 argument.
11326 @example
11327 m4_map_args_pair([, m4_reverse], [], [1], [2], [3])
11328 @result{}, 2, 1, 3
11329 m4_map_args_pair([, m4_reverse], [, m4_dquote], [1], [2], [3])
11330 @result{}, 2, 1, [3]
11331 m4_map_args_pair([, m4_reverse], [, m4_dquote], [1], [2], [3], [4])
11332 @result{}, 2, 1, 4, 3
11333 @end example
11334 @end defmac
11336 @defmac m4_map_args_sep (@ovar{pre}, @ovar{post}, @ovar{sep}, @var{arg}@dots{})
11337 @msindex{map_args_sep}
11338 Expand the sequence @code{@var{pre}[@var{arg}]@var{post}} for each
11339 argument, additionally expanding @var{sep} between arguments.  One
11340 common use of this macro is constructing a macro call, where the opening
11341 and closing parentheses are split between @var{pre} and @var{post}; in
11342 particular, @code{m4_map_args([@var{macro}], [@var{arg}])} is equivalent
11343 to @code{m4_map_args_sep([@var{macro}(], [)], [], [@var{arg}])}.  This
11344 macro provides the most efficient means for iterating over an arbitrary
11345 list of arguments, particularly when repeatedly constructing a macro
11346 call with more arguments than @var{arg}.
11347 @end defmac
11349 @defmac m4_map_args_w (@var{string}, @ovar{pre}, @ovar{post}, @ovar{sep})
11350 @msindex{map_args_w}
11351 Expand the sequence @code{@var{pre}[word]@var{post}} for each word in
11352 the whitespace-separated @var{string}, additionally expanding @var{sep}
11353 between words.  This macro provides the most efficient means for
11354 iterating over a whitespace-separated string.  In particular,
11355 @code{m4_map_args_w([@var{string}], [@var{action}(], [)])} is more
11356 efficient than @code{m4_foreach_w([var], [@var{string}],
11357 [@var{action}(m4_defn([var]))])}.
11358 @end defmac
11360 @defmac m4_shiftn (@var{count}, @dots{})
11361 @defmacx m4_shift2 (@dots{})
11362 @defmacx m4_shift3 (@dots{})
11363 @msindex{shift2}
11364 @msindex{shift3}
11365 @msindex{shiftn}
11366 @code{m4_shiftn} performs @var{count} iterations of @code{m4_shift},
11367 along with validation that enough arguments were passed in to match the
11368 shift count, and that the count is positive.  @code{m4_shift2} and
11369 @code{m4_shift3} are specializations
11370 of @code{m4_shiftn}, introduced in Autoconf 2.62, and are more efficient
11371 for two and three shifts, respectively.
11372 @end defmac
11374 @defmac m4_stack_foreach (@var{macro}, @var{action})
11375 @defmacx m4_stack_foreach_lifo (@var{macro}, @var{action})
11376 @msindex{stack_foreach}
11377 @msindex{stack_foreach_lifo}
11378 For each of the @code{m4_pushdef} definitions of @var{macro}, expand
11379 @var{action} with the single argument of a definition of @var{macro}.
11380 @code{m4_stack_foreach} starts with the oldest definition, while
11381 @code{m4_stack_foreach_lifo} starts with the current definition.
11382 @var{action} should not push or pop definitions of @var{macro}, nor is
11383 there any guarantee that the current definition of @var{macro} matches
11384 the argument that was passed to @var{action}.  The macro @code{m4_curry}
11385 can be used if @var{action} needs more than one argument, although in
11386 that case it is more efficient to use @var{m4_stack_foreach_sep}.
11388 Due to technical limitations, there are a few low-level m4sugar
11389 functions, such as @code{m4_pushdef}, that cannot be used as the
11390 @var{macro} argument.
11392 @example
11393 m4_pushdef([a], [1])m4_pushdef([a], [2])dnl
11394 m4_stack_foreach([a], [ m4_incr])
11395 @result{} 2 3
11396 m4_stack_foreach_lifo([a], [ m4_curry([m4_substr], [abcd])])
11397 @result{} cd bcd
11398 @end example
11399 @end defmac
11401 @defmac m4_stack_foreach_sep (@var{macro}, @ovar{pre}, @ovar{post}, @ovar{sep})
11402 @defmacx m4_stack_foreach_sep_lifo (@var{macro}, @ovar{pre}, @ovar{post}, @
11403   @ovar{sep})
11404 @msindex{stack_foreach_sep}
11405 @msindex{stack_foreach_sep_lifo}
11406 Expand the sequence @code{@var{pre}[definition]@var{post}} for each
11407 @code{m4_pushdef} definition of @var{macro}, additionally expanding
11408 @var{sep} between definitions.  @code{m4_stack_foreach_sep} visits the
11409 oldest definition first, while @code{m4_stack_foreach_sep_lifo} visits
11410 the current definition first.  This macro provides the most efficient
11411 means for iterating over a pushdef stack.  In particular,
11412 @code{m4_stack_foreach([@var{macro}], [@var{action}])} is short for
11413 @code{m4_stack_foreach_sep([@var{macro}], [@var{action}(], [)])}.
11414 @end defmac
11416 @node Evaluation Macros
11417 @subsection Evaluation Macros
11419 The following macros give some control over the order of the evaluation
11420 by adding or removing levels of quotes.
11422 @defmac m4_apply (@var{macro}, @var{list})
11423 @msindex{apply}
11424 Apply the elements of the quoted, comma-separated @var{list} as the
11425 arguments to @var{macro}.  If @var{list} is empty, invoke @var{macro}
11426 without arguments.  Note the difference between @code{m4_indir}, which
11427 expects its first argument to be a macro name but can use names that are
11428 otherwise invalid, and @code{m4_apply}, where @var{macro} can contain
11429 other text, but must end in a valid macro name.
11430 @example
11431 m4_apply([m4_count], [])
11432 @result{}0
11433 m4_apply([m4_count], [[]])
11434 @result{}1
11435 m4_apply([m4_count], [[1], [2]])
11436 @result{}2
11437 m4_apply([m4_join], [[|], [1], [2]])
11438 @result{}1|2
11439 @end example
11440 @end defmac
11442 @defmac m4_count (@var{arg}, @dots{})
11443 @msindex{count}
11444 This macro returns the decimal count of the number of arguments it was
11445 passed.
11446 @end defmac
11448 @defmac m4_curry (@var{macro}, @var{arg}@dots{})
11449 @msindex{curry}
11450 This macro performs argument currying.  The expansion of this macro is
11451 another macro name that expects exactly one argument; that argument is
11452 then appended to the @var{arg} list, and then @var{macro} is expanded
11453 with the resulting argument list.
11455 @example
11456 m4_curry([m4_curry], [m4_reverse], [1])([2])([3])
11457 @result{}3, 2, 1
11458 @end example
11460 Unfortunately, due to a limitation in M4 1.4.x, it is not possible to
11461 pass the definition of a builtin macro as the argument to the output of
11462 @code{m4_curry}; the empty string is used instead of the builtin token.
11463 This behavior is rectified by using M4 1.6 or newer.
11464 @end defmac
11466 @defmac m4_do (@var{arg}, @dots{})
11467 @msindex{do}
11468 This macro loops over its arguments and expands each @var{arg} in
11469 sequence.  Its main use is for readability; it allows the use of
11470 indentation and fewer @code{dnl} to result in the same expansion.  This
11471 macro guarantees that no expansion will be concatenated with subsequent
11472 text; to achieve full concatenation, use @code{m4_unquote(m4_join([],
11473 @var{arg@dots{}}))}.
11475 @example
11476 m4_define([ab],[1])m4_define([bc],[2])m4_define([abc],[3])dnl
11477 m4_do([a],[b])c
11478 @result{}abc
11479 m4_unquote(m4_join([],[a],[b]))c
11480 @result{}3
11481 m4_define([a],[A])m4_define([b],[B])m4_define([c],[C])dnl
11482 m4_define([AB],[4])m4_define([BC],[5])m4_define([ABC],[6])dnl
11483 m4_do([a],[b])c
11484 @result{}ABC
11485 m4_unquote(m4_join([],[a],[b]))c
11486 @result{}3
11487 @end example
11488 @end defmac
11490 @defmac m4_dquote (@var{arg}, @dots{})
11491 @msindex{dquote}
11492 Return the arguments as a quoted list of quoted arguments.
11493 Conveniently, if there is just one @var{arg}, this effectively adds a
11494 level of quoting.
11495 @end defmac
11497 @defmac m4_dquote_elt (@var{arg}, @dots{})
11498 @msindex{dquote_elt}
11499 Return the arguments as a series of double-quoted arguments.  Whereas
11500 @code{m4_dquote} returns a single argument, @code{m4_dquote_elt} returns
11501 as many arguments as it was passed.
11502 @end defmac
11504 @defmac m4_echo (@var{arg}, @dots{})
11505 @msindex{echo}
11506 Return the arguments, with the same level of quoting.  Other than
11507 discarding whitespace after unquoted commas, this macro is a no-op.
11508 @end defmac
11510 @defmac m4_expand (@var{arg})
11511 @msindex{expand}
11512 Return the expansion of @var{arg} as a quoted string.  Whereas
11513 @code{m4_quote} is designed to collect expanded text into a single
11514 argument, @code{m4_expand} is designed to perform one level of expansion
11515 on quoted text.  One distinction is in the treatment of whitespace
11516 following a comma in the original @var{arg}.  Any time multiple
11517 arguments are collected into one with @code{m4_quote}, the M4 argument
11518 collection rules discard the whitespace.  However, with @code{m4_expand},
11519 whitespace is preserved, even after the expansion of macros contained in
11520 @var{arg}.  Additionally, @code{m4_expand} is able to expand text that
11521 would involve an unterminated comment, whereas expanding that same text
11522 as the argument to @code{m4_quote} runs into difficulty in finding the
11523 end of the argument.  Since manipulating diversions during argument
11524 collection is inherently unsafe, @code{m4_expand} issues an error if
11525 @var{arg} attempts to change the current diversion (@pxref{Diversion
11526 support}).
11528 @example
11529 m4_define([active], [ACT, IVE])dnl
11530 m4_define([active2], [[ACT, IVE]])dnl
11531 m4_quote(active, active)
11532 @result{}ACT,IVE,ACT,IVE
11533 m4_expand([active, active])
11534 @result{}ACT, IVE, ACT, IVE
11535 m4_quote(active2, active2)
11536 @result{}ACT, IVE,ACT, IVE
11537 m4_expand([active2, active2])
11538 @result{}ACT, IVE, ACT, IVE
11539 m4_expand([# m4_echo])
11540 @result{}# m4_echo
11541 m4_quote(# m4_echo)
11543 @result{}# m4_echo)
11544 @result{}
11545 @end example
11547 Note that @code{m4_expand} cannot handle an @var{arg} that expands to
11548 literal unbalanced quotes, but that quadrigraphs can be used when
11549 unbalanced output is necessary.  Likewise, unbalanced parentheses should
11550 be supplied with double quoting or a quadrigraph.
11552 @example
11553 m4_define([pattern], [[!@@<:@@]])dnl
11554 m4_define([bar], [BAR])dnl
11555 m4_expand([case $foo in
11556   m4_defn([pattern])@@:@}@@ bar ;;
11557   *[)] blah ;;
11558 esac])
11559 @result{}case $foo in
11560 @result{}  [![]) BAR ;;
11561 @result{}  *) blah ;;
11562 @result{}esac
11563 @end example
11564 @end defmac
11566 @defmac m4_ignore (@dots{})
11567 @msindex{ignore}
11568 This macro was introduced in Autoconf 2.62.  Expands to nothing,
11569 ignoring all of its arguments.  By itself, this isn't very useful.
11570 However, it can be used to conditionally ignore an arbitrary number of
11571 arguments, by deciding which macro name to apply to a list of arguments.
11572 @example
11573 dnl foo outputs a message only if [debug] is defined.
11574 m4_define([foo],
11575 [m4_ifdef([debug],[AC_MSG_NOTICE],[m4_ignore])([debug message])])
11576 @end example
11578 Note that for earlier versions of Autoconf, the macro @code{__gnu__} can
11579 serve the same purpose, although it is less readable.
11580 @end defmac
11582 @defmac m4_make_list (@var{arg}, @dots{})
11583 @msindex{make_list}
11584 This macro exists to aid debugging of M4sugar algorithms.  Its net
11585 effect is similar to @code{m4_dquote}---it produces a quoted list of
11586 quoted arguments, for each @var{arg}.  The difference is that this
11587 version uses a comma-newline separator instead of just comma, to improve
11588 readability of the list; with the result that it is less efficient than
11589 @code{m4_dquote}.
11590 @example
11591 m4_define([zero],[0])m4_define([one],[1])m4_define([two],[2])dnl
11592 m4_dquote(zero, [one], [[two]])
11593 @result{}[0],[one],[[two]]
11594 m4_make_list(zero, [one], [[two]])
11595 @result{}[0],
11596 @result{}[one],
11597 @result{}[[two]]
11598 m4_foreach([number], m4_dquote(zero, [one], [[two]]), [ number])
11599 @result{} 0 1 two
11600 m4_foreach([number], m4_make_list(zero, [one], [[two]]), [ number])
11601 @result{} 0 1 two
11602 @end example
11603 @end defmac
11605 @c m4_noquote is too dangerous to document - it invokes macros that
11606 @c probably rely on @samp{[]} nested quoting for proper operation.  The
11607 @c user should generally prefer m4_unquote instead.
11609 @defmac m4_quote (@var{arg}, @dots{})
11610 @msindex{quote}
11611 Return the arguments as a single entity, i.e., wrap them into a pair of
11612 quotes.  This effectively collapses multiple arguments into one,
11613 although it loses whitespace after unquoted commas in the process.
11614 @end defmac
11616 @defmac m4_reverse (@var{arg}, @dots{})
11617 @msindex{reverse}
11618 Outputs each argument with the same level of quoting, but in reverse
11619 order, and with space following each comma for readability.
11621 @example
11622 m4_define([active], [ACT,IVE])
11623 @result{}
11624 m4_reverse(active, [active])
11625 @result{}active, IVE, ACT
11626 @end example
11627 @end defmac
11629 @defmac m4_unquote (@var{arg}, @dots{})
11630 @msindex{unquote}
11631 This macro was introduced in Autoconf 2.62.  Expand each argument,
11632 separated by commas.  For a single @var{arg}, this effectively removes a
11633 layer of quoting, and @code{m4_unquote([@var{arg}])} is more efficient
11634 than the equivalent @code{m4_do([@var{arg}])}.  For multiple arguments,
11635 this results in an unquoted list of expansions.  This is commonly used
11636 with @code{m4_split}, in order to convert a single quoted list into a
11637 series of quoted elements.
11638 @end defmac
11640 The following example aims at emphasizing the difference between several
11641 scenarios: not using these macros, using @code{m4_defn}, using
11642 @code{m4_quote}, using @code{m4_dquote}, and using @code{m4_expand}.
11644 @example
11645 $ @kbd{cat example.m4}
11646 dnl Overquote, so that quotes are visible.
11647 m4_define([show], [$[]1 = [$1], $[]@@ = [$@@]])
11648 m4_define([a], [A])
11649 m4_define([mkargs], [1, 2[,] 3])
11650 m4_define([arg1], [[$1]])
11651 m4_divert([0])dnl
11652 show(a, b)
11653 show([a, b])
11654 show(m4_quote(a, b))
11655 show(m4_dquote(a, b))
11656 show(m4_expand([a, b]))
11658 arg1(mkargs)
11659 arg1([mkargs])
11660 arg1(m4_defn([mkargs]))
11661 arg1(m4_quote(mkargs))
11662 arg1(m4_dquote(mkargs))
11663 arg1(m4_expand([mkargs]))
11664 $ @kbd{autom4te -l m4sugar example.m4}
11665 $1 = A, $@@ = [A],[b]
11666 $1 = a, b, $@@ = [a, b]
11667 $1 = A,b, $@@ = [A,b]
11668 $1 = [A],[b], $@@ = [[A],[b]]
11669 $1 = A, b, $@@ = [A, b]
11672 mkargs
11673 1, 2[,] 3
11674 1,2, 3
11675 [1],[2, 3]
11676 1, 2, 3
11677 @end example
11680 @node Text processing Macros
11681 @subsection String manipulation in M4
11683 The following macros may be used to manipulate strings in M4.  Many of
11684 the macros in this section intentionally result in quoted strings as
11685 output, rather than subjecting the arguments to further expansions.  As
11686 a result, if you are manipulating text that contains active M4
11687 characters, the arguments are passed with single quoting rather than
11688 double.
11690 @defmac m4_append (@var{macro-name}, @var{string}, @ovar{separator})
11691 @defmacx m4_append_uniq (@var{macro-name}, @var{string}, @ovar{separator} @
11692   @ovar{if-uniq}, @ovar{if-duplicate})
11693 @msindex{append}
11694 @msindex{append_uniq}
11695 Redefine @var{macro-name} to its former contents with @var{separator}
11696 and @var{string} added at the end.  If @var{macro-name} was undefined
11697 before (but not if it was defined but empty), then no @var{separator} is
11698 added.  As of Autoconf 2.62, neither @var{string} nor @var{separator}
11699 are expanded during this macro; instead, they are expanded when
11700 @var{macro-name} is invoked.
11702 @code{m4_append} can be used to grow strings, and @code{m4_append_uniq}
11703 to grow strings without duplicating substrings.  Additionally,
11704 @code{m4_append_uniq} takes two optional parameters as of Autoconf 2.62;
11705 @var{if-uniq} is expanded if @var{string} was appended, and
11706 @var{if-duplicate} is expanded if @var{string} was already present.
11707 Also, @code{m4_append_uniq} warns if @var{separator} is not empty, but
11708 occurs within @var{string}, since that can lead to duplicates.
11710 Note that @code{m4_append} can scale linearly in the length of the final
11711 string, depending on the quality of the underlying M4 implementation,
11712 while @code{m4_append_uniq} has an inherent quadratic scaling factor.
11713 If an algorithm can tolerate duplicates in the final string, use the
11714 former for speed.  If duplicates must be avoided, consider using
11715 @code{m4_set_add} instead (@pxref{Set manipulation Macros}).
11717 @example
11718 m4_define([active], [ACTIVE])dnl
11719 m4_append([sentence], [This is an])dnl
11720 m4_append([sentence], [ active ])dnl
11721 m4_append([sentence], [symbol.])dnl
11722 sentence
11723 @result{}This is an ACTIVE symbol.
11724 m4_undefine([active])dnl
11725 @result{}This is an active symbol.
11726 m4_append_uniq([list], [one], [, ], [new], [existing])
11727 @result{}new
11728 m4_append_uniq([list], [one], [, ], [new], [existing])
11729 @result{}existing
11730 m4_append_uniq([list], [two], [, ], [new], [existing])
11731 @result{}new
11732 m4_append_uniq([list], [three], [, ], [new], [existing])
11733 @result{}new
11734 m4_append_uniq([list], [two], [, ], [new], [existing])
11735 @result{}existing
11736 list
11737 @result{}one, two, three
11738 m4_dquote(list)
11739 @result{}[one],[two],[three]
11740 m4_append([list2], [one], [[, ]])dnl
11741 m4_append_uniq([list2], [two], [[, ]])dnl
11742 m4_append([list2], [three], [[, ]])dnl
11743 list2
11744 @result{}one, two, three
11745 m4_dquote(list2)
11746 @result{}[one, two, three]
11747 @end example
11748 @end defmac
11750 @defmac m4_append_uniq_w (@var{macro-name}, @var{strings})
11751 @msindex{append_uniq_w}
11752 This macro was introduced in Autoconf 2.62.  It is similar to
11753 @code{m4_append_uniq}, but treats @var{strings} as a whitespace
11754 separated list of words to append, and only appends unique words.
11755 @var{macro-name} is updated with a single space between new words.
11756 @example
11757 m4_append_uniq_w([numbers], [1 1 2])dnl
11758 m4_append_uniq_w([numbers], [ 2 3 ])dnl
11759 numbers
11760 @result{}1 2 3
11761 @end example
11762 @end defmac
11764 @defmac m4_chomp (@var{string})
11765 @defmacx m4_chomp_all (@var{string})
11766 @msindex{chomp}
11767 @msindex{chomp_all}
11768 Output @var{string} in quotes, but without a trailing newline.  The
11769 macro @code{m4_chomp} is slightly faster, and removes at most one
11770 newline; the macro @code{m4_chomp_all} removes all consecutive trailing
11771 newlines.  Unlike @code{m4_flatten}, embedded newlines are left intact,
11772 and backslash does not influence the result.
11773 @end defmac
11775 @defmac m4_combine (@ovar{separator}, @var{prefix-list}, @ovar{infix}, @
11776   @var{suffix-1}, @ovar{suffix-2}, @dots{})
11777 @msindex{combine}
11778 This macro produces a quoted string containing the pairwise combination
11779 of every element of the quoted, comma-separated @var{prefix-list}, and
11780 every element from the @var{suffix} arguments.  Each pairwise
11781 combination is joined with @var{infix} in the middle, and successive
11782 pairs are joined by @var{separator}.  No expansion occurs on any of the
11783 arguments.  No output occurs if either the @var{prefix} or @var{suffix}
11784 list is empty, but the lists can contain empty elements.
11785 @example
11786 m4_define([a], [oops])dnl
11787 m4_combine([, ], [[a], [b], [c]], [-], [1], [2], [3])
11788 @result{}a-1, a-2, a-3, b-1, b-2, b-3, c-1, c-2, c-3
11789 m4_combine([, ], [[a], [b]], [-])
11790 @result{}
11791 m4_combine([, ], [[a], [b]], [-], [])
11792 @result{}a-, b-
11793 m4_combine([, ], [], [-], [1], [2])
11794 @result{}
11795 m4_combine([, ], [[]], [-], [1], [2])
11796 @result{}-1, -2
11797 @end example
11798 @end defmac
11800 @defmac m4_flatten (@var{string})
11801 @msindex{flatten}
11802 Flatten @var{string} into a single line.  Delete all backslash-newline
11803 pairs, and replace all remaining newlines with a space.  The result is
11804 still a quoted string.
11805 @end defmac
11807 @defmac m4_join (@ovar{separator}, @var{args}@dots{})
11808 @defmacx m4_joinall (@ovar{separator}, @var{args}@dots{})
11809 @msindex{join}
11810 @msindex{joinall}
11811 Concatenate each @var{arg}, separated by @var{separator}.
11812 @code{joinall} uses every argument, while @code{join} omits empty
11813 arguments so that there are no back-to-back separators in the output.
11814 The result is a quoted string.
11815 @example
11816 m4_define([active], [ACTIVE])dnl
11817 m4_join([|], [one], [], [active], [two])
11818 @result{}one|active|two
11819 m4_joinall([|], [one], [], [active], [two])
11820 @result{}one||active|two
11821 @end example
11823 Note that if all you intend to do is join @var{args} with commas between
11824 them, to form a quoted list suitable for @code{m4_foreach}, it is more
11825 efficient to use @code{m4_dquote}.
11826 @end defmac
11828 @defmac m4_newline (@ovar{text})
11829 @msindex{newline}
11830 This macro was introduced in Autoconf 2.62, and expands to a newline,
11831 followed by any @var{text}.
11832 It is primarily useful for maintaining macro formatting, and ensuring
11833 that M4 does not discard leading whitespace during argument collection.
11834 @end defmac
11836 @defmac m4_normalize (@var{string})
11837 @msindex{normalize}
11838 Remove leading and trailing spaces and tabs, sequences of
11839 backslash-then-newline, and replace multiple spaces, tabs, and newlines
11840 with a single space.  This is a combination of @code{m4_flatten} and
11841 @code{m4_strip}.  To determine if @var{string} consists only of bytes
11842 that would be removed by @code{m4_normalize}, you can use
11843 @code{m4_ifblank}.
11844 @end defmac
11846 @defmac m4_re_escape (@var{string})
11847 @msindex{re_escape}
11848 Backslash-escape all characters in @var{string} that are active in
11849 regexps.
11850 @end defmac
11852 @defmac m4_split (@var{string}, @dvar{regexp, [\t ]+})
11853 @msindex{split}
11854 Split @var{string} into an M4 list of elements quoted by @samp{[} and
11855 @samp{]}, while keeping white space at the beginning and at the end.
11856 If @var{regexp} is given, use it instead of @samp{[\t ]+} for splitting.
11857 If @var{string} is empty, the result is an empty list.
11858 @end defmac
11860 @defmac m4_strip (@var{string})
11861 @msindex{strip}
11862 Strip whitespace from @var{string}.  Sequences of spaces and tabs are
11863 reduced to a single space, then leading and trailing spaces are removed.
11864 The result is still a quoted string.  Note that this does not interfere
11865 with newlines; if you want newlines stripped as well, consider
11866 @code{m4_flatten}, or do it all at once with @code{m4_normalize}.  To
11867 quickly test if @var{string} has only whitespace, use @code{m4_ifblank}.
11868 @end defmac
11870 @defmac m4_text_box (@var{message}, @dvar{frame, -})
11871 @msindex{text_box}
11872 Add a text box around @var{message}, using @var{frame} as the border
11873 character above and below the message.  The frame correctly accounts for
11874 the subsequent expansion of @var{message}.  For example:
11875 @example
11876 m4_define([macro], [abc])dnl
11877 m4_text_box([macro])
11878 @result{}## --- ##
11879 @result{}## abc ##
11880 @result{}## --- ##
11881 @end example
11883 The @var{message} must contain balanced quotes and parentheses, although
11884 quadrigraphs can be used to work around this.
11885 @end defmac
11887 @defmac m4_text_wrap (@var{string}, @ovar{prefix}, @
11888   @dvar{prefix1, @var{prefix}}, @dvar{width, 79})
11889 @msindex{text_wrap}
11890 Break @var{string} into a series of whitespace-separated words, then
11891 output those words separated by spaces, and wrapping lines any time the
11892 output would exceed @var{width} columns.  If given, @var{prefix1} begins
11893 the first line, and @var{prefix} begins all wrapped lines.  If
11894 @var{prefix1} is longer than @var{prefix}, then the first line consists
11895 of just @var{prefix1}.  If @var{prefix} is longer than @var{prefix1},
11896 padding is inserted so that the first word of @var{string} begins at the
11897 same indentation as all wrapped lines.  Note that using literal tab
11898 characters in any of the arguments will interfere with the calculation
11899 of width.  No expansions occur on @var{prefix}, @var{prefix1}, or the
11900 words of @var{string}, although quadrigraphs are recognized.
11902 For some examples:
11903 @example
11904 m4_text_wrap([Short string */], [   ], [/* ], [20])
11905 @result{}/* Short string */
11906 m4_text_wrap([Much longer string */], [   ], [/* ], [20])
11907 @result{}/* Much longer
11908 @result{}   string */
11909 m4_text_wrap([Short doc.], [          ], [  --short ], [30])
11910 @result{}  --short Short doc.
11911 m4_text_wrap([Short doc.], [          ], [  --too-wide ], [30])
11912 @result{}  --too-wide
11913 @result{}          Short doc.
11914 m4_text_wrap([Super long documentation.], [     ],
11915              [  --too-wide ], 30)
11916 @result{}  --too-wide
11917 @result{}     Super long
11918 @result{}     documentation.
11919 @end example
11920 @end defmac
11922 @defmac m4_tolower (@var{string})
11923 @defmacx m4_toupper (@var{string})
11924 @msindex{tolower}
11925 @msindex{toupper}
11926 Return @var{string} with letters converted to upper or lower case,
11927 respectively.
11928 @end defmac
11930 @node Number processing Macros
11931 @subsection Arithmetic computation in M4
11933 The following macros facilitate integer arithmetic operations.
11934 Where a parameter is documented as taking an arithmetic expression, you
11935 can use anything that can be parsed by @code{m4_eval}.
11937 @defmac m4_cmp (@var{expr-1}, @var{expr-2})
11938 @msindex{cmp}
11939 Compare the arithmetic expressions @var{expr-1} and @var{expr-2}, and
11940 expand to @samp{-1} if @var{expr-1} is smaller, @samp{0} if they are
11941 equal, and @samp{1} if @var{expr-1} is larger.
11942 @end defmac
11944 @defmac m4_list_cmp (@var{list-1}, @var{list-2})
11945 @msindex{list_cmp}
11946 Compare the two M4 lists consisting of comma-separated arithmetic
11947 expressions, left to right.  Expand to @samp{-1} for the first element
11948 pairing where the value from @var{list-1} is smaller, @samp{1} where the
11949 value from @var{list-2} is smaller, or @samp{0} if both lists have the
11950 same values.  If one list is shorter than the other, the remaining
11951 elements of the longer list are compared against zero.
11952 @example
11953 m4_list_cmp([1, 0],       [1])
11954 @result{}0
11955 m4_list_cmp([1, [1 * 0]], [1, 0])
11956 @result{}0
11957 m4_list_cmp([1, 2],       [1, 0])
11958 @result{}1
11959 m4_list_cmp([1, [1+1], 3],[1, 2])
11960 @result{}1
11961 m4_list_cmp([1, 2, -3],   [1, 2])
11962 @result{}-1
11963 m4_list_cmp([1, 0],       [1, 2])
11964 @result{}-1
11965 m4_list_cmp([1],          [1, 2])
11966 @result{}-1
11967 @end example
11968 @end defmac
11970 @defmac m4_max (@var{arg}, @dots{})
11971 @msindex{max}
11972 This macro was introduced in Autoconf 2.62.  Expand to the decimal value
11973 of the maximum arithmetic expression among all the arguments.
11974 @end defmac
11976 @defmac m4_min (@var{arg}, @dots{})
11977 @msindex{min}
11978 This macro was introduced in Autoconf 2.62.  Expand to the decimal value
11979 of the minimum arithmetic expression among all the arguments.
11980 @end defmac
11982 @defmac m4_sign (@var{expr})
11983 @msindex{sign}
11984 Expand to @samp{-1} if the arithmetic expression @var{expr} is negative,
11985 @samp{1} if it is positive, and @samp{0} if it is zero.
11986 @end defmac
11988 @anchor{m4_version_compare}
11989 @defmac m4_version_compare (@var{version-1}, @var{version-2})
11990 @msindex{version_compare}
11991 This macro was introduced in Autoconf 2.53, but had a number of
11992 usability limitations that were not lifted until Autoconf 2.62.  Compare
11993 the version strings @var{version-1} and @var{version-2}, and expand to
11994 @samp{-1} if @var{version-1} is smaller, @samp{0} if they are the same,
11995 or @samp{1} @var{version-2} is smaller.  Version strings must be a list
11996 of elements separated by @samp{.}, @samp{,} or @samp{-}, where each
11997 element is a number along with optional case-insensitive letters
11998 designating beta releases.  The comparison stops at the leftmost element
11999 that contains a difference, although a 0 element compares equal to a
12000 missing element.
12002 It is permissible to include commit identifiers in @var{version}, such
12003 as an abbreviated SHA1 of the commit, provided there is still a
12004 monotonically increasing prefix to allow for accurate version-based
12005 comparisons.  For example, this paragraph was written when the
12006 development snapshot of autoconf claimed to be at version
12007 @samp{2.61a-248-dc51}, or 248 commits after the 2.61a release, with an
12008 abbreviated commit identification of @samp{dc51}.
12010 @example
12011 m4_version_compare([1.1], [2.0])
12012 @result{}-1
12013 m4_version_compare([2.0b], [2.0a])
12014 @result{}1
12015 m4_version_compare([1.1.1], [1.1.1a])
12016 @result{}-1
12017 m4_version_compare([1.2], [1.1.1a])
12018 @result{}1
12019 m4_version_compare([1.0], [1])
12020 @result{}0
12021 m4_version_compare([1.1pre], [1.1PRE])
12022 @result{}0
12023 m4_version_compare([1.1a], [1,10])
12024 @result{}-1
12025 m4_version_compare([2.61a], [2.61a-248-dc51])
12026 @result{}-1
12027 m4_version_compare([2.61b], [2.61a-248-dc51])
12028 @result{}1
12029 @end example
12030 @end defmac
12032 @defmac m4_version_prereq (@var{version}, @ovar{if-new-enough}, @
12033   @dvar{if-old, m4_fatal})
12034 @msindex{version_prereq}
12035 Compares @var{version} against the version of Autoconf currently
12036 running.  If the running version is at @var{version} or newer, expand
12037 @var{if-new-enough}, but if @var{version} is larger than the version
12038 currently executing, expand @var{if-old}, which defaults to printing an
12039 error message and exiting m4sugar with status 63.  When given only one
12040 argument, this behaves like @code{AC_PREREQ} (@pxref{Versioning}).
12041 Remember that the autoconf philosophy favors feature checks over version
12042 checks.
12043 @end defmac
12045 @node Set manipulation Macros
12046 @subsection Set manipulation in M4
12047 @cindex Set manipulation
12048 @cindex Data structure, set
12049 @cindex Unordered set manipulation
12051 Sometimes, it is necessary to track a set of data, where the order does
12052 not matter and where there are no duplicates in the set.  The following
12053 macros facilitate set manipulations.  Each set is an opaque object,
12054 which can only be accessed via these basic operations.  The underlying
12055 implementation guarantees linear scaling for set creation, which is more
12056 efficient than using the quadratic @code{m4_append_uniq}.  Both set
12057 names and values can be arbitrary strings, except for unbalanced quotes.
12058 This implementation ties up memory for removed elements until the next
12059 operation that must traverse all the elements of a set; and although
12060 that may slow down some operations until the memory for removed elements
12061 is pruned, it still guarantees linear performance.
12063 @defmac m4_set_add (@var{set}, @var{value}, @ovar{if-uniq}, @ovar{if-dup})
12064 @msindex{set_add}
12065 Adds the string @var{value} as a member of set @var{set}.  Expand
12066 @var{if-uniq} if the element was added, or @var{if-dup} if it was
12067 previously in the set.  Operates in amortized constant time, so that set
12068 creation scales linearly.
12069 @end defmac
12071 @defmac m4_set_add_all (@var{set}, @var{value}@dots{})
12072 @msindex{set_add_all}
12073 Adds each @var{value} to the set @var{set}.  This is slightly more
12074 efficient than repeatedly invoking @code{m4_set_add}.
12075 @end defmac
12077 @defmac m4_set_contains (@var{set}, @var{value}, @ovar{if-present}, @
12078  @ovar{if-absent})
12079 @msindex{set_contains}
12080 Expands @var{if-present} if the string @var{value} is a member of
12081 @var{set}, otherwise @var{if-absent}.
12083 @example
12084 m4_set_contains([a], [1], [yes], [no])
12085 @result{}no
12086 m4_set_add([a], [1], [added], [dup])
12087 @result{}added
12088 m4_set_add([a], [1], [added], [dup])
12089 @result{}dup
12090 m4_set_contains([a], [1], [yes], [no])
12091 @result{}yes
12092 m4_set_remove([a], [1], [removed], [missing])
12093 @result{}removed
12094 m4_set_contains([a], [1], [yes], [no])
12095 @result{}no
12096 m4_set_remove([a], [1], [removed], [missing])
12097 @result{}missing
12098 @end example
12099 @end defmac
12101 @defmac m4_set_contents (@var{set}, @ovar{sep})
12102 @defmacx m4_set_dump (@var{set}, @ovar{sep})
12103 @msindex{set_contents}
12104 @msindex{set_dump}
12105 Expands to a single string consisting of all the members of the set
12106 @var{set}, each separated by @var{sep}, which is not expanded.
12107 @code{m4_set_contents} leaves the elements in @var{set} but reclaims any
12108 memory occupied by removed elements, while @code{m4_set_dump} is a
12109 faster one-shot action that also deletes the set.  No provision is made
12110 for disambiguating members that contain a non-empty @var{sep} as a
12111 substring; use @code{m4_set_empty} to distinguish between an empty set
12112 and the set containing only the empty string.  The order of the output
12113 is unspecified; in the current implementation, part of the speed of
12114 @code{m4_set_dump} results from using a different output order than
12115 @code{m4_set_contents}.  These macros scale linearly in the size of the
12116 set before memory pruning, and @code{m4_set_contents([@var{set}],
12117 [@var{sep}])} is faster than
12118 @code{m4_joinall([@var{sep}]m4_set_listc([@var{set}]))}.
12120 @example
12121 m4_set_add_all([a], [1], [2], [3])
12122 @result{}
12123 m4_set_contents([a], [-])
12124 @result{}1-2-3
12125 m4_joinall([-]m4_set_listc([a]))
12126 @result{}1-2-3
12127 m4_set_dump([a], [-])
12128 @result{}3-2-1
12129 m4_set_contents([a])
12130 @result{}
12131 m4_set_add([a], [])
12132 @result{}
12133 m4_set_contents([a], [-])
12134 @result{}
12135 @end example
12136 @end defmac
12138 @defmac m4_set_delete (@var{set})
12139 @msindex{set_delete}
12140 Delete all elements and memory associated with @var{set}.  This is
12141 linear in the set size, and faster than removing one element at a time.
12142 @end defmac
12144 @defmac m4_set_difference (@var{seta}, @var{setb})
12145 @defmacx m4_set_intersection (@var{seta}, @var{setb})
12146 @defmacx m4_set_union (@var{seta}, @var{setb})
12147 @msindex{set_difference}
12148 @msindex{set_intersection}
12149 @msindex{set_union}
12150 Compute the relation between @var{seta} and @var{setb}, and output the
12151 result as a list of quoted arguments without duplicates and with a
12152 leading comma.  Set difference selects the elements in @var{seta} but
12153 not @var{setb}, intersection selects only elements in both sets, and
12154 union selects elements in either set.  These actions are linear in the
12155 sum of the set sizes.  The leading comma is necessary to distinguish
12156 between no elements and the empty string as the only element.
12158 @example
12159 m4_set_add_all([a], [1], [2], [3])
12160 @result{}
12161 m4_set_add_all([b], [3], [], [4])
12162 @result{}
12163 m4_set_difference([a], [b])
12164 @result{},1,2
12165 m4_set_difference([b], [a])
12166 @result{},,4
12167 m4_set_intersection([a], [b])
12168 @result{},3
12169 m4_set_union([a], [b])
12170 @result{},1,2,3,,4
12171 @end example
12172 @end defmac
12174 @defmac m4_set_empty (@var{set}, @ovar{if-empty}, @ovar{if-elements})
12175 @msindex{set_empty}
12176 Expand @var{if-empty} if the set @var{set} has no elements, otherwise
12177 expand @var{if-elements}.  This macro operates in constant time.  Using
12178 this macro can help disambiguate output from @code{m4_set_contents} or
12179 @code{m4_set_list}.
12180 @end defmac
12182 @defmac m4_set_foreach (@var{set}, @var{variable}, @var{action})
12183 @msindex{set_foreach}
12184 For each element in the set @var{set}, expand @var{action} with the
12185 macro @var{variable} defined as the set element.  Behavior is
12186 unspecified if @var{action} recursively lists the contents of @var{set}
12187 (although listing other sets is acceptable), or if it modifies the set
12188 in any way other than removing the element currently contained in
12189 @var{variable}.  This macro is faster than the corresponding
12190 @code{m4_foreach([@var{variable}],
12191 m4_indir([m4_dquote]m4_set_listc([@var{set}])), [@var{action}])},
12192 although @code{m4_set_map} might be faster still.
12194 @example
12195 m4_set_add_all([a]m4_for([i], [1], [5], [], [,i]))
12196 @result{}
12197 m4_set_contents([a])
12198 @result{}12345
12199 m4_set_foreach([a], [i],
12200   [m4_if(m4_eval(i&1), [0], [m4_set_remove([a], i, [i])])])
12201 @result{}24
12202 m4_set_contents([a])
12203 @result{}135
12204 @end example
12205 @end defmac
12207 @defmac m4_set_list (@var{set})
12208 @defmacx m4_set_listc (@var{set})
12209 @msindex{set_list}
12210 @msindex{set_listc}
12211 Produce a list of arguments, where each argument is a quoted element
12212 from the set @var{set}.  The variant @code{m4_set_listc} is unambiguous,
12213 by adding a leading comma if there are any set elements, whereas the
12214 variant @code{m4_set_list} cannot distinguish between an empty set and a
12215 set containing only the empty string.  These can be directly used in
12216 macros that take multiple arguments, such as @code{m4_join} or
12217 @code{m4_set_add_all}, or wrapped by @code{m4_dquote} for macros that
12218 take a quoted list, such as @code{m4_map} or @code{m4_foreach}.  Any
12219 memory occupied by removed elements is reclaimed during these macros.
12221 @example
12222 m4_set_add_all([a], [1], [2], [3])
12223 @result{}
12224 m4_set_list([a])
12225 @result{}1,2,3
12226 m4_set_list([b])
12227 @result{}
12228 m4_set_listc([b])
12229 @result{}
12230 m4_count(m4_set_list([b]))
12231 @result{}1
12232 m4_set_empty([b], [0], [m4_count(m4_set_list([b]))])
12233 @result{}0
12234 m4_set_add([b], [])
12235 @result{}
12236 m4_set_list([b])
12237 @result{}
12238 m4_set_listc([b])
12239 @result{},
12240 m4_count(m4_set_list([b]))
12241 @result{}1
12242 m4_set_empty([b], [0], [m4_count(m4_set_list([b]))])
12243 @result{}1
12244 @end example
12245 @end defmac
12247 @defmac m4_set_map (@var{set}, @var{action})
12248 @msindex{set_map}
12249 For each element in the set @var{set}, expand @var{action} with a single
12250 argument of the set element.  Behavior is unspecified if @var{action}
12251 recursively lists the contents of @var{set} (although listing other sets
12252 is acceptable), or if it modifies the set in any way other than removing
12253 the element passed as an argument.  This macro is faster than either
12254 corresponding counterpart of
12255 @code{m4_map_args([@var{action}]m4_set_listc([@var{set}]))} or
12256 @code{m4_set_foreach([@var{set}], [var],
12257 [@var{action}(m4_defn([var]))])}.  It is possible to use @code{m4_curry}
12258 if more than one argument is needed for @var{action}, although it is
12259 more efficient to use @code{m4_set_map_sep} in that case.
12260 @end defmac
12262 @defmac m4_set_map_sep (@var{set}, @ovar{pre}, @ovar{post}, @ovar{sep})
12263 @msindex{set_map_sep}
12264 For each element in the set @var{set}, expand
12265 @code{@var{pre}[element]@var{post}}, additionally expanding @var{sep}
12266 between elements.  Behavior is unspecified if the expansion recursively
12267 lists the contents of @var{set} (although listing other sets
12268 is acceptable), or if it modifies the set in any way other than removing
12269 the element visited by the expansion.  This macro provides the most
12270 efficient means for non-destructively visiting the elements of a set; in
12271 particular, @code{m4_set_map([@var{set}], [@var{action}])} is equivalent
12272 to @code{m4_set_map_sep([@var{set}], [@var{action}(], [)])}.
12273 @end defmac
12275 @defmac m4_set_remove (@var{set}, @var{value}, @ovar{if-present}, @
12276  @ovar{if-absent})
12277 @msindex{set_remove}
12278 If @var{value} is an element in the set @var{set}, then remove it and
12279 expand @var{if-present}.  Otherwise expand @var{if-absent}.  This macro
12280 operates in constant time so that multiple removals will scale linearly
12281 rather than quadratically; but when used outside of
12282 @code{m4_set_foreach} or @code{m4_set_map}, it leaves memory occupied
12283 until the set is later
12284 compacted by @code{m4_set_contents} or @code{m4_set_list}.  Several
12285 other set operations are then less efficient between the time of element
12286 removal and subsequent memory compaction, but still maintain their
12287 guaranteed scaling performance.
12288 @end defmac
12290 @defmac m4_set_size (@var{set})
12291 @msindex{set_size}
12292 Expand to the size of the set @var{set}.  This implementation operates
12293 in constant time, and is thus more efficient than
12294 @code{m4_eval(m4_count(m4_set_listc([set])) - 1)}.
12295 @end defmac
12298 @node Forbidden Patterns
12299 @subsection Forbidden Patterns
12300 @cindex Forbidden patterns
12301 @cindex Patterns, forbidden
12303 M4sugar provides a means to define suspicious patterns, patterns
12304 describing tokens which should not be found in the output.  For
12305 instance, if an Autoconf @file{configure} script includes tokens such as
12306 @samp{AC_DEFINE}, or @samp{dnl}, then most probably something went
12307 wrong (typically a macro was not evaluated because of overquotation).
12309 M4sugar forbids all the tokens matching @samp{^_?m4_} and @samp{^dnl$}.
12310 Additional layers, such as M4sh and Autoconf, add additional forbidden
12311 patterns to the list.
12313 @defmac m4_pattern_forbid (@var{pattern})
12314 @msindex{pattern_forbid}
12315 Declare that no token matching @var{pattern} must be found in the output.
12316 Comments are not checked; this can be a problem if, for instance, you
12317 have some macro left unexpanded after an @samp{#include}.  No consensus
12318 is currently found in the Autoconf community, as some people consider it
12319 should be valid to name macros in comments (which doesn't make sense to
12320 the authors of this documentation: input, such as macros, should be
12321 documented by @samp{dnl} comments; reserving @samp{#}-comments to
12322 document the output).
12323 @end defmac
12325 Of course, you might encounter exceptions to these generic rules, for
12326 instance you might have to refer to @samp{$m4_flags}.
12328 @defmac m4_pattern_allow (@var{pattern})
12329 @msindex{pattern_allow}
12330 Any token matching @var{pattern} is allowed, including if it matches an
12331 @code{m4_pattern_forbid} pattern.
12332 @end defmac
12334 @node Programming in M4sh
12335 @chapter Programming in M4sh
12337 M4sh, pronounced ``mash'', is aiming at producing portable Bourne shell
12338 scripts.  This name was coined by Lars J. Aas, who notes that,
12339 according to the Webster's Revised Unabridged Dictionary (1913):
12341 @quotation
12342 Mash \Mash\, n.  [Akin to G. meisch, maisch, meische, maische, mash,
12343 wash, and prob.@: to AS. miscian to mix.  See ``Mix''.]
12345 @enumerate 1
12346 @item
12347 A mass of mixed ingredients reduced to a soft pulpy state by beating or
12348 pressure@enddots{}
12350 @item
12351 A mixture of meal or bran and water fed to animals.
12353 @item
12354 A mess; trouble.  [Obs.] --Beau.@: & Fl.
12355 @end enumerate
12356 @end quotation
12358 M4sh reserves the M4 macro namespace @samp{^_AS_} for internal use, and
12359 the namespace @samp{^AS_} for M4sh macros.  It also reserves the shell
12360 and environment variable namespace @samp{^as_}, and the here-doc
12361 delimiter namespace @samp{^_AS[A-Z]} in the output file.  You should not
12362 define your own macros or output shell code that conflicts with these
12363 namespaces.
12365 @menu
12366 * Common Shell Constructs::     Portability layer for common shell constructs
12367 * Polymorphic Variables::       Support for indirect variable names
12368 * Initialization Macros::       Macros to establish a sane shell environment
12369 * File Descriptor Macros::      File descriptor macros for input and output
12370 @end menu
12372 @node Common Shell Constructs
12373 @section Common Shell Constructs
12375 M4sh provides portable alternatives for some common shell constructs
12376 that unfortunately are not portable in practice.
12378 @c Deprecated, to be replaced by a better API
12379 @ignore
12380 @defmac AS_BASENAME (@var{file-name})
12381 @asindex{BASENAME}
12382 Output the non-directory portion of @var{file-name}.  For example,
12383 if @code{$file} is @samp{/one/two/three}, the command
12384 @code{base=`AS_BASENAME(["$file"])`} sets @code{base} to @samp{three}.
12385 @end defmac
12386 @end ignore
12388 @defmac AS_CASE (@var{word}, @ovar{pattern1}, @ovar{if-matched1}, @
12389   @dots{}, @ovar{default})
12390 @asindex{CASE}
12391 Expand into a shell @samp{case} statement, where @var{word} is matched
12392 against one or more patterns.  @var{if-matched} is run if the
12393 corresponding pattern matched @var{word}, else @var{default} is run.
12394 Avoids several portability issues (@pxref{case, , Limitations of Shell
12395 Builtins}).
12396 @end defmac
12398 @c Deprecated, to be replaced by a better API
12399 @ignore
12400 @defmac AS_DIRNAME (@var{file-name})
12401 @asindex{DIRNAME}
12402 Output the directory portion of @var{file-name}.  For example,
12403 if @code{$file} is @samp{/one/two/three}, the command
12404 @code{dir=`AS_DIRNAME(["$file"])`} sets @code{dir} to @samp{/one/two}.
12405 @end defmac
12406 @end ignore
12408 @defmac AS_ECHO (@var{word})
12409 @asindex{ECHO}
12410 Emits @var{word} to the standard output, followed by a newline.  @var{word}
12411 must be a single shell word (typically a quoted string).  The bytes of
12412 @var{word} are output as-is, even if it starts with "-" or contains "\".
12413 Redirections can be placed outside the macro invocation.  This is much
12414 more portable than using @command{echo} (@pxref{echo, , Limitations of
12415 Shell Builtins}).
12416 @end defmac
12418 @defmac AS_ECHO_N (@var{word})
12419 @asindex{ECHO_N}
12420 Emits @var{word} to the standard output, without a following newline.
12421 @var{word} must be a single shell word (typically a quoted string) and,
12422 for portability, should not include more than one newline.  The bytes of
12423 @var{word} are output as-is, even if it starts with "-" or contains "\".
12424 Redirections can be placed outside the macro invocation.
12425 @end defmac
12427 @defmac AS_ESCAPE (@var{string}, @dvar{chars, `\"$})
12428 @asindex{ESCAPE}
12429 Expands to @var{string}, with any characters in @var{chars} escaped with
12430 a backslash (@samp{\}).  @var{chars} should be at most four bytes long,
12431 and only contain characters from the set @samp{`\"$}; however,
12432 characters may be safely listed more than once in @var{chars} for the
12433 sake of syntax highlighting editors.  The current implementation expands
12434 @var{string} after adding escapes; if @var{string} contains macro calls
12435 that in turn expand to text needing shell quoting, you can use
12436 @code{AS_ESCAPE(m4_dquote(m4_expand([string])))}.
12438 The default for @var{chars} (@samp{\"$`}) is the set of characters
12439 needing escapes when @var{string} will be used literally within double
12440 quotes.  One common variant is the set of characters to protect when
12441 @var{string} will be used literally within back-ticks or an unquoted
12442 here-doc (@samp{\$`}).  Another common variant is @samp{""}, which can
12443 be used to form a double-quoted string containing the same expansions
12444 that would have occurred if @var{string} were expanded in an unquoted
12445 here-doc; however, when using this variant, care must be taken that
12446 @var{string} does not use double quotes within complex variable
12447 expansions (such as @samp{$@{foo-`echo "hi"`@}}) that would be broken
12448 with improper escapes.
12450 This macro is often used with @code{AS_ECHO}.  For an example, observe
12451 the output generated by the shell code generated from this snippet:
12453 @example
12454 foo=bar
12455 AS_ECHO(["AS_ESCAPE(["$foo" = ])AS_ESCAPE(["$foo"], [""])"])
12456 @result{}"$foo" = "bar"
12457 m4_define([macro], [a, [\b]])
12458 AS_ECHO(["AS_ESCAPE([[macro]])"])
12459 @result{}macro
12460 AS_ECHO(["AS_ESCAPE([macro])"])
12461 @result{}a, b
12462 AS_ECHO(["AS_ESCAPE(m4_dquote(m4_expand([macro])))"])
12463 @result{}a, \b
12464 @end example
12466 @comment Should we add AS_ESCAPE_SINGLE? If we do, we can optimize in
12467 @comment the case of @var{string} that does not contain '.
12468 To escape a string that will be placed within single quotes, use:
12470 @example
12471 m4_bpatsubst([[@var{string}]], ['], ['\\''])
12472 @end example
12473 @end defmac
12475 @defmac AS_EXIT (@dvar{status, $?})
12476 @asindex{EXIT}
12477 Emit code to exit the shell with @var{status}, defaulting to @samp{$?}.
12478 This macro
12479 works around shells that see the exit status of the command prior to
12480 @code{exit} inside a @samp{trap 0} handler (@pxref{trap, , Limitations
12481 of Shell Builtins}).
12482 @end defmac
12484 @defmac AS_IF (@var{test1}, @ovar{run-if-true1}, @dots{}, @ovar{run-if-false})
12485 @asindex{IF}
12486 Run shell code @var{test1}.  If @var{test1} exits with a zero status then
12487 run shell code @var{run-if-true1}, else examine further tests.  If no test
12488 exits with a zero status, run shell code @var{run-if-false}, with
12489 simplifications if either @var{run-if-true1} or @var{run-if-false}
12490 is empty.  For example,
12492 @example
12493 AS_IF([test "x$foo" = xyes], [HANDLE_FOO([yes])],
12494       [test "x$foo" != xno], [HANDLE_FOO([maybe])],
12495       [echo foo not specified])
12496 @end example
12498 @noindent
12499 ensures any required macros of @code{HANDLE_FOO}
12500 are expanded before the first test.
12501 @end defmac
12503 @defmac AS_MKDIR_P (@var{file-name})
12504 @asindex{MKDIR_P}
12505 Make the directory @var{file-name}, including intervening directories
12506 as necessary.  This is equivalent to @samp{mkdir -p -- @var{file-name}},
12507 except that it is portable to older versions of @command{mkdir} that
12508 lack support for the @option{-p} option or for the @option{--}
12509 delimiter (@pxref{mkdir, , Limitations of Usual Tools}).  Also,
12510 @code{AS_MKDIR_P}
12511 succeeds if @var{file-name} is a symbolic link to an existing directory,
12512 even though Posix is unclear whether @samp{mkdir -p} should
12513 succeed in that case.  If creation of @var{file-name} fails, exit the
12514 script.
12516 Also see the @code{AC_PROG_MKDIR_P} macro (@pxref{Particular Programs}).
12517 @end defmac
12519 @defmac AS_SET_STATUS (@var{status})
12520 @asindex{SET_STATUS}
12521 Emit shell code to set the value of @samp{$?} to @var{status}, as
12522 efficiently as possible.  However, this is not guaranteed to abort a
12523 shell running with @code{set -e} (@pxref{set, , Limitations of Shell
12524 Builtins}).
12525 @end defmac
12527 @defmac AS_TR_CPP (@var{expression})
12528 @asindex{TR_CPP}
12529 Transform @var{expression} into a valid right-hand side for a C @code{#define}.
12530 For example:
12532 @example
12533 # This outputs "#define HAVE_CHAR_P 1".
12534 # Notice the m4 quoting around #, to prevent an m4 comment
12535 type="char *"
12536 echo "[#]define AS_TR_CPP([HAVE_$type]) 1"
12537 @end example
12538 @end defmac
12540 @defmac AS_TR_SH (@var{expression})
12541 @asindex{TR_SH}
12542 Transform @var{expression} into a valid shell variable name.  For example:
12544 @example
12545 # This outputs "Have it!".
12546 header="sys/some file.h"
12547 AS_TR_SH([HAVE_$header])=yes
12548 if test "x$HAVE_sys_some_file_h" = xyes; then echo "Have it!"; fi
12549 @end example
12550 @end defmac
12552 @defmac AS_SET_CATFILE (@var{var}, @var{dir}, @var{file})
12553 @asindex{SET_CATFILE}
12554 Set the shell variable @var{var} to @var{dir}/@var{file}, but
12555 optimizing the common cases (@var{dir} or @var{file} is @samp{.},
12556 @var{file} is absolute, etc.).
12557 @end defmac
12559 @defmac AS_UNSET (@var{var})
12560 @asindex{UNSET}
12561 Unsets the shell variable @var{var}, working around bugs in older
12562 shells (@pxref{unset, , Limitations of Shell
12563 Builtins}).  @var{var} can be a literal or indirect variable name.
12564 @end defmac
12566 @defmac AS_VERSION_COMPARE (@var{version-1}, @var{version-2}, @
12567   @ovar{action-if-less}, @ovar{action-if-equal}, @ovar{action-if-greater})
12568 @asindex{VERSION_COMPARE}
12569 Compare two strings @var{version-1} and @var{version-2}, possibly
12570 containing shell variables, as version strings, and expand
12571 @var{action-if-less}, @var{action-if-equal}, or @var{action-if-greater}
12572 depending upon the result.
12573 The algorithm to compare is similar to the one used by strverscmp in
12574 glibc (@pxref{String/Array Comparison, , String/Array Comparison, libc,
12575 The @acronym{GNU} C Library}).
12576 @end defmac
12578 @node Polymorphic Variables
12579 @section Support for indirect variable names
12580 @cindex variable name indirection
12581 @cindex polymorphic variable name
12582 @cindex indirection, variable name
12584 Often, it is convenient to write a macro that will emit shell code
12585 operating on a shell variable.  The simplest case is when the variable
12586 name is known.  But a more powerful idiom is writing shell code that can
12587 work through an indirection, where another variable or command
12588 substitution produces the name of the variable to actually manipulate.
12589 M4sh supports the notion of polymorphic shell variables, making it easy
12590 to write a macro that can deal with either literal or indirect variable
12591 names and output shell code appropriate for both use cases.  Behavior is
12592 undefined if expansion of an indirect variable does not result in a
12593 literal variable name.
12595 @defmac AS_LITERAL_IF (@var{expression}, @ovar{if-literal}, @ovar{if-not})
12596 @asindex{LITERAL_IF}
12597 If the expansion of @var{expression} is definitely a shell literal,
12598 expand @var{if-literal}.  If the expansion of @var{expression} looks
12599 like it might contain shell indirections (such as @code{$var} or
12600 @code{`expr`}), then @var{if-not} is expanded.  In order to reduce the
12601 time spent deciding whether an expression is literal, the implementation
12602 is somewhat conservative (for example, @samp{'[$]'} is a single-quoted
12603 shell literal, but causes @var{if-not} to be expanded).  While this
12604 macro is often used for recognizing shell variable names, it can also be
12605 used in other contexts.
12607 @example
12608 AC_DEFUN([MY_ACTION],
12609 [AS_LITERAL_IF([$1],
12610 [echo "$1"],
12611 [AS_VAR_COPY([tmp], [$1])
12612 echo "$tmp"])])
12613 @end example
12614 @end defmac
12616 @defmac AS_VAR_APPEND (@var{var}, @var{text})
12617 @asindex{APPEND}
12618 Emit shell code to append the shell expansion of @var{text} to the end
12619 of the current contents of the polymorphic shell variable @var{var},
12620 taking advantage of shells that provide the @samp{+=} extension for more
12621 efficient scaling.
12623 For situations where the final contents of @var{var} are relatively
12624 short (less than 256 bytes), it is more efficient to use the simpler
12625 code sequence of @code{@var{var}=$@{@var{var}@}@var{text}} (or its
12626 polymorphic equivalent of @code{AS_VAR_COPY([tmp], [@var{var}])} and
12627 @code{AS_VAR_SET([@var{var}], ["$tmp"@var{text}])}).  But in the case
12628 when the script will be repeatedly appending text into @code{var},
12629 issues of scaling start to become apparent.  A naive implementation
12630 requires execution time linear to the length of the current contents of
12631 @var{var} as well as the length of @var{text} for a single append, for
12632 an overall quadratic scaling with multiple appends.  This macro takes
12633 advantage of shells which provide the extension
12634 @code{@var{var}+=@var{text}}, which can provide amortized constant time
12635 for a single append, for an overall linear scaling with multiple
12636 appends.  Note that unlike @code{AS_VAR_SET}, this macro requires that
12637 @var{text} be quoted properly to avoid field splitting and file name
12638 expansion.
12639 @end defmac
12641 @defmac AS_VAR_ARITH (@var{var}, @var{expression})
12642 @asindex{ARITH}
12643 Emit shell code to compute the arithmetic expansion of @var{expression},
12644 assigning the result as the contents of the polymorphic shell variable
12645 @var{var}.  The code takes advantage of shells that provide @samp{$(())}
12646 for fewer forks, but uses @command{expr} as a fallback.  Therefore, the
12647 syntax for a valid @var{expression} is rather limited: all operators
12648 must occur as separate shell arguments and with proper quoting, there is
12649 no portable equality operator, all variables containing numeric values
12650 must be expanded prior to the computation, all numeric values must be
12651 provided in decimal without leading zeroes, and the first shell argument
12652 should not be a negative number.  In the following example, this snippet
12653 will print @samp{(2+3)*4 == 20}.
12655 @example
12656 bar=3
12657 AS_VAR_ARITH([foo], [\( 2 + $bar \) \* 4])
12658 echo "(2+$bar)*4 == $foo"
12659 @end example
12660 @end defmac
12662 @defmac AS_VAR_COPY (@var{dest}, @var{source})
12663 @asindex{VAR_COPY}
12664 Emit shell code to assign the contents of the polymorphic shell variable
12665 @var{source} to the polymorphic shell variable @var{dest}.  For example,
12666 executing this M4sh snippet will output @samp{bar hi}:
12668 @example
12669 foo=bar bar=hi
12670 AS_VAR_COPY([a], [foo])
12671 AS_VAR_COPY([b], [$foo])
12672 echo "$a $b"
12673 @end example
12675 When it is necessary to access the contents of an indirect variable
12676 inside a shell double-quoted context, the recommended idiom is to first
12677 copy the contents into a temporary literal shell variable.
12679 @smallexample
12680 for header in stdint_h inttypes_h ; do
12681   AS_VAR_COPY([var], [ac_cv_header_$header])
12682   echo "$header detected: $var"
12683 done
12684 @end smallexample
12685 @end defmac
12687 @comment AS_VAR_GET is intentionally undocumented; it can't handle
12688 @comment trailing newlines uniformly, and forks too much.
12690 @defmac AS_VAR_IF (@var{var}, @ovar{value}, @ovar{if-equal}, @
12691   @ovar{if-not-equal})
12692 @asindex{VAR_IF}
12693 Output a shell conditional statement.  If the contents of the
12694 polymorphic shell variable @var{var} match the string @var{value},
12695 execute @var{if-equal}; otherwise execute @var{if-not-equal}.  Avoids
12696 shell bugs if an interrupt signal arrives while a command substitution
12697 in @var{var} is being expanded.
12698 @end defmac
12700 @defmac AS_VAR_PUSHDEF (@var{m4-name}, @var{value})
12701 @defmacx AS_VAR_POPDEF (@var{m4-name})
12702 @asindex{VAR_PUSHDEF}
12703 @asindex{VAR_POPDEF}
12704 @cindex composing variable names
12705 @cindex variable names, composing
12706 A common M4sh idiom involves composing shell variable names from an m4
12707 argument (for example, writing a macro that uses a cache variable).
12708 @var{value} can be an arbitrary string, which will be transliterated
12709 into a valid shell name by @code{AS_TR_SH}.  In order to access the
12710 composed variable name based on @var{value}, it is easier to declare a
12711 temporary m4 macro @var{m4-name} with @code{AS_VAR_PUSHDEF}, then use
12712 that macro as the argument to subsequent @code{AS_VAR} macros as a
12713 polymorphic variable name, and finally free the temporary macro with
12714 @code{AS_VAR_POPDEF}.  These macros are often followed with @code{dnl},
12715 to avoid excess newlines in the output.
12717 Here is an involved example, that shows the power of writing macros that
12718 can handle composed shell variable names:
12720 @example
12721 m4_define([MY_CHECK_HEADER],
12722 [AS_VAR_PUSHDEF([my_Header], [ac_cv_header_$1])dnl
12723 AS_VAR_IF([my_Header], [yes], [echo "header $1 available"])dnl
12724 AS_VAR_POPDEF([my_Header])dnl
12726 MY_CHECK_HEADER([stdint.h])
12727 for header in inttypes.h stdlib.h ; do
12728   MY_CHECK_HEADER([$header])
12729 done
12730 @end example
12732 @noindent
12733 In the above example, @code{MY_CHECK_HEADER} can operate on polymorphic
12734 variable names.  In the first invocation, the m4 argument is
12735 @code{stdint.h}, which transliterates into a literal @code{stdint_h}.
12736 As a result, the temporary macro @code{my_Header} expands to the literal
12737 shell name @samp{ac_cv_header_stdint_h}.  In the second invocation, the
12738 m4 argument to @code{MY_CHECK_HEADER} is @code{$header}, and the
12739 temporary macro @code{my_Header} expands to the indirect shell name
12740 @samp{$as_my_Header}.  During the shell execution of the for loop, when
12741 @samp{$header} contains @samp{inttypes.h}, then @samp{$as_my_Header}
12742 contains @samp{ac_cv_header_inttypes_h}.  If this script is then run on a
12743 platform where all three headers have been previously detected, the
12744 output of the script will include:
12746 @smallexample
12747 header stdint.h detected
12748 header inttypes.h detected
12749 header stdlib.h detected
12750 @end smallexample
12751 @end defmac
12753 @defmac AS_VAR_SET (@var{var}, @ovar{value})
12754 @asindex{VAR_SET}
12755 Emit shell code to assign the contents of the polymorphic shell variable
12756 @var{var} to the shell expansion of @var{value}.  @var{value} is not
12757 subject to field splitting or file name expansion, so if command
12758 substitution is used, it may be done with @samp{`""`} rather than using
12759 an intermediate variable (@pxref{Shell Substitutions}).  However,
12760 @var{value} does undergo rescanning for additional macro names; behavior
12761 is unspecified if late expansion results in any shell meta-characters.
12762 @end defmac
12764 @defmac AS_VAR_SET_IF (@var{var}, @ovar{if-set}, @ovar{if-undef})
12765 @asindex{VAR_SET_IF}
12766 Emit a shell conditional statement, which executes @var{if-set} if the
12767 polymorphic shell variable @code{var} is set to any value, and
12768 @var{if-undef} otherwise.
12769 @end defmac
12771 @defmac AS_VAR_TEST_SET (@var{var})
12772 @asindex{VAR_TEST_SET}
12773 Emit a shell statement that results in a successful exit status only if
12774 the polymorphic shell variable @code{var} is set.
12775 @end defmac
12777 @node Initialization Macros
12778 @section Initialization Macros
12780 @defmac AS_BOURNE_COMPATIBLE
12781 @asindex{BOURNE_COMPATIBLE}
12782 Set up the shell to be more compatible with the Bourne shell as
12783 standardized by Posix, if possible.  This may involve setting
12784 environment variables, or setting options, or similar
12785 implementation-specific actions.  This macro is deprecated, since
12786 @code{AS_INIT} already invokes it.
12787 @end defmac
12789 @defmac AS_INIT
12790 @asindex{INIT}
12791 @evindex LC_ALL
12792 @evindex SHELL
12793 Initialize the M4sh environment.  This macro calls @code{m4_init}, then
12794 outputs the @code{#! /bin/sh} line, a notice about where the output was
12795 generated from, and code to sanitize the environment for the rest of the
12796 script.  Among other initializations, this sets @env{SHELL} to the shell
12797 chosen to run the script (@pxref{CONFIG_SHELL}), and @env{LC_ALL} to
12798 ensure the C locale.  Finally, it changes the current diversion to
12799 @code{BODY}.
12800 @end defmac
12802 @defmac AS_INIT_GENERATED (@var{file}, @ovar{comment})
12803 @asindex{INIT_GENERATED}
12804 Emit shell code to start the creation of a subsidiary shell script in
12805 @var{file}, including changing @var{file} to be executable.  This macro
12806 populates the child script with information learned from the parent
12807 (thus, the emitted code is equivalent in effect, but more efficient,
12808 than the code output by @code{AS_INIT}, @code{AS_BOURNE_COMPATIBLE}, and
12809 @code{AS_SHELL_SANITIZE}).  If present, @var{comment} is output near the
12810 beginning of the child, prior to the shell initialization code, and is
12811 subject to parameter expansion, command substitution, and backslash
12812 quote removal.  The
12813 parent script should check the exit status after this macro, in case
12814 @var{file} could not be properly created (for example, if the disk was
12815 full).  If successfully created, the parent script can then proceed to
12816 append additional M4sh constructs into the child script.
12818 Note that the child script starts life without a log file open, so if
12819 the parent script uses logging (@pxref{AS_MESSAGE_LOG_FD}), you
12820 must temporarily disable any attempts to use the log file until after
12821 emitting code to open a log within the child.  On the other hand, if the
12822 parent script has @code{AS_MESSAGE_FD} redirected somewhere besides
12823 @samp{1}, then the child script already has code that copies stdout to
12824 that descriptor.  Currently, the suggested
12825 idiom for writing a M4sh shell script from within another script is:
12827 @example
12828 AS_INIT_GENERATED([@var{file}], [[# My child script.
12829 ]]) || @{ AS_ECHO(["Failed to create child script"]); AS_EXIT; @}
12830 m4_pushdef([AS_MESSAGE_LOG_FD])dnl
12831 cat >> "@var{file}" <<\__EOF__
12832 # Code to initialize AS_MESSAGE_LOG_FD
12833 m4_popdef([AS_MESSAGE_LOG_FD])dnl
12834 # Additional code
12835 __EOF__
12836 @end example
12838 This, however, may change in the future as the M4sh interface is
12839 stabilized further.
12841 Also, be aware that use of @env{LINENO} within the child script may
12842 report line numbers relative to their location in the parent script,
12843 even when using @code{AS_LINENO_PREPARE}, if the parent script was
12844 unable to locate a shell with working @env{LINENO} support.
12845 @end defmac
12847 @defmac AS_LINENO_PREPARE
12848 @asindex{LINENO_PREPARE}
12849 @evindex LINENO
12850 Find a shell that supports the special variable @env{LINENO}, which
12851 contains the number of the currently executing line.  This macro is
12852 automatically invoked by @code{AC_INIT} in configure scripts.
12853 @end defmac
12855 @defmac AS_ME_PREPARE
12856 @asindex{ME_PREPARE}
12857 Set up variable @env{as_me} to be the basename of the currently executing
12858 script.  This macro is automatically invoked by @code{AC_INIT} in
12859 configure scripts.
12860 @end defmac
12862 @defmac AS_SHELL_SANITIZE
12863 @asindex{SHELL_SANITIZE}
12864 Initialize the shell suitably for @command{configure} scripts.  This has
12865 the effect of @code{AS_BOURNE_COMPATIBLE}, and sets some other
12866 environment variables for predictable results from configuration tests.
12867 For example, it sets @env{LC_ALL} to change to the default C locale.
12868 @xref{Special Shell Variables}.  This macro is deprecated, since
12869 @code{AS_INIT} already invokes it.
12870 @end defmac
12873 @node File Descriptor Macros
12874 @section File Descriptor Macros
12875 @cindex input
12876 @cindex standard input
12877 @cindex file descriptors
12878 @cindex descriptors
12879 @cindex low-level output
12880 @cindex output, low-level
12882 The following macros define file descriptors used to output messages
12883 (or input values) from @file{configure} scripts.
12884 For example:
12886 @example
12887 echo "$wombats found" >&AS_MESSAGE_LOG_FD
12888 echo 'Enter desired kangaroo count:' >&AS_MESSAGE_FD
12889 read kangaroos <&AS_ORIGINAL_STDIN_FD`
12890 @end example
12892 @noindent
12893 However doing so is seldom needed, because Autoconf provides higher
12894 level macros as described below.
12896 @defmac AS_MESSAGE_FD
12897 @asindex{MESSAGE_FD}
12898 The file descriptor for @samp{checking for...}  messages and results.
12899 By default, @code{AS_INIT} sets this to @samp{1} for standalone M4sh
12900 clients.  However, @code{AC_INIT} shuffles things around to another file
12901 descriptor, in order to allow the @option{-q} option of
12902 @command{configure} to choose whether messages should go to the script's
12903 standard output or be discarded.
12905 If you want to display some messages, consider using one of the printing
12906 macros (@pxref{Printing Messages}) instead.  Copies of messages output
12907 via these macros are also recorded in @file{config.log}.
12908 @end defmac
12910 @anchor{AS_MESSAGE_LOG_FD}
12911 @defmac AS_MESSAGE_LOG_FD
12912 @asindex{MESSAGE_LOG_FD}
12913 This must either be empty, or expand to a file descriptor for log
12914 messages.  By default, @code{AS_INIT} sets this macro to the empty
12915 string for standalone M4sh clients, thus disabling logging.  However,
12916 @code{AC_INIT} shuffles things around so that both @command{configure}
12917 and @command{config.status} use @file{config.log} for log messages.
12918 Macros that run tools, like @code{AC_COMPILE_IFELSE} (@pxref{Running the
12919 Compiler}), redirect all output to this descriptor.  You may want to do
12920 so if you develop such a low-level macro.
12921 @end defmac
12923 @defmac AS_ORIGINAL_STDIN_FD
12924 @asindex{ORIGINAL_STDIN_FD}
12925 This must expand to a file descriptor for the original standard input.
12926 By default, @code{AS_INIT} sets this macro to @samp{0} for standalone
12927 M4sh clients.  However, @code{AC_INIT} shuffles things around for
12928 safety.
12930 When @command{configure} runs, it may accidentally execute an
12931 interactive command that has the same name as the non-interactive meant
12932 to be used or checked.  If the standard input was the terminal, such
12933 interactive programs would cause @command{configure} to stop, pending
12934 some user input.  Therefore @command{configure} redirects its standard
12935 input from @file{/dev/null} during its initialization.  This is not
12936 normally a problem, since @command{configure} normally does not need
12937 user input.
12939 In the extreme case where your @file{configure} script really needs to
12940 obtain some values from the original standard input, you can read them
12941 explicitly from @code{AS_ORIGINAL_STDIN_FD}.
12942 @end defmac
12945 @c =================================================== Writing Autoconf Macros.
12947 @node Writing Autoconf Macros
12948 @chapter Writing Autoconf Macros
12950 When you write a feature test that could be applicable to more than one
12951 software package, the best thing to do is encapsulate it in a new macro.
12952 Here are some instructions and guidelines for writing Autoconf macros.
12954 @menu
12955 * Macro Definitions::           Basic format of an Autoconf macro
12956 * Macro Names::                 What to call your new macros
12957 * Reporting Messages::          Notifying @command{autoconf} users
12958 * Dependencies Between Macros::  What to do when macros depend on other macros
12959 * Obsoleting Macros::           Warning about old ways of doing things
12960 * Coding Style::                Writing Autoconf macros @`a la Autoconf
12961 @end menu
12963 @node Macro Definitions
12964 @section Macro Definitions
12966 @defmac AC_DEFUN (@var{name}, @ovar{body})
12967 @acindex{DEFUN}
12968 Autoconf macros are defined using the @code{AC_DEFUN} macro, which is
12969 similar to the M4 builtin @code{m4_define} macro; this creates a macro
12970 named @var{name} and with @var{body} as its expansion.  In addition to
12971 defining a macro, @code{AC_DEFUN} adds to it some code that is used to
12972 constrain the order in which macros are called, while avoiding redundant
12973 output (@pxref{Prerequisite Macros}).
12974 @end defmac
12976 An Autoconf macro definition looks like this:
12978 @example
12979 AC_DEFUN(@var{macro-name}, @var{macro-body})
12980 @end example
12982 You can refer to any arguments passed to the macro as @samp{$1},
12983 @samp{$2}, etc.  @xref{Definitions, , How to define new macros, m4.info,
12984 @acronym{GNU} M4}, for more complete information on writing M4 macros.
12986 Most macros fall in one of two general categories.  The first category
12987 includes macros which take arguments, in order to generate output
12988 parameterized by those arguments.  Macros in this category are designed
12989 to be directly expanded, often multiple times, and should not be used as
12990 the argument to @code{AC_REQUIRE}.  The other category includes macros
12991 which are shorthand for a fixed block of text, and therefore do not take
12992 arguments.  For this category of macros, directly expanding the macro
12993 multiple times results in redundant output, so it is more common to use
12994 the macro as the argument to @code{AC_REQUIRE}, or to declare the macro
12995 with @code{AC_DEFUN_ONCE} (@pxref{One-Shot Macros}).
12997 Be sure to properly quote both the @var{macro-body} @emph{and} the
12998 @var{macro-name} to avoid any problems if the macro happens to have
12999 been previously defined.
13001 Each macro should have a header comment that gives its prototype, and a
13002 brief description.  When arguments have default values, display them in
13003 the prototype.  For example:
13005 @example
13006 # AC_MSG_ERROR(ERROR, [EXIT-STATUS = 1])
13007 # --------------------------------------
13008 m4_define([AC_MSG_ERROR],
13009   [@{ AS_MESSAGE([error: $1], [2])
13010      exit m4_default([$2], [1]); @}])
13011 @end example
13013 Comments about the macro should be left in the header comment.  Most
13014 other comments make their way into @file{configure}, so just keep
13015 using @samp{#} to introduce comments.
13017 @cindex @code{dnl}
13018 If you have some special comments about pure M4 code, comments
13019 that make no sense in @file{configure} and in the header comment, then
13020 use the builtin @code{dnl}: it causes M4 to discard the text
13021 through the next newline.
13023 Keep in mind that @code{dnl} is rarely needed to introduce comments;
13024 @code{dnl} is more useful to get rid of the newlines following macros
13025 that produce no output, such as @code{AC_REQUIRE}.
13027 Public third-party macros need to use @code{AC_DEFUN}, and not
13028 @code{m4_define}, in order to be found by @command{aclocal}
13029 (@pxref{Extending aclocal,,, automake, @acronym{GNU} Automake}).
13030 Additionally, if it is ever determined that a macro should be made
13031 obsolete, it is easy to convert from @code{AC_DEFUN} to @code{AU_DEFUN}
13032 in order to have @command{autoupdate} assist the user in choosing a
13033 better alternative, but there is no corresponding way to make
13034 @code{m4_define} issue an upgrade notice (@pxref{AU_DEFUN}).
13036 There is another subtle, but important, difference between using
13037 @code{m4_define} and @code{AC_DEFUN}: only the former is unaffected by
13038 @code{AC_REQUIRE}.  When writing a file, it is always safe to replace a
13039 block of text with a @code{m4_define} macro that will expand to the same
13040 text.  But replacing a block of text with an @code{AC_DEFUN} macro with
13041 the same content does not necessarily give the same results, because it
13042 changes the location where any embedded but unsatisfied
13043 @code{AC_REQUIRE} invocations within the block will be expanded.  For an
13044 example of this, see @ref{Expanded Before Required}.
13046 @node Macro Names
13047 @section Macro Names
13049 All of the public Autoconf macros have all-uppercase names in the
13050 namespace @samp{^AC_} to prevent them from accidentally conflicting with
13051 other text; Autoconf also reserves the namespace @samp{^_AC_} for
13052 internal macros.  All shell variables that they use for internal
13053 purposes have mostly-lowercase names starting with @samp{ac_}.  Autoconf
13054 also uses here-doc delimiters in the namespace @samp{^_AC[A-Z]}.  During
13055 @command{configure}, files produced by Autoconf make heavy use of the
13056 file system namespace @samp{^conf}.
13058 Since Autoconf is built on top of M4sugar (@pxref{Programming in
13059 M4sugar}) and M4sh (@pxref{Programming in M4sh}), you must also be aware
13060 of those namespaces (@samp{^_?\(m4\|AS\)_}).  And since
13061 @file{configure.ac} is also designed to be scanned by Autoheader,
13062 Autoscan, Autoupdate, and Automake, you should be aware of the
13063 @samp{^_?A[HNUM]_} namespaces.  In general, you @emph{should not use}
13064 the namespace of a package that does not own the macro or shell code you
13065 are writing.
13067 To ensure that your macros don't conflict with present or future
13068 Autoconf macros, you should prefix your own macro names and any shell
13069 variables they use with some other sequence.  Possibilities include your
13070 initials, or an abbreviation for the name of your organization or
13071 software package.  Historically, people have not always followed the
13072 rule of using a namespace appropriate for their package, and this has
13073 made it difficult for determining the origin of a macro (and where to
13074 report bugs about that macro), as well as difficult for the true
13075 namespace owner to add new macros without interference from pre-existing
13076 uses of third-party macros.  Perhaps the best example of this confusion
13077 is the @code{AM_GNU_GETTEXT} macro, which belongs, not to Automake, but
13078 to Gettext.
13080 Most of the Autoconf macros' names follow a structured naming convention
13081 that indicates the kind of feature check by the name.  The macro names
13082 consist of several words, separated by underscores, going from most
13083 general to most specific.  The names of their cache variables use the
13084 same convention (@pxref{Cache Variable Names}, for more information on
13085 them).
13087 The first word of the name after the namespace initials (such as
13088 @samp{AC_}) usually tells the category
13089 of the feature being tested.  Here are the categories used in Autoconf for
13090 specific test macros, the kind of macro that you are more likely to
13091 write.  They are also used for cache variables, in all-lowercase.  Use
13092 them where applicable; where they're not, invent your own categories.
13094 @table @code
13095 @item C
13096 C language builtin features.
13097 @item DECL
13098 Declarations of C variables in header files.
13099 @item FUNC
13100 Functions in libraries.
13101 @item GROUP
13102 Posix group owners of files.
13103 @item HEADER
13104 Header files.
13105 @item LIB
13106 C libraries.
13107 @item PROG
13108 The base names of programs.
13109 @item MEMBER
13110 Members of aggregates.
13111 @item SYS
13112 Operating system features.
13113 @item TYPE
13114 C builtin or declared types.
13115 @item VAR
13116 C variables in libraries.
13117 @end table
13119 After the category comes the name of the particular feature being
13120 tested.  Any further words in the macro name indicate particular aspects
13121 of the feature.  For example, @code{AC_PROG_CC_STDC} checks whether the
13122 C compiler supports @acronym{ISO} Standard C.
13124 An internal macro should have a name that starts with an underscore;
13125 Autoconf internals should therefore start with @samp{_AC_}.
13126 Additionally, a macro that is an internal subroutine of another macro
13127 should have a name that starts with an underscore and the name of that
13128 other macro, followed by one or more words saying what the internal
13129 macro does.  For example, @code{AC_PATH_X} has internal macros
13130 @code{_AC_PATH_X_XMKMF} and @code{_AC_PATH_X_DIRECT}.
13132 @node Reporting Messages
13133 @section Reporting Messages
13134 @cindex Messages, from @command{autoconf}
13136 When macros statically diagnose abnormal situations, benign or fatal, it
13137 is possible to make @command{autoconf} detect the problem, and refuse to
13138 create @file{configure} in the case of an error.  The macros in this
13139 section are considered obsolescent, and new code should use M4sugar
13140 macros for this purpose, see @ref{Diagnostic Macros}.
13142 On the other hand, it is possible to want to detect errors when
13143 @command{configure} is run, which are dependent on the environment of
13144 the user rather than the maintainer.  For dynamic diagnostics, see
13145 @ref{Printing Messages}.
13147 @defmac AC_DIAGNOSE (@var{category}, @var{message})
13148 @acindex{DIAGNOSE}
13149 Report @var{message} as a warning (or as an error if requested by the
13150 user) if warnings of the @var{category} are turned on.  This macro is
13151 obsolescent; you are encouraged to use:
13152 @example
13153 m4_warn([@var{category}], [@var{message}])
13154 @end example
13155 @noindent
13156 instead.  @xref{m4_warn}, for more details, including valid
13157 @var{category} names.
13158 @end defmac
13160 @defmac AC_WARNING (@var{message})
13161 @acindex{WARNING}
13162 Report @var{message} as a syntax warning.  This macro is obsolescent;
13163 you are encouraged to use:
13164 @example
13165 m4_warn([syntax], [@var{message}])
13166 @end example
13167 @noindent
13168 instead.  @xref{m4_warn}, for more details, as well as better
13169 finer-grained categories of warnings (not all problems have to do with
13170 syntax).
13171 @end defmac
13173 @defmac AC_FATAL (@var{message})
13174 @acindex{FATAL}
13175 Report a severe error @var{message}, and have @command{autoconf} die.
13176 This macro is obsolescent; you are encouraged to use:
13177 @example
13178 m4_fatal([@var{message}])
13179 @end example
13180 @noindent
13181 instead.  @xref{m4_fatal}, for more details.
13182 @end defmac
13184 When the user runs @samp{autoconf -W error}, warnings from
13185 @code{m4_warn} (including those issued through @code{AC_DIAGNOSE} and
13186 @code{AC_WARNING}) are reported as errors, see @ref{autoconf Invocation}.
13188 @node Dependencies Between Macros
13189 @section Dependencies Between Macros
13190 @cindex Dependencies between macros
13192 Some Autoconf macros depend on other macros having been called first in
13193 order to work correctly.  Autoconf provides a way to ensure that certain
13194 macros are called if needed and a way to warn the user if macros are
13195 called in an order that might cause incorrect operation.
13197 @menu
13198 * Prerequisite Macros::         Ensuring required information
13199 * Suggested Ordering::          Warning about possible ordering problems
13200 * One-Shot Macros::             Ensuring a macro is called only once
13201 @end menu
13203 @node Prerequisite Macros
13204 @subsection Prerequisite Macros
13205 @cindex Prerequisite macros
13206 @cindex Macros, prerequisites
13208 A macro that you write might need to use values that have previously
13209 been computed by other macros.  For example, @code{AC_DECL_YYTEXT}
13210 examines the output of @code{flex} or @code{lex}, so it depends on
13211 @code{AC_PROG_LEX} having been called first to set the shell variable
13212 @code{LEX}.
13214 Rather than forcing the user of the macros to keep track of the
13215 dependencies between them, you can use the @code{AC_REQUIRE} macro to do
13216 it automatically.  @code{AC_REQUIRE} can ensure that a macro is only
13217 called if it is needed, and only called once.
13219 @defmac AC_REQUIRE (@var{macro-name})
13220 @acindex{REQUIRE}
13221 If the M4 macro @var{macro-name} has not already been called, call it
13222 (without any arguments).  Make sure to quote @var{macro-name} with
13223 square brackets.  @var{macro-name} must have been defined using
13224 @code{AC_DEFUN} or else contain a call to @code{AC_PROVIDE} to indicate
13225 that it has been called.
13227 @code{AC_REQUIRE} must be used inside a macro defined by @code{AC_DEFUN}; it
13228 must not be called from the top level.  Also, it does not make sense to
13229 require a macro that takes parameters.
13230 @end defmac
13232 @code{AC_REQUIRE} is often misunderstood.  It really implements
13233 dependencies between macros in the sense that if one macro depends upon
13234 another, the latter is expanded @emph{before} the body of the
13235 former.  To be more precise, the required macro is expanded before
13236 the outermost defined macro in the current expansion stack.
13237 In particular, @samp{AC_REQUIRE([FOO])} is not replaced with the body of
13238 @code{FOO}.  For instance, this definition of macros:
13240 @example
13241 @group
13242 AC_DEFUN([TRAVOLTA],
13243 [test "$body_temperature_in_celsius" -gt "38" &&
13244   dance_floor=occupied])
13245 AC_DEFUN([NEWTON_JOHN],
13246 [test "x$hair_style" = xcurly &&
13247   dance_floor=occupied])
13248 @end group
13250 @group
13251 AC_DEFUN([RESERVE_DANCE_FLOOR],
13252 [if date | grep '^Sat.*pm' >/dev/null 2>&1; then
13253   AC_REQUIRE([TRAVOLTA])
13254   AC_REQUIRE([NEWTON_JOHN])
13255 fi])
13256 @end group
13257 @end example
13259 @noindent
13260 with this @file{configure.ac}
13262 @example
13263 AC_INIT([Dance Manager], [1.0], [bug-dance@@example.org])
13264 RESERVE_DANCE_FLOOR
13265 if test "x$dance_floor" = xoccupied; then
13266   AC_MSG_ERROR([cannot pick up here, let's move])
13268 @end example
13270 @noindent
13271 does not leave you with a better chance to meet a kindred soul at
13272 other times than Saturday night since it expands into:
13274 @example
13275 @group
13276 test "$body_temperature_in_Celsius" -gt "38" &&
13277   dance_floor=occupied
13278 test "x$hair_style" = xcurly &&
13279   dance_floor=occupied
13281 if date | grep '^Sat.*pm' >/dev/null 2>&1; then
13285 @end group
13286 @end example
13288 This behavior was chosen on purpose: (i) it prevents messages in
13289 required macros from interrupting the messages in the requiring macros;
13290 (ii) it avoids bad surprises when shell conditionals are used, as in:
13292 @example
13293 @group
13294 if @dots{}; then
13295   AC_REQUIRE([SOME_CHECK])
13297 @dots{}
13298 SOME_CHECK
13299 @end group
13300 @end example
13302 However, this implementation can lead to another class of problems.
13303 Consider the case where an outer macro first expands, then indirectly
13304 requires, an inner macro:
13306 @example
13307 AC_DEFUN([TESTA], [[echo in A
13308 if test -n "$SEEN_A" ; then echo duplicate ; fi
13309 SEEN_A=:]])
13310 AC_DEFUN([TESTB], [AC_REQUIRE([TESTA])[echo in B
13311 if test -z "$SEEN_A" ; then echo bug ; fi]])
13312 AC_DEFUN([TESTC], [AC_REQUIRE([TESTB])[echo in C]])
13313 AC_DEFUN([OUTER], [[echo in OUTER]
13316 OUTER
13317 @end example
13319 @noindent
13320 Prior to Autoconf 2.64, the implementation of @code{AC_REQUIRE}
13321 recognized that @code{TESTB} needed to be hoisted prior to the expansion
13322 of @code{OUTER}, but because @code{TESTA} had already been directly
13323 expanded, it failed to hoist @code{TESTA}.  Therefore, the expansion of
13324 @code{TESTB} occurs prior to its prerequisites, leading to the following
13325 output:
13327 @example
13328 in B
13330 in OUTER
13331 in A
13332 in C
13333 @end example
13335 @noindent
13336 Newer Autoconf is smart enough to recognize this situation, and hoists
13337 @code{TESTA} even though it has already been expanded, but issues a
13338 syntax warning in the process.  This is because the hoisted expansion of
13339 @code{TESTA} defeats the purpose of using @code{AC_REQUIRE} to avoid
13340 redundant code, and causes its own set of problems if the hoisted macro
13341 is not idempotent:
13343 @example
13344 in A
13345 in B
13346 in OUTER
13347 in A
13348 duplicate
13349 in C
13350 @end example
13352 The bug is not in Autoconf, but in the macro definitions.  If you ever
13353 pass a particular macro name to @code{AC_REQUIRE}, then you are implying
13354 that the macro only needs to be expanded once.  But to enforce this,
13355 either the macro must be declared with @code{AC_DEFUN_ONCE} (although
13356 this only helps in Autoconf 2.64 or newer), or all
13357 uses of that macro should be through @code{AC_REQUIRE}; directly
13358 expanding the macro defeats the point of using @code{AC_REQUIRE} to
13359 eliminate redundant expansion.  In the example, this rule of thumb was
13360 violated because @code{TESTB} requires @code{TESTA} while @code{OUTER}
13361 directly expands it.  One way of fixing the bug is to factor
13362 @code{TESTA} into two macros, the portion designed for direct and
13363 repeated use (here, named @code{TESTA}), and the portion designed for
13364 one-shot output and used only inside @code{AC_REQUIRE} (here, named
13365 @code{TESTA_PREREQ}).  Then, by fixing all clients to use the correct
13366 calling convention according to their needs:
13368 @example
13369 AC_DEFUN([TESTA], [AC_REQUIRE([TESTA_PREREQ])[echo in A]])
13370 AC_DEFUN([TESTA_PREREQ], [[echo in A_PREREQ
13371 if test -n "$SEEN_A" ; then echo duplicate ; fi
13372 SEEN_A=:]])
13373 AC_DEFUN([TESTB], [AC_REQUIRE([TESTA_PREREQ])[echo in B
13374 if test -z "$SEEN_A" ; then echo bug ; fi]])
13375 AC_DEFUN([TESTC], [AC_REQUIRE([TESTB])[echo in C]])
13376 AC_DEFUN([OUTER], [[echo in OUTER]
13377 TESTA
13378 TESTC])
13379 OUTER
13380 @end example
13382 @noindent
13383 the resulting output will then obey all dependency rules and avoid any
13384 syntax warnings, whether the script is built with old or new Autoconf
13385 versions:
13387 @example
13388 in A_PREREQ
13389 in B
13390 in OUTER
13391 in A
13392 in C
13393 @end example
13395 The helper macros @code{AS_IF} and @code{AS_CASE} may be used to
13396 enforce expansion of required macros outside of shell conditional
13397 constructs.  You are furthermore encouraged, although not required, to
13398 put all @code{AC_REQUIRE} calls
13399 at the beginning of a macro.  You can use @code{dnl} to avoid the empty
13400 lines they leave.
13402 @node Suggested Ordering
13403 @subsection Suggested Ordering
13404 @cindex Macros, ordering
13405 @cindex Ordering macros
13407 Some macros should be run before another macro if both are called, but
13408 neither @emph{requires} that the other be called.  For example, a macro
13409 that changes the behavior of the C compiler should be called before any
13410 macros that run the C compiler.  Many of these dependencies are noted in
13411 the documentation.
13413 Autoconf provides the @code{AC_BEFORE} macro to warn users when macros
13414 with this kind of dependency appear out of order in a
13415 @file{configure.ac} file.  The warning occurs when creating
13416 @command{configure} from @file{configure.ac}, not when running
13417 @command{configure}.
13419 For example, @code{AC_PROG_CPP} checks whether the C compiler
13420 can run the C preprocessor when given the @option{-E} option.  It should
13421 therefore be called after any macros that change which C compiler is
13422 being used, such as @code{AC_PROG_CC}.  So @code{AC_PROG_CC} contains:
13424 @example
13425 AC_BEFORE([$0], [AC_PROG_CPP])dnl
13426 @end example
13428 @noindent
13429 This warns the user if a call to @code{AC_PROG_CPP} has already occurred
13430 when @code{AC_PROG_CC} is called.
13432 @defmac AC_BEFORE (@var{this-macro-name}, @var{called-macro-name})
13433 @acindex{BEFORE}
13434 Make M4 print a warning message to the standard error output if
13435 @var{called-macro-name} has already been called.  @var{this-macro-name}
13436 should be the name of the macro that is calling @code{AC_BEFORE}.  The
13437 macro @var{called-macro-name} must have been defined using
13438 @code{AC_DEFUN} or else contain a call to @code{AC_PROVIDE} to indicate
13439 that it has been called.
13440 @end defmac
13442 @node One-Shot Macros
13443 @subsection One-Shot Macros
13444 @cindex One-shot macros
13445 @cindex Macros, called once
13447 Some macros should be called only once, either because calling them
13448 multiple time is unsafe, or because it is bad style.  For instance
13449 Autoconf ensures that @code{AC_CANONICAL_BUILD} and cousins
13450 (@pxref{Canonicalizing}) are evaluated only once, because it makes no
13451 sense to run these expensive checks more than once.  Such one-shot
13452 macros can be defined using @code{AC_DEFUN_ONCE}.
13454 @defmac AC_DEFUN_ONCE (@var{macro-name}, @var{macro-body})
13455 @acindex{DEFUN_ONCE}
13456 Declare macro @var{macro-name} like @code{AC_DEFUN} would (@pxref{Macro
13457 Definitions}), but add additional logic that guarantees that only the
13458 first use of the macro (whether by direct expansion or
13459 @code{AC_REQUIRE}) causes an expansion of @var{macro-body}; the
13460 expansion will occur before the start of any enclosing macro defined by
13461 @code{AC_DEFUN}.  Subsequent expansions are silently ignored.
13462 Generally, it does not make sense for @var{macro-body} to use parameters
13463 such as @code{$1}.
13464 @end defmac
13466 Prior to Autoconf 2.64, a macro defined by @code{AC_DEFUN_ONCE} would
13467 emit a warning if it was directly expanded a second time, so for
13468 portability, it is better to use @code{AC_REQUIRE} than direct
13469 invocation of @var{macro-name} inside a macro defined by @code{AC_DEFUN}
13470 (@pxref{Prerequisite Macros}).
13472 @node Obsoleting Macros
13473 @section Obsoleting Macros
13474 @cindex Obsoleting macros
13475 @cindex Macros, obsoleting
13477 Configuration and portability technology has evolved over the years.
13478 Often better ways of solving a particular problem are developed, or
13479 ad-hoc approaches are systematized.  This process has occurred in many
13480 parts of Autoconf.  One result is that some of the macros are now
13481 considered @dfn{obsolete}; they still work, but are no longer considered
13482 the best thing to do, hence they should be replaced with more modern
13483 macros.  Ideally, @command{autoupdate} should replace the old macro calls
13484 with their modern implementation.
13486 Autoconf provides a simple means to obsolete a macro.
13488 @anchor{AU_DEFUN}
13489 @defmac AU_DEFUN (@var{old-macro}, @var{implementation}, @ovar{message})
13490 @auindex{DEFUN}
13491 Define @var{old-macro} as @var{implementation}.  The only difference
13492 with @code{AC_DEFUN} is that the user is warned that
13493 @var{old-macro} is now obsolete.
13495 If she then uses @command{autoupdate}, the call to @var{old-macro} is
13496 replaced by the modern @var{implementation}.  @var{message} should
13497 include information on what to do after running @command{autoupdate};
13498 @command{autoupdate} prints it as a warning, and includes it
13499 in the updated @file{configure.ac} file.
13501 The details of this macro are hairy: if @command{autoconf} encounters an
13502 @code{AU_DEFUN}ed macro, all macros inside its second argument are expanded
13503 as usual.  However, when @command{autoupdate} is run, only M4 and M4sugar
13504 macros are expanded here, while all other macros are disabled and
13505 appear literally in the updated @file{configure.ac}.
13506 @end defmac
13508 @defmac AU_ALIAS (@var{old-name}, @var{new-name})
13509 @auindex{ALIAS}
13510 Used if the @var{old-name} is to be replaced by a call to @var{new-macro}
13511 with the same parameters.  This happens for example if the macro was renamed.
13512 @end defmac
13514 @node Coding Style
13515 @section Coding Style
13516 @cindex Coding style
13518 The Autoconf macros follow a strict coding style.  You are encouraged to
13519 follow this style, especially if you intend to distribute your macro,
13520 either by contributing it to Autoconf itself, or via other means.
13522 The first requirement is to pay great attention to the quotation.  For
13523 more details, see @ref{Autoconf Language}, and @ref{M4 Quotation}.
13525 Do not try to invent new interfaces.  It is likely that there is a macro
13526 in Autoconf that resembles the macro you are defining: try to stick to
13527 this existing interface (order of arguments, default values, etc.).  We
13528 @emph{are} conscious that some of these interfaces are not perfect;
13529 nevertheless, when harmless, homogeneity should be preferred over
13530 creativity.
13532 Be careful about clashes both between M4 symbols and between shell
13533 variables.
13535 If you stick to the suggested M4 naming scheme (@pxref{Macro Names}),
13536 you are unlikely to generate conflicts.  Nevertheless, when you need to
13537 set a special value, @emph{avoid using a regular macro name}; rather,
13538 use an ``impossible'' name.  For instance, up to version 2.13, the macro
13539 @code{AC_SUBST} used to remember what @var{symbol} macros were already defined
13540 by setting @code{AC_SUBST_@var{symbol}}, which is a regular macro name.
13541 But since there is a macro named @code{AC_SUBST_FILE}, it was just
13542 impossible to @samp{AC_SUBST(FILE)}!  In this case,
13543 @code{AC_SUBST(@var{symbol})} or @code{_AC_SUBST(@var{symbol})} should
13544 have been used (yes, with the parentheses).
13545 @c or better yet, high-level macros such as @code{m4_expand_once}
13547 No Autoconf macro should ever enter the user-variable name space; i.e.,
13548 except for the variables that are the actual result of running the
13549 macro, all shell variables should start with @code{ac_}.  In
13550 addition, small macros or any macro that is likely to be embedded in
13551 other macros should be careful not to use obvious names.
13553 @cindex @code{dnl}
13554 Do not use @code{dnl} to introduce comments: most of the comments you
13555 are likely to write are either header comments which are not output
13556 anyway, or comments that should make their way into @file{configure}.
13557 There are exceptional cases where you do want to comment special M4
13558 constructs, in which case @code{dnl} is right, but keep in mind that it
13559 is unlikely.
13561 M4 ignores the leading blanks and newlines before each argument.
13562 Use this feature to
13563 indent in such a way that arguments are (more or less) aligned with the
13564 opening parenthesis of the macro being called.  For instance, instead of
13566 @example
13567 AC_CACHE_CHECK(for EMX OS/2 environment,
13568 ac_cv_emxos2,
13569 [AC_COMPILE_IFELSE([AC_LANG_PROGRAM(, [return __EMX__;])],
13570 [ac_cv_emxos2=yes], [ac_cv_emxos2=no])])
13571 @end example
13573 @noindent
13574 write
13576 @example
13577 AC_CACHE_CHECK([for EMX OS/2 environment], [ac_cv_emxos2],
13578 [AC_COMPILE_IFELSE([AC_LANG_PROGRAM([], [return __EMX__;])],
13579                    [ac_cv_emxos2=yes],
13580                    [ac_cv_emxos2=no])])
13581 @end example
13583 @noindent
13584 or even
13586 @example
13587 AC_CACHE_CHECK([for EMX OS/2 environment],
13588                [ac_cv_emxos2],
13589                [AC_COMPILE_IFELSE([AC_LANG_PROGRAM([],
13590                                                    [return __EMX__;])],
13591                                   [ac_cv_emxos2=yes],
13592                                   [ac_cv_emxos2=no])])
13593 @end example
13595 When using @code{AC_RUN_IFELSE} or any macro that cannot work when
13596 cross-compiling, provide a pessimistic value (typically @samp{no}).
13598 Feel free to use various tricks to prevent auxiliary tools, such as
13599 syntax-highlighting editors, from behaving improperly.  For instance,
13600 instead of:
13602 @example
13603 m4_bpatsubst([$1], [$"])
13604 @end example
13606 @noindent
13609 @example
13610 m4_bpatsubst([$1], [$""])
13611 @end example
13613 @noindent
13614 so that Emacsen do not open an endless ``string'' at the first quote.
13615 For the same reasons, avoid:
13617 @example
13618 test $[#] != 0
13619 @end example
13621 @noindent
13622 and use:
13624 @example
13625 test $[@@%:@@] != 0
13626 @end example
13628 @noindent
13629 Otherwise, the closing bracket would be hidden inside a @samp{#}-comment,
13630 breaking the bracket-matching highlighting from Emacsen.  Note the
13631 preferred style to escape from M4: @samp{$[1]}, @samp{$[@@]}, etc.  Do
13632 not escape when it is unnecessary.  Common examples of useless quotation
13633 are @samp{[$]$1} (write @samp{$$1}), @samp{[$]var} (use @samp{$var}),
13634 etc.  If you add portability issues to the picture, you'll prefer
13635 @samp{$@{1+"$[@@]"@}} to @samp{"[$]@@"}, and you'll prefer do something
13636 better than hacking Autoconf @code{:-)}.
13638 When using @command{sed}, don't use @option{-e} except for indenting
13639 purposes.  With the @code{s} and @code{y} commands, the preferred
13640 separator is @samp{/} unless @samp{/} itself might appear in the pattern
13641 or replacement, in which case you should use @samp{|}, or optionally
13642 @samp{,} if you know the pattern and replacement cannot contain a file
13643 name.  If none of these characters will do, choose a printable character
13644 that cannot appear in the pattern or replacement.  Characters from the
13645 set @samp{"#$&'()*;<=>?`|~} are good choices if the pattern or
13646 replacement might contain a file name, since they have special meaning
13647 to the shell and are less likely to occur in file names.
13649 @xref{Macro Definitions}, for details on how to define a macro.  If a
13650 macro doesn't use @code{AC_REQUIRE}, is expected to never be the object
13651 of an @code{AC_REQUIRE} directive, and macros required by other macros
13652 inside arguments do not need to be expanded before this macro, then
13653 use @code{m4_define}.  In case of doubt, use @code{AC_DEFUN}.
13654 Also take into account that public third-party macros need to use
13655 @code{AC_DEFUN} in order to be found by @command{aclocal}
13656 (@pxref{Extending aclocal,,, automake, @acronym{GNU} Automake}).
13657 All the @code{AC_REQUIRE} statements should be at the beginning of the
13658 macro, and each statement should be followed by @code{dnl}.
13660 You should not rely on the number of arguments: instead of checking
13661 whether an argument is missing, test that it is not empty.  It provides
13662 both a simpler and a more predictable interface to the user, and saves
13663 room for further arguments.
13665 Unless the macro is short, try to leave the closing @samp{])} at the
13666 beginning of a line, followed by a comment that repeats the name of the
13667 macro being defined.  This introduces an additional newline in
13668 @command{configure}; normally, that is not a problem, but if you want to
13669 remove it you can use @samp{[]dnl} on the last line.  You can similarly
13670 use @samp{[]dnl} after a macro call to remove its newline.  @samp{[]dnl}
13671 is recommended instead of @samp{dnl} to ensure that M4 does not
13672 interpret the @samp{dnl} as being attached to the preceding text or
13673 macro output.  For example, instead of:
13675 @example
13676 AC_DEFUN([AC_PATH_X],
13677 [AC_MSG_CHECKING([for X])
13678 AC_REQUIRE_CPP()
13679 @r{# @dots{}omitted@dots{}}
13680   AC_MSG_RESULT([libraries $x_libraries, headers $x_includes])
13681 fi])
13682 @end example
13684 @noindent
13685 you would write:
13687 @example
13688 AC_DEFUN([AC_PATH_X],
13689 [AC_REQUIRE_CPP()[]dnl
13690 AC_MSG_CHECKING([for X])
13691 @r{# @dots{}omitted@dots{}}
13692   AC_MSG_RESULT([libraries $x_libraries, headers $x_includes])
13693 fi[]dnl
13694 ])# AC_PATH_X
13695 @end example
13697 If the macro is long, try to split it into logical chunks.  Typically,
13698 macros that check for a bug in a function and prepare its
13699 @code{AC_LIBOBJ} replacement should have an auxiliary macro to perform
13700 this setup.  Do not hesitate to introduce auxiliary macros to factor
13701 your code.
13703 In order to highlight the recommended coding style, here is a macro
13704 written the old way:
13706 @example
13707 dnl Check for EMX on OS/2.
13708 dnl _AC_EMXOS2
13709 AC_DEFUN(_AC_EMXOS2,
13710 [AC_CACHE_CHECK(for EMX OS/2 environment, ac_cv_emxos2,
13711 [AC_COMPILE_IFELSE([AC_LANG_PROGRAM(, return __EMX__;)],
13712 ac_cv_emxos2=yes, ac_cv_emxos2=no)])
13713 test "x$ac_cv_emxos2" = xyes && EMXOS2=yes])
13714 @end example
13716 @noindent
13717 and the new way:
13719 @example
13720 # _AC_EMXOS2
13721 # ----------
13722 # Check for EMX on OS/2.
13723 m4_define([_AC_EMXOS2],
13724 [AC_CACHE_CHECK([for EMX OS/2 environment], [ac_cv_emxos2],
13725 [AC_COMPILE_IFELSE([AC_LANG_PROGRAM([], [return __EMX__;])],
13726                    [ac_cv_emxos2=yes],
13727                    [ac_cv_emxos2=no])])
13728 test "x$ac_cv_emxos2" = xyes && EMXOS2=yes[]dnl
13729 ])# _AC_EMXOS2
13730 @end example
13735 @c ============================================= Portable Shell Programming
13737 @node Portable Shell
13738 @chapter Portable Shell Programming
13739 @cindex Portable shell programming
13741 When writing your own checks, there are some shell-script programming
13742 techniques you should avoid in order to make your code portable.  The
13743 Bourne shell and upward-compatible shells like the Korn shell and Bash
13744 have evolved over the years, and many features added to the original
13745 System7 shell are now supported on all interesting porting targets.
13746 However, the following discussion between Russ Allbery and Robert Lipe
13747 is worth reading:
13749 @noindent
13750 Russ Allbery:
13752 @quotation
13753 The @acronym{GNU} assumption that @command{/bin/sh} is the one and only shell
13754 leads to a permanent deadlock.  Vendors don't want to break users'
13755 existing shell scripts, and there are some corner cases in the Bourne
13756 shell that are not completely compatible with a Posix shell.  Thus,
13757 vendors who have taken this route will @emph{never} (OK@dots{}``never say
13758 never'') replace the Bourne shell (as @command{/bin/sh}) with a
13759 Posix shell.
13760 @end quotation
13762 @noindent
13763 Robert Lipe:
13765 @quotation
13766 This is exactly the problem.  While most (at least most System V's) do
13767 have a Bourne shell that accepts shell functions most vendor
13768 @command{/bin/sh} programs are not the Posix shell.
13770 So while most modern systems do have a shell @emph{somewhere} that meets the
13771 Posix standard, the challenge is to find it.
13772 @end quotation
13774 For this reason, part of the job of M4sh (@pxref{Programming in M4sh})
13775 is to find such a shell.  But to prevent trouble, if you're not using
13776 M4sh you should not take advantage of features that were added after Unix
13777 version 7, circa 1977 (@pxref{Systemology}); you should not use aliases,
13778 negated character classes, or even @command{unset}.  @code{#} comments,
13779 while not in Unix version 7, were retrofitted in the original Bourne
13780 shell and can be assumed to be part of the least common denominator.
13782 On the other hand, if you're using M4sh you can assume that the shell
13783 has the features that were added in SVR2 (circa 1984), including shell
13784 functions,
13785 @command{return}, @command{unset}, and I/O redirection for builtins.  For
13786 more information, refer to @uref{http://@/www.in-ulm.de/@/~mascheck/@/bourne/}.
13787 However, some pitfalls have to be avoided for portable use of these
13788 constructs; these will be documented in the rest of this chapter.
13789 See in particular @ref{Shell Functions} and @ref{Limitations of
13790 Builtins, , Limitations of Shell Builtins}.
13792 Some ancient systems have quite
13793 small limits on the length of the @samp{#!} line; for instance, 32
13794 bytes (not including the newline) on SunOS 4.
13795 However, these ancient systems are no longer of practical concern.
13797 The set of external programs you should run in a @command{configure} script
13798 is fairly small.  @xref{Utilities in Makefiles, , Utilities in
13799 Makefiles, standards, @acronym{GNU} Coding Standards}, for the list.  This
13800 restriction allows users to start out with a fairly small set of
13801 programs and build the rest, avoiding too many interdependencies between
13802 packages.
13804 Some of these external utilities have a portable subset of features; see
13805 @ref{Limitations of Usual Tools}.
13807 There are other sources of documentation about shells.  The
13808 specification for the Posix
13809 @uref{http://@/www.opengroup.org/@/susv3/@/utilities/@/xcu_chap02@/.html, Shell
13810 Command Language}, though more generous than the restrictive shell
13811 subset described above, is fairly portable nowadays.  Also please see
13812 @uref{http://@/www.faqs.org/@/faqs/@/unix-faq/@/shell/, the Shell FAQs}.
13814 @menu
13815 * Shellology::                  A zoology of shells
13816 * Here-Documents::              Quirks and tricks
13817 * File Descriptors::            FDs and redirections
13818 * File System Conventions::     File names
13819 * Shell Pattern Matching::      Pattern matching
13820 * Shell Substitutions::         Variable and command expansions
13821 * Assignments::                 Varying side effects of assignments
13822 * Parentheses::                 Parentheses in shell scripts
13823 * Slashes::                     Slashes in shell scripts
13824 * Special Shell Variables::     Variables you should not change
13825 * Shell Functions::             What to look out for if you use them
13826 * Limitations of Builtins::     Portable use of not so portable /bin/sh
13827 * Limitations of Usual Tools::  Portable use of portable tools
13828 @end menu
13830 @node Shellology
13831 @section Shellology
13832 @cindex Shellology
13834 There are several families of shells, most prominently the Bourne family
13835 and the C shell family which are deeply incompatible.  If you want to
13836 write portable shell scripts, avoid members of the C shell family.  The
13837 @uref{http://@/www.faqs.org/@/faqs/@/unix-faq/@/shell/@/shell-differences/, the
13838 Shell difference FAQ} includes a small history of Posix shells, and a
13839 comparison between several of them.
13841 Below we describe some of the members of the Bourne shell family.
13843 @table @asis
13844 @item Ash
13845 @cindex Ash
13846 Ash is often used on @acronym{GNU}/Linux and @acronym{BSD}
13847 systems as a light-weight Bourne-compatible shell.  Ash 0.2 has some
13848 bugs that are fixed in the 0.3.x series, but portable shell scripts
13849 should work around them, since version 0.2 is still shipped with many
13850 @acronym{GNU}/Linux distributions.
13852 To be compatible with Ash 0.2:
13854 @itemize @minus
13855 @item
13856 don't use @samp{$?} after expanding empty or unset variables,
13857 or at the start of an @command{eval}:
13859 @example
13860 foo=
13861 false
13862 $foo
13863 echo "Do not use it: $?"
13864 false
13865 eval 'echo "Do not use it: $?"'
13866 @end example
13868 @item
13869 don't use command substitution within variable expansion:
13871 @example
13872 cat $@{FOO=`bar`@}
13873 @end example
13875 @item
13876 beware that single builtin substitutions are not performed by a
13877 subshell, hence their effect applies to the current shell!  @xref{Shell
13878 Substitutions}, item ``Command Substitution''.
13879 @end itemize
13881 @item Bash
13882 @cindex Bash
13883 To detect whether you are running Bash, test whether
13884 @code{BASH_VERSION} is set.  To require
13885 Posix compatibility, run @samp{set -o posix}.  @xref{Bash POSIX
13886 Mode, , Bash Posix Mode, bash, The @acronym{GNU} Bash Reference
13887 Manual}, for details.
13889 @item Bash 2.05 and later
13890 @cindex Bash 2.05 and later
13891 Versions 2.05 and later of Bash use a different format for the
13892 output of the @command{set} builtin, designed to make evaluating its
13893 output easier.  However, this output is not compatible with earlier
13894 versions of Bash (or with many other shells, probably).  So if
13895 you use Bash 2.05 or higher to execute @command{configure},
13896 you'll need to use Bash 2.05 for all other build tasks as well.
13898 @item Ksh
13899 @cindex Ksh
13900 @cindex Korn shell
13901 @prindex @samp{ksh}
13902 @prindex @samp{ksh88}
13903 @prindex @samp{ksh93}
13904 The Korn shell is compatible with the Bourne family and it mostly
13905 conforms to Posix.  It has two major variants commonly
13906 called @samp{ksh88} and @samp{ksh93}, named after the years of initial
13907 release.  It is usually called @command{ksh}, but is called @command{sh}
13908 on some hosts if you set your path appropriately.
13910 Solaris systems have three variants:
13911 @prindex @command{/usr/bin/ksh} on Solaris
13912 @command{/usr/bin/ksh} is @samp{ksh88}; it is
13913 standard on Solaris 2.0 and later.
13914 @prindex @command{/usr/xpg4/bin/sh} on Solaris
13915 @command{/usr/xpg4/bin/sh} is a Posix-compliant variant of
13916 @samp{ksh88}; it is standard on Solaris 9 and later.
13917 @prindex @command{/usr/dt/bin/dtksh} on Solaris
13918 @command{/usr/dt/bin/dtksh} is @samp{ksh93}.
13919 Variants that are not standard may be parts of optional
13920 packages.  There is no extra charge for these packages, but they are
13921 not part of a minimal OS install and therefore some installations may
13922 not have it.
13924 Starting with Tru64 Version 4.0, the Korn shell @command{/usr/bin/ksh}
13925 is also available as @command{/usr/bin/posix/sh}.  If the environment
13926 variable @env{BIN_SH} is set to @code{xpg4}, subsidiary invocations of
13927 the standard shell conform to Posix.
13929 @item Pdksh
13930 @prindex @samp{pdksh}
13931 A public-domain clone of the Korn shell called @command{pdksh} is widely
13932 available: it has most of the @samp{ksh88} features along with a few of
13933 its own.  It usually sets @code{KSH_VERSION}, except if invoked as
13934 @command{/bin/sh} on Open@acronym{BSD}, and similarly to Bash you can require
13935 Posix compatibility by running @samp{set -o posix}.  Unfortunately, with
13936 @command{pdksh} 5.2.14 (the latest stable version as of January 2007)
13937 Posix mode is buggy and causes @command{pdksh} to depart from Posix in
13938 at least one respect:
13940 @example
13941 $ @kbd{echo "`echo \"hello\"`"}
13942 hello
13943 $ @kbd{set -o posix}
13944 $ @kbd{echo "`echo \"hello\"`"}
13945 "hello"
13946 @end example
13948 The last line of output contains spurious quotes.  This is yet another
13949 reason why portable shell code should not contain
13950 @code{"`@dots{}\"@dots{}\"@dots{}`"} constructs (@pxref{Shell
13951 Substitutions}).
13953 @item Zsh
13954 @cindex Zsh
13955 To detect whether you are running @command{zsh}, test whether
13956 @code{ZSH_VERSION} is set.  By default @command{zsh} is @emph{not}
13957 compatible with the Bourne shell: you must execute @samp{emulate sh},
13958 and for @command{zsh} versions before 3.1.6-dev-18 you must also
13959 set @code{NULLCMD} to @samp{:}.  @xref{Compatibility, , Compatibility,
13960 zsh, The Z Shell Manual}, for details.
13962 The default Mac OS X @command{sh} was originally Zsh; it was changed to
13963 Bash in Mac OS X 10.2.
13964 @end table
13966 @node Here-Documents
13967 @section Here-Documents
13968 @cindex Here-documents
13969 @cindex Shell here-documents
13971 Don't rely on @samp{\} being preserved just because it has no special
13972 meaning together with the next symbol.  In the native @command{sh}
13973 on Open@acronym{BSD} 2.7 @samp{\"} expands to @samp{"} in here-documents with
13974 unquoted delimiter.  As a general rule, if @samp{\\} expands to @samp{\}
13975 use @samp{\\} to get @samp{\}.
13977 With Open@acronym{BSD} 2.7's @command{sh}
13979 @example
13980 @group
13981 $ @kbd{cat <<EOF
13982 > \" \\
13983 > EOF}
13984 " \
13985 @end group
13986 @end example
13988 @noindent
13989 and with Bash:
13991 @example
13992 @group
13993 bash-2.04$ @kbd{cat <<EOF
13994 > \" \\
13995 > EOF}
13996 \" \
13997 @end group
13998 @end example
14000 Some shells mishandle large here-documents: for example,
14001 Solaris 10 @command{dtksh} and the UnixWare 7.1.1 Posix shell, which are
14002 derived from Korn shell version M-12/28/93d, mishandle braced variable
14003 expansion that crosses a 1024- or 4096-byte buffer boundary
14004 within a here-document.  Only the part of the variable name after the boundary
14005 is used.  For example, @code{$@{variable@}} could be replaced by the expansion
14006 of @code{$@{ble@}}.  If the end of the variable name is aligned with the block
14007 boundary, the shell reports an error, as if you used @code{$@{@}}.
14008 Instead of @code{$@{variable-default@}}, the shell may expand
14009 @code{$@{riable-default@}}, or even @code{$@{fault@}}.  This bug can often
14010 be worked around by omitting the braces: @code{$variable}.  The bug was
14011 fixed in
14012 @samp{ksh93g} (1998-04-30) but as of 2006 many operating systems were
14013 still shipping older versions with the bug.
14015 Many shells (including the Bourne shell) implement here-documents
14016 inefficiently.  In particular, some shells can be extremely inefficient when
14017 a single statement contains many here-documents.  For instance if your
14018 @file{configure.ac} includes something like:
14020 @example
14021 @group
14022 if <cross_compiling>; then
14023   assume this and that
14024 else
14025   check this
14026   check that
14027   check something else
14028   @dots{}
14029   on and on forever
14030   @dots{}
14032 @end group
14033 @end example
14035 A shell parses the whole @code{if}/@code{fi} construct, creating
14036 temporary files for each here-document in it.  Some shells create links
14037 for such here-documents on every @code{fork}, so that the clean-up code
14038 they had installed correctly removes them.  It is creating the links
14039 that can take the shell forever.
14041 Moving the tests out of the @code{if}/@code{fi}, or creating multiple
14042 @code{if}/@code{fi} constructs, would improve the performance
14043 significantly.  Anyway, this kind of construct is not exactly the
14044 typical use of Autoconf.  In fact, it's even not recommended, because M4
14045 macros can't look into shell conditionals, so we may fail to expand a
14046 macro when it was expanded before in a conditional path, and the
14047 condition turned out to be false at runtime, and we end up not
14048 executing the macro at all.
14050 @node File Descriptors
14051 @section File Descriptors
14052 @cindex Descriptors
14053 @cindex File descriptors
14054 @cindex Shell file descriptors
14056 Most shells, if not all (including Bash, Zsh, Ash), output traces on
14057 stderr, even for subshells.  This might result in undesirable content
14058 if you meant to capture the standard-error output of the inner command:
14060 @example
14061 $ @kbd{ash -x -c '(eval "echo foo >&2") 2>stderr'}
14062 $ @kbd{cat stderr}
14063 + eval echo foo >&2
14064 + echo foo
14066 $ @kbd{bash -x -c '(eval "echo foo >&2") 2>stderr'}
14067 $ @kbd{cat stderr}
14068 + eval 'echo foo >&2'
14069 ++ echo foo
14071 $ @kbd{zsh -x -c '(eval "echo foo >&2") 2>stderr'}
14072 @i{# Traces on startup files deleted here.}
14073 $ @kbd{cat stderr}
14074 +zsh:1> eval echo foo >&2
14075 +zsh:1> echo foo
14077 @end example
14079 @noindent
14080 One workaround is to grep out uninteresting lines, hoping not to remove
14081 good ones.
14083 If you intend to redirect both standard error and standard output,
14084 redirect standard output first.  This works better with @acronym{HP-UX},
14085 since its shell mishandles tracing if standard error is redirected
14086 first:
14088 @example
14089 $ @kbd{sh -x -c ': 2>err >out'}
14090 + :
14091 + 2> err $ @kbd{cat err}
14092 1> out
14093 @end example
14095 Don't try to redirect the standard error of a command substitution.  It
14096 must be done @emph{inside} the command substitution.  When running
14097 @samp{: `cd /zorglub` 2>/dev/null} expect the error message to
14098 escape, while @samp{: `cd /zorglub 2>/dev/null`} works properly.
14100 It is worth noting that Zsh (but not Ash nor Bash) makes it possible
14101 in assignments though: @samp{foo=`cd /zorglub` 2>/dev/null}.
14103 When catering to old systems, don't redirect the same file descriptor
14104 several times, as you are doomed to failure under Ultrix.
14106 @example
14107 ULTRIX V4.4 (Rev. 69) System #31: Thu Aug 10 19:42:23 GMT 1995
14108 UWS V4.4 (Rev. 11)
14109 $ @kbd{eval 'echo matter >fullness' >void}
14110 illegal io
14111 $ @kbd{eval '(echo matter >fullness)' >void}
14112 illegal io
14113 $ @kbd{(eval '(echo matter >fullness)') >void}
14114 Ambiguous output redirect.
14115 @end example
14117 @noindent
14118 In each case the expected result is of course @file{fullness} containing
14119 @samp{matter} and @file{void} being empty.  However, this bug is
14120 probably not of practical concern to modern platforms.
14122 Solaris 10 @command{sh} will try to optimize away a @command{:} command
14123 in a loop after the first iteration, even if it is redirected:
14125 @example
14126 $ @kbd{for i in 1 2 3 ; do : >x$i; done}
14127 $ @kbd{ls}
14129 @end example
14131 @noindent
14132 As a workaround, @command{echo} or @command{eval} can be used.
14134 Don't rely on file descriptors 0, 1, and 2 remaining closed in a
14135 subsidiary program.  If any of these descriptors is closed, the
14136 operating system may open an unspecified file for the descriptor in the
14137 new process image.  Posix says this may be done only if the subsidiary
14138 program is set-user-ID or set-group-ID, but @acronym{HP-UX} 11.23 does
14139 it even for ordinary programs.
14141 Don't rely on open file descriptors being open in child processes.  In
14142 @command{ksh}, file descriptors above 2 which are opened using
14143 @samp{exec @var{n}>file} are closed by a subsequent @samp{exec} (such as
14144 that involved in the fork-and-exec which runs a program or script).
14145 Thus, using @command{sh}, we have:
14147 @example
14148 $ @kbd{cat ./descrips}
14149 #!/bin/sh -
14150 echo hello >&5
14151 $ @kbd{exec 5>t}
14152 $ @kbd{./descrips}
14153 $ @kbd{cat t}
14154 hello
14156 @end example
14158 @noindent
14159 But using ksh:
14161 @example
14162 $ @kbd{exec 5>t}
14163 $ @kbd{./descrips}
14164 hello
14165 $ @kbd{cat t}
14167 @end example
14169 @noindent
14170 Within the process which runs the @samp{descrips} script, file
14171 descriptor 5 is closed.
14173 Don't rely on redirection to a closed file descriptor to cause an
14174 error.  With Solaris @command{/bin/sh}, when the redirection fails, the
14175 output goes to the original file descriptor.
14177 @example
14178 $ @kbd{bash -c 'echo hi >&3' 3>&-; echo $?}
14179 bash: 3: Bad file descriptor
14181 $ @kbd{/bin/sh -c 'echo hi >&3' 3>&-; echo $?}
14184 @end example
14186 @acronym{DOS} variants cannot rename or remove open files, such as in
14187 @samp{mv foo bar >foo} or @samp{rm foo >foo}, even though this is
14188 perfectly portable among Posix hosts.
14190 A few ancient systems reserved some file descriptors.  By convention,
14191 file descriptor 3 was opened to @file{/dev/tty} when you logged into
14192 Eighth Edition (1985) through Tenth Edition Unix (1989).  File
14193 descriptor 4 had a special use on the Stardent/Kubota Titan (circa
14194 1990), though we don't now remember what it was.  Both these systems are
14195 obsolete, so it's now safe to treat file descriptors 3 and 4 like any
14196 other file descriptors.
14198 @node File System Conventions
14199 @section File System Conventions
14200 @cindex File system conventions
14202 Autoconf uses shell-script processing extensively, so the file names
14203 that it processes should not contain characters that are special to the
14204 shell.  Special characters include space, tab, newline, @sc{nul}, and
14205 the following:
14207 @example
14208 " # $ & ' ( ) * ; < = > ? [ \ ` |
14209 @end example
14211 Also, file names should not begin with @samp{~} or @samp{-}, and should
14212 contain neither @samp{-} immediately after @samp{/} nor @samp{~}
14213 immediately after @samp{:}.  On Posix-like platforms, directory names
14214 should not contain @samp{:}, as this runs afoul of @samp{:} used as the
14215 path separator.
14217 These restrictions apply not only to the files that you distribute, but
14218 also to the absolute file names of your source, build, and destination
14219 directories.
14221 On some Posix-like platforms, @samp{!} and @samp{^} are special too, so
14222 they should be avoided.
14224 Posix lets implementations treat leading @file{//} specially, but
14225 requires leading @file{///} and beyond to be equivalent to @file{/}.
14226 Most Unix variants treat @file{//} like @file{/}.  However, some treat
14227 @file{//} as a ``super-root'' that can provide access to files that are
14228 not otherwise reachable from @file{/}.  The super-root tradition began
14229 with Apollo Domain/OS, which died out long ago, but unfortunately Cygwin
14230 has revived it.
14232 While @command{autoconf} and friends are usually run on some Posix
14233 variety, they can be used on other systems, most notably @acronym{DOS}
14234 variants.  This impacts several assumptions regarding file names.
14236 @noindent
14237 For example, the following code:
14239 @example
14240 case $foo_dir in
14241   /*) # Absolute
14242      ;;
14243   *)
14244      foo_dir=$dots$foo_dir ;;
14245 esac
14246 @end example
14248 @noindent
14249 fails to properly detect absolute file names on those systems, because
14250 they can use a drivespec, and usually use a backslash as directory
14251 separator.  If you want to be portable to @acronym{DOS} variants (at the
14252 price of rejecting valid but oddball Posix file names like @file{a:\b}),
14253 you can check for absolute file names like this:
14255 @cindex absolute file names, detect
14256 @example
14257 case $foo_dir in
14258   [\\/]* | ?:[\\/]* ) # Absolute
14259      ;;
14260   *)
14261      foo_dir=$dots$foo_dir ;;
14262 esac
14263 @end example
14265 @noindent
14266 Make sure you quote the brackets if appropriate and keep the backslash as
14267 first character (@pxref{case, , Limitations of Shell Builtins}).
14269 Also, because the colon is used as part of a drivespec, these systems don't
14270 use it as path separator.  When creating or accessing paths, you can use the
14271 @code{PATH_SEPARATOR} output variable instead.  @command{configure} sets this
14272 to the appropriate value for the build system (@samp{:} or @samp{;}) when it
14273 starts up.
14275 File names need extra care as well.  While @acronym{DOS} variants
14276 that are Posixy enough to run @command{autoconf} (such as @acronym{DJGPP})
14277 are usually able to handle long file names properly, there are still
14278 limitations that can seriously break packages.  Several of these issues
14279 can be easily detected by the
14280 @uref{ftp://@/ftp.gnu.org/@/gnu/@/non-gnu/@/doschk/@/doschk-1.1.tar.gz, doschk}
14281 package.
14283 A short overview follows; problems are marked with @sc{sfn}/@sc{lfn} to
14284 indicate where they apply: @sc{sfn} means the issues are only relevant to
14285 plain @acronym{DOS}, not to @acronym{DOS} under Microsoft Windows
14286 variants, while @sc{lfn} identifies problems that exist even under
14287 Microsoft Windows variants.
14289 @table @asis
14290 @item No multiple dots (@sc{sfn})
14291 @acronym{DOS} cannot handle multiple dots in file names.  This is an especially
14292 important thing to remember when building a portable configure script,
14293 as @command{autoconf} uses a .in suffix for template files.
14295 This is perfectly OK on Posix variants:
14297 @example
14298 AC_CONFIG_HEADERS([config.h])
14299 AC_CONFIG_FILES([source.c foo.bar])
14300 AC_OUTPUT
14301 @end example
14303 @noindent
14304 but it causes problems on @acronym{DOS}, as it requires @samp{config.h.in},
14305 @samp{source.c.in} and @samp{foo.bar.in}.  To make your package more portable
14306 to @acronym{DOS}-based environments, you should use this instead:
14308 @example
14309 AC_CONFIG_HEADERS([config.h:config.hin])
14310 AC_CONFIG_FILES([source.c:source.cin foo.bar:foobar.in])
14311 AC_OUTPUT
14312 @end example
14314 @item No leading dot (@sc{sfn})
14315 @acronym{DOS} cannot handle file names that start with a dot.  This is usually
14316 not important for @command{autoconf}.
14318 @item Case insensitivity (@sc{lfn})
14319 @acronym{DOS} is case insensitive, so you cannot, for example, have both a
14320 file called @samp{INSTALL} and a directory called @samp{install}.  This
14321 also affects @command{make}; if there's a file called @samp{INSTALL} in
14322 the directory, @samp{make install} does nothing (unless the
14323 @samp{install} target is marked as PHONY).
14325 @item The 8+3 limit (@sc{sfn})
14326 Because the @acronym{DOS} file system only stores the first 8 characters of
14327 the file name and the first 3 of the extension, those must be unique.
14328 That means that @file{foobar-part1.c}, @file{foobar-part2.c} and
14329 @file{foobar-prettybird.c} all resolve to the same file name
14330 (@file{FOOBAR-P.C}).  The same goes for @file{foo.bar} and
14331 @file{foo.bartender}.
14333 The 8+3 limit is not usually a problem under Microsoft Windows, as it
14334 uses numeric
14335 tails in the short version of file names to make them unique.  However, a
14336 registry setting can turn this behavior off.  While this makes it
14337 possible to share file trees containing long file names between @sc{sfn}
14338 and @sc{lfn} environments, it also means the above problem applies there
14339 as well.
14341 @item Invalid characters (@sc{lfn})
14342 Some characters are invalid in @acronym{DOS} file names, and should therefore
14343 be avoided.  In a @sc{lfn} environment, these are @samp{/}, @samp{\},
14344 @samp{?}, @samp{*}, @samp{:}, @samp{<}, @samp{>}, @samp{|} and @samp{"}.
14345 In a @sc{sfn} environment, other characters are also invalid.  These
14346 include @samp{+}, @samp{,}, @samp{[} and @samp{]}.
14348 @item Invalid names (@sc{lfn})
14349 Some @acronym{DOS} file names are reserved, and cause problems if you
14350 try to use files with those names.  These names include @file{CON},
14351 @file{AUX}, @file{COM1}, @file{COM2}, @file{COM3}, @file{COM4},
14352 @file{LPT1}, @file{LPT2}, @file{LPT3}, @file{NUL}, and @file{PRN}.
14353 File names are case insensitive, so even names like
14354 @file{aux/config.guess} are disallowed.
14356 @end table
14358 @node Shell Pattern Matching
14359 @section Shell Pattern Matching
14360 @cindex Shell pattern matching
14362 Nowadays portable patterns can use negated character classes like
14363 @samp{[!-aeiou]}.  The older syntax @samp{[^-aeiou]} is supported by
14364 some shells but not others; hence portable scripts should never use
14365 @samp{^} as the first character of a bracket pattern.
14367 Outside the C locale, patterns like @samp{[a-z]} are problematic since
14368 they may match characters that are not lower-case letters.
14370 @node Shell Substitutions
14371 @section Shell Substitutions
14372 @cindex Shell substitutions
14374 Contrary to a persistent urban legend, the Bourne shell does not
14375 systematically split variables and back-quoted expressions, in particular
14376 on the right-hand side of assignments and in the argument of @code{case}.
14377 For instance, the following code:
14379 @example
14380 case "$given_srcdir" in
14381 .)  top_srcdir="`echo "$dots" | sed 's|/$||'`" ;;
14382 *)  top_srcdir="$dots$given_srcdir" ;;
14383 esac
14384 @end example
14386 @noindent
14387 is more readable when written as:
14389 @example
14390 case $given_srcdir in
14391 .)  top_srcdir=`echo "$dots" | sed 's|/$||'` ;;
14392 *)  top_srcdir=$dots$given_srcdir ;;
14393 esac
14394 @end example
14396 @noindent
14397 and in fact it is even @emph{more} portable: in the first case of the
14398 first attempt, the computation of @code{top_srcdir} is not portable,
14399 since not all shells properly understand @code{"`@dots{}"@dots{}"@dots{}`"}.
14400 Worse yet, not all shells understand @code{"`@dots{}\"@dots{}\"@dots{}`"}
14401 the same way.  There is just no portable way to use double-quoted
14402 strings inside double-quoted back-quoted expressions (pfew!).
14404 @table @code
14405 @item $@@
14406 @cindex @samp{"$@@"}
14407 One of the most famous shell-portability issues is related to
14408 @samp{"$@@"}.  When there are no positional arguments, Posix says
14409 that @samp{"$@@"} is supposed to be equivalent to nothing, but the
14410 original Unix version 7 Bourne shell treated it as equivalent to
14411 @samp{""} instead, and this behavior survives in later implementations
14412 like Digital Unix 5.0.
14414 The traditional way to work around this portability problem is to use
14415 @samp{$@{1+"$@@"@}}.  Unfortunately this method does not work with
14416 Zsh (3.x and 4.x), which is used on Mac OS X@.  When emulating
14417 the Bourne shell, Zsh performs word splitting on @samp{$@{1+"$@@"@}}:
14419 @example
14420 zsh $ @kbd{emulate sh}
14421 zsh $ @kbd{for i in "$@@"; do echo $i; done}
14422 Hello World
14424 zsh $ @kbd{for i in $@{1+"$@@"@}; do echo $i; done}
14425 Hello
14426 World
14428 @end example
14430 @noindent
14431 Zsh handles plain @samp{"$@@"} properly, but we can't use plain
14432 @samp{"$@@"} because of the portability problems mentioned above.
14433 One workaround relies on Zsh's ``global aliases'' to convert
14434 @samp{$@{1+"$@@"@}} into @samp{"$@@"} by itself:
14436 @example
14437 test "$@{ZSH_VERSION+set@}" = set && alias -g '$@{1+"$@@"@}'='"$@@"'
14438 @end example
14440 Zsh only recognizes this alias when a shell word matches it exactly;
14441 @samp{"foo"$@{1+"$@@"@}} remains subject to word splitting.  Since this
14442 case always yields at least one shell word, use plain @samp{"$@@"}.
14444 A more conservative workaround is to avoid @samp{"$@@"} if it is
14445 possible that there may be no positional arguments.  For example,
14446 instead of:
14448 @example
14449 cat conftest.c "$@@"
14450 @end example
14452 you can use this instead:
14454 @example
14455 case $# in
14456 0) cat conftest.c;;
14457 *) cat conftest.c "$@@";;
14458 esac
14459 @end example
14461 Autoconf macros often use the @command{set} command to update
14462 @samp{$@@}, so if you are writing shell code intended for
14463 @command{configure} you should not assume that the value of @samp{$@@}
14464 persists for any length of time.
14467 @item $@{10@}
14468 @cindex positional parameters
14469 The 10th, 11th, @dots{} positional parameters can be accessed only after
14470 a @code{shift}.  The 7th Edition shell reported an error if given
14471 @code{$@{10@}}, and
14472 Solaris 10 @command{/bin/sh} still acts that way:
14474 @example
14475 $ @kbd{set 1 2 3 4 5 6 7 8 9 10}
14476 $ @kbd{echo $@{10@}}
14477 bad substitution
14478 @end example
14480 @item $@{@var{var}:-@var{value}@}
14481 @c Info cannot handle `:' in index entries.
14482 @c @cindex $@{@var{var}:-@var{value}@}
14483 Old @acronym{BSD} shells, including the Ultrix @code{sh}, don't accept the
14484 colon for any shell substitution, and complain and die.
14485 Similarly for $@{@var{var}:=@var{value}@}, $@{@var{var}:?@var{value}@}, etc.
14487 @item $@{@var{var}=@var{literal}@}
14488 @cindex $@{@var{var}=@var{literal}@}
14489 Be sure to quote:
14491 @example
14492 : $@{var='Some words'@}
14493 @end example
14495 @noindent
14496 otherwise some shells, such as on Digital Unix V 5.0, die because
14497 of a ``bad substitution''.
14499 @sp 1
14501 Solaris @command{/bin/sh} has a frightening bug in its interpretation
14502 of this.  Imagine you need set a variable to a string containing
14503 @samp{@}}.  This @samp{@}} character confuses Solaris @command{/bin/sh}
14504 when the affected variable was already set.  This bug can be exercised
14505 by running:
14507 @example
14508 $ @kbd{unset foo}
14509 $ @kbd{foo=$@{foo='@}'@}}
14510 $ @kbd{echo $foo}
14512 $ @kbd{foo=$@{foo='@}'   # no error; this hints to what the bug is}
14513 $ @kbd{echo $foo}
14515 $ @kbd{foo=$@{foo='@}'@}}
14516 $ @kbd{echo $foo}
14517 @}@}
14518  ^ ugh!
14519 @end example
14521 It seems that @samp{@}} is interpreted as matching @samp{$@{}, even
14522 though it is enclosed in single quotes.  The problem doesn't happen
14523 using double quotes.
14525 @item $@{@var{var}=@var{expanded-value}@}
14526 @cindex $@{@var{var}=@var{expanded-value}@}
14527 On Ultrix,
14528 running
14530 @example
14531 default="yu,yaa"
14532 : $@{var="$default"@}
14533 @end example
14535 @noindent
14536 sets @var{var} to @samp{M-yM-uM-,M-yM-aM-a}, i.e., the 8th bit of
14537 each char is set.  You don't observe the phenomenon using a simple
14538 @samp{echo $var} since apparently the shell resets the 8th bit when it
14539 expands $var.  Here are two means to make this shell confess its sins:
14541 @example
14542 $ @kbd{cat -v <<EOF
14543 $var
14544 EOF}
14545 @end example
14547 @noindent
14550 @example
14551 $ @kbd{set | grep '^var=' | cat -v}
14552 @end example
14554 One classic incarnation of this bug is:
14556 @example
14557 default="a b c"
14558 : $@{list="$default"@}
14559 for c in $list; do
14560   echo $c
14561 done
14562 @end example
14564 @noindent
14565 You'll get @samp{a b c} on a single line.  Why?  Because there are no
14566 spaces in @samp{$list}: there are @samp{M- }, i.e., spaces with the 8th
14567 bit set, hence no IFS splitting is performed!!!
14569 One piece of good news is that Ultrix works fine with @samp{:
14570 $@{list=$default@}}; i.e., if you @emph{don't} quote.  The bad news is
14571 then that @acronym{QNX} 4.25 then sets @var{list} to the @emph{last} item of
14572 @var{default}!
14574 The portable way out consists in using a double assignment, to switch
14575 the 8th bit twice on Ultrix:
14577 @example
14578 list=$@{list="$default"@}
14579 @end example
14581 @noindent
14582 @dots{}but beware of the @samp{@}} bug from Solaris (see above).  For safety,
14583 use:
14585 @example
14586 test "$@{var+set@}" = set || var=@var{@{value@}}
14587 @end example
14589 @item $@{#@var{var}@}
14590 @itemx $@{@var{var}%@var{word}@}
14591 @itemx $@{@var{var}%%@var{word}@}
14592 @itemx $@{@var{var}#@var{word}@}
14593 @itemx $@{@var{var}##@var{word}@}
14594 @cindex $@{#@var{var}@}
14595 @cindex $@{@var{var}%@var{word}@}
14596 @cindex $@{@var{var}%%@var{word}@}
14597 @cindex $@{@var{var}#@var{word}@}
14598 @cindex $@{@var{var}##@var{word}@}
14599 Posix requires support for these usages, but they do not work with many
14600 traditional shells, e.g., Solaris 10 @command{/bin/sh}.
14602 Also, @command{pdksh} 5.2.14 mishandles some @var{word} forms.  For
14603 example if @samp{$1} is @samp{a/b} and @samp{$2} is @samp{a}, then
14604 @samp{$@{1#$2@}} should yield @samp{/b}, but with @command{pdksh} it
14605 yields the empty string.
14608 @item `@var{commands}`
14609 @cindex `@var{commands}`
14610 @cindex Command Substitution
14611 Posix requires shells to trim all trailing newlines from command
14612 output before substituting it, so assignments like
14613 @samp{dir=`echo "$file" | tr a A`} do not work as expected if
14614 @samp{$file} ends in a newline.
14616 While in general it makes no sense, do not substitute a single builtin
14617 with side effects, because Ash 0.2, trying to optimize, does not fork a
14618 subshell to perform the command.
14620 For instance, if you wanted to check that @command{cd} is silent, do not
14621 use @samp{test -z "`cd /`"} because the following can happen:
14623 @example
14624 $ @kbd{pwd}
14625 /tmp
14626 $ @kbd{test -z "`cd /`" && pwd}
14628 @end example
14630 @noindent
14631 The result of @samp{foo=`exit 1`} is left as an exercise to the reader.
14633 The MSYS shell leaves a stray byte in the expansion of a double-quoted
14634 command substitution of a native program, if the end of the substitution
14635 is not aligned with the end of the double quote.  This may be worked
14636 around by inserting another pair of quotes:
14638 @example
14639 $ @kbd{echo "`printf 'foo\r\n'` bar" > broken}
14640 $ @kbd{echo "`printf 'foo\r\n'`"" bar" | cmp - broken}
14641 - broken differ: char 4, line 1
14642 @end example
14644 Upon interrupt or SIGTERM, some shells may abort a command substitution,
14645 replace it with a null string, and wrongly evaluate the enclosing
14646 command before entering the trap or ending the script.  This can lead to
14647 spurious errors:
14649 @example
14650 $ @kbd{sh -c 'if test `sleep 5; echo hi` = hi; then echo yes; fi'}
14651 $ @kbd{^C}
14652 sh: test: hi: unexpected operator/operand
14653 @end example
14655 @noindent
14656 You can avoid this by assigning the command substitution to a temporary
14657 variable:
14659 @example
14660 $ @kbd{sh -c 'res=`sleep 5; echo hi`
14661          if test "x$res" = xhi; then echo yes; fi'}
14662 $ @kbd{^C}
14663 @end example
14665 @item $(@var{commands})
14666 @cindex $(@var{commands})
14667 This construct is meant to replace @samp{`@var{commands}`},
14668 and it has most of the problems listed under @code{`@var{commands}`}.
14670 This construct can be
14671 nested while this is impossible to do portably with back quotes.
14672 Unfortunately it is not yet universally supported.  Most notably, even recent
14673 releases of Solaris don't support it:
14675 @example
14676 $ @kbd{showrev -c /bin/sh | grep version}
14677 Command version: SunOS 5.10 Generic 121005-03 Oct 2006
14678 $ @kbd{echo $(echo blah)}
14679 syntax error: `(' unexpected
14680 @end example
14682 @noindent
14683 nor does @sc{irix} 6.5's Bourne shell:
14684 @example
14685 $ @kbd{uname -a}
14686 IRIX firebird-image 6.5 07151432 IP22
14687 $ @kbd{echo $(echo blah)}
14688 $(echo blah)
14689 @end example
14691 If you do use @samp{$(@var{commands})}, make sure that the commands
14692 do not start with a parenthesis, as that would cause confusion with
14693 a different notation @samp{$((@var{expression}))} that in modern
14694 shells is an arithmetic expression not a command.  To avoid the
14695 confusion, insert a space between the two opening parentheses.
14697 Avoid @var{commands} that contain unbalanced parentheses in
14698 here-documents, comments, or case statement patterns, as many shells
14699 mishandle them.  For example, Bash 3.1, @samp{ksh88}, @command{pdksh}
14700 5.2.14, and Zsh 4.2.6 all mishandle the following valid command:
14702 @example
14703 echo $(case x in x) echo hello;; esac)
14704 @end example
14707 @item $((@var{expression}))
14708 @cindex $((@var{expression}))
14709 Arithmetic expansion is not portable as some shells (most
14710 notably Solaris 10 @command{/bin/sh}) don't support it.
14712 Among shells that do support @samp{$(( ))}, not all of them obey the
14713 Posix rule that octal and hexadecimal constants must be recognized:
14715 @example
14716 $ @kbd{bash -c 'echo $(( 010 + 0x10 ))'}
14718 $ @kbd{zsh -c 'echo $(( 010 + 0x10 ))'}
14720 $ @kbd{zsh -c 'emulate sh; echo $(( 010 + 0x10 ))'}
14722 $ @kbd{pdksh -c 'echo $(( 010 + 0x10 ))'}
14723 pdksh:  010 + 0x10 : bad number `0x10'
14724 $ @kbd{pdksh -c 'echo $(( 010 ))'}
14726 @end example
14728 When it is available, using arithmetic expansion provides a noticeable
14729 speedup in script execution; but testing for support requires
14730 @command{eval} to avoid syntax errors.  The following construct is used
14731 by @code{AS_VAR_ARITH} to provide arithmetic computation when all
14732 arguments are provided in decimal and without a leading zero, and all
14733 operators are properly quoted and appear as distinct arguments:
14735 @example
14736 if ( eval 'test $(( 1 + 1 )) = 2' ) 2>/dev/null; then
14737   eval 'func_arith ()
14738   @{
14739     func_arith_result=$(( $* ))
14740   @}'
14741 else
14742   func_arith ()
14743   @{
14744     func_arith_result=`expr "$@@"`
14745   @}
14747 func_arith 1 + 1
14748 foo=$func_arith_result
14749 @end example
14752 @item ^
14753 @cindex ^ quoting
14754 Always quote @samp{^}, otherwise traditional shells such as
14755 @command{/bin/sh} on Solaris 10 treat this like @samp{|}.
14757 @end table
14760 @node Assignments
14761 @section Assignments
14762 @cindex Shell assignments
14764 When setting several variables in a row, be aware that the order of the
14765 evaluation is undefined.  For instance @samp{foo=1 foo=2; echo $foo}
14766 gives @samp{1} with Solaris @command{/bin/sh}, but @samp{2} with Bash.
14767 You must use
14768 @samp{;} to enforce the order: @samp{foo=1; foo=2; echo $foo}.
14770 Don't rely on the following to find @file{subdir/program}:
14772 @example
14773 PATH=subdir$PATH_SEPARATOR$PATH program
14774 @end example
14776 @noindent
14777 as this does not work with Zsh 3.0.6.  Use something like this
14778 instead:
14780 @example
14781 (PATH=subdir$PATH_SEPARATOR$PATH; export PATH; exec program)
14782 @end example
14784 Don't rely on the exit status of an assignment: Ash 0.2 does not change
14785 the status and propagates that of the last statement:
14787 @example
14788 $ @kbd{false || foo=bar; echo $?}
14790 $ @kbd{false || foo=`:`; echo $?}
14792 @end example
14794 @noindent
14795 and to make things even worse, @acronym{QNX} 4.25 just sets the exit status
14796 to 0 in any case:
14798 @example
14799 $ @kbd{foo=`exit 1`; echo $?}
14801 @end example
14803 To assign default values, follow this algorithm:
14805 @enumerate
14806 @item
14807 If the default value is a literal and does not contain any closing
14808 brace, use:
14810 @example
14811 : $@{var='my literal'@}
14812 @end example
14814 @item
14815 If the default value contains no closing brace, has to be expanded, and
14816 the variable being initialized is not intended to be IFS-split
14817 (i.e., it's not a list), then use:
14819 @example
14820 : $@{var="$default"@}
14821 @end example
14823 @item
14824 If the default value contains no closing brace, has to be expanded, and
14825 the variable being initialized is intended to be IFS-split (i.e., it's a list),
14826 then use:
14828 @example
14829 var=$@{var="$default"@}
14830 @end example
14832 @item
14833 If the default value contains a closing brace, then use:
14835 @example
14836 test "$@{var+set@}" = set || var="has a '@}'"
14837 @end example
14838 @end enumerate
14840 In most cases @samp{var=$@{var="$default"@}} is fine, but in case of
14841 doubt, just use the last form.  @xref{Shell Substitutions}, items
14842 @samp{$@{@var{var}:-@var{value}@}} and @samp{$@{@var{var}=@var{value}@}}
14843 for the rationale.
14845 @node Parentheses
14846 @section Parentheses in Shell Scripts
14847 @cindex Shell parentheses
14849 Beware of two opening parentheses in a row, as many shell
14850 implementations treat them specially.  Posix requires that the command
14851 @samp{((cat))} must behave like @samp{(cat)}, but many shells, including
14852 Bash and the Korn shell, treat @samp{((cat))} as an arithmetic
14853 expression equivalent to @samp{let "cat"}, and may or may not report an
14854 error when they detect that @samp{cat} is not a number.  As another
14855 example, @samp{pdksh} 5.2.14 misparses the following code:
14857 @example
14858 if ((true) || false); then
14859   echo ok
14861 @end example
14863 @noindent
14864 To work around this problem, insert a space between the two opening
14865 parentheses.  There is a similar problem and workaround with
14866 @samp{$((}; see @ref{Shell Substitutions}.
14868 @node Slashes
14869 @section Slashes in Shell Scripts
14870 @cindex Shell slashes
14872 Unpatched Tru64 5.1 @command{sh} omits the last slash of command-line
14873 arguments that contain two trailing slashes:
14875 @example
14876 $ @kbd{echo / // /// //// .// //.}
14877 / / // /// ./ //.
14878 $ @kbd{x=//}
14879 $ @kbd{eval "echo \$x"}
14881 $ @kbd{set -x}
14882 $ @kbd{echo abc | tr -t ab //}
14883 + echo abc
14884 + tr -t ab /
14886 @end example
14888 Unpatched Tru64 4.0 @command{sh} adds a slash after @samp{"$var"} if the
14889 variable is empty and the second double-quote is followed by a word that
14890 begins and ends with slash:
14892 @example
14893 $ @kbd{sh -xc 'p=; echo "$p"/ouch/'}
14895 + echo //ouch/
14896 //ouch/
14897 @end example
14899 However, our understanding is that patches are available, so perhaps
14900 it's not worth worrying about working around these horrendous bugs.
14902 @node Special Shell Variables
14903 @section Special Shell Variables
14904 @cindex Shell variables
14905 @cindex Special shell variables
14907 Some shell variables should not be used, since they can have a deep
14908 influence on the behavior of the shell.  In order to recover a sane
14909 behavior from the shell, some variables should be unset; M4sh takes
14910 care of this and provides fallback values, whenever needed, to cater
14911 for a very old @file{/bin/sh} that does not support @command{unset}.
14912 (@pxref{Portable Shell, , Portable Shell Programming}).
14914 As a general rule, shell variable names containing a lower-case letter
14915 are safe; you can define and use these variables without worrying about
14916 their effect on the underlying system, and without worrying about
14917 whether the shell changes them unexpectedly.  (The exception is the
14918 shell variable @code{status}, as described below.)
14920 Here is a list of names that are known to cause trouble.  This list is
14921 not exhaustive, but you should be safe if you avoid the name
14922 @code{status} and names containing only upper-case letters and
14923 underscores.
14925 @c Alphabetical order, case insensitive, `A' before `a'.
14926 @table @code
14927 @item _
14928 Many shells reserve @samp{$_} for various purposes, e.g., the name of
14929 the last command executed.
14931 @item BIN_SH
14932 @evindex BIN_SH
14933 In Tru64, if @env{BIN_SH} is set to @code{xpg4}, subsidiary invocations of
14934 the standard shell conform to Posix.
14936 @item CDPATH
14937 @evindex CDPATH
14938 When this variable is set it specifies a list of directories to search
14939 when invoking @code{cd} with a relative file name that did not start
14940 with @samp{./} or @samp{../}.  Posix
14941 1003.1-2001 says that if a nonempty directory name from @env{CDPATH}
14942 is used successfully, @code{cd} prints the resulting absolute
14943 file name.  Unfortunately this output can break idioms like
14944 @samp{abs=`cd src && pwd`} because @code{abs} receives the name twice.
14945 Also, many shells do not conform to this part of Posix; for
14946 example, @command{zsh} prints the result only if a directory name
14947 other than @file{.} was chosen from @env{CDPATH}.
14949 In practice the shells that have this problem also support
14950 @command{unset}, so you can work around the problem as follows:
14952 @example
14953 (unset CDPATH) >/dev/null 2>&1 && unset CDPATH
14954 @end example
14956 You can also avoid output by ensuring that your directory name is
14957 absolute or anchored at @samp{./}, as in @samp{abs=`cd ./src && pwd`}.
14959 Configure scripts use M4sh, which automatically unsets @env{CDPATH} if
14960 possible, so you need not worry about this problem in those scripts.
14962 @item DUALCASE
14963 @evindex DUALCASE
14964 In the MKS shell, case statements and file name generation are
14965 case-insensitive unless @env{DUALCASE} is nonzero.
14966 Autoconf-generated scripts export this variable when they start up.
14968 @item ENV
14969 @itemx MAIL
14970 @itemx MAILPATH
14971 @itemx PS1
14972 @itemx PS2
14973 @itemx PS4
14974 @evindex ENV
14975 @evindex MAIL
14976 @evindex MAILPATH
14977 @evindex PS1
14978 @evindex PS2
14979 @evindex PS4
14980 These variables should not matter for shell scripts, since they are
14981 supposed to affect only interactive shells.  However, at least one
14982 shell (the pre-3.0 @sc{uwin} Korn shell) gets confused about
14983 whether it is interactive, which means that (for example) a @env{PS1}
14984 with a side effect can unexpectedly modify @samp{$?}.  To work around
14985 this bug, M4sh scripts (including @file{configure} scripts) do something
14986 like this:
14988 @example
14989 (unset ENV) >/dev/null 2>&1 && unset ENV MAIL MAILPATH
14990 PS1='$ '
14991 PS2='> '
14992 PS4='+ '
14993 @end example
14995 @noindent
14996 (actually, there is some complication due to bugs in @command{unset};
14997 see @pxref{unset, , Limitations of Shell Builtins}).
14999 @item FPATH
15000 The Korn shell uses @env{FPATH} to find shell functions, so avoid
15001 @env{FPATH} in portable scripts.  @env{FPATH} is consulted after
15002 @env{PATH}, but you still need to be wary of tests that use @env{PATH}
15003 to find whether a command exists, since they might report the wrong
15004 result if @env{FPATH} is also set.
15006 @item IFS
15007 @evindex IFS
15008 Long ago, shell scripts inherited @env{IFS} from the environment,
15009 but this caused many problems so modern shells ignore any environment
15010 settings for @env{IFS}.
15012 Don't set the first character of @code{IFS} to backslash.  Indeed,
15013 Bourne shells use the first character (backslash) when joining the
15014 components in @samp{"$@@"} and some shells then reinterpret (!)@: the
15015 backslash escapes, so you can end up with backspace and other strange
15016 characters.
15018 The proper value for @code{IFS} (in regular code, not when performing
15019 splits) is @samp{@key{SPC}@key{TAB}@key{RET}}.  The first character is
15020 especially important, as it is used to join the arguments in @samp{$*};
15021 however, note that traditional shells, but also bash-2.04, fail to adhere
15022 to this and join with a space anyway.
15024 @item LANG
15025 @itemx LC_ALL
15026 @itemx LC_COLLATE
15027 @itemx LC_CTYPE
15028 @itemx LC_MESSAGES
15029 @itemx LC_MONETARY
15030 @itemx LC_NUMERIC
15031 @itemx LC_TIME
15032 @evindex LANG
15033 @evindex LC_ALL
15034 @evindex LC_COLLATE
15035 @evindex LC_CTYPE
15036 @evindex LC_MESSAGES
15037 @evindex LC_MONETARY
15038 @evindex LC_NUMERIC
15039 @evindex LC_TIME
15041 You should set all these variables to @samp{C} because so much
15042 configuration code assumes the C locale and Posix requires that locale
15043 environment variables be set to @samp{C} if the C locale is desired;
15044 @file{configure} scripts and M4sh do that for you.
15045 Export these variables after setting them.
15047 @c  However, some older, nonstandard
15048 @c  systems (notably @acronym{SCO}) break if locale environment variables
15049 @c  are set to @samp{C}, so when running on these systems
15050 @c  Autoconf-generated scripts unset the variables instead.
15052 @item LANGUAGE
15053 @evindex LANGUAGE
15055 @env{LANGUAGE} is not specified by Posix, but it is a @acronym{GNU}
15056 extension that overrides @env{LC_ALL} in some cases, so you (or M4sh)
15057 should set it too.
15059 @item LC_ADDRESS
15060 @itemx LC_IDENTIFICATION
15061 @itemx LC_MEASUREMENT
15062 @itemx LC_NAME
15063 @itemx LC_PAPER
15064 @itemx LC_TELEPHONE
15065 @evindex LC_ADDRESS
15066 @evindex LC_IDENTIFICATION
15067 @evindex LC_MEASUREMENT
15068 @evindex LC_NAME
15069 @evindex LC_PAPER
15070 @evindex LC_TELEPHONE
15072 These locale environment variables are @acronym{GNU} extensions.  They
15073 are treated like their Posix brethren (@env{LC_COLLATE},
15074 etc.)@: as described above.
15076 @item LINENO
15077 Most modern shells provide the current line number in @code{LINENO}.
15078 Its value is the line number of the beginning of the current command.
15079 M4sh, and hence Autoconf, attempts to execute @command{configure} with
15080 a shell that supports @code{LINENO}.  If no such shell is available, it
15081 attempts to implement @code{LINENO} with a Sed prepass that replaces each
15082 instance of the string @code{$LINENO} (not followed by an alphanumeric
15083 character) with the line's number.  In M4sh scripts you should execute
15084 @code{AS_LINENO_PREPARE} so that these workarounds are included in
15085 your script; configure scripts do this automatically in @code{AC_INIT}.
15087 You should not rely on @code{LINENO} within @command{eval} or shell
15088 functions, as the behavior differs in practice.  The presence of a
15089 quoted newline within simple commands can alter which line number is
15090 used as the starting point for @code{$LINENO} substitutions within that
15091 command.  Also, the possibility of the Sed prepass means that you should
15092 not rely on @code{$LINENO} when quoted, when in here-documents, or when
15093 line continuations are used.  Subshells should be OK, though.  In the
15094 following example, lines 1, 9, and 14 are portable, but the other
15095 instances of @code{$LINENO} do not have deterministic values:
15097 @example
15098 @group
15099 $ @kbd{cat lineno}
15100 echo 1. $LINENO
15101 echo "2. $LINENO
15102 3. $LINENO"
15103 cat <<EOF
15104 5. $LINENO
15105 6. $LINENO
15106 7. \$LINENO
15108 ( echo 9. $LINENO )
15109 eval 'echo 10. $LINENO'
15110 eval 'echo 11. $LINENO
15111 echo 12. $LINENO'
15112 echo 13. '$LINENO'
15113 echo 14. $LINENO '
15114 15.' $LINENO
15115 f () @{ echo $1 $LINENO;
15116 echo $1 $LINENO @}
15117 f 18.
15118 echo 19. \
15119 $LINENO
15120 @end group
15121 @group
15122 $ @kbd{bash-3.2 ./lineno}
15123 1. 1
15124 2. 3
15125 3. 3
15126 5. 4
15127 6. 4
15128 7. $LINENO
15129 9. 9
15130 10. 10
15131 11. 12
15132 12. 13
15133 13. $LINENO
15134 14. 14
15135 15. 14
15136 18. 16
15137 18. 17
15138 19. 19
15139 @end group
15140 @group
15141 $ @kbd{zsh-4.3.4 ./lineno}
15142 1. 1
15143 2. 2
15144 3. 2
15145 5. 4
15146 6. 4
15147 7. $LINENO
15148 9. 9
15149 10. 1
15150 11. 1
15151 12. 2
15152 13. $LINENO
15153 14. 14
15154 15. 14
15155 18. 0
15156 18. 1
15157 19. 19
15158 @end group
15159 @group
15160 $ @kbd{pdksh-5.2.14 ./lineno}
15161 1. 1
15162 2. 2
15163 3. 2
15164 5. 4
15165 6. 4
15166 7. $LINENO
15167 9. 9
15168 10. 0
15169 11. 0
15170 12. 0
15171 13. $LINENO
15172 14. 14
15173 15. 14
15174 18. 16
15175 18. 17
15176 19. 19
15177 @end group
15178 @group
15179 $ @kbd{sed '=' <lineno |}
15180 > @kbd{  sed '}
15181 > @kbd{    N}
15182 > @kbd{    s,$,-,}
15183 > @kbd{    t loop}
15184 > @kbd{    :loop}
15185 > @kbd{    s,^\([0-9]*\)\(.*\)[$]LINENO\([^a-zA-Z0-9_]\),\1\2\1\3,}
15186 > @kbd{    t loop}
15187 > @kbd{    s,-$,,}
15188 > @kbd{    s,^[0-9]*\n,,}
15189 > @kbd{  ' |}
15190 > @kbd{  sh}
15191 1. 1
15192 2. 2
15193 3. 3
15194 5. 5
15195 6. 6
15196 7. \7
15197 9. 9
15198 10. 10
15199 11. 11
15200 12. 12
15201 13. 13
15202 14. 14
15203 15. 15
15204 18. 16
15205 18. 17
15206 19. 20
15207 @end group
15208 @end example
15210 In particular, note that @file{config.status} (and any other subsidiary
15211 script created by @code{AS_INIT_GENERATED}) might report line numbers
15212 relative to the parent script as a result of the potential Sed pass.
15214 @item NULLCMD
15215 @evindex NULLCMD
15216 When executing the command @samp{>foo}, @command{zsh} executes
15217 @samp{$NULLCMD >foo} unless it is operating in Bourne shell
15218 compatibility mode and the @command{zsh} version is newer
15219 than 3.1.6-dev-18.  If you are using an older @command{zsh}
15220 and forget to set @env{NULLCMD},
15221 your script might be suspended waiting for data on its standard input.
15223 @item PATH_SEPARATOR
15224 @evindex PATH_SEPARATOR
15225 On @acronym{DJGPP} systems, the @env{PATH_SEPARATOR} environment
15226 variable can be set to either @samp{:} or @samp{;} to control the path
15227 separator Bash uses to set up certain environment variables (such as
15228 @env{PATH}).  You can set this variable to @samp{;} if you want
15229 @command{configure} to use @samp{;} as a separator; this might be useful
15230 if you plan to use non-Posix shells to execute files.  @xref{File System
15231 Conventions}, for more information about @code{PATH_SEPARATOR}.
15233 @item PWD
15234 @evindex PWD
15235 Posix 1003.1-2001 requires that @command{cd} and
15236 @command{pwd} must update the @env{PWD} environment variable to point
15237 to the logical name of the current directory, but traditional shells
15238 do not support this.  This can cause confusion if one shell instance
15239 maintains @env{PWD} but a subsidiary and different shell does not know
15240 about @env{PWD} and executes @command{cd}; in this case @env{PWD}
15241 points to the wrong directory.  Use @samp{`pwd`} rather than
15242 @samp{$PWD}.
15244 @item RANDOM
15245 Many shells provide @code{RANDOM}, a variable that returns a different
15246 integer each time it is used.  Most of the time, its value does not
15247 change when it is not used, but on @sc{irix} 6.5 the value changes all
15248 the time.  This can be observed by using @command{set}.  It is common
15249 practice to use @code{$RANDOM} as part of a file name, but code
15250 shouldn't rely on @code{$RANDOM} expanding to a nonempty string.
15252 @item status
15253 This variable is an alias to @samp{$?} for @code{zsh} (at least 3.1.6),
15254 hence read-only.  Do not use it.
15255 @end table
15257 @node Shell Functions
15258 @section Shell Functions
15259 @cindex Shell Functions
15261 Nowadays, it is difficult to find a shell that does not support
15262 shell functions at all.  However, some differences should be expected.
15264 Inside a shell function, you should not rely on the error status of a
15265 subshell if the last command of that subshell was @code{exit} or
15266 @code{trap}, as this triggers bugs in zsh 4.x; while Autoconf tries to
15267 find a shell that does not exhibit the bug, zsh might be the only shell
15268 present on the user's machine.
15270 Likewise, the state of @samp{$?} is not reliable when entering a shell
15271 function.  This has the effect that using a function as the first
15272 command in a @command{trap} handler can cause problems.
15274 @example
15275 $ @kbd{bash -c 'foo()@{ echo $?; @}; trap foo 0; (exit 2); exit 2'; echo $?}
15278 $ @kbd{ash -c 'foo()@{ echo $?; @}; trap foo 0; (exit 2); exit 2'; echo $?}
15281 @end example
15283 Not all shells treat shell functions as simple commands impacted by
15284 @samp{set -e}, for example with Solaris 10 @command{bin/sh}:
15286 @example
15287 $ @kbd{bash -c 'f()@{ return 1; @}; set -e; f; echo oops}
15288 $ @kbd{/bin/sh -c 'f()@{ return 1; @}; set -e; f; echo oops}
15289 oops
15290 @end example
15292 Shell variables and functions may share the same namespace, for example
15293 with Solaris 10 @command{/bin/sh}:
15295 @example
15296 $ @kbd{f () @{ :; @}; f=; f}
15297 f: not found
15298 @end example
15300 @noindent
15301 For this reason, Autoconf (actually M4sh, @pxref{Programming in M4sh})
15302 uses the prefix @samp{as_fn_} for its functions.
15304 Handling of positional parameters and shell options varies among shells.
15305 For example, Korn shells reset and restore trace output (@samp{set -x})
15306 and other options upon function entry and exit.  Inside a function,
15307 @acronym{IRIX} sh sets @samp{$0} to the function name.
15309 It is not portable to pass temporary environment variables to shell
15310 functions.  Solaris @command{/bin/sh} does not see the variable.
15311 Meanwhile, not all shells follow the Posix rule that the assignment must
15312 affect the current environment in the same manner as special built-ins.
15314 @example
15315 $ @kbd{/bin/sh -c 'func()@{ echo $a;@}; a=1 func; echo $a'}
15316 @result{}
15317 @result{}
15318 $ @kbd{ash -c 'func()@{ echo $a;@}; a=1 func; echo $a'}
15319 @result{}1
15320 @result{}
15321 $ @kbd{bash -c 'set -o posix; func()@{ echo $a;@}; a=1 func; echo $a'}
15322 @result{}1
15323 @result{}1
15324 @end example
15326 Some ancient Bourne shell variants with function support did not reset
15327 @samp{$@var{i}, @var{i} >= 0}, upon function exit, so effectively the
15328 arguments of the script were lost after the first function invocation.
15329 It is probably not worth worrying about these shells any more.
15331 With @acronym{AIX} sh, a @command{trap} on 0 installed in a shell function
15332 triggers at function exit rather than at script exit, see @xref{trap, ,
15333 Limitations of Shell Builtins}.
15335 @node Limitations of Builtins
15336 @section Limitations of Shell Builtins
15337 @cindex Shell builtins
15338 @cindex Limitations of shell builtins
15340 No, no, we are serious: some shells do have limitations!  :)
15342 You should always keep in mind that any builtin or command may support
15343 options, and therefore differ in behavior with arguments
15344 starting with a dash.  For instance, even the innocent @samp{echo "$word"}
15345 can give unexpected results when @code{word} starts with a dash.  It is
15346 often possible to avoid this problem using @samp{echo "x$word"}, taking
15347 the @samp{x} into account later in the pipe.  Many of these limitations
15348 can be worked around using M4sh (@pxref{Programming in M4sh}).
15350 @c This table includes things like `@command{test} (files)', so we can't
15351 @c use @table @command.
15352 @table @asis
15353 @item @command{.}
15354 @c --------------
15355 @prindex @command{.}
15356 Use @command{.} only with regular files (use @samp{test -f}).  Bash
15357 2.03, for instance, chokes on @samp{. /dev/null}.  Remember that
15358 @command{.} uses @env{PATH} if its argument contains no slashes.  Also,
15359 some shells, including bash 3.2, implicitly append the current directory
15360 to this @env{PATH} search, even though Posix forbids it.  So if you want
15361 to use @command{.} on a file @file{foo} in the current directory, you
15362 must use @samp{. ./foo}.
15364 @item @command{!}
15365 @c --------------
15366 @prindex @command{!}
15367 The Unix version 7 shell did not support
15368 negating the exit status of commands with @command{!}, and this feature
15369 is still absent from some shells (e.g., Solaris @command{/bin/sh}).
15370 Other shells, such as FreeBSD @command{/bin/sh} or @command{ash}, have
15371 bugs when using @command{!}:
15373 @example
15374 $ @kbd{sh -c '! : | :'; echo $?}
15376 $ @kbd{ash -c '! : | :'; echo $?}
15378 $ @kbd{sh -c '! @{ :; @}'; echo $?}
15380 $ @kbd{ash -c '! @{ :; @}'; echo $?}
15381 @{: not found
15382 Syntax error: "@}" unexpected
15384 @end example
15386 Shell code like this:
15388 @example
15389 if ! cmp file1 file2 >/dev/null 2>&1; then
15390   echo files differ or trouble
15392 @end example
15394 is therefore not portable in practice.  Typically it is easy to rewrite
15395 such code, e.g.:
15397 @example
15398 cmp file1 file2 >/dev/null 2>&1 ||
15399   echo files differ or trouble
15400 @end example
15402 More generally, one can always rewrite @samp{! @var{command}} as:
15404 @example
15405 if @var{command}; then (exit 1); else :; fi
15406 @end example
15409 @item @command{@{...@}}
15410 @c --------------------
15411 @prindex @command{@{...@}}
15412 Bash 3.2 (and earlier versions) sometimes does not properly set
15413 @samp{$?} when failing to write redirected output of a compound command.
15414 This problem is most commonly observed with @samp{@{@dots{}@}}; it does
15415 not occur with @samp{(@dots{})}.  For example:
15417 @example
15418 $ @kbd{bash -c '@{ echo foo; @} >/bad; echo $?'}
15419 bash: line 1: /bad: Permission denied
15421 $ @kbd{bash -c 'while :; do echo; done >/bad; echo $?'}
15422 bash: line 1: /bad: Permission denied
15424 @end example
15426 To work around the bug, prepend @samp{:;}:
15428 @example
15429 $ @kbd{bash -c ':;@{ echo foo; @} >/bad; echo $?'}
15430 bash: line 1: /bad: Permission denied
15432 @end example
15434 Posix requires a syntax error if a brace list has no contents.  However,
15435 not all shells obey this rule; and on shells where empty lists are
15436 permitted, the effect on @samp{$?} is inconsistent.  To avoid problems,
15437 ensure that a brace list is never empty.
15439 @example
15440 $ @kbd{bash -c 'false; @{ @}; echo $?' || echo $?}
15441 bash: line 1: syntax error near unexpected token `@}'
15442 bash: line 1: `false; @{ @}; echo $?'
15444 $ @kbd{zsh -c 'false; @{ @}; echo $?' || echo $?}
15446 $ @kbd{pdksh -c 'false; @{ @}; echo $?' || echo $?}
15448 @end example
15451 @item @command{break}
15452 @c ------------------
15453 @prindex @command{break}
15454 The use of @samp{break 2} etc.@: is safe.
15457 @anchor{case}
15458 @item @command{case}
15459 @c -----------------
15460 @prindex @command{case}
15461 You don't need to quote the argument; no splitting is performed.
15463 You don't need the final @samp{;;}, but you should use it.
15465 Posix requires support for @code{case} patterns with opening
15466 parentheses like this:
15468 @example
15469 case $file_name in
15470   (*.c) echo "C source code";;
15471 esac
15472 @end example
15474 @noindent
15475 but the @code{(} in this example is not portable to many Bourne
15476 shell implementations, which is a pity for those of us using tools that
15477 rely on balanced parentheses.  For instance, with Solaris
15478 @command{/bin/sh}:
15480 @example
15481 $ @kbd{case foo in (foo) echo foo;; esac}
15482 @error{}syntax error: `(' unexpected
15483 @end example
15485 @noindent
15486 The leading @samp{(} can be omitted safely.  Unfortunately, there are
15487 contexts where unbalanced parentheses cause other problems, such as when
15488 using a syntax-highlighting editor that searches for the balancing
15489 counterpart, or more importantly, when using a case statement as an
15490 underquoted argument to an Autoconf macro.  @xref{Balancing
15491 Parentheses}, for tradeoffs involved in various styles of dealing with
15492 unbalanced @samp{)}.
15494 Zsh handles pattern fragments derived from parameter expansions or
15495 command substitutions as though quoted:
15497 @example
15498 $ pat=\?; case aa in ?$pat) echo match;; esac
15499 $ pat=\?; case a? in ?$pat) echo match;; esac
15500 match
15501 @end example
15503 @noindent
15504 Because of a bug in its @code{fnmatch}, Bash fails to properly
15505 handle backslashes in character classes:
15507 @example
15508 bash-2.02$ @kbd{case /tmp in [/\\]*) echo OK;; esac}
15509 bash-2.02$
15510 @end example
15512 @noindent
15513 This is extremely unfortunate, since you are likely to use this code to
15514 handle Posix or @sc{ms-dos} absolute file names.  To work around this
15515 bug, always put the backslash first:
15517 @example
15518 bash-2.02$ @kbd{case '\TMP' in [\\/]*) echo OK;; esac}
15520 bash-2.02$ @kbd{case /tmp in [\\/]*) echo OK;; esac}
15522 @end example
15524 Many Bourne shells cannot handle closing brackets in character classes
15525 correctly.
15527 Some shells also have problems with backslash escaping in case you do not want
15528 to match the backslash: both a backslash and the escaped character match this
15529 pattern.  To work around this, specify the character class in a variable, so
15530 that quote removal does not apply afterwards, and the special characters don't
15531 have to be backslash-escaped:
15533 @example
15534 $ @kbd{case '\' in [\<]) echo OK;; esac}
15536 $ @kbd{scanset='[<]'; case '\' in $scanset) echo OK;; esac}
15538 @end example
15540 Even with this, Solaris @command{ksh} matches a backslash if the set
15541 contains any
15542 of the characters @samp{|}, @samp{&}, @samp{(}, or @samp{)}.
15544 Conversely, Tru64 @command{ksh} (circa 2003) erroneously always matches
15545 a closing parenthesis if not specified in a character class:
15547 @example
15548 $ @kbd{case foo in *\)*) echo fail ;; esac}
15549 fail
15550 $ @kbd{case foo in *')'*) echo fail ;; esac}
15551 fail
15552 @end example
15554 Some shells, such as Ash 0.3.8, are confused by an empty
15555 @code{case}/@code{esac}:
15557 @example
15558 ash-0.3.8 $ @kbd{case foo in esac;}
15559 @error{}Syntax error: ";" unexpected (expecting ")")
15560 @end example
15562 Posix requires @command{case} to give an exit status of 0 if no cases
15563 match.  However, @command{/bin/sh} in Solaris 10 does not obey this
15564 rule.  Meanwhile, it is unclear whether a case that matches, but
15565 contains no statements, must also change the exit status to 0.  The M4sh
15566 macro @code{AS_CASE} works around these inconsistencies.
15568 @example
15569 $ @kbd{bash -c 'case `false` in ?) ;; esac; echo $?'}
15571 $ @kbd{/bin/sh -c 'case `false` in ?) ;; esac; echo $?'}
15573 @end example
15576 @item @command{cd}
15577 @c ---------------
15578 @prindex @command{cd}
15579 Posix 1003.1-2001 requires that @command{cd} must support
15580 the @option{-L} (``logical'') and @option{-P} (``physical'') options,
15581 with @option{-L} being the default.  However, traditional shells do
15582 not support these options, and their @command{cd} command has the
15583 @option{-P} behavior.
15585 Portable scripts should assume neither option is supported, and should
15586 assume neither behavior is the default.  This can be a bit tricky,
15587 since the Posix default behavior means that, for example,
15588 @samp{ls ..} and @samp{cd ..} may refer to different directories if
15589 the current logical directory is a symbolic link.  It is safe to use
15590 @code{cd @var{dir}} if @var{dir} contains no @file{..} components.
15591 Also, Autoconf-generated scripts check for this problem when computing
15592 variables like @code{ac_top_srcdir} (@pxref{Configuration Actions}),
15593 so it is safe to @command{cd} to these variables.
15595 See @xref{Special Shell Variables}, for portability problems involving
15596 @command{cd} and the @env{CDPATH} environment variable.
15597 Also please see the discussion of the @command{pwd} command.
15600 @anchor{echo}
15601 @item @command{echo}
15602 @c -----------------
15603 @prindex @command{echo}
15604 The simple @command{echo} is probably the most surprising source of
15605 portability troubles.  It is not possible to use @samp{echo} portably
15606 unless both options and escape sequences are omitted.  Don't expect any
15607 option.
15609 Do not use backslashes in the arguments, as there is no consensus on
15610 their handling.  For @samp{echo '\n' | wc -l}, the @command{sh} of
15611 Solaris outputs 2, but Bash and Zsh (in @command{sh} emulation mode) output 1.
15612 The problem is truly @command{echo}: all the shells
15613 understand @samp{'\n'} as the string composed of a backslash and an
15614 @samp{n}.
15616 Because of these problems, do not pass a string containing arbitrary
15617 characters to @command{echo}.  For example, @samp{echo "$foo"} is safe
15618 if you know that @var{foo}'s value cannot contain backslashes and cannot
15619 start with @samp{-}, but otherwise you should use a here-document like
15620 this:
15622 @example
15623 cat <<EOF
15624 $foo
15626 @end example
15628 New applications which are not aiming at portability should use
15629 @command{printf} instead of @command{echo}.  M4sh provides the
15630 @code{AS_ECHO} and @code{AS_ECHO_N} macros, which choose between
15631 @samp{echo -n} on implementations where that works, @command{printf} if
15632 it is available, or other creative tricks in order to work around the
15633 above problems.
15636 @item @command{eval}
15637 @c -----------------
15638 @prindex @command{eval}
15639 The @command{eval} command is useful in limited circumstances, e.g.,
15640 using commands like @samp{eval table_$key=\$value} and @samp{eval
15641 value=table_$key} to simulate a hash table when the key is known to be
15642 alphanumeric.
15644 You should also be wary of common bugs in @command{eval} implementations.
15645 In some shell implementations (e.g., older @command{ash}, Open@acronym{BSD} 3.8
15646 @command{sh}, @command{pdksh} v5.2.14 99/07/13.2, and @command{zsh}
15647 4.2.5), the arguments of @samp{eval} are evaluated in a context where
15648 @samp{$?} is 0, so they exhibit behavior like this:
15650 @example
15651 $ @kbd{false; eval 'echo $?'}
15653 @end example
15655 The correct behavior here is to output a nonzero value,
15656 but portable scripts should not rely on this.
15658 You should not rely on @code{LINENO} within @command{eval}.
15659 @xref{Special Shell Variables}.
15661 Note that, even though these bugs are easily avoided,
15662 @command{eval} is tricky to use on arbitrary arguments.
15663 It is obviously unwise to use @samp{eval $cmd} if the string value of
15664 @samp{cmd} was derived from an untrustworthy source.  But even if the
15665 string value is valid, @samp{eval $cmd} might not work as intended,
15666 since it causes field splitting and file name expansion to occur twice,
15667 once for the @command{eval} and once for the command itself.  It is
15668 therefore safer to use @samp{eval "$cmd"}.  For example, if @var{cmd}
15669 has the value @samp{cat test?.c}, @samp{eval $cmd} might expand to the
15670 equivalent of @samp{cat test;.c} if there happens to be a file named
15671 @file{test;.c} in the current directory; and this in turn
15672 mistakenly attempts to invoke @command{cat} on the file @file{test} and
15673 then execute the command @command{.c}.  To avoid this problem, use
15674 @samp{eval "$cmd"} rather than @samp{eval $cmd}.
15676 However, suppose that you want to output the text of the evaluated
15677 command just before executing it.  Assuming the previous example,
15678 @samp{echo "Executing: $cmd"} outputs @samp{Executing: cat test?.c}, but
15679 this output doesn't show the user that @samp{test;.c} is the actual name
15680 of the copied file.  Conversely, @samp{eval "echo Executing: $cmd"}
15681 works on this example, but it fails with @samp{cmd='cat foo >bar'},
15682 since it mistakenly replaces the contents of @file{bar} by the
15683 string @samp{cat foo}.  No simple, general, and portable solution to
15684 this problem is known.
15686 @item @command{exec}
15687 @c -----------------
15688 @prindex @command{exec}
15689 Posix describes several categories of shell built-ins.  Special
15690 built-ins (such as @command{exit}) must impact the environment of the
15691 current shell, and need not be available through @command{exec}.  All
15692 other built-ins are regular, and must not propagate variable assignments
15693 to the environment of the current shell.  However, the group of regular
15694 built-ins is further distinguished by commands that do not require a
15695 @env{PATH} search (such as @command{cd}), in contrast to built-ins that
15696 are offered as a more efficient version of something that must still be
15697 found in a @env{PATH} search (such as @command{echo}).  Posix is not
15698 clear on whether @command{exec} must work with the list of 17 utilities
15699 that are invoked without a @env{PATH} search, and many platforms lack an
15700 executable for some of those built-ins:
15702 @example
15703 $ @kbd{sh -c 'exec cd /tmp'}
15704 sh: line 0: exec: cd: not found
15705 @end example
15707 All other built-ins that provide utilities specified by Posix must have
15708 a counterpart executable that exists on @env{PATH}, although Posix
15709 allows @command{exec} to use the built-in instead of the executable.
15710 For example, contrast @command{bash} 3.2 and @command{pdksh} 5.2.14:
15712 @example
15713 $ @kbd{bash -c 'pwd --version' | head -n1}
15714 bash: line 0: pwd: --: invalid option
15715 pwd: usage: pwd [-LP]
15716 $ @kbd{bash -c 'exec pwd --version' | head -n1}
15717 pwd (GNU coreutils) 6.10
15718 $ @kbd{pdksh -c 'exec pwd --version' | head -n1}
15719 pdksh: pwd: --: unknown option
15720 @end example
15722 When it is desired to avoid a regular shell built-in, the workaround is
15723 to use some other forwarding command, such as @command{env} or
15724 @command{nice}, that will ensure a path search:
15726 @example
15727 $ @kbd{pdksh -c 'exec true --version' | head -n1}
15728 $ @kbd{pdksh -c 'nice true --version' | head -n1}
15729 true (GNU coreutils) 6.10
15730 $ @kbd{pdksh -c 'env true --version' | head -n1}
15731 true (GNU coreutils) 6.10
15732 @end example
15734 @item @command{exit}
15735 @c -----------------
15736 @prindex @command{exit}
15737 The default value of @command{exit} is supposed to be @code{$?};
15738 unfortunately, some shells, such as the @acronym{DJGPP} port of Bash 2.04, just
15739 perform @samp{exit 0}.
15741 @example
15742 bash-2.04$ @kbd{foo=`exit 1` || echo fail}
15743 fail
15744 bash-2.04$ @kbd{foo=`(exit 1)` || echo fail}
15745 fail
15746 bash-2.04$ @kbd{foo=`(exit 1); exit` || echo fail}
15747 bash-2.04$
15748 @end example
15750 Using @samp{exit $?} restores the expected behavior.
15752 Some shell scripts, such as those generated by @command{autoconf}, use a
15753 trap to clean up before exiting.  If the last shell command exited with
15754 nonzero status, the trap also exits with nonzero status so that the
15755 invoker can tell that an error occurred.
15757 Unfortunately, in some shells, such as Solaris @command{/bin/sh}, an exit
15758 trap ignores the @code{exit} command's argument.  In these shells, a trap
15759 cannot determine whether it was invoked by plain @code{exit} or by
15760 @code{exit 1}.  Instead of calling @code{exit} directly, use the
15761 @code{AC_MSG_ERROR} macro that has a workaround for this problem.
15764 @anchor{export}
15765 @item @command{export}
15766 @c -------------------
15767 @prindex @command{export}
15768 The builtin @command{export} dubs a shell variable @dfn{environment
15769 variable}.  Each update of exported variables corresponds to an update
15770 of the environment variables.  Conversely, each environment variable
15771 received by the shell when it is launched should be imported as a shell
15772 variable marked as exported.
15774 Alas, many shells, such as Solaris @command{/bin/sh},
15775 @sc{irix} 6.3, @sc{irix} 5.2,
15776 @acronym{AIX} 4.1.5, and Digital Unix 4.0, forget to
15777 @command{export} the environment variables they receive.  As a result,
15778 two variables coexist: the environment variable and the shell
15779 variable.  The following code demonstrates this failure:
15781 @example
15782 #!/bin/sh
15783 echo $FOO
15784 FOO=bar
15785 echo $FOO
15786 exec /bin/sh $0
15787 @end example
15789 @noindent
15790 when run with @samp{FOO=foo} in the environment, these shells print
15791 alternately @samp{foo} and @samp{bar}, although they should print only
15792 @samp{foo} and then a sequence of @samp{bar}s.
15794 Therefore you should @command{export} again each environment variable
15795 that you update; the export can occur before or after the assignment.
15797 Posix is not clear on whether the @command{export} of an undefined
15798 variable causes the variable to be defined with the value of an empty
15799 string, or merely marks any future definition of a variable by that name
15800 for export.  Various shells behave differently in this regard:
15802 @example
15803 $ @kbd{sh -c 'export foo; env | grep foo'}
15804 $ @kbd{ash -c 'export foo; env | grep foo'}
15805 foo=
15806 @end example
15808 @item @command{false}
15809 @c ------------------
15810 @prindex @command{false}
15811 Don't expect @command{false} to exit with status 1: in native
15812 Solaris @file{/bin/false} exits with status 255.
15815 @item @command{for}
15816 @c ----------------
15817 @prindex @command{for}
15818 To loop over positional arguments, use:
15820 @example
15821 for arg
15823   echo "$arg"
15824 done
15825 @end example
15827 @noindent
15828 You may @emph{not} leave the @code{do} on the same line as @code{for},
15829 since some shells improperly grok:
15831 @example
15832 for arg; do
15833   echo "$arg"
15834 done
15835 @end example
15837 If you want to explicitly refer to the positional arguments, given the
15838 @samp{$@@} bug (@pxref{Shell Substitutions}), use:
15840 @example
15841 for arg in $@{1+"$@@"@}; do
15842   echo "$arg"
15843 done
15844 @end example
15846 @noindent
15847 But keep in mind that Zsh, even in Bourne shell emulation mode, performs
15848 word splitting on @samp{$@{1+"$@@"@}}; see @ref{Shell Substitutions},
15849 item @samp{$@@}, for more.
15852 @item @command{if}
15853 @c ---------------
15854 @prindex @command{if}
15855 Using @samp{!} is not portable.  Instead of:
15857 @example
15858 if ! cmp -s file file.new; then
15859   mv file.new file
15861 @end example
15863 @noindent
15864 use:
15866 @example
15867 if cmp -s file file.new; then :; else
15868   mv file.new file
15870 @end example
15872 @noindent
15873 Or, especially if the @dfn{else} branch is short, you can use @code{||}.
15874 In M4sh, the @code{AS_IF} macro provides an easy way to write these kinds
15875 of conditionals:
15877 @example
15878 AS_IF([cmp -s file file.new], [], [mv file.new file])
15879 @end example
15881 This is especially useful in other M4 macros, where the @dfn{then} and
15882 @dfn{else} branches might be macro arguments.
15884 Some very old shells did not reset the exit status from an @command{if}
15885 with no @command{else}:
15887 @example
15888 $ @kbd{if (exit 42); then true; fi; echo $?}
15890 @end example
15892 @noindent
15893 whereas a proper shell should have printed @samp{0}.  But this is no
15894 longer a portability problem; any shell that supports functions gets it
15895 correct.  However, it explains why some makefiles have lengthy
15896 constructs:
15898 @example
15899 if test -f "$file"; then
15900   install "$file" "$dest"
15901 else
15902   :
15904 @end example
15907 @item @command{printf}
15908 @c ------------------
15909 @prindex @command{printf}
15910 A format string starting with a @samp{-} can cause problems.
15911 Bash interprets it as an option and
15912 gives an error.  And @samp{--} to mark the end of options is not good
15913 in the Net@acronym{BSD} Almquist shell (e.g., 0.4.6) which takes that
15914 literally as the format string.  Putting the @samp{-} in a @samp{%c}
15915 or @samp{%s} is probably easiest:
15917 @example
15918 printf %s -foo
15919 @end example
15921 Bash 2.03 mishandles an escape sequence that happens to evaluate to @samp{%}:
15923 @example
15924 $ @kbd{printf '\045'}
15925 bash: printf: `%': missing format character
15926 @end example
15928 Large outputs may cause trouble.  On Solaris 2.5.1 through 10, for
15929 example, @file{/usr/bin/printf} is buggy, so when using
15930 @command{/bin/sh} the command @samp{printf %010000x 123} normally dumps
15931 core.
15933 Since @command{printf} is not always a shell builtin, there is a
15934 potential speed penalty for using @code{printf %s\\n} as a replacement
15935 for an @command{echo} that does not interpret @samp{\} or leading
15936 @samp{-}. With Solaris @command{ksh}, it is possible to use @code{print
15937 -r --} for this role instead.
15940 @item @command{pwd}
15941 @c ----------------
15942 @prindex @command{pwd}
15943 With modern shells, plain @command{pwd} outputs a ``logical''
15944 directory name, some of whose components may be symbolic links.  These
15945 directory names are in contrast to ``physical'' directory names, whose
15946 components are all directories.
15948 Posix 1003.1-2001 requires that @command{pwd} must support
15949 the @option{-L} (``logical'') and @option{-P} (``physical'') options,
15950 with @option{-L} being the default.  However, traditional shells do
15951 not support these options, and their @command{pwd} command has the
15952 @option{-P} behavior.
15954 Portable scripts should assume neither option is supported, and should
15955 assume neither behavior is the default.  Also, on many hosts
15956 @samp{/bin/pwd} is equivalent to @samp{pwd -P}, but Posix
15957 does not require this behavior and portable scripts should not rely on
15960 Typically it's best to use plain @command{pwd}.  On modern hosts this
15961 outputs logical directory names, which have the following advantages:
15963 @itemize @bullet
15964 @item
15965 Logical names are what the user specified.
15966 @item
15967 Physical names may not be portable from one installation
15968 host to another due to network file system gymnastics.
15969 @item
15970 On modern hosts @samp{pwd -P} may fail due to lack of permissions to
15971 some parent directory, but plain @command{pwd} cannot fail for this
15972 reason.
15973 @end itemize
15975 Also please see the discussion of the @command{cd} command.
15978 @item @command{read}
15979 @c -----------------
15980 @prindex @command{read}
15981 No options are portable, not even support @option{-r} (Solaris
15982 @command{/bin/sh} for example).
15985 @anchor{set}
15986 @item @command{set}
15987 @c ----------------
15988 @prindex @command{set}
15989 With the Free@acronym{BSD} 6.0 shell, the @command{set} command (without
15990 any options) does not sort its output.
15992 The @command{set} builtin faces the usual problem with arguments
15993 starting with a
15994 dash.  Modern shells such as Bash or Zsh understand @option{--} to specify
15995 the end of the options (any argument after @option{--} is a parameter,
15996 even @samp{-x} for instance), but many traditional shells (e.g., Solaris
15997 10 @command{/bin/sh}) simply stop option
15998 processing as soon as a non-option argument is found.  Therefore, use
15999 @samp{dummy} or simply @samp{x} to end the option processing, and use
16000 @command{shift} to pop it out:
16002 @example
16003 set x $my_list; shift
16004 @end example
16006 Avoid @samp{set -}, e.g., @samp{set - $my_list}.  Posix no
16007 longer requires support for this command, and in traditional shells
16008 @samp{set - $my_list} resets the @option{-v} and @option{-x} options, which
16009 makes scripts harder to debug.
16011 Some nonstandard shells do not recognize more than one option
16012 (e.g., @samp{set -e -x} assigns @samp{-x} to the command line).  It is
16013 better to combine them:
16015 @example
16016 set -ex
16017 @end example
16019 @cindex @command{set -e}
16020 The option @option{-e} has historically been underspecified, with enough
16021 ambiguities to cause numerous differences across various shell
16022 implementations.  Perhaps the best reference is
16023 @uref{http://www.opengroup.org/@/austin/@/mailarchives/@/ag-review/@/msg03507.html,
16024 this link}, recommending a change to Posix 2008 to match @command{ksh88}
16025 behavior.  Note that mixing @code{set -e} and shell functions is asking
16026 for surprises:
16028 @example
16029 set -e
16030 doit()
16032   rm file
16033   echo one
16035 doit || echo two
16036 @end example
16038 @noindent
16039 According to the recommendation, @samp{one} should always be output
16040 regardless of whether the @command{rm} failed, because it occurs within
16041 the body of the shell function @samp{doit} invoked on the left side of
16042 @samp{||}, where the effects of @samp{set -e} are not enforced.
16043 Likewise, @samp{two} should never be printed, since the failure of
16044 @command{rm} does not abort the function, such that the status of
16045 @samp{doit} is 0.
16047 The @acronym{BSD} shell has had several problems with the @option{-e}
16048 option.  Older versions of the @acronym{BSD}
16049 shell (circa 1990) mishandled @samp{&&}, @samp{||}, @samp{if}, and
16050 @samp{case} when @option{-e} was in effect, causing the shell to exit
16051 unexpectedly in some cases.  This was particularly a problem with
16052 makefiles, and led to circumlocutions like @samp{sh -c 'test -f file ||
16053 touch file'}, where the seemingly-unnecessary @samp{sh -c '@dots{}'}
16054 wrapper works around the bug (@pxref{Failure in Make Rules}).
16056 Even relatively-recent versions of the @acronym{BSD} shell (e.g.,
16057 Open@acronym{BSD} 3.4) wrongly exit with @option{-e} if a command within
16058 @samp{&&} fails inside a compound statement.  For example:
16060 @example
16061 #! /bin/sh
16062 set -e
16063 foo=''
16064 test -n "$foo" && exit 1
16065 echo one
16066 if :; then
16067   test -n "$foo" && exit 1
16069 echo two
16070 @end example
16072 @noindent
16073 does not print @samp{two}.  One workaround is to use @samp{if test -n
16074 "$foo"; then exit 1; fi} rather than @samp{test -n "$foo" && exit 1}.
16075 Another possibility is to warn @acronym{BSD} users not to use @samp{sh -e}.
16077 Portable scripts should not use @samp{set -e} if @command{trap} is used
16078 to install an exit handler.  This is because Tru64/OSF 5.1 @command{sh}
16079 sometimes enters the trap handler with the exit status of the command
16080 prior to the one that triggered the errexit handler:
16082 @example
16083 $ @kbd{sh -ec 'trap '\''echo $?'\'' 0; false'}
16085 $ @kbd{sh -c 'set -e; trap '\''echo $?'\'' 0; false'}
16087 @end example
16089 @noindent
16090 Thus, when writing a script in M4sh, rather than trying to rely on
16091 @samp{set -e}, it is better to append @samp{|| AS_EXIT} to any
16092 statement where it is desirable to abort on failure.
16094 @item @command{shift}
16095 @c ------------------
16096 @prindex @command{shift}
16097 Not only is @command{shift}ing a bad idea when there is nothing left to
16098 shift, but in addition it is not portable: the shell of @acronym{MIPS
16099 RISC/OS} 4.52 refuses to do it.
16101 Don't use @samp{shift 2} etc.; while it in the SVR1 shell (1983),
16102 it is also absent in many pre-Posix shells.
16105 @item @command{source}
16106 @c -------------------
16107 @prindex @command{source}
16108 This command is not portable, as Posix does not require it; use
16109 @command{.} instead.
16112 @item @command{test}
16113 @c -----------------
16114 @prindex @command{test}
16115 The @code{test} program is the way to perform many file and string
16116 tests.  It is often invoked by the alternate name @samp{[}, but using
16117 that name in Autoconf code is asking for trouble since it is an M4 quote
16118 character.
16120 The @option{-a}, @option{-o}, @samp{(}, and @samp{)} operands are not
16121 portable and should be avoided.  Thus, portable uses of @command{test}
16122 should never have more than four arguments, and scripts should use shell
16123 constructs like @samp{&&} and @samp{||} instead.  If you combine
16124 @samp{&&} and @samp{||} in the same statement, keep in mind that they
16125 have equal precedence, so it is often better to parenthesize even when
16126 this is redundant.  For example:
16128 @smallexample
16129 # Not portable:
16130 test "X$a" = "X$b" -a \
16131   '(' "X$c" != "X$d" -o "X$e" = "X$f" ')'
16133 # Portable:
16134 test "X$a" = "X$b" &&
16135   @{ test "X$c" != "X$d" || test "X$e" = "X$f"; @}
16136 @end smallexample
16138 @command{test} does not process options like most other commands do; for
16139 example, it does not recognize the @option{--} argument as marking the
16140 end of options.
16142 It is safe to use @samp{!} as a @command{test} operator.  For example,
16143 @samp{if test ! -d foo; @dots{}} is portable even though @samp{if ! test
16144 -d foo; @dots{}} is not.
16147 @item @command{test} (files)
16148 @c -------------------------
16149 To enable @command{configure} scripts to support cross-compilation, they
16150 shouldn't do anything that tests features of the build system instead of
16151 the host system.  But occasionally you may find it necessary to check
16152 whether some arbitrary file exists.  To do so, use @samp{test -f} or
16153 @samp{test -r}.  Do not use @samp{test -x}, because 4.3@acronym{BSD} does not
16154 have it.  Do not use @samp{test -e} either, because Solaris @command{/bin/sh}
16155 lacks it.  To test for symbolic links on systems that have them, use
16156 @samp{test -h} rather than @samp{test -L}; either form conforms to
16157 Posix 1003.1-2001, but older shells like Solaris 8
16158 @code{/bin/sh} support only @option{-h}.
16160 @item @command{test} (strings)
16161 @c ---------------------------
16162 Posix says that @samp{test "@var{string}"} succeeds if @var{string} is
16163 not null, but this usage is not portable to traditional platforms like
16164 Solaris 10 @command{/bin/sh}, which mishandle strings like @samp{!} and
16165 @samp{-n}.
16167 Posix also says that @samp{test ! "@var{string}"},
16168 @samp{test -n "@var{string}"} and
16169 @samp{test -z "@var{string}"} work with any string, but many
16170 shells (such as Solaris, @acronym{AIX} 3.2, @sc{unicos} 10.0.0.6,
16171 Digital Unix 4, etc.)@: get confused if
16172 @var{string} looks like an operator:
16174 @example
16175 $ @kbd{test -n =}
16176 test: argument expected
16177 $ @kbd{test ! -n}
16178 test: argument expected
16179 @end example
16181 Similarly, Posix says that both @samp{test "@var{string1}" = "@var{string2"}}
16182 and @samp{test "@var{string1}" != "@var{string2"}} work for any pairs of
16183 strings, but in practice this is not true for troublesome strings that
16184 look like operators or parentheses, or that begin with @samp{-}.
16186 It is best to protect such strings with a leading @samp{X}, e.g.,
16187 @samp{test "X@var{string}" != X} rather than @samp{test -n
16188 "@var{string}"} or @samp{test ! "@var{string}"}.
16190 It is common to find variations of the following idiom:
16192 @example
16193 test -n "`echo $ac_feature | sed 's/[-a-zA-Z0-9_]//g'`" &&
16194   @var{action}
16195 @end example
16197 @noindent
16198 to take an action when a token matches a given pattern.  Such constructs
16199 should be avoided by using:
16201 @example
16202 case $ac_feature in
16203   *[!-a-zA-Z0-9_]*) @var{action};;
16204 esac
16205 @end example
16207 If the pattern is a complicated regular expression that cannot be
16208 expressed as a shell pattern, use something like this instead:
16210 @example
16211 expr "X$ac_feature" : 'X.*[^-a-zA-Z0-9_]' >/dev/null &&
16212   @var{action}
16213 @end example
16215 @samp{expr "X@var{foo}" : "X@var{bar}"} is more robust than @samp{echo
16216 "X@var{foo}" | grep "^X@var{bar}"}, because it avoids problems when
16217 @samp{@var{foo}} contains backslashes.
16220 @anchor{trap}
16221 @item @command{trap}
16222 @c -----------------
16223 @prindex @command{trap}
16224 It is safe to trap at least the signals 1, 2, 13, and 15.  You can also
16225 trap 0, i.e., have the @command{trap} run when the script ends (either via an
16226 explicit @command{exit}, or the end of the script).  The trap for 0 should be
16227 installed outside of a shell function, or @acronym{AIX} 5.3 @command{/bin/sh}
16228 will invoke the trap at the end of this function.
16230 Posix says that @samp{trap - 1 2 13 15} resets the traps for the
16231 specified signals to their default values, but many common shells (e.g.,
16232 Solaris @command{/bin/sh}) misinterpret this and attempt to execute a
16233 ``command'' named @command{-} when the specified conditions arise.
16234 There is no portable workaround, except for @samp{trap - 0}, for which
16235 @samp{trap '' 0} is a portable substitute.
16237 Although Posix is not absolutely clear on this point, it is widely
16238 admitted that when entering the trap @samp{$?} should be set to the exit
16239 status of the last command run before the trap.  The ambiguity can be
16240 summarized as: ``when the trap is launched by an @command{exit}, what is
16241 the @emph{last} command run: that before @command{exit}, or
16242 @command{exit} itself?''
16244 Bash considers @command{exit} to be the last command, while Zsh and
16245 Solaris @command{/bin/sh} consider that when the trap is run it is
16246 @emph{still} in the @command{exit}, hence it is the previous exit status
16247 that the trap receives:
16249 @example
16250 $ @kbd{cat trap.sh}
16251 trap 'echo $?' 0
16252 (exit 42); exit 0
16253 $ @kbd{zsh trap.sh}
16255 $ @kbd{bash trap.sh}
16257 @end example
16259 The portable solution is then simple: when you want to @samp{exit 42},
16260 run @samp{(exit 42); exit 42}, the first @command{exit} being used to
16261 set the exit status to 42 for Zsh, and the second to trigger the trap
16262 and pass 42 as exit status for Bash.  In M4sh, this is covered by using
16263 @code{AS_EXIT}.
16265 The shell in Free@acronym{BSD} 4.0 has the following bug: @samp{$?} is
16266 reset to 0 by empty lines if the code is inside @command{trap}.
16268 @example
16269 $ @kbd{trap 'false}
16271 echo $?' 0
16272 $ @kbd{exit}
16274 @end example
16276 @noindent
16277 Fortunately, this bug only affects @command{trap}.
16279 @item @command{true}
16280 @c -----------------
16281 @prindex @command{true}
16282 @c Info cannot handle `:' in index entries.
16283 @c @prindex @command{:}
16284 Don't worry: as far as we know @command{true} is portable.
16285 Nevertheless, it's not always a builtin (e.g., Bash 1.x), and the
16286 portable shell community tends to prefer using @command{:}.  This has a
16287 funny side effect: when asked whether @command{false} is more portable
16288 than @command{true} Alexandre Oliva answered:
16290 @quotation
16291 In a sense, yes, because if it doesn't exist, the shell will produce an
16292 exit status of failure, which is correct for @command{false}, but not
16293 for @command{true}.
16294 @end quotation
16297 @anchor{unset}
16298 @item @command{unset}
16299 @c ------------------
16300 @prindex @command{unset}
16301 In some nonconforming shells (e.g., Bash 2.05a), @code{unset FOO} fails
16302 when @code{FOO} is not set.  You can use
16304 @smallexample
16305 FOO=; unset FOO
16306 @end smallexample
16308 if you are not sure that @code{FOO} is set.
16310 A few ancient shells lack @command{unset} entirely.  For some variables
16311 such as @code{PS1}, you can use a neutralizing value instead:
16313 @smallexample
16314 PS1='$ '
16315 @end smallexample
16317 Usually, shells that do not support @command{unset} need less effort to
16318 make the environment sane, so for example is not a problem if you cannot
16319 unset @command{CDPATH} on those shells.  However, Bash 2.01 mishandles
16320 @code{unset MAIL} in some cases and dumps core.  So, you should do
16321 something like
16323 @smallexample
16324 ( (unset MAIL) || exit 1) >/dev/null 2>&1 && unset MAIL || :
16325 @end smallexample
16327 @noindent
16328 @xref{Special Shell Variables}, for some neutralizing values.  Also, see
16329 @ref{export, , Limitations of Builtins}, for
16330 the case of environment variables.
16332 @item @command{wait}
16333 @c -----------------
16334 @prindex @command{wait}
16335 The exit status of @command{wait} is not always reliable.
16336 @end table
16338 @node Limitations of Usual Tools
16339 @section Limitations of Usual Tools
16340 @cindex Limitations of usual tools
16342 The small set of tools you can expect to find on any machine can still
16343 include some limitations you should be aware of.
16345 @comment Between this list and the list of builtins above, we should
16346 @comment mention all the tools in GNU Coding Standards ``Utilities in
16347 @comment Makefiles''.
16349 @c This table includes things like `@command{expr} (|)', so we can't
16350 @c use @table @command.
16351 @table @asis
16352 @item @command{awk}
16353 @c ----------------
16354 @prindex @command{awk}
16355 Don't leave white space before the opening parenthesis in a user function call.
16356 Posix does not allow this and @acronym{GNU} Awk rejects it:
16358 @example
16359 $ @kbd{gawk 'function die () @{ print "Aaaaarg!"  @}
16360         BEGIN @{ die () @}'}
16361 gawk: cmd. line:2:         BEGIN @{ die () @}
16362 gawk: cmd. line:2:                      ^ parse error
16363 $ @kbd{gawk 'function die () @{ print "Aaaaarg!"  @}
16364         BEGIN @{ die() @}'}
16365 Aaaaarg!
16366 @end example
16368 Posix says that if a program contains only @samp{BEGIN} actions, and
16369 contains no instances of @code{getline}, then the program merely
16370 executes the actions without reading input.  However, traditional Awk
16371 implementations (such as Solaris 10 @command{awk}) read and discard
16372 input in this case.  Portable scripts can redirect input from
16373 @file{/dev/null} to work around the problem.  For example:
16375 @example
16376 awk 'BEGIN @{print "hello world"@}' </dev/null
16377 @end example
16379 Posix says that in an @samp{END} action, @samp{$NF} (and presumably,
16380 @samp{$1}) retain their value from the last record read, if no
16381 intervening @samp{getline} occurred.  However, some implementations
16382 (such as Solaris 10 @samp{/usr/bin/awk}, @samp{nawk}, or Darwin
16383 @samp{awk}) reset these variables.  A workaround is to use an
16384 intermediate variable prior to the @samp{END} block.  For example:
16386 @example
16387 $ @kbd{cat end.awk}
16388 @{ tmp = $1 @}
16389 END @{ print "a", $1, $NF, "b", tmp @}
16390 $ @kbd{echo 1 | awk -f end.awk}
16391 a   b 1
16392 $ @kbd{echo 1 | gawk -f end.awk}
16393 a 1 1 b 1
16394 @end example
16396 If you want your program to be deterministic, don't depend on @code{for}
16397 on arrays:
16399 @example
16400 $ @kbd{cat for.awk}
16401 END @{
16402   arr["foo"] = 1
16403   arr["bar"] = 1
16404   for (i in arr)
16405     print i
16407 $ @kbd{gawk -f for.awk </dev/null}
16410 $ @kbd{nawk -f for.awk </dev/null}
16413 @end example
16415 Some Awk implementations, such as @acronym{HP-UX} 11.0's native one,
16416 mishandle anchors:
16418 @example
16419 $ @kbd{echo xfoo | $AWK '/foo|^bar/ @{ print @}'}
16420 $ @kbd{echo bar | $AWK '/foo|^bar/ @{ print @}'}
16422 $ @kbd{echo xfoo | $AWK '/^bar|foo/ @{ print @}'}
16423 xfoo
16424 $ @kbd{echo bar | $AWK '/^bar|foo/ @{ print @}'}
16426 @end example
16428 @noindent
16429 Either do not depend on such patterns (i.e., use @samp{/^(.*foo|bar)/},
16430 or use a simple test to reject such implementations.
16432 On @samp{ia64-hp-hpux11.23}, Awk mishandles @code{printf} conversions
16433 after @code{%u}:
16435 @example
16436 $ @kbd{awk 'BEGIN @{ printf "%u %d\n", 0, -1 @}'}
16437 0 0
16438 @end example
16440 @acronym{AIX} version 5.2 has an arbitrary limit of 399 on the
16441 length of regular expressions and literal strings in an Awk program.
16443 Traditional Awk implementations derived from Unix version 7, such as
16444 Solaris @command{/bin/awk}, have many limitations and do not
16445 conform to Posix.  Nowadays @code{AC_PROG_AWK} (@pxref{Particular
16446 Programs}) finds you an Awk that doesn't have these problems, but if
16447 for some reason you prefer not to use @code{AC_PROG_AWK} you may need to
16448 address them.
16450 Traditional Awk does not support multidimensional arrays or user-defined
16451 functions.
16453 Traditional Awk does not support the @option{-v} option.  You can use
16454 assignments after the program instead, e.g., @code{$AWK '@{print v
16455 $1@}' v=x}; however, don't forget that such assignments are not
16456 evaluated until they are encountered (e.g., after any @code{BEGIN}
16457 action).
16459 Traditional Awk does not support the keywords @code{delete} or @code{do}.
16461 Traditional Awk does not support the expressions
16462 @code{@var{a}?@var{b}:@var{c}}, @code{!@var{a}}, @code{@var{a}^@var{b}},
16463 or @code{@var{a}^=@var{b}}.
16465 Traditional Awk does not support the predefined @code{CONVFMT} variable.
16467 Traditional Awk supports only the predefined functions @code{exp}, @code{index},
16468 @code{int}, @code{length}, @code{log}, @code{split}, @code{sprintf},
16469 @code{sqrt}, and @code{substr}.
16471 Traditional Awk @code{getline} is not at all compatible with Posix;
16472 avoid it.
16474 Traditional Awk has @code{for (i in a) @dots{}} but no other uses of the
16475 @code{in} keyword.  For example, it lacks @code{if (i in a) @dots{}}.
16477 In code portable to both traditional and modern Awk, @code{FS} must be a
16478 string containing just one ordinary character, and similarly for the
16479 field-separator argument to @code{split}.
16481 Traditional Awk has a limit of 99 fields in a record.  Since some Awk
16482 implementations, like Tru64's, split the input even if you don't refer
16483 to any field in the script, to circumvent this problem, set @samp{FS}
16484 to an unusual character and use @code{split}.
16486 Traditional Awk has a limit of at most 99 bytes in a number formatted by
16487 @code{OFMT}; for example, @code{OFMT="%.300e"; print 0.1;} typically
16488 dumps core.
16490 The original version of Awk had a limit of at most 99 bytes per
16491 @code{split} field, 99 bytes per @code{substr} substring, and 99 bytes
16492 per run of non-special characters in a @code{printf} format, but these
16493 bugs have been fixed on all practical hosts that we know of.
16495 HP-UX 11.00 and IRIX 6.5 Awk require that input files have a line length
16496 of at most 3070 bytes.
16498 @item @command{basename}
16499 @c ---------------------
16500 @prindex @command{basename}
16501 Not all hosts have a working @command{basename}.
16502 You can use @command{expr} instead.
16504 @c AS_BASENAME is to be replaced by a better API.
16505 @ignore
16506 Not all hosts have a working @command{basename}, and you should instead
16507 use @code{AS_BASENAME} (@pxref{Programming in M4sh}), followed by
16508 @command{expr} if you need to strip a suffix.  For example:
16510 @example
16511 a=`basename "$aname"`       # This is not portable.
16512 a=`AS_BASENAME(["$aname"])` # This is more portable.
16514 # This is not portable.
16515 c=`basename "$cname" .c`
16517 # This is more portable.
16518 c=`AS_BASENAME(["$cname"])`
16519 case $c in
16520 ?*.c) c=`expr "X$c" : 'X\(.*\)\.c'`;;
16521 esac
16522 @end example
16523 @end ignore
16526 @item @command{cat}
16527 @c ----------------
16528 @prindex @command{cat}
16529 Don't rely on any option.
16532 @item @command{cc}
16533 @c ---------------
16534 @prindex @command{cc}
16535 The command @samp{cc -c foo.c} traditionally produces an object file
16536 named @file{foo.o}.  Most compilers allow @option{-c} to be combined
16537 with @option{-o} to specify a different object file name, but
16538 Posix does not require this combination and a few compilers
16539 lack support for it.  @xref{C Compiler}, for how @acronym{GNU} Make
16540 tests for this feature with @code{AC_PROG_CC_C_O}.
16542 When a compilation such as @samp{cc -o foo foo.c} fails, some compilers
16543 (such as @sc{cds} on Reliant Unix) leave a @file{foo.o}.
16545 @acronym{HP-UX} @command{cc} doesn't accept @file{.S} files to preprocess and
16546 assemble.  @samp{cc -c foo.S} appears to succeed, but in fact does
16547 nothing.
16549 The default executable, produced by @samp{cc foo.c}, can be
16551 @itemize
16552 @item @file{a.out} --- usual Posix convention.
16553 @item @file{b.out} --- i960 compilers (including @command{gcc}).
16554 @item @file{a.exe} --- @acronym{DJGPP} port of @command{gcc}.
16555 @item @file{a_out.exe} --- GNV @command{cc} wrapper for DEC C on OpenVMS.
16556 @item @file{foo.exe} --- various MS-DOS compilers.
16557 @end itemize
16559 The C compiler's traditional name is @command{cc}, but other names like
16560 @command{gcc} are common.  Posix 1003.1-2001 specifies the
16561 name @command{c99}, but older Posix editions specified
16562 @command{c89} and anyway these standard names are rarely used in
16563 practice.  Typically the C compiler is invoked from makefiles that use
16564 @samp{$(CC)}, so the value of the @samp{CC} make variable selects the
16565 compiler name.
16567 @item @command{chgrp}
16568 @itemx @command{chown}
16569 @c -------------------
16570 @prindex @command{chgrp}
16571 @prindex @command{chown}
16572 It is not portable to change a file's group to a group that the owner
16573 does not belong to.
16575 @item @command{chmod}
16576 @c ------------------
16577 @prindex @command{chmod}
16578 Avoid usages like @samp{chmod -w file}; use @samp{chmod a-w file}
16579 instead, for two reasons.  First, plain @option{-w} does not necessarily
16580 make the file unwritable, since it does not affect mode bits that
16581 correspond to bits in the file mode creation mask.  Second,
16582 Posix says that the @option{-w} might be interpreted as an
16583 implementation-specific option, not as a mode; Posix suggests
16584 using @samp{chmod -- -w file} to avoid this confusion, but unfortunately
16585 @samp{--} does not work on some older hosts.
16588 @item @command{cmp}
16589 @c ----------------
16590 @prindex @command{cmp}
16591 @command{cmp} performs a raw data comparison of two files, while
16592 @command{diff} compares two text files.  Therefore, if you might compare
16593 DOS files, even if only checking whether two files are different, use
16594 @command{diff} to avoid spurious differences due to differences of
16595 newline encoding.
16598 @item @command{cp}
16599 @c ---------------
16600 @prindex @command{cp}
16601 Avoid the @option{-r} option, since Posix 1003.1-2004 marks it as
16602 obsolescent and its behavior on special files is implementation-defined.
16603 Use @option{-R} instead.  On @acronym{GNU} hosts the two options
16604 are equivalent, but on Solaris hosts (for example) @code{cp -r}
16605 reads from pipes instead of replicating them.
16607 Some @command{cp} implementations (e.g., @acronym{BSD/OS} 4.2) do not allow
16608 trailing slashes at the end of nonexistent destination directories.  To
16609 avoid this problem, omit the trailing slashes.  For example, use
16610 @samp{cp -R source /tmp/newdir} rather than @samp{cp -R source
16611 /tmp/newdir/} if @file{/tmp/newdir} does not exist.
16613 @c This is thanks to Ian.
16614 The ancient SunOS 4 @command{cp} does not support @option{-f}, although
16615 its @command{mv} does.
16617 @cindex timestamp resolution
16618 Traditionally, file timestamps had 1-second resolution, and @samp{cp
16619 -p} copied the timestamps exactly.  However, many modern file systems
16620 have timestamps with 1-nanosecond resolution.  Unfortunately, @samp{cp
16621 -p} implementations truncate timestamps when copying files, so this
16622 can result in the destination file appearing to be older than the
16623 source.  The exact amount of truncation depends on the resolution of
16624 the system calls that @command{cp} uses; traditionally this was
16625 @code{utime}, which has 1-second resolution, but some newer
16626 @command{cp} implementations use @code{utimes}, which has
16627 1-microsecond resolution.  These newer implementations include @acronym{GNU}
16628 Core Utilities 5.0.91 or later, and Solaris 8 (sparc) patch 109933-02 or
16629 later.  Unfortunately as of January 2006 there is still no system
16630 call to set timestamps to the full nanosecond resolution.
16632 Bob Proulx notes that @samp{cp -p} always @emph{tries} to copy
16633 ownerships.  But whether it actually does copy ownerships or not is a
16634 system dependent policy decision implemented by the kernel.  If the
16635 kernel allows it then it happens.  If the kernel does not allow it then
16636 it does not happen.  It is not something @command{cp} itself has control
16637 over.
16639 In Unix System V any user can chown files to any other user, and System
16640 V also has a non-sticky @file{/tmp}.  That probably derives from the
16641 heritage of System V in a business environment without hostile users.
16642 @acronym{BSD} changed this
16643 to be a more secure model where only root can @command{chown} files and
16644 a sticky @file{/tmp} is used.  That undoubtedly derives from the heritage
16645 of @acronym{BSD} in a campus environment.
16647 @acronym{GNU}/Linux and Solaris by default follow @acronym{BSD}, but
16648 can be configured to allow a System V style @command{chown}.  On the
16649 other hand, @acronym{HP-UX} follows System V, but can
16650 be configured to use the modern security model and disallow
16651 @command{chown}.  Since it is an administrator-configurable parameter
16652 you can't use the name of the kernel as an indicator of the behavior.
16656 @item @command{date}
16657 @c -----------------
16658 @prindex @command{date}
16659 Some versions of @command{date} do not recognize special @samp{%} directives,
16660 and unfortunately, instead of complaining, they just pass them through,
16661 and exit with success:
16663 @example
16664 $ @kbd{uname -a}
16665 OSF1 medusa.sis.pasteur.fr V5.1 732 alpha
16666 $ @kbd{date "+%s"}
16668 @end example
16671 @item @command{diff}
16672 @c -----------------
16673 @prindex @command{diff}
16674 Option @option{-u} is nonportable.
16676 Some implementations, such as Tru64's, fail when comparing to
16677 @file{/dev/null}.  Use an empty file instead.
16680 @item @command{dirname}
16681 @c --------------------
16682 @prindex @command{dirname}
16683 Not all hosts have a working @command{dirname}, and you should instead
16684 use @code{AS_DIRNAME} (@pxref{Programming in M4sh}).  For example:
16686 @example
16687 dir=`dirname "$file"`       # This is not portable.
16688 dir=`AS_DIRNAME(["$file"])` # This is more portable.
16689 @end example
16692 @item @command{egrep}
16693 @c ------------------
16694 @prindex @command{egrep}
16695 Posix 1003.1-2001 no longer requires @command{egrep},
16696 but many hosts do not yet support the Posix
16697 replacement @code{grep -E}.  Also, some traditional implementations do
16698 not work on long input lines.  To work around these problems, invoke
16699 @code{AC_PROG_EGREP} and then use @code{$EGREP}.
16701 Portable extended regular expressions should use @samp{\} only to escape
16702 characters in the string @samp{$()*+.?[\^@{|}.  For example, @samp{\@}}
16703 is not portable, even though it typically matches @samp{@}}.
16705 The empty alternative is not portable.  Use @samp{?} instead.  For
16706 instance with Digital Unix v5.0:
16708 @example
16709 > printf "foo\n|foo\n" | $EGREP '^(|foo|bar)$'
16710 |foo
16711 > printf "bar\nbar|\n" | $EGREP '^(foo|bar|)$'
16712 bar|
16713 > printf "foo\nfoo|\n|bar\nbar\n" | $EGREP '^(foo||bar)$'
16715 |bar
16716 @end example
16718 @command{$EGREP} also suffers the limitations of @command{grep}
16719 (@pxref{grep, , Limitations of Usual Tools}).
16721 @item @command{expr}
16722 @c -----------------
16723 @prindex @command{expr}
16724 Not all implementations obey the Posix rule that @samp{--} separates
16725 options from arguments; likewise, not all implementations provide the
16726 extension to Posix that the first argument can be treated as part of a
16727 valid expression rather than an invalid option if it begins with
16728 @samp{-}.  When performing arithmetic, use @samp{expr 0 + $var} if
16729 @samp{$var} might be a negative number, to keep @command{expr} from
16730 interpreting it as an option.
16732 No @command{expr} keyword starts with @samp{X}, so use @samp{expr
16733 X"@var{word}" : 'X@var{regex}'} to keep @command{expr} from
16734 misinterpreting @var{word}.
16736 Don't use @code{length}, @code{substr}, @code{match} and @code{index}.
16738 @item @command{expr} (@samp{|})
16739 @prindex @command{expr} (@samp{|})
16740 You can use @samp{|}.  Although Posix does require that @samp{expr
16741 ''} return the empty string, it does not specify the result when you
16742 @samp{|} together the empty string (or zero) with the empty string.  For
16743 example:
16745 @example
16746 expr '' \| ''
16747 @end example
16749 Posix 1003.2-1992 returns the empty string
16750 for this case, but traditional Unix returns @samp{0} (Solaris is
16751 one such example).  In Posix 1003.1-2001, the specification was
16752 changed to match traditional Unix's behavior (which is
16753 bizarre, but it's too late to fix this).  Please note that the same
16754 problem does arise when the empty string results from a computation,
16755 as in:
16757 @example
16758 expr bar : foo \| foo : bar
16759 @end example
16761 @noindent
16762 Avoid this portability problem by avoiding the empty string.
16765 @item @command{expr} (@samp{:})
16766 @c ----------------------------
16767 @prindex @command{expr}
16768 Portable @command{expr} regular expressions should use @samp{\} to
16769 escape only characters in the string @samp{$()*.0123456789[\^n@{@}}.
16770 For example, alternation, @samp{\|}, is common but Posix does not
16771 require its support, so it should be avoided in portable scripts.
16772 Similarly, @samp{\+} and @samp{\?} should be avoided.
16774 Portable @command{expr} regular expressions should not begin with
16775 @samp{^}.  Patterns are automatically anchored so leading @samp{^} is
16776 not needed anyway.
16778 On the other hand, the behavior of the @samp{$} anchor is not portable
16779 on multi-line strings.  Posix is ambiguous whether the anchor applies to
16780 each line, as was done in older versions of @acronym{GNU} Coreutils, or
16781 whether it applies only to the end of the overall string, as in
16782 Coreutils 6.0 and most other implementations.
16784 @example
16785 $ @kbd{baz='foo}
16786 > @kbd{bar'}
16787 $ @kbd{expr "X$baz" : 'X\(foo\)$'}
16789 $ @kbd{expr-5.97 "X$baz" : 'X\(foo\)$'}
16791 @end example
16793 The Posix standard is ambiguous as to whether
16794 @samp{expr 'a' : '\(b\)'} outputs @samp{0} or the empty string.
16795 In practice, it outputs the empty string on most platforms, but portable
16796 scripts should not assume this.  For instance, the @acronym{QNX} 4.25 native
16797 @command{expr} returns @samp{0}.
16799 One might think that a way to get a uniform behavior would be to use
16800 the empty string as a default value:
16802 @example
16803 expr a : '\(b\)' \| ''
16804 @end example
16806 @noindent
16807 Unfortunately this behaves exactly as the original expression; see the
16808 @command{expr} (@samp{|}) entry for more information.
16810 Some ancient @command{expr} implementations (e.g., SunOS 4 @command{expr} and
16811 Solaris 8 @command{/usr/ucb/expr}) have a silly length limit that causes
16812 @command{expr} to fail if the matched substring is longer than 120
16813 bytes.  In this case, you might want to fall back on @samp{echo|sed} if
16814 @command{expr} fails.  Nowadays this is of practical importance only for
16815 the rare installer who mistakenly puts @file{/usr/ucb} before
16816 @file{/usr/bin} in @env{PATH}.
16818 On Mac OS X 10.4, @command{expr} mishandles the pattern @samp{[^-]} in
16819 some cases.  For example, the command
16820 @example
16821 expr Xpowerpc-apple-darwin8.1.0 : 'X[^-]*-[^-]*-\(.*\)'
16822 @end example
16824 @noindent
16825 outputs @samp{apple-darwin8.1.0} rather than the correct @samp{darwin8.1.0}.
16826 This particular case can be worked around by substituting @samp{[^--]}
16827 for @samp{[^-]}.
16829 Don't leave, there is some more!
16831 The @acronym{QNX} 4.25 @command{expr}, in addition of preferring @samp{0} to
16832 the empty string, has a funny behavior in its exit status: it's always 1
16833 when parentheses are used!
16835 @example
16836 $ @kbd{val=`expr 'a' : 'a'`; echo "$?: $val"}
16837 0: 1
16838 $ @kbd{val=`expr 'a' : 'b'`; echo "$?: $val"}
16839 1: 0
16841 $ @kbd{val=`expr 'a' : '\(a\)'`; echo "?: $val"}
16842 1: a
16843 $ @kbd{val=`expr 'a' : '\(b\)'`; echo "?: $val"}
16844 1: 0
16845 @end example
16847 @noindent
16848 In practice this can be a big problem if you are ready to catch failures
16849 of @command{expr} programs with some other method (such as using
16850 @command{sed}), since you may get twice the result.  For instance
16852 @example
16853 $ @kbd{expr 'a' : '\(a\)' || echo 'a' | sed 's/^\(a\)$/\1/'}
16854 @end example
16856 @noindent
16857 outputs @samp{a} on most hosts, but @samp{aa} on @acronym{QNX} 4.25.  A
16858 simple workaround consists of testing @command{expr} and using a variable
16859 set to @command{expr} or to @command{false} according to the result.
16861 Tru64 @command{expr} incorrectly treats the result as a number, if it
16862 can be interpreted that way:
16864 @example
16865 $ @kbd{expr 00001 : '.*\(...\)'}
16867 @end example
16869 On @acronym{HP-UX} 11, @command{expr} only supports a single
16870 sub-expression.
16872 @example
16873 $ @kbd{expr 'Xfoo' : 'X\(f\(oo\)*\)$'}
16874 expr: More than one '\(' was used.
16875 @end example
16878 @item @command{fgrep}
16879 @c ------------------
16880 @prindex @command{fgrep}
16881 Posix 1003.1-2001 no longer requires @command{fgrep},
16882 but many hosts do not yet support the Posix
16883 replacement @code{grep -F}.  Also, some traditional implementations do
16884 not work on long input lines.  To work around these problems, invoke
16885 @code{AC_PROG_FGREP} and then use @code{$FGREP}.
16888 @item @command{find}
16889 @c -----------------
16890 @prindex @command{find}
16891 The option @option{-maxdepth} seems to be @acronym{GNU} specific.
16892 Tru64 v5.1, Net@acronym{BSD} 1.5 and Solaris @command{find}
16893 commands do not understand it.
16895 The replacement of @samp{@{@}} is guaranteed only if the argument is
16896 exactly @emph{@{@}}, not if it's only a part of an argument.  For
16897 instance on DU, and @acronym{HP-UX} 10.20 and @acronym{HP-UX} 11:
16899 @example
16900 $ @kbd{touch foo}
16901 $ @kbd{find . -name foo -exec echo "@{@}-@{@}" \;}
16902 @{@}-@{@}
16903 @end example
16905 @noindent
16906 while @acronym{GNU} @command{find} reports @samp{./foo-./foo}.
16909 @anchor{grep}
16910 @item @command{grep}
16911 @c -----------------
16912 @prindex @command{grep}
16913 Portable scripts can rely on the @command{grep} options @option{-c},
16914 @option{-l}, @option{-n}, and @option{-v}, but should avoid other
16915 options.  For example, don't use @option{-w}, as Posix does not require
16916 it and Irix 6.5.16m's @command{grep} does not support it.  Also,
16917 portable scripts should not combine @option{-c} with @option{-l},
16918 as Posix does not allow this.
16920 Some of the options required by Posix are not portable in practice.
16921 Don't use @samp{grep -q} to suppress output, because many @command{grep}
16922 implementations (e.g., Solaris) do not support @option{-q}.
16923 Don't use @samp{grep -s} to suppress output either, because Posix
16924 says @option{-s} does not suppress output, only some error messages;
16925 also, the @option{-s} option of traditional @command{grep} behaved
16926 like @option{-q} does in most modern implementations.  Instead,
16927 redirect the standard output and standard error (in case the file
16928 doesn't exist) of @code{grep} to @file{/dev/null}.  Check the exit
16929 status of @code{grep} to determine whether it found a match.
16931 Some traditional @command{grep} implementations do not work on long
16932 input lines.  On AIX the default @code{grep} silently truncates long
16933 lines on the input before matching.
16935 Also, many implementations do not support multiple regexps
16936 with @option{-e}: they either reject @option{-e} entirely (e.g., Solaris)
16937 or honor only the last pattern (e.g., @acronym{IRIX} 6.5 and NeXT).  To
16938 work around these problems, invoke @code{AC_PROG_GREP} and then use
16939 @code{$GREP}.
16941 Another possible workaround for the multiple @option{-e} problem is to
16942 separate the patterns by newlines, for example:
16944 @example
16945 grep 'foo
16946 bar' in.txt
16947 @end example
16949 @noindent
16950 except that this fails with traditional @command{grep}
16951 implementations and with Open@acronym{BSD} 3.8 @command{grep}.
16953 Traditional @command{grep} implementations (e.g., Solaris) do not
16954 support the @option{-E} or @option{-F} options.  To work around these
16955 problems, invoke @code{AC_PROG_EGREP} and then use @code{$EGREP}, and
16956 similarly for @code{AC_PROG_FGREP} and @code{$FGREP}.  Even if you are
16957 willing to require support for Posix @command{grep}, your script should
16958 not use both @option{-E} and @option{-F}, since Posix does not allow
16959 this combination.
16961 Portable @command{grep} regular expressions should use @samp{\} only to
16962 escape characters in the string @samp{$()*.0123456789[\^@{@}}.  For example,
16963 alternation, @samp{\|}, is common but Posix does not require its
16964 support in basic regular expressions, so it should be avoided in
16965 portable scripts.  Solaris and HP-UX @command{grep} do not support it.
16966 Similarly, the following escape sequences should also be avoided:
16967 @samp{\<}, @samp{\>}, @samp{\+}, @samp{\?}, @samp{\`}, @samp{\'},
16968 @samp{\B}, @samp{\b}, @samp{\S}, @samp{\s}, @samp{\W}, and @samp{\w}.
16970 Posix does not specify the behavior of @command{grep} on binary files.
16971 An example where this matters is using @acronym{BSD} @command{grep} to
16972 search text that includes embedded @acronym{ANSI} escape sequences for
16973 colored output to terminals (@samp{\033[m} is the sequence to restore
16974 normal output); the behavior depends on whether input is seekable:
16976 @example
16977 $ @kbd{printf 'esc\033[mape\n' > sample}
16978 $ @kbd{grep . sample}
16979 Binary file sample matches
16980 $ @kbd{cat sample | grep .}
16981 escape
16982 @end example
16985 @item @command{join}
16986 @c -----------------
16987 @prindex @command{join}
16988 Solaris 8 @command{join} has bugs when the second operand is standard
16989 input, and when standard input is a pipe.  For example, the following
16990 shell script causes Solaris 8 @command{join} to loop forever:
16992 @example
16993 cat >file <<'EOF'
16994 1 x
16995 2 y
16997 cat file | join file -
16998 @end example
17000 Use @samp{join - file} instead.
17003 @item @command{ln}
17004 @c ---------------
17005 @prindex @command{ln}
17006 @cindex Symbolic links
17007 Don't rely on @command{ln} having a @option{-f} option.  Symbolic links
17008 are not available on old systems; use @samp{$(LN_S)} as a portable substitute.
17010 For versions of the @acronym{DJGPP} before 2.04,
17011 @command{ln} emulates symbolic links
17012 to executables by generating a stub that in turn calls the real
17013 program.  This feature also works with nonexistent files like in the
17014 Posix spec.  So @samp{ln -s file link} generates @file{link.exe},
17015 which attempts to call @file{file.exe} if run.  But this feature only
17016 works for executables, so @samp{cp -p} is used instead for these
17017 systems.  @acronym{DJGPP} versions 2.04 and later have full support
17018 for symbolic links.
17021 @item @command{ls}
17022 @c ---------------
17023 @prindex @command{ls}
17024 @cindex Listing directories
17025 The portable options are @option{-acdilrtu}.  Current practice is for
17026 @option{-l} to output both owner and group, even though ancient versions
17027 of @command{ls} omitted the group.
17029 On ancient hosts, @samp{ls foo} sent the diagnostic @samp{foo not found}
17030 to standard output if @file{foo} did not exist.  Hence a shell command
17031 like @samp{sources=`ls *.c 2>/dev/null`} did not always work, since it
17032 was equivalent to @samp{sources='*.c not found'} in the absence of
17033 @samp{.c} files.  This is no longer a practical problem, since current
17034 @command{ls} implementations send diagnostics to standard error.
17036 The behavior of @command{ls} on a directory that is being concurrently
17037 modified is not always predictable, because of a data race where cached
17038 information returned by @code{readdir} does not match the current
17039 directory state.  In fact, MacOS 10.5 has an intermittent bug where
17040 @code{readdir}, and thus @command{ls}, sometimes lists a file more than
17041 once if other files were added or removed from the directory immediately
17042 prior to the @command{ls} call.  Since @command{ls} already sorts its
17043 output, the duplicate entries can be avoided by piping the results
17044 through @code{uniq}.
17046 @anchor{mkdir}
17047 @item @command{mkdir}
17048 @c ------------------
17049 @prindex @command{mkdir}
17050 @cindex Making directories
17051 No @command{mkdir} option is portable to older systems.  Instead of
17052 @samp{mkdir -p @var{file-name}}, you should use
17053 @code{AS_MKDIR_P(@var{file-name})} (@pxref{Programming in M4sh})
17054 or @code{AC_PROG_MKDIR_P} (@pxref{Particular Programs}).
17056 Combining the @option{-m} and @option{-p} options, as in @samp{mkdir -m
17057 go-w -p @var{dir}}, often leads to trouble.  Free@acronym{BSD}
17058 @command{mkdir} incorrectly attempts to change the permissions of
17059 @var{dir} even if it already exists.  @acronym{HP-UX} 11.23 and
17060 @acronym{IRIX} 6.5 @command{mkdir} often assign the wrong permissions to
17061 any newly-created parents of @var{dir}.
17063 Posix does not clearly specify whether @samp{mkdir -p foo}
17064 should succeed when @file{foo} is a symbolic link to an already-existing
17065 directory.  The @acronym{GNU} Core Utilities 5.1.0 @command{mkdir}
17066 succeeds, but Solaris @command{mkdir} fails.
17068 Traditional @code{mkdir -p} implementations suffer from race conditions.
17069 For example, if you invoke @code{mkdir -p a/b} and @code{mkdir -p a/c}
17070 at the same time, both processes might detect that @file{a} is missing,
17071 one might create @file{a}, then the other might try to create @file{a}
17072 and fail with a @code{File exists} diagnostic.  The @acronym{GNU} Core
17073 Utilities (@samp{fileutils} version 4.1), Free@acronym{BSD} 5.0,
17074 Net@acronym{BSD} 2.0.2, and Open@acronym{BSD} 2.4 are known to be
17075 race-free when two processes invoke @code{mkdir -p} simultaneously, but
17076 earlier versions are vulnerable.  Solaris @command{mkdir} is still
17077 vulnerable as of Solaris 10, and other traditional Unix systems are
17078 probably vulnerable too.  This possible race is harmful in parallel
17079 builds when several Make rules call @code{mkdir -p} to
17080 construct directories.  You may use
17081 @code{install-sh -d} as a safe replacement, provided this script is
17082 recent enough; the copy shipped with Autoconf 2.60 and Automake 1.10 is
17083 OK, but copies from older versions are vulnerable.
17086 @item @command{mkfifo}
17087 @itemx @command{mknod}
17088 @c -------------------
17089 @prindex @command{mkfifo}
17090 @prindex @command{mknod}
17091 The GNU Coding Standards state that @command{mknod} is safe to use on
17092 platforms where it has been tested to exist; but it is generally portable
17093 only for creating named FIFOs, since device numbers are
17094 platform-specific.  Autotest uses @command{mkfifo} to implement parallel
17095 testsuites.  Posix states that behavior is unspecified when opening a
17096 named FIFO for both reading and writing; on at least Cygwin, this
17097 results in failure on any attempt to read or write to that file
17098 descriptor.
17100 @item @command{mktemp}
17101 @c -------------------
17102 @prindex @command{mktemp}
17103 @cindex Creating temporary files
17104 Shell scripts can use temporary files safely with @command{mktemp}, but
17105 it does not exist on all systems.  A portable way to create a safe
17106 temporary file name is to create a temporary directory with mode 700 and
17107 use a file inside this directory.  Both methods prevent attackers from
17108 gaining control, though @command{mktemp} is far less likely to fail
17109 gratuitously under attack.
17111 Here is sample code to create a new temporary directory safely:
17113 @example
17114 # Create a temporary directory $tmp in $TMPDIR (default /tmp).
17115 # Use mktemp if possible; otherwise fall back on mkdir,
17116 # with $RANDOM to make collisions less likely.
17117 : $@{TMPDIR=/tmp@}
17119   tmp=`
17120     (umask 077 && mktemp -d "$TMPDIR/fooXXXXXX") 2>/dev/null
17121   ` &&
17122   test -n "$tmp" && test -d "$tmp"
17123 @} || @{
17124   tmp=$TMPDIR/foo$$-$RANDOM
17125   (umask 077 && mkdir "$tmp")
17126 @} || exit $?
17127 @end example
17130 @item @command{mv}
17131 @c ---------------
17132 @prindex @command{mv}
17133 @cindex Moving open files
17134 The only portable options are @option{-f} and @option{-i}.
17136 Moving individual files between file systems is portable (it was in Unix
17137 version 6),
17138 but it is not always atomic: when doing @samp{mv new existing}, there's
17139 a critical section where neither the old nor the new version of
17140 @file{existing} actually exists.
17142 On some systems moving files from @file{/tmp} can sometimes cause
17143 undesirable (but perfectly valid) warnings, even if you created these
17144 files.  This is because @file{/tmp} belongs to a group that ordinary
17145 users are not members of, and files created in @file{/tmp} inherit
17146 the group of @file{/tmp}.  When the file is copied, @command{mv} issues
17147 a diagnostic without failing:
17149 @smallexample
17150 $ @kbd{touch /tmp/foo}
17151 $ @kbd{mv /tmp/foo .}
17152 @error{}mv: ./foo: set owner/group (was: 100/0): Operation not permitted
17153 $ @kbd{echo $?}
17155 $ @kbd{ls foo}
17157 @end smallexample
17159 @noindent
17160 This annoying behavior conforms to Posix, unfortunately.
17162 Moving directories across mount points is not portable, use @command{cp}
17163 and @command{rm}.
17165 @acronym{DOS} variants cannot rename or remove open files, and do not
17166 support commands like @samp{mv foo bar >foo}, even though this is
17167 perfectly portable among Posix hosts.
17170 @item @command{od}
17171 @c ---------------
17172 @prindex @command{od}
17174 In Mac OS X 10.3, @command{od} does not support the
17175 standard Posix options @option{-A}, @option{-j}, @option{-N}, or
17176 @option{-t}, or the @acronym{XSI} option @option{-s}.  The only
17177 supported Posix option is @option{-v}, and the only supported
17178 @acronym{XSI} options are those in @option{-bcdox}.  The @acronym{BSD}
17179 @command{hexdump} program can be used instead.
17181 This problem no longer exists in Mac OS X 10.4.3.
17184 @item @command{rm}
17185 @c ---------------
17186 @prindex @command{rm}
17187 The @option{-f} and @option{-r} options are portable.
17189 It is not portable to invoke @command{rm} without operands.  For
17190 example, on many systems @samp{rm -f -r} (with no other arguments)
17191 silently succeeds without doing anything, but it fails with a diagnostic
17192 on Net@acronym{BSD} 2.0.2.
17194 A file might not be removed even if its parent directory is writable
17195 and searchable.  Many Posix hosts cannot remove a mount point, a named
17196 stream, a working directory, or a last link to a file that is being
17197 executed.
17199 @acronym{DOS} variants cannot rename or remove open files, and do not
17200 support commands like @samp{rm foo >foo}, even though this is
17201 perfectly portable among Posix hosts.
17203 @item @command{rmdir}
17204 @c ------------------
17205 @prindex @command{rmdir}
17206 Just as with @command{rm}, some platforms refuse to remove a working
17207 directory.
17209 @anchor{sed}
17210 @item @command{sed}
17211 @c ----------------
17212 @prindex @command{sed}
17213 Patterns should not include the separator (unless escaped), even as part
17214 of a character class.  In conformance with Posix, the Cray
17215 @command{sed} rejects @samp{s/[^/]*$//}: use @samp{s,[^/]*$,,}.
17217 Avoid empty patterns within parentheses (i.e., @samp{\(\)}).  Posix does
17218 not require support for empty patterns, and Unicos 9 @command{sed} rejects
17219 them.
17221 Unicos 9 @command{sed} loops endlessly on patterns like @samp{.*\n.*}.
17223 Sed scripts should not use branch labels longer than 7 characters and
17224 should not contain comments.  @acronym{HP-UX} sed has a limit of 99 commands
17225 (not counting @samp{:} commands) and
17226 48 labels, which can not be circumvented by using more than one script
17227 file.  It can execute up to 19 reads with the @samp{r} command per cycle.
17228 Solaris @command{/usr/ucb/sed} rejects usages that exceed a limit of
17229 about 6000 bytes for the internal representation of commands.
17231 Avoid redundant @samp{;}, as some @command{sed} implementations, such as
17232 Net@acronym{BSD} 1.4.2's, incorrectly try to interpret the second
17233 @samp{;} as a command:
17235 @example
17236 $ @kbd{echo a | sed 's/x/x/;;s/x/x/'}
17237 sed: 1: "s/x/x/;;s/x/x/": invalid command code ;
17238 @end example
17240 Input should not have unreasonably long lines, since some @command{sed}
17241 implementations have an input buffer limited to 4000 bytes.  Likewise,
17242 not all @command{sed} implementations can handle embedded @code{NUL} or
17243 a missing trailing newline.
17245 Portable @command{sed} regular expressions should use @samp{\} only to escape
17246 characters in the string @samp{$()*.0123456789[\^n@{@}}.  For example,
17247 alternation, @samp{\|}, is common but Posix does not require its
17248 support, so it should be avoided in portable scripts.  Solaris
17249 @command{sed} does not support alternation; e.g., @samp{sed '/a\|b/d'}
17250 deletes only lines that contain the literal string @samp{a|b}.
17251 Similarly, @samp{\+} and @samp{\?} should be avoided.
17253 Anchors (@samp{^} and @samp{$}) inside groups are not portable.
17255 Nested parentheses in patterns (e.g., @samp{\(\(a*\)b*)\)}) are
17256 quite portable to current hosts, but was not supported by some ancient
17257 @command{sed} implementations like SVR3.
17259 Some @command{sed} implementations, e.g., Solaris,
17260 restrict the special role of the asterisk to one-character regular expressions.
17261 This may lead to unexpected behavior:
17263 @example
17264 $ @kbd{echo '1*23*4' | /usr/bin/sed 's/\(.\)*/x/g'}
17265 x2x4
17266 $ @kbd{echo '1*23*4' | /usr/xpg4/bin/sed 's/\(.\)*/x/g'}
17268 @end example
17270 The @option{-e} option is mostly portable.
17271 However, its argument
17272 cannot start with @samp{a}, @samp{c}, or @samp{i},
17273 as this runs afoul of a Tru64 5.1 bug.
17274 Also, its argument cannot be empty, as this fails on @acronym{AIX} 5.3.
17275 Some people prefer to use @samp{-e}:
17277 @example
17278 sed -e '@var{command-1}' \
17279     -e '@var{command-2}'
17280 @end example
17282 @noindent
17283 as opposed to the equivalent:
17285 @example
17286 sed '
17287   @var{command-1}
17288   @var{command-2}
17290 @end example
17292 @noindent
17293 The following usage is sometimes equivalent:
17295 @example
17296 sed '@var{command-1};@var{command-2}'
17297 @end example
17299 but Posix says that this use of a semicolon has undefined effect if
17300 @var{command-1}'s verb is @samp{@{}, @samp{a}, @samp{b}, @samp{c},
17301 @samp{i}, @samp{r}, @samp{t}, @samp{w}, @samp{:}, or @samp{#}, so you
17302 should use semicolon only with simple scripts that do not use these
17303 verbs.
17305 Commands inside @{ @} brackets are further restricted.  Posix says that
17306 they cannot be preceded by addresses, @samp{!}, or @samp{;}, and that
17307 each command must be followed immediately by a newline, without any
17308 intervening blanks or semicolons.  The closing bracket must be alone on
17309 a line, other than white space preceding or following it.
17311 Contrary to yet another urban legend, you may portably use @samp{&} in
17312 the replacement part of the @code{s} command to mean ``what was
17313 matched''.  All descendants of Unix version 7 @command{sed}
17314 (at least; we
17315 don't have first hand experience with older @command{sed} implementations) have
17316 supported it.
17318 Posix requires that you must not have any white space between
17319 @samp{!} and the following command.  It is OK to have blanks between
17320 the address and the @samp{!}.  For instance, on Solaris:
17322 @example
17323 $ @kbd{echo "foo" | sed -n '/bar/ ! p'}
17324 @error{}Unrecognized command: /bar/ ! p
17325 $ @kbd{echo "foo" | sed -n '/bar/! p'}
17326 @error{}Unrecognized command: /bar/! p
17327 $ @kbd{echo "foo" | sed -n '/bar/ !p'}
17329 @end example
17331 Posix also says that you should not combine @samp{!} and @samp{;}.  If
17332 you use @samp{!}, it is best to put it on a command that is delimited by
17333 newlines rather than @samp{;}.
17335 Also note that Posix requires that the @samp{b}, @samp{t}, @samp{r}, and
17336 @samp{w} commands be followed by exactly one space before their argument.
17337 On the other hand, no white space is allowed between @samp{:} and the
17338 subsequent label name.
17340 If a sed script is specified on the command line and ends in an
17341 @samp{a}, @samp{c}, or @samp{i} command, the last line of inserted text
17342 should be followed by a newline.  Otherwise some @command{sed}
17343 implementations (e.g., Open@acronym{BSD} 3.9) do not append a newline to the
17344 inserted text.
17346 Many @command{sed} implementations (e.g., MacOS X 10.4,
17347 Open@acronym{BSD} 3.9, Solaris 10
17348 @command{/usr/ucb/sed}) strip leading white space from the text of
17349 @samp{a}, @samp{c}, and @samp{i} commands.  Prepend a backslash to
17350 work around this incompatibility with Posix:
17352 @example
17353 $ @kbd{echo flushleft | sed 'a\}
17354 > @kbd{   indented}
17355 > @kbd{'}
17356 flushleft
17357 indented
17358 $ @kbd{echo foo | sed 'a\}
17359 > @kbd{\   indented}
17360 > @kbd{'}
17361 flushleft
17362    indented
17363 @end example
17365 Posix requires that with an empty regular expression, the last non-empty
17366 regular expression from either an address specification or substitution
17367 command is applied.  However, busybox 1.6.1 complains when using a
17368 substitution command with a replacement containing a back-reference to
17369 an empty regular expression; the workaround is repeating the regular
17370 expression.
17372 @example
17373 $ @kbd{echo abc | busybox sed '/a\(b\)c/ s//\1/'}
17374 sed: No previous regexp.
17375 $ @kbd{echo abc | busybox sed '/a\(b\)c/ s/a\(b\)c/\1/'}
17377 @end example
17380 @item @command{sed} (@samp{t})
17381 @c ---------------------------
17382 @prindex @command{sed} (@samp{t})
17383 Some old systems have @command{sed} that ``forget'' to reset their
17384 @samp{t} flag when starting a new cycle.  For instance on @acronym{MIPS
17385 RISC/OS}, and on @sc{irix} 5.3, if you run the following @command{sed}
17386 script (the line numbers are not actual part of the texts):
17388 @example
17389 s/keep me/kept/g  # a
17390 t end             # b
17391 s/.*/deleted/g    # c
17392 :end              # d
17393 @end example
17395 @noindent
17398 @example
17399 delete me         # 1
17400 delete me         # 2
17401 keep me           # 3
17402 delete me         # 4
17403 @end example
17405 @noindent
17406 you get
17408 @example
17409 deleted
17410 delete me
17411 kept
17412 deleted
17413 @end example
17415 @noindent
17416 instead of
17418 @example
17419 deleted
17420 deleted
17421 kept
17422 deleted
17423 @end example
17425 Why?  When processing line 1, (c) matches, therefore sets the @samp{t}
17426 flag, and the output is produced.  When processing
17427 line 2, the @samp{t} flag is still set (this is the bug).  Command (a)
17428 fails to match, but @command{sed} is not supposed to clear the @samp{t}
17429 flag when a substitution fails.  Command (b) sees that the flag is set,
17430 therefore it clears it, and jumps to (d), hence you get @samp{delete me}
17431 instead of @samp{deleted}.  When processing line (3), @samp{t} is clear,
17432 (a) matches, so the flag is set, hence (b) clears the flags and jumps.
17433 Finally, since the flag is clear, line 4 is processed properly.
17435 There are two things one should remember about @samp{t} in @command{sed}.
17436 Firstly, always remember that @samp{t} jumps if @emph{some} substitution
17437 succeeded, not only the immediately preceding substitution.  Therefore,
17438 always use a fake @samp{t clear} followed by a @samp{:clear} on the next
17439 line, to reset the @samp{t} flag where needed.
17441 Secondly, you cannot rely on @command{sed} to clear the flag at each new
17442 cycle.
17444 One portable implementation of the script above is:
17446 @example
17447 t clear
17448 :clear
17449 s/keep me/kept/g
17450 t end
17451 s/.*/deleted/g
17452 :end
17453 @end example
17455 @item @command{sleep}
17456 @c ------------------
17457 @prindex @command{sleep}
17458 Using @command{sleep} is generally portable.  However, remember that
17459 adding a @command{sleep} to work around timestamp issues, with a minimum
17460 granularity of one second, doesn't scale well for parallel builds on
17461 modern machines with sub-second process completion.
17463 @item @command{sort}
17464 @c -----------------
17465 @prindex @command{sort}
17466 Remember that sort order is influenced by the current locale.  Inside
17467 @file{configure}, the C locale is in effect, but in Makefile snippets,
17468 you may need to specify @code{LC_ALL=C sort}.
17470 @item @command{tar}
17471 @c ----------------
17472 @prindex @command{tar}
17473 There are multiple file formats for @command{tar}; if you use Automake,
17474 the macro @code{AM_INIT_AUTOMAKE} has some options controlling which
17475 level of portability to use.
17477 @anchor{touch}
17478 @item @command{touch}
17479 @c ------------------
17480 @prindex @command{touch}
17481 @cindex timestamp resolution
17482 If you specify the desired timestamp (e.g., with the @option{-r}
17483 option), @command{touch} typically uses the @code{utime} or
17484 @code{utimes} system call, which can result in the same kind of
17485 timestamp truncation problems that @samp{cp -p} has.
17487 On ancient @acronym{BSD} systems, @command{touch} or any command that
17488 results in an empty file does not update the timestamps, so use a
17489 command like @command{echo} as a workaround.
17490 Also,
17491 @acronym{GNU} @command{touch} 3.16r (and presumably all before that)
17492 fails to work on SunOS 4.1.3 when the empty file is on an
17493 @acronym{NFS}-mounted 4.2 volume.
17494 However, these problems are no longer of practical concern.
17496 @item @command{tr}
17497 @c ---------------
17498 @prindex @command{tr}
17499 @cindex carriage return, deleting
17500 @cindex deleting carriage return
17501 Not all versions of @command{tr} handle all backslash character escapes.
17502 For example, Solaris 10 @command{/usr/ucb/tr} falls over, even though
17503 Solaris contains more modern @command{tr} in other locations.
17504 Therefore, it is more portable to use octal escapes, even though this
17505 ties the result to @acronym{ASCII}, when using @command{tr} to delete
17506 newlines or carriage returns.
17508 @example
17509 $ @kbd{@{ echo moon; echo light; @} | /usr/ucb/tr -d '\n' ; echo}
17511 light
17512 $ @kbd{@{ echo moon; echo light; @} | /usr/bin/tr -d '\n' ; echo}
17513 moonlight
17514 $ @kbd{@{ echo moon; echo light; @} | /usr/ucb/tr -d '\012' ; echo}
17515 moonlight
17516 @end example
17518 Posix requires @command{tr} to operate on binary files.  But at least
17519 Solaris @command{/usr/ucb/tr} still fails to handle @samp{\0} as the
17520 octal escape for @code{NUL}.  On Solaris, when using @command{tr} to
17521 neutralize a binary file by converting @code{NUL} to a different
17522 character, it is necessary to use @command{/usr/xpg4/bin/tr} instead.
17524 @example
17525 $ @kbd{printf 'a\0b\n' | /usr/ucb/tr '\0' '~' | wc -c}
17527 $ @kbd{printf 'a\0b\n' | /usr/xpg4/bin/tr '\0' '~' | wc -c}
17529 @end example
17531 @end table
17534 @node Portable Make
17535 @chapter Portable Make Programming
17536 @prindex @command{make}
17537 @cindex Limitations of @command{make}
17539 Writing portable makefiles is an art.  Since a makefile's commands are
17540 executed by the shell, you must consider the shell portability issues
17541 already mentioned.  However, other issues are specific to @command{make}
17542 itself.
17544 @menu
17545 * $< in Ordinary Make Rules::   $< in ordinary rules
17546 * Failure in Make Rules::       Failing portably in rules
17547 * Special Chars in Names::      Special Characters in Macro Names
17548 * Backslash-Newline-Newline::   Empty last lines in macro definitions
17549 * Backslash-Newline Comments::  Spanning comments across line boundaries
17550 * Long Lines in Makefiles::     Line length limitations
17551 * Macros and Submakes::         @code{make macro=value} and submakes
17552 * The Make Macro MAKEFLAGS::    @code{$(MAKEFLAGS)} portability issues
17553 * The Make Macro SHELL::        @code{$(SHELL)} portability issues
17554 * Comments in Make Rules::      Other problems with Make comments
17555 * obj/ and Make::               Don't name a subdirectory @file{obj}
17556 * make -k Status::              Exit status of @samp{make -k}
17557 * VPATH and Make::              @code{VPATH} woes
17558 * Single Suffix Rules::         Single suffix rules and separated dependencies
17559 * Timestamps and Make::         Subsecond timestamp resolution
17560 @end menu
17562 @node $< in Ordinary Make Rules
17563 @section @code{$<} in Ordinary Make Rules
17565 Posix says that the @samp{$<} construct in makefiles can be
17566 used only in inference rules and in the @samp{.DEFAULT} rule; its
17567 meaning in ordinary rules is unspecified.  Solaris @command{make}
17568 for instance replaces it with the empty string.  Open@acronym{BSD} (3.0 and
17569 later) @command{make} diagnoses these uses and errors out.
17571 @node Failure in Make Rules
17572 @section Failure in Make Rules
17574 Posix 2008 requires that @command{make} must invoke each command with
17575 the equivalent of a @samp{sh -e -c} subshell, which causes the
17576 subshell to exit immediately if a subsidiary simple-command fails,
17577 although not all @command{make} implementations have historically
17578 followed this rule.  For
17579 example, the command @samp{touch T; rm -f U} may attempt to
17580 remove @file{U} even if the @command{touch} fails, although this is not
17581 permitted with Posix make.  One way to work around failures in simple
17582 commands is to reword them so that they always succeed, e.g., @samp{touch
17583 T || :; rm -f U}.
17584 However, even this approach can run into common bugs in @acronym{BSD}
17585 implementations of the @option{-e} option of @command{sh} and
17586 @command{set} (@pxref{set, , Limitations of Shell Builtins}), so if you
17587 are worried
17588 about porting to buggy @acronym{BSD} shells it may be simpler to migrate
17589 complicated @command{make} actions into separate scripts.
17591 @node Special Chars in Names
17592 @section Special Characters in Make Macro Names
17594 Posix limits macro names to nonempty strings containing only
17595 @acronym{ASCII} letters and digits, @samp{.}, and @samp{_}.  Many
17596 @command{make} implementations allow a wider variety of characters, but
17597 portable makefiles should avoid them.  It is portable to start a name
17598 with a special character, e.g., @samp{$(.FOO)}.
17600 Some ancient @command{make} implementations don't support leading
17601 underscores in macro names.  An example is @acronym{NEWS-OS} 4.2R.
17603 @example
17604 $ @kbd{cat Makefile}
17605 _am_include = #
17606 _am_quote =
17607 all:; @@echo this is test
17608 $ @kbd{make}
17609 Make: Must be a separator on rules line 2.  Stop.
17610 $ @kbd{cat Makefile2}
17611 am_include = #
17612 am_quote =
17613 all:; @@echo this is test
17614 $ @kbd{make -f Makefile2}
17615 this is test
17616 @end example
17618 @noindent
17619 However, this problem is no longer of practical concern.
17621 @node Backslash-Newline-Newline
17622 @section Backslash-Newline-Newline in Make Macro Values
17624 @c  This has been seen on ia64 hpux 11.20, and on one hppa hpux 10.20,
17625 @c  but another hppa hpux 10.20 didn't have it.  Bob Proulx
17626 @c  <bob@proulx.com> thinks it was in hpux 8.0 too.
17627 On some versions of @acronym{HP-UX}, @command{make} reads multiple newlines
17628 following a backslash, continuing to the next non-empty line.  For
17629 example,
17631 @example
17632 FOO = one \
17634 BAR = two
17636 test:
17637         : FOO is "$(FOO)"
17638         : BAR is "$(BAR)"
17639 @end example
17641 @noindent
17642 shows @code{FOO} equal to @code{one BAR = two}.  Other implementations
17643 sensibly let a backslash continue only to the immediately following
17644 line.
17646 @node Backslash-Newline Comments
17647 @section Backslash-Newline in Make Comments
17649 According to Posix, Make comments start with @code{#}
17650 and continue until an unescaped newline is reached.
17652 @example
17653 $ @kbd{cat Makefile}
17654 # A = foo \
17655       bar \
17656       baz
17658 all:
17659         @@echo ok
17660 $ @kbd{make}   # GNU make
17662 @end example
17664 @noindent
17665 However this is not always the case.  Some implementations
17666 discard everything from @code{#} through the end of the line, ignoring any
17667 trailing backslash.
17669 @example
17670 $ @kbd{pmake}  # BSD make
17671 "Makefile", line 3: Need an operator
17672 Fatal errors encountered -- cannot continue
17673 @end example
17675 @noindent
17676 Therefore, if you want to comment out a multi-line definition, prefix each
17677 line with @code{#}, not only the first.
17679 @example
17680 # A = foo \
17681 #     bar \
17682 #     baz
17683 @end example
17685 @node Long Lines in Makefiles
17686 @section Long Lines in Makefiles
17688 Tru64 5.1's @command{make} has been reported to crash when given a
17689 makefile with lines longer than around 20 kB.  Earlier versions are
17690 reported to exit with @code{Line too long} diagnostics.
17692 @node Macros and Submakes
17693 @section @code{make macro=value} and Submakes
17695 A command-line variable definition such as @code{foo=bar} overrides any
17696 definition of @code{foo} in a makefile.  Some @command{make}
17697 implementations (such as @acronym{GNU} @command{make}) propagate this
17698 override to subsidiary invocations of @command{make}.  Some other
17699 implementations do not pass the substitution along to submakes.
17701 @example
17702 $ @kbd{cat Makefile}
17703 foo = foo
17704 one:
17705         @@echo $(foo)
17706         $(MAKE) two
17707 two:
17708         @@echo $(foo)
17709 $ @kbd{make foo=bar}            # GNU make 3.79.1
17711 make two
17712 make[1]: Entering directory `/home/adl'
17714 make[1]: Leaving directory `/home/adl'
17715 $ @kbd{pmake foo=bar}           # BSD make
17717 pmake two
17719 @end example
17721 You have a few possibilities if you do want the @code{foo=bar} override
17722 to propagate to submakes.  One is to use the @option{-e}
17723 option, which causes all environment variables to have precedence over
17724 the makefile macro definitions, and declare foo as an environment
17725 variable:
17727 @example
17728 $ @kbd{env foo=bar make -e}
17729 @end example
17731 The @option{-e} option is propagated to submakes automatically,
17732 and since the environment is inherited between @command{make}
17733 invocations, the @code{foo} macro is overridden in
17734 submakes as expected.
17736 This syntax (@code{foo=bar make -e}) is portable only when used
17737 outside of a makefile, for instance from a script or from the
17738 command line.  When run inside a @command{make} rule, @acronym{GNU}
17739 @command{make} 3.80 and prior versions forget to propagate the
17740 @option{-e} option to submakes.
17742 Moreover, using @option{-e} could have unexpected side effects if your
17743 environment contains some other macros usually defined by the
17744 makefile.  (See also the note about @code{make -e} and @code{SHELL}
17745 below.)
17747 Another way to propagate overrides to submakes is to do it
17748 manually, from your makefile:
17750 @example
17751 foo = foo
17752 one:
17753         @@echo $(foo)
17754         $(MAKE) foo=$(foo) two
17755 two:
17756         @@echo $(foo)
17757 @end example
17759 You need to foresee all macros that a user might want to override if
17760 you do that.
17762 @node The Make Macro MAKEFLAGS
17763 @section The Make Macro MAKEFLAGS
17764 @cindex @code{MAKEFLAGS} and @command{make}
17765 @cindex @command{make} and @code{MAKEFLAGS}
17767 Posix requires @command{make} to use @code{MAKEFLAGS} to affect the
17768 current and recursive invocations of make, but allows implementations
17769 several formats for the variable.  It is tricky to parse
17770 @code{$MAKEFLAGS} to determine whether @option{-s} for silent execution
17771 or @option{-k} for continued execution are in effect.  For example, you
17772 cannot assume that the first space-separated word in @code{$MAKEFLAGS}
17773 contains single-letter options, since in the Cygwin version of
17774 @acronym{GNU} @command{make} it is either @option{--unix} or
17775 @option{--win32} with the second word containing single-letter options.
17777 @example
17778 $ @kbd{cat Makefile}
17779 all:
17780         @@echo MAKEFLAGS = $(MAKEFLAGS)
17781 $ @kbd{make}
17782 MAKEFLAGS = --unix
17783 $ @kbd{make -k}
17784 MAKEFLAGS = --unix -k
17785 @end example
17787 @node The Make Macro SHELL
17788 @section The Make Macro @code{SHELL}
17789 @cindex @code{SHELL} and @command{make}
17790 @cindex @command{make} and @code{SHELL}
17792 Posix-compliant @command{make} internally uses the @code{$(SHELL)}
17793 macro to spawn shell processes and execute Make rules.  This
17794 is a builtin macro supplied by @command{make}, but it can be modified
17795 by a makefile or by a command-line argument.
17797 Not all @command{make} implementations define this @code{SHELL} macro.
17798 Tru64
17799 @command{make} is an example; this implementation always uses
17800 @code{/bin/sh}.  So it's a good idea to always define @code{SHELL} in
17801 your makefiles.  If you use Autoconf, do
17803 @example
17804 SHELL = @@SHELL@@
17805 @end example
17807 @noindent
17808 If you use Automake, this is done for you.
17810 Do not force @code{SHELL = /bin/sh} because that is not correct
17811 everywhere.  Remember, @file{/bin/sh} is not Posix compliant on many
17812 systems, such as FreeBSD 4, NetBSD 3, AIX 3, Solaris 10, or Tru64.
17813 Additionally, @acronym{DJGPP} lacks @code{/bin/sh}, and when its
17814 @acronym{GNU} @command{make} port sees such a setting it enters a
17815 special emulation mode where features like pipes and redirections are
17816 emulated on top of DOS's @command{command.com}.  Unfortunately this
17817 emulation is incomplete; for instance it does not handle command
17818 substitutions.  Using @code{@@SHELL@@} means that your makefile will
17819 benefit from the same improved shell, such as @command{bash} or
17820 @command{ksh}, that was discovered during @command{configure}, so that
17821 you aren't fighting two different sets of shell bugs between the two
17822 contexts.
17824 Posix-compliant @command{make} should never acquire the value of
17825 $(SHELL) from the environment, even when @code{make -e} is used
17826 (otherwise, think about what would happen to your rules if
17827 @code{SHELL=/bin/tcsh}).
17829 However not all @command{make} implementations have this exception.
17830 For instance it's not surprising that Tru64 @command{make} doesn't
17831 protect @code{SHELL}, since it doesn't use it.
17833 @example
17834 $ @kbd{cat Makefile}
17835 SHELL = /bin/sh
17836 FOO = foo
17837 all:
17838         @@echo $(SHELL)
17839         @@echo $(FOO)
17840 $ @kbd{env SHELL=/bin/tcsh FOO=bar make -e}   # Tru64 Make
17841 /bin/tcsh
17843 $ @kbd{env SHELL=/bin/tcsh FOO=bar gmake -e}  # GNU make
17844 /bin/sh
17846 @end example
17848 Conversely, @command{make} is not supposed to export any changes to the
17849 macro @code{SHELL} to child processes.  Again, many implementations
17850 break this rule:
17852 @example
17853 $ @kbd{cat Makefile}
17854 all:
17855         @@echo $(SHELL)
17856         @@printenv SHELL
17857 $ @kbd{env SHELL=sh make -e SHELL=/bin/ksh}   # BSD Make, GNU make 3.80
17858 /bin/ksh
17859 /bin/ksh
17860 $ @kbd{env SHELL=sh gmake -e SHELL=/bin/ksh}  # GNU make 3.81
17861 /bin/ksh
17863 @end example
17865 @node Comments in Make Rules
17866 @section Comments in Make Rules
17867 @cindex Comments in @file{Makefile} rules
17868 @cindex @file{Makefile} rules and comments
17870 Never put comments in a rule.
17872 Some @command{make} treat anything starting with a tab as a command for
17873 the current rule, even if the tab is immediately followed by a @code{#}.
17874 The @command{make} from Tru64 Unix V5.1 is one of them.  The following
17875 makefile runs @code{# foo} through the shell.
17877 @example
17878 all:
17879         # foo
17880 @end example
17882 @node obj/ and Make
17883 @section The @file{obj/} Subdirectory and Make
17884 @cindex @file{obj/}, subdirectory
17885 @cindex @acronym{BSD} @command{make} and @file{obj/}
17887 Never name one of your subdirectories @file{obj/} if you don't like
17888 surprises.
17890 If an @file{obj/} directory exists, @acronym{BSD} @command{make} enters it
17891 before reading the makefile.  Hence the makefile in the
17892 current directory is not read.
17894 @example
17895 $ @kbd{cat Makefile}
17896 all:
17897         echo Hello
17898 $ @kbd{cat obj/Makefile}
17899 all:
17900         echo World
17901 $ @kbd{make}      # GNU make
17902 echo Hello
17903 Hello
17904 $ @kbd{pmake}     # BSD make
17905 echo World
17906 World
17907 @end example
17909 @node make -k Status
17910 @section Exit Status of @code{make -k}
17911 @cindex @code{make -k}
17913 Do not rely on the exit status of @code{make -k}.  Some implementations
17914 reflect whether they encountered an error in their exit status; other
17915 implementations always succeed.
17917 @example
17918 $ @kbd{cat Makefile}
17919 all:
17920         false
17921 $ @kbd{make -k; echo exit status: $?}    # GNU make
17922 false
17923 make: *** [all] Error 1
17924 exit status: 2
17925 $ @kbd{pmake -k; echo exit status: $?}   # BSD make
17926 false
17927 *** Error code 1 (continuing)
17928 exit status: 0
17929 @end example
17931 @node VPATH and Make
17932 @section @code{VPATH} and Make
17933 @cindex @code{VPATH}
17935 Posix does not specify the semantics of @code{VPATH}.  Typically,
17936 @command{make} supports @code{VPATH}, but its implementation is not
17937 consistent.
17939 Autoconf and Automake support makefiles whose usages of @code{VPATH} are
17940 portable to recent-enough popular implementations of @command{make}, but
17941 to keep the resulting makefiles portable, a package's makefile
17942 prototypes must take the following issues into account.  These issues
17943 are complicated and are often poorly understood, and installers who use
17944 @code{VPATH} should expect to find many bugs in this area.  If you use
17945 @code{VPATH}, the simplest way to avoid these portability bugs is to
17946 stick with @acronym{GNU} @command{make}, since it is the most
17947 commonly-used @command{make} among Autoconf users.
17949 Here are some known issues with some @code{VPATH}
17950 implementations.
17952 @menu
17953 * VPATH and Double-colon::      Problems with @samp{::} on ancient hosts
17954 * $< in Explicit Rules::        @code{$<} does not work in ordinary rules
17955 * Automatic Rule Rewriting::    @code{VPATH} goes wild on Solaris
17956 * Tru64 Directory Magic::       @command{mkdir} goes wild on Tru64
17957 * Make Target Lookup::          More details about @code{VPATH} lookup
17958 @end menu
17960 @node VPATH and Double-colon
17961 @subsection @code{VPATH} and Double-colon Rules
17962 @cindex @code{VPATH} and double-colon rules
17963 @cindex double-colon rules and @code{VPATH}
17965 With ancient versions of Sun @command{make},
17966 any assignment to @code{VPATH} causes @command{make} to execute only
17967 the first set of double-colon rules.
17968 However, this problem is no longer of practical concern.
17970 @node $< in Explicit Rules
17971 @subsection @code{$<} Not Supported in Explicit Rules
17972 @cindex explicit rules, @code{$<}, and @code{VPATH}
17973 @cindex @code{$<}, explicit rules, and @code{VPATH}
17974 @cindex @code{VPATH}, explicit rules, and @code{$<}
17976 Using @code{$<} in explicit rules is not portable.
17977 The prerequisite file must be named explicitly in the rule.  If you want
17978 to find the prerequisite via a @code{VPATH} search, you have to code the
17979 whole thing manually.  @xref{Build Directories}.
17981 @node Automatic Rule Rewriting
17982 @subsection Automatic Rule Rewriting
17983 @cindex @code{VPATH} and automatic rule rewriting
17984 @cindex automatic rule rewriting and @code{VPATH}
17986 Some @command{make} implementations, such as Solaris and Tru64,
17987 search for prerequisites in @code{VPATH} and
17988 then rewrite each occurrence as a plain word in the rule.
17989 For instance:
17991 @example
17992 # This isn't portable to GNU make.
17993 VPATH = ../pkg/src
17994 f.c: if.c
17995         cp if.c f.c
17996 @end example
17998 @noindent
17999 executes @code{cp ../pkg/src/if.c f.c} if @file{if.c} is
18000 found in @file{../pkg/src}.
18002 However, this rule leads to real problems in practice.  For example, if
18003 the source directory contains an ordinary file named @file{test} that is
18004 used in a dependency, Solaris @command{make} rewrites commands like
18005 @samp{if test -r foo; @dots{}} to @samp{if ../pkg/src/test -r foo;
18006 @dots{}}, which is typically undesirable.  To avoid this problem,
18007 portable makefiles should never mention a source file whose name is that
18008 of a shell keyword like @file{until} or a shell command like
18009 @command{cat} or @command{gcc} or @command{test}.
18011 Because of these problems @acronym{GNU} @command{make} and many other
18012 @command{make} implementations do not rewrite commands, so portable
18013 makefiles should
18014 search @code{VPATH} manually.  It is tempting to write this:
18016 @smallexample
18017 # This isn't portable to Solaris make.
18018 VPATH = ../pkg/src
18019 f.c: if.c
18020         cp `test -f if.c || echo $(VPATH)/`if.c f.c
18021 @end smallexample
18023 @noindent
18024 However, the ``prerequisite rewriting'' still applies here.  So if
18025 @file{if.c} is in @file{../pkg/src}, Solaris and Tru64 @command{make}
18026 execute
18028 @smallexample
18029 cp `test -f ../pkg/src/if.c || echo ../pkg/src/`if.c f.c
18030 @end smallexample
18032 @noindent
18033 which reduces to
18035 @example
18036 cp if.c f.c
18037 @end example
18039 @noindent
18040 and thus fails.  Oops.
18042 A simple workaround, and good practice anyway, is to use @samp{$?} and
18043 @samp{$@@} when possible:
18045 @smallexample
18046 VPATH = ../pkg/src
18047 f.c: if.c
18048         cp $? $@@
18049 @end smallexample
18051 @noindent
18052 but this does not generalize well to commands with multiple
18053 prerequisites.  A more general workaround is to rewrite the rule so that
18054 the prerequisite @file{if.c} never appears as a plain word.  For
18055 example, these three rules would be safe, assuming @file{if.c} is in
18056 @file{../pkg/src} and the other files are in the working directory:
18058 @smallexample
18059 VPATH = ../pkg/src
18060 f.c: if.c f1.c
18061         cat `test -f ./if.c || echo $(VPATH)/`if.c f1.c >$@@
18062 g.c: if.c g1.c
18063         cat `test -f 'if.c' || echo $(VPATH)/`if.c g1.c >$@@
18064 h.c: if.c h1.c
18065         cat `test -f "if.c" || echo $(VPATH)/`if.c h1.c >$@@
18066 @end smallexample
18068 Things get worse when your prerequisites are in a macro.
18070 @example
18071 VPATH = ../pkg/src
18072 HEADERS = f.h g.h h.h
18073 install-HEADERS: $(HEADERS)
18074         for i in $(HEADERS); do \
18075           $(INSTALL) -m 644 \
18076             `test -f $$i || echo $(VPATH)/`$$i \
18077             $(DESTDIR)$(includedir)/$$i; \
18078         done
18079 @end example
18081 The above @code{install-HEADERS} rule is not Solaris-proof because @code{for
18082 i in $(HEADERS);} is expanded to @code{for i in f.h g.h h.h;}
18083 where @code{f.h} and @code{g.h} are plain words and are hence
18084 subject to @code{VPATH} adjustments.
18086 If the three files are in @file{../pkg/src}, the rule is run as:
18088 @example
18089 for i in ../pkg/src/f.h ../pkg/src/g.h h.h; do \
18090   install -m 644 \
18091      `test -f $i || echo ../pkg/src/`$i \
18092      /usr/local/include/$i; \
18093 done
18094 @end example
18096 where the two first @command{install} calls fail.  For instance,
18097 consider the @code{f.h} installation:
18099 @example
18100 install -m 644 \
18101   `test -f ../pkg/src/f.h || \
18102     echo ../pkg/src/ \
18103   `../pkg/src/f.h \
18104   /usr/local/include/../pkg/src/f.h;
18105 @end example
18107 @noindent
18108 It reduces to:
18110 @example
18111 install -m 644 \
18112   ../pkg/src/f.h \
18113   /usr/local/include/../pkg/src/f.h;
18114 @end example
18116 Note that the manual @code{VPATH} search did not cause any problems here;
18117 however this command installs @file{f.h} in an incorrect directory.
18119 Trying to quote @code{$(HEADERS)} in some way, as we did for
18120 @code{foo.c} a few makefiles ago, does not help:
18122 @example
18123 install-HEADERS: $(HEADERS)
18124         headers='$(HEADERS)'; \
18125         for i in $$headers; do \
18126           $(INSTALL) -m 644 \
18127             `test -f $$i || echo $(VPATH)/`$$i \
18128             $(DESTDIR)$(includedir)/$$i; \
18129         done
18130 @end example
18132 Now, @code{headers='$(HEADERS)'} macro-expands to:
18134 @example
18135 headers='f.h g.h h.h'
18136 @end example
18138 @noindent
18139 but @code{g.h} is still a plain word.  (As an aside, the idiom
18140 @code{headers='$(HEADERS)'; for i in $$headers;} is a good
18141 idea if @code{$(HEADERS)} can be empty, because some shells diagnose a
18142 syntax error on @code{for i in;}.)
18144 One workaround is to strip this unwanted @file{../pkg/src/} prefix manually:
18146 @example
18147 VPATH = ../pkg/src
18148 HEADERS = f.h g.h h.h
18149 install-HEADERS: $(HEADERS)
18150         headers='$(HEADERS)'; \
18151         for i in $$headers; do \
18152           i=`expr "$$i" : '$(VPATH)/\(.*\)'`;
18153           $(INSTALL) -m 644 \
18154             `test -f $$i || echo $(VPATH)/`$$i \
18155             $(DESTDIR)$(includedir)/$$i; \
18156         done
18157 @end example
18159 Automake does something similar.  However the above hack works only if
18160 the files listed in @code{HEADERS} are in the current directory or a
18161 subdirectory; they should not be in an enclosing directory.  If we had
18162 @code{HEADERS = ../f.h}, the above fragment would fail in a VPATH
18163 build with Tru64 @command{make}.  The reason is that not only does
18164 Tru64 @command{make} rewrite dependencies, but it also simplifies
18165 them.  Hence @code{../f.h} becomes @code{../pkg/f.h} instead of
18166 @code{../pkg/src/../f.h}.  This obviously defeats any attempt to strip
18167 a leading @file{../pkg/src/} component.
18169 The following example makes the behavior of Tru64 @command{make}
18170 more apparent.
18172 @example
18173 $ @kbd{cat Makefile}
18174 VPATH = sub
18175 all: ../foo
18176         echo ../foo
18177 $ @kbd{ls}
18178 Makefile foo
18179 $ @kbd{make}
18180 echo foo
18182 @end example
18184 @noindent
18185 Dependency @file{../foo} was found in @file{sub/../foo}, but Tru64
18186 @command{make} simplified it as @file{foo}.  (Note that the @file{sub/}
18187 directory does not even exist, this just means that the simplification
18188 occurred before the file was checked for.)
18190 For the record here is how SunOS 4 @command{make} behaves on this
18191 example.
18193 @smallexample
18194 $ @kbd{make}
18195 make: Fatal error: Don't know how to make target `../foo'
18196 $ @kbd{mkdir sub}
18197 $ @kbd{make}
18198 echo sub/../foo
18199 sub/../foo
18200 @end smallexample
18203 @node Tru64 Directory Magic
18204 @subsection Tru64 @command{make} Creates Prerequisite Directories Magically
18205 @cindex @code{VPATH} and prerequisite directories
18206 @cindex prerequisite directories and @code{VPATH}
18208 When a prerequisite is a subdirectory of @code{VPATH}, Tru64
18209 @command{make} creates it in the current directory.
18211 @example
18212 $ @kbd{mkdir -p foo/bar build}
18213 $ @kbd{cd build}
18214 $ @kbd{cat >Makefile <<END
18215 VPATH = ..
18216 all: foo/bar
18217 END}
18218 $ @kbd{make}
18219 mkdir foo
18220 mkdir foo/bar
18221 @end example
18223 This can yield unexpected results if a rule uses a manual @code{VPATH}
18224 search as presented before.
18226 @example
18227 VPATH = ..
18228 all : foo/bar
18229         command `test -d foo/bar || echo ../`foo/bar
18230 @end example
18232 The above @command{command} is run on the empty @file{foo/bar}
18233 directory that was created in the current directory.
18235 @node Make Target Lookup
18236 @subsection Make Target Lookup
18237 @cindex @code{VPATH}, resolving target pathnames
18239 @acronym{GNU} @command{make} uses a complex algorithm to decide when it
18240 should use files found via a @code{VPATH} search.  @xref{Search
18241 Algorithm, , How Directory Searches are Performed, make, The @acronym{GNU} Make
18242 Manual}.
18244 If a target needs to be rebuilt, @acronym{GNU} @command{make} discards the
18245 file name found during the @code{VPATH} search for this target, and
18246 builds the file locally using the file name given in the makefile.
18247 If a target does not need to be rebuilt, @acronym{GNU} @command{make} uses the
18248 file name found during the @code{VPATH} search.
18250 Other @command{make} implementations, like Net@acronym{BSD} @command{make}, are
18251 easier to describe: the file name found during the @code{VPATH} search
18252 is used whether the target needs to be rebuilt or not.  Therefore
18253 new files are created locally, but existing files are updated at their
18254 @code{VPATH} location.
18256 Open@acronym{BSD} and Free@acronym{BSD} @command{make}, however,
18257 never perform a
18258 @code{VPATH} search for a dependency that has an explicit rule.
18259 This is extremely annoying.
18261 When attempting a @code{VPATH} build for an autoconfiscated package
18262 (e.g., @code{mkdir build && cd build && ../configure}), this means
18263 @acronym{GNU}
18264 @command{make} builds everything locally in the @file{build}
18265 directory, while @acronym{BSD} @command{make} builds new files locally and
18266 updates existing files in the source directory.
18268 @example
18269 $ @kbd{cat Makefile}
18270 VPATH = ..
18271 all: foo.x bar.x
18272 foo.x bar.x: newer.x
18273         @@echo Building $@@
18274 $ @kbd{touch ../bar.x}
18275 $ @kbd{touch ../newer.x}
18276 $ @kbd{make}        # GNU make
18277 Building foo.x
18278 Building bar.x
18279 $ @kbd{pmake}       # NetBSD make
18280 Building foo.x
18281 Building ../bar.x
18282 $ @kbd{fmake}       # FreeBSD make, OpenBSD make
18283 Building foo.x
18284 Building bar.x
18285 $ @kbd{tmake}       # Tru64 make
18286 Building foo.x
18287 Building bar.x
18288 $ @kbd{touch ../bar.x}
18289 $ @kbd{make}        # GNU make
18290 Building foo.x
18291 $ @kbd{pmake}       # NetBSD make
18292 Building foo.x
18293 $ @kbd{fmake}       # FreeBSD make, OpenBSD make
18294 Building foo.x
18295 Building bar.x
18296 $ @kbd{tmake}       # Tru64 make
18297 Building foo.x
18298 Building bar.x
18299 @end example
18301 Note how Net@acronym{BSD} @command{make} updates @file{../bar.x} in its
18302 VPATH location, and how Free@acronym{BSD}, Open@acronym{BSD}, and Tru64
18303 @command{make} always
18304 update @file{bar.x}, even when @file{../bar.x} is up to date.
18306 Another point worth mentioning is that once @acronym{GNU} @command{make} has
18307 decided to ignore a @code{VPATH} file name (e.g., it ignored
18308 @file{../bar.x} in the above example) it continues to ignore it when
18309 the target occurs as a prerequisite of another rule.
18311 The following example shows that @acronym{GNU} @command{make} does not look up
18312 @file{bar.x} in @code{VPATH} before performing the @code{.x.y} rule,
18313 because it ignored the @code{VPATH} result of @file{bar.x} while running
18314 the @code{bar.x: newer.x} rule.
18316 @example
18317 $ @kbd{cat Makefile}
18318 VPATH = ..
18319 all: bar.y
18320 bar.x: newer.x
18321         @@echo Building $@@
18322 .SUFFIXES: .x .y
18323 .x.y:
18324         cp $< $@@
18325 $ @kbd{touch ../bar.x}
18326 $ @kbd{touch ../newer.x}
18327 $ @kbd{make}        # GNU make
18328 Building bar.x
18329 cp bar.x bar.y
18330 cp: cannot stat `bar.x': No such file or directory
18331 make: *** [bar.y] Error 1
18332 $ @kbd{pmake}       # NetBSD make
18333 Building ../bar.x
18334 cp ../bar.x bar.y
18335 $ @kbd{rm bar.y}
18336 $ @kbd{fmake}       # FreeBSD make, OpenBSD make
18337 echo Building bar.x
18338 cp bar.x bar.y
18339 cp: cannot stat `bar.x': No such file or directory
18340 *** Error code 1
18341 $ @kbd{tmake}       # Tru64 make
18342 Building bar.x
18343 cp: bar.x: No such file or directory
18344 *** Exit 1
18345 @end example
18347 Note that if you drop away the command from the @code{bar.x: newer.x}
18348 rule, @acronym{GNU} @command{make} magically starts to work: it
18349 knows that @code{bar.x} hasn't been updated, therefore it doesn't
18350 discard the result from @code{VPATH} (@file{../bar.x}) in succeeding
18351 uses.  Tru64 also works, but Free@acronym{BSD} and Open@acronym{BSD}
18352 still don't.
18354 @example
18355 $ @kbd{cat Makefile}
18356 VPATH = ..
18357 all: bar.y
18358 bar.x: newer.x
18359 .SUFFIXES: .x .y
18360 .x.y:
18361         cp $< $@@
18362 $ @kbd{touch ../bar.x}
18363 $ @kbd{touch ../newer.x}
18364 $ @kbd{make}        # GNU make
18365 cp ../bar.x bar.y
18366 $ @kbd{rm bar.y}
18367 $ @kbd{pmake}       # NetBSD make
18368 cp ../bar.x bar.y
18369 $ @kbd{rm bar.y}
18370 $ @kbd{fmake}       # FreeBSD make, OpenBSD make
18371 cp bar.x bar.y
18372 cp: cannot stat `bar.x': No such file or directory
18373 *** Error code 1
18374 $ @kbd{tmake}       # Tru64 make
18375 cp ../bar.x bar.y
18376 @end example
18378 It seems the sole solution that would please every @command{make}
18379 implementation is to never rely on @code{VPATH} searches for targets.
18380 In other words, @code{VPATH} should be reserved to unbuilt sources.
18383 @node Single Suffix Rules
18384 @section Single Suffix Rules and Separated Dependencies
18385 @cindex Single Suffix Inference Rule
18386 @cindex Rule, Single Suffix Inference
18387 A @dfn{Single Suffix Rule} is basically a usual suffix (inference) rule
18388 (@samp{.from.to:}), but which @emph{destination} suffix is empty
18389 (@samp{.from:}).
18391 @cindex Separated Dependencies
18392 @dfn{Separated dependencies} simply refers to listing the prerequisite
18393 of a target, without defining a rule.  Usually one can list on the one
18394 hand side, the rules, and on the other hand side, the dependencies.
18396 Solaris @command{make} does not support separated dependencies for
18397 targets defined by single suffix rules:
18399 @example
18400 $ @kbd{cat Makefile}
18401 .SUFFIXES: .in
18402 foo: foo.in
18403 .in:
18404         cp $< $@@
18405 $ @kbd{touch foo.in}
18406 $ @kbd{make}
18407 $ @kbd{ls}
18408 Makefile  foo.in
18409 @end example
18411 @noindent
18412 while @acronym{GNU} Make does:
18414 @example
18415 $ @kbd{gmake}
18416 cp foo.in foo
18417 $ @kbd{ls}
18418 Makefile  foo       foo.in
18419 @end example
18421 Note it works without the @samp{foo: foo.in} dependency.
18423 @example
18424 $ @kbd{cat Makefile}
18425 .SUFFIXES: .in
18426 .in:
18427         cp $< $@@
18428 $ @kbd{make foo}
18429 cp foo.in foo
18430 @end example
18432 @noindent
18433 and it works with double suffix inference rules:
18435 @example
18436 $ @kbd{cat Makefile}
18437 foo.out: foo.in
18438 .SUFFIXES: .in .out
18439 .in.out:
18440         cp $< $@@
18441 $ @kbd{make}
18442 cp foo.in foo.out
18443 @end example
18445 As a result, in such a case, you have to write target rules.
18447 @node Timestamps and Make
18448 @section Timestamp Resolution and Make
18449 @cindex timestamp resolution
18450 Traditionally, file timestamps had 1-second resolution, and
18451 @command{make} used those timestamps to determine whether one file was
18452 newer than the other.  However, many modern file systems have
18453 timestamps with 1-nanosecond resolution.  Some @command{make}
18454 implementations look at the entire timestamp; others ignore the
18455 fractional part, which can lead to incorrect results.  Normally this
18456 is not a problem, but in some extreme cases you may need to use tricks
18457 like @samp{sleep 1} to work around timestamp truncation bugs.
18459 Commands like @samp{cp -p} and @samp{touch -r} typically do not copy
18460 file timestamps to their full resolutions (@pxref{touch, , Limitations of Usual
18461 Tools}).  Hence you should be wary of rules like this:
18463 @example
18464 dest: src
18465         cp -p src dest
18466 @end example
18468 as @file{dest} often appears to be older than @file{src} after the
18469 timestamp is truncated, and this can cause @command{make} to do
18470 needless rework the next time it is invoked.  To work around this
18471 problem, you can use a timestamp file, e.g.:
18473 @example
18474 dest-stamp: src
18475         cp -p src dest
18476         date >dest-stamp
18477 @end example
18482 @c ======================================== Portable C and C++ Programming
18484 @node Portable C and C++
18485 @chapter Portable C and C++ Programming
18486 @cindex Portable C and C++ programming
18488 C and C++ programs often use low-level features of the underlying
18489 system, and therefore are often more difficult to make portable to other
18490 platforms.
18492 Several standards have been developed to help make your programs more
18493 portable.  If you write programs with these standards in mind, you can
18494 have greater confidence that your programs work on a wide variety
18495 of systems.  @xref{Standards, , Language Standards Supported by
18496 @acronym{GCC}, gcc, Using the @acronym{GNU} Compiler Collection
18497 (@acronym{GCC})}, for a list of C-related
18498 standards.  Many programs also assume the
18499 @uref{http://@/www.opengroup.org/@/susv3, Posix standard}.
18501 Some old code is written to be portable to K&R C, which predates any C
18502 standard.  K&R C compilers are no longer of practical interest, though,
18503 and the rest of section assumes at least C89, the first C standard.
18505 Program portability is a huge topic, and this section can only briefly
18506 introduce common pitfalls.  @xref{System Portability, , Portability
18507 between System Types, standards, @acronym{GNU} Coding Standards}, for
18508 more information.
18510 @menu
18511 * Varieties of Unportability::  How to make your programs unportable
18512 * Integer Overflow::            When integers get too large
18513 * Preprocessor Arithmetic::     @code{#if} expression problems
18514 * Null Pointers::               Properties of null pointers
18515 * Buffer Overruns::             Subscript errors and the like
18516 * Volatile Objects::            @code{volatile} and signals
18517 * Floating Point Portability::  Portable floating-point arithmetic
18518 * Exiting Portably::            Exiting and the exit status
18519 @end menu
18521 @node Varieties of Unportability
18522 @section Varieties of Unportability
18523 @cindex portability
18525 Autoconf tests and ordinary programs often need to test what is allowed
18526 on a system, and therefore they may need to deliberately exceed the
18527 boundaries of what the standards allow, if only to see whether an
18528 optional feature is present.  When you write such a program, you should
18529 keep in mind the difference between constraints, unspecified behavior,
18530 and undefined behavior.
18532 In C, a @dfn{constraint} is a rule that the compiler must enforce.  An
18533 example constraint is that C programs must not declare a bit-field with
18534 negative width.  Tests can therefore reliably assume that programs with
18535 negative-width bit-fields are rejected by a compiler that conforms
18536 to the standard.
18538 @dfn{Unspecified behavior} is valid behavior, where the standard allows
18539 multiple possibilities.  For example, the order of evaluation of
18540 function arguments is unspecified.  Some unspecified behavior is
18541 @dfn{implementation-defined}, i.e., documented by the implementation,
18542 but since Autoconf tests cannot read the documentation they cannot
18543 distinguish between implementation-defined and other unspecified
18544 behavior.  It is common for Autoconf tests to probe implementations to
18545 determine otherwise-unspecified behavior.
18547 @dfn{Undefined behavior} is invalid behavior, where the standard allows
18548 the implementation to do anything it pleases.  For example,
18549 dereferencing a null pointer leads to undefined behavior.  If possible,
18550 test programs should avoid undefined behavior, since a program with
18551 undefined behavior might succeed on a test that should fail.
18553 The above rules apply to programs that are intended to conform to the
18554 standard.  However, strictly-conforming programs are quite rare, since
18555 the standards are so limiting.  A major goal of Autoconf is to support
18556 programs that use implementation features not described by the standard,
18557 and it is fairly common for test programs to violate the above rules, if
18558 the programs work well enough in practice.
18560 @node Integer Overflow
18561 @section Integer Overflow
18562 @cindex integer overflow
18563 @cindex overflow, signed integer
18564 @cindex signed integer overflow
18565 @cindex wraparound arithmetic
18567 In practice many portable C programs assume that signed integer overflow wraps
18568 around reliably using two's complement arithmetic.  Yet the C standard
18569 says that program behavior is undefined on overflow, and in a few cases
18570 C programs do not work on some modern implementations because their
18571 overflows do not wrap around as their authors expected.  Conversely, in
18572 signed integer remainder, the C standard requires overflow
18573 behavior that is commonly not implemented.
18575 @menu
18576 * Integer Overflow Basics::      Why integer overflow is a problem
18577 * Signed Overflow Examples::     Examples of code assuming wraparound
18578 * Optimization and Wraparound::  Optimizations that break uses of wraparound
18579 * Signed Overflow Advice::       Practical advice for signed overflow issues
18580 * Signed Integer Division::      @code{INT_MIN / -1} and @code{INT_MIN % -1}
18581 @end menu
18583 @node Integer Overflow Basics
18584 @subsection Basics of Integer Overflow
18585 @cindex integer overflow
18586 @cindex overflow, signed integer
18587 @cindex signed integer overflow
18588 @cindex wraparound arithmetic
18590 In languages like C, unsigned integer overflow reliably wraps around;
18591 e.g., @code{UINT_MAX + 1} yields zero.
18592 This is guaranteed by the C standard and is
18593 portable in practice, unless you specify aggressive,
18594 nonstandard optimization options
18595 suitable only for special applications.
18597 In contrast, the C standard says that signed integer overflow leads to
18598 undefined behavior where a program can do anything, including dumping
18599 core or overrunning a buffer.  The misbehavior can even precede the
18600 overflow.  Such an overflow can occur during addition, subtraction,
18601 multiplication, division, and left shift.
18603 Despite this requirement of the standard, many C programs and Autoconf
18604 tests assume that signed integer overflow silently wraps around modulo a
18605 power of two, using two's complement arithmetic, so long as you cast the
18606 resulting value to a signed integer type or store it into a signed
18607 integer variable.  If you use conservative optimization flags, such
18608 programs are generally portable to the vast majority of modern
18609 platforms, with a few exceptions discussed later.
18611 For historical reasons the C standard also allows implementations with
18612 ones' complement or signed magnitude arithmetic, but it is safe to
18613 assume two's complement nowadays.
18615 Also, overflow can occur when converting an out-of-range value to a
18616 signed integer type.  Here a standard implementation must define what
18617 happens, but this might include raising an exception.  In practice all
18618 known implementations support silent wraparound in this case, so you need
18619 not worry about other possibilities.
18621 @node Signed Overflow Examples
18622 @subsection Examples of Code Assuming Wraparound Overflow
18623 @cindex integer overflow
18624 @cindex overflow, signed integer
18625 @cindex signed integer overflow
18626 @cindex wraparound arithmetic
18628 There has long been a tension between what the C standard requires for
18629 signed integer overflow, and what C programs commonly assume.  The
18630 standard allows aggressive optimizations based on assumptions that
18631 overflow never occurs, but many practical C programs rely on overflow
18632 wrapping around.  These programs do not conform to the standard, but
18633 they commonly work in practice because compiler writers are
18634 understandably reluctant to implement optimizations that would break
18635 many programs, unless perhaps a user specifies aggressive optimization.
18637 The C Standard says that if a program has signed integer overflow its
18638 behavior is undefined, and the undefined behavior can even precede the
18639 overflow.  To take an extreme example:
18641 @c Inspired by Robert Dewar's example in
18642 @c <http://gcc.gnu.org/ml/gcc/2007-01/msg00038.html> (2007-01-01).
18643 @example
18644 if (password == expected_password)
18645   allow_superuser_privileges ();
18646 else if (counter++ == INT_MAX)
18647   abort ();
18648 else
18649   printf ("%d password mismatches\n", counter);
18650 @end example
18652 @noindent
18653 If the @code{int} variable @code{counter} equals @code{INT_MAX},
18654 @code{counter++} must overflow and the behavior is undefined, so the C
18655 standard allows the compiler to optimize away the test against
18656 @code{INT_MAX} and the @code{abort} call.
18657 Worse, if an earlier bug in the program lets the compiler deduce that
18658 @code{counter == INT_MAX} or that @code{counter} previously overflowed,
18659 the C standard allows the compiler to optimize away the password test
18660 and generate code that allows superuser privileges unconditionally.
18662 Despite this requirement by the standard, it has long been common for C
18663 code to assume wraparound arithmetic after signed overflow, and all
18664 known practical C implementations support some C idioms that assume
18665 wraparound signed arithmetic, even if the idioms do not conform
18666 strictly to the standard.  If your code looks like the following
18667 examples it will almost surely work with real-world compilers.
18669 Here is an example derived from the 7th Edition Unix implementation of
18670 @code{atoi} (1979-01-10):
18672 @example
18673 char *p;
18674 int f, n;
18675 @dots{}
18676 while (*p >= '0' && *p <= '9')
18677   n = n * 10 + *p++ - '0';
18678 return (f ? -n : n);
18679 @end example
18681 @noindent
18682 Even if the input string is in range, on most modern machines this has
18683 signed overflow when computing the most negative integer (the @code{-n}
18684 overflows) or a value near an extreme integer (the first @code{+}
18685 overflows).
18687 Here is another example, derived from the 7th Edition implementation of
18688 @code{rand} (1979-01-10).  Here the programmer expects both
18689 multiplication and addition to wrap on overflow:
18691 @example
18692 static long int randx = 1;
18693 @dots{}
18694 randx = randx * 1103515245 + 12345;
18695 return (randx >> 16) & 077777;
18696 @end example
18698 In the following example, derived from the @acronym{GNU} C Library 2.5
18699 implementation of @code{mktime} (2006-09-09), the code assumes
18700 wraparound arithmetic in @code{+} to detect signed overflow:
18702 @example
18703 time_t t, t1, t2;
18704 int sec_requested, sec_adjustment;
18705 @dots{}
18706 t1 = t + sec_requested;
18707 t2 = t1 + sec_adjustment;
18708 if (((t1 < t) != (sec_requested < 0))
18709     | ((t2 < t1) != (sec_adjustment < 0)))
18710   return -1;
18711 @end example
18713 If your code looks like these examples, it is probably safe even though
18714 it does not strictly conform to the C standard.  This might lead one to
18715 believe that one can generally assume wraparound on overflow, but that
18716 is not always true, as can be seen in the next section.
18718 @node Optimization and Wraparound
18719 @subsection Optimizations That Break Wraparound Arithmetic
18720 @cindex loop induction
18722 Compilers sometimes generate code that is incompatible with wraparound
18723 integer arithmetic.  A simple example is an algebraic simplification: a
18724 compiler might translate @code{(i * 2000) / 1000} to @code{i * 2}
18725 because it assumes that @code{i * 2000} does not overflow.  The
18726 translation is not equivalent to the original when overflow occurs:
18727 e.g., in the typical case of 32-bit signed two's complement wraparound
18728 @code{int}, if @code{i} has type @code{int} and value @code{1073742},
18729 the original expression returns @minus{}2147483 but the optimized
18730 version returns the mathematically correct value 2147484.
18732 More subtly, loop induction optimizations often exploit the undefined
18733 behavior of signed overflow.  Consider the following contrived function
18734 @code{sumc}:
18736 @example
18738 sumc (int lo, int hi)
18740   int sum = 0;
18741   int i;
18742   for (i = lo; i <= hi; i++)
18743     sum ^= i * 53;
18744   return sum;
18746 @end example
18748 @noindent
18749 To avoid multiplying by 53 each time through the loop, an optimizing
18750 compiler might internally transform @code{sumc} to the equivalent of the
18751 following:
18753 @example
18755 transformed_sumc (int lo, int hi)
18757   int sum = 0;
18758   int hic = hi * 53;
18759   int ic;
18760   for (ic = lo * 53; ic <= hic; ic += 53)
18761     sum ^= ic;
18762   return sum;
18764 @end example
18766 @noindent
18767 This transformation is allowed by the C standard, but it is invalid for
18768 wraparound arithmetic when @code{INT_MAX / 53 < hi}, because then the
18769 overflow in computing expressions like @code{hi * 53} can cause the
18770 expression @code{i <= hi} to yield a different value from the
18771 transformed expression @code{ic <= hic}.
18773 For this reason, compilers that use loop induction and similar
18774 techniques often do not support reliable wraparound arithmetic when a
18775 loop induction variable like @code{ic} is involved.  Since loop
18776 induction variables are generated by the compiler, and are not visible
18777 in the source code, it is not always trivial to say whether the problem
18778 affects your code.
18780 Hardly any code actually depends on wraparound arithmetic in cases like
18781 these, so in practice these loop induction optimizations are almost
18782 always useful.  However, edge cases in this area can cause problems.
18783 For example:
18785 @example
18786 int j;
18787 for (j = 1; 0 < j; j *= 2)
18788   test (j);
18789 @end example
18791 @noindent
18792 Here, the loop attempts to iterate through all powers of 2 that
18793 @code{int} can represent, but the C standard allows a compiler to
18794 optimize away the comparison and generate an infinite loop,
18795 under the argument that behavior is undefined on overflow.  As of this
18796 writing this optimization is not done by any production version of
18797 @acronym{GCC} with @option{-O2}, but it might be performed by other
18798 compilers, or by more aggressive @acronym{GCC} optimization options,
18799 and the @acronym{GCC} developers have not decided whether it will
18800 continue to work with @acronym{GCC} and @option{-O2}.
18802 @node Signed Overflow Advice
18803 @subsection Practical Advice for Signed Overflow Issues
18804 @cindex integer overflow
18805 @cindex overflow, signed integer
18806 @cindex signed integer overflow
18807 @cindex wraparound arithmetic
18809 Ideally the safest approach is to avoid signed integer overflow
18810 entirely.  For example, instead of multiplying two signed integers, you
18811 can convert them to unsigned integers, multiply the unsigned values,
18812 then test whether the result is in signed range.
18814 Rewriting code in this way will be inconvenient, though, particularly if
18815 the signed values might be negative.  Also, it may hurt
18816 performance.  Using unsigned arithmetic to check for overflow is
18817 particularly painful to do portably and efficiently when dealing with an
18818 integer type like @code{uid_t} whose width and signedness vary from
18819 platform to platform.
18821 Furthermore, many C applications pervasively assume wraparound behavior
18822 and typically it is not easy to find and remove all these assumptions.
18823 Hence it is often useful to maintain nonstandard code that assumes
18824 wraparound on overflow, instead of rewriting the code.  The rest of this
18825 section attempts to give practical advice for this situation.
18827 If your code wants to detect signed integer overflow in @code{sum = a +
18828 b}, it is generally safe to use an expression like @code{(sum < a) != (b
18829 < 0)}.
18831 If your code uses a signed loop index, make sure that the index cannot
18832 overflow, along with all signed expressions derived from the index.
18833 Here is a contrived example of problematic code with two instances of
18834 overflow.
18836 @example
18837 for (i = INT_MAX - 10; i <= INT_MAX; i++)
18838   if (i + 1 < 0)
18839     @{
18840       report_overflow ();
18841       break;
18842     @}
18843 @end example
18845 @noindent
18846 Because of the two overflows, a compiler might optimize away or
18847 transform the two comparisons in a way that is incompatible with the
18848 wraparound assumption.
18850 If your code uses an expression like @code{(i * 2000) / 1000} and you
18851 actually want the multiplication to wrap around on overflow, use
18852 unsigned arithmetic
18853 to do it, e.g., @code{((int) (i * 2000u)) / 1000}.
18855 If your code assumes wraparound behavior and you want to insulate it
18856 against any @acronym{GCC} optimizations that would fail to support that
18857 behavior, you should use @acronym{GCC}'s @option{-fwrapv} option, which
18858 causes signed overflow to wrap around reliably (except for division and
18859 remainder, as discussed in the next section).
18861 If you need to port to platforms where signed integer overflow does not
18862 reliably wrap around (e.g., due to hardware overflow checking, or to
18863 highly aggressive optimizations), you should consider debugging with
18864 @acronym{GCC}'s @option{-ftrapv} option, which causes signed overflow to
18865 raise an exception.
18867 @node Signed Integer Division
18868 @subsection Signed Integer Division and Integer Overflow
18869 @cindex division, integer
18871 Overflow in signed
18872 integer division is not always harmless: for example, on CPUs of the
18873 i386 family, dividing @code{INT_MIN} by @code{-1} yields a SIGFPE signal
18874 which by default terminates the program.  Worse, taking the remainder
18875 of these two values typically yields the same signal on these CPUs,
18876 even though the C standard requires @code{INT_MIN % -1} to yield zero
18877 because the expression does not overflow.
18879 @node Preprocessor Arithmetic
18880 @section Preprocessor Arithmetic
18881 @cindex preprocessor arithmetic
18883 In C99, preprocessor arithmetic, used for @code{#if} expressions, must
18884 be evaluated as if all signed values are of type @code{intmax_t} and all
18885 unsigned values of type @code{uintmax_t}.  Many compilers are buggy in
18886 this area, though.  For example, as of 2007, Sun C mishandles @code{#if
18887 LLONG_MIN < 0} on a platform with 32-bit @code{long int} and 64-bit
18888 @code{long long int}.  Also, some older preprocessors mishandle
18889 constants ending in @code{LL}.  To work around these problems, you can
18890 compute the value of expressions like @code{LONG_MAX < LLONG_MAX} at
18891 @code{configure}-time rather than at @code{#if}-time.
18893 @node Null Pointers
18894 @section Properties of Null Pointers
18895 @cindex null pointers
18897 Most modern hosts reliably fail when you attempt to dereference a null
18898 pointer.
18900 On almost all modern hosts, null pointers use an all-bits-zero internal
18901 representation, so you can reliably use @code{memset} with 0 to set all
18902 the pointers in an array to null values.
18904 If @code{p} is a null pointer to an object type, the C expression
18905 @code{p + 0} always evaluates to @code{p} on modern hosts, even though
18906 the standard says that it has undefined behavior.
18908 @node Buffer Overruns
18909 @section Buffer Overruns and Subscript Errors
18910 @cindex buffer overruns
18912 Buffer overruns and subscript errors are the most common dangerous
18913 errors in C programs.  They result in undefined behavior because storing
18914 outside an array typically modifies storage that is used by some other
18915 object, and most modern systems lack runtime checks to catch these
18916 errors.  Programs should not rely on buffer overruns being caught.
18918 There is one exception to the usual rule that a portable program cannot
18919 address outside an array.  In C, it is valid to compute the address just
18920 past an object, e.g., @code{&a[N]} where @code{a} has @code{N} elements,
18921 so long as you do not dereference the resulting pointer.  But it is not
18922 valid to compute the address just before an object, e.g., @code{&a[-1]};
18923 nor is it valid to compute two past the end, e.g., @code{&a[N+1]}.  On
18924 most platforms @code{&a[-1] < &a[0] && &a[N] < &a[N+1]}, but this is not
18925 reliable in general, and it is usually easy enough to avoid the
18926 potential portability problem, e.g., by allocating an extra unused array
18927 element at the start or end.
18929 @uref{http://@/valgrind.org/, Valgrind} can catch many overruns.
18930 @acronym{GCC}
18931 users might also consider using the @option{-fmudflap} option to catch
18932 overruns.
18934 Buffer overruns are usually caused by off-by-one errors, but there are
18935 more subtle ways to get them.
18937 Using @code{int} values to index into an array or compute array sizes
18938 causes problems on typical 64-bit hosts where an array index might
18939 be @math{2^31} or larger.  Index values of type @code{size_t} avoid this
18940 problem, but cannot be negative.  Index values of type @code{ptrdiff_t}
18941 are signed, and are wide enough in practice.
18943 If you add or multiply two numbers to calculate an array size, e.g.,
18944 @code{malloc (x * sizeof y + z)}, havoc ensues if the addition or
18945 multiplication overflows.
18947 Many implementations of the @code{alloca} function silently misbehave
18948 and can generate buffer overflows if given sizes that are too large.
18949 The size limits are implementation dependent, but are at least 4000
18950 bytes on all platforms that we know about.
18952 The standard functions @code{asctime}, @code{asctime_r}, @code{ctime},
18953 @code{ctime_r}, and @code{gets} are prone to buffer overflows, and
18954 portable code should not use them unless the inputs are known to be
18955 within certain limits.  The time-related functions can overflow their
18956 buffers if given timestamps out of range (e.g., a year less than -999
18957 or greater than 9999).  Time-related buffer overflows cannot happen with
18958 recent-enough versions of the @acronym{GNU} C library, but are possible
18959 with other
18960 implementations.  The @code{gets} function is the worst, since it almost
18961 invariably overflows its buffer when presented with an input line larger
18962 than the buffer.
18964 @node Volatile Objects
18965 @section Volatile Objects
18966 @cindex volatile objects
18968 The keyword @code{volatile} is often misunderstood in portable code.
18969 Its use inhibits some memory-access optimizations, but programmers often
18970 wish that it had a different meaning than it actually does.
18972 @code{volatile} was designed for code that accesses special objects like
18973 memory-mapped device registers whose contents spontaneously change.
18974 Such code is inherently low-level, and it is difficult to specify
18975 portably what @code{volatile} means in these cases.  The C standard
18976 says, ``What constitutes an access to an object that has
18977 volatile-qualified type is implementation-defined,'' so in theory each
18978 implementation is supposed to fill in the gap by documenting what
18979 @code{volatile} means for that implementation.  In practice, though,
18980 this documentation is usually absent or incomplete.
18982 One area of confusion is the distinction between objects defined with
18983 volatile types, and volatile lvalues.  From the C standard's point of
18984 view, an object defined with a volatile type has externally visible
18985 behavior.  You can think of such objects as having little oscilloscope
18986 probes attached to them, so that the user can observe some properties of
18987 accesses to them, just as the user can observe data written to output
18988 files.  However, the standard does not make it clear whether users can
18989 observe accesses by volatile lvalues to ordinary objects.  For example:
18991 @example
18992 /* Declare and access a volatile object.
18993    Accesses to X are "visible" to users.  */
18994 static int volatile x;
18995 x = 1;
18997 /* Access two ordinary objects via a volatile lvalue.
18998    It's not clear whether accesses to *P are "visible".  */
18999 int y;
19000 int *z = malloc (sizeof (int));
19001 int volatile *p;
19002 p = &y;
19003 *p = 1;
19004 p = z;
19005 *p = 1;
19006 @end example
19008 Programmers often wish that @code{volatile} meant ``Perform the memory
19009 access here and now, without merging several memory accesses, without
19010 changing the memory word size, and without reordering.''  But the C
19011 standard does not require this.  For objects defined with a volatile
19012 type, accesses must be done before the next sequence point; but
19013 otherwise merging, reordering, and word-size change is allowed.  Worse,
19014 it is not clear from the standard whether volatile lvalues provide more
19015 guarantees in general than nonvolatile lvalues, if the underlying
19016 objects are ordinary.
19018 Even when accessing objects defined with a volatile type,
19019 the C standard allows only
19020 extremely limited signal handlers: the behavior is undefined if a signal
19021 handler reads any nonlocal object, or writes to any nonlocal object
19022 whose type is not @code{sig_atomic_t volatile}, or calls any standard
19023 library function other than @code{abort}, @code{signal}, and (if C99)
19024 @code{_Exit}.  Hence C compilers need not worry about a signal handler
19025 disturbing ordinary computation, unless the computation accesses a
19026 @code{sig_atomic_t volatile} lvalue that is not a local variable.
19027 (There is an obscure exception for accesses via a pointer to a volatile
19028 character, since it may point into part of a @code{sig_atomic_t
19029 volatile} object.)  Posix
19030 adds to the list of library functions callable from a portable signal
19031 handler, but otherwise is like the C standard in this area.
19033 Some C implementations allow memory-access optimizations within each
19034 translation unit, such that actual behavior agrees with the behavior
19035 required by the standard only when calling a function in some other
19036 translation unit, and a signal handler acts like it was called from a
19037 different translation unit.  The C standard hints that in these
19038 implementations, objects referred to by signal handlers ``would require
19039 explicit specification of @code{volatile} storage, as well as other
19040 implementation-defined restrictions.''  But unfortunately even for this
19041 special case these other restrictions are often not documented well.
19042 @xref{Volatiles, , When is a Volatile Object Accessed?, gcc, Using the
19043 @acronym{GNU} Compiler Collection (@acronym{GCC})}, for some
19044 restrictions imposed by @acronym{GCC}.  @xref{Defining Handlers, ,
19045 Defining Signal Handlers, libc, The @acronym{GNU} C Library}, for some
19046 restrictions imposed by the @acronym{GNU} C library.  Restrictions
19047 differ on other platforms.
19049 If possible, it is best to use a signal handler that fits within the
19050 limits imposed by the C and Posix standards.
19052 If this is not practical, you can try the following rules of thumb.  A
19053 signal handler should access only volatile lvalues, preferably lvalues
19054 that refer to objects defined with a volatile type, and should not
19055 assume that the accessed objects have an internally consistent state
19056 if they are larger than a machine word.  Furthermore, installers
19057 should employ compilers and compiler options that are commonly used
19058 for building operating system kernels, because kernels often need more
19059 from @code{volatile} than the C Standard requires, and installers who
19060 compile an application in a similar environment can sometimes benefit
19061 from the extra constraints imposed by kernels on compilers.
19062 Admittedly we are handwaving somewhat here, as there are few
19063 guarantees in this area; the rules of thumb may help to fix some bugs
19064 but there is a good chance that they will not fix them all.
19066 For @code{volatile}, C++ has the same problems that C does.
19067 Multithreaded applications have even more problems with @code{volatile},
19068 but they are beyond the scope of this section.
19070 The bottom line is that using @code{volatile} typically hurts
19071 performance but should not hurt correctness.  In some cases its use
19072 does help correctness, but these cases are often so poorly understood
19073 that all too often adding @code{volatile} to a data structure merely
19074 alleviates some symptoms of a bug while not fixing the bug in general.
19076 @node Floating Point Portability
19077 @section Floating Point Portability
19078 @cindex floating point
19080 Almost all modern systems use IEEE-754 floating point, and it is safe to
19081 assume IEEE-754 in most portable code these days.  For more information,
19082 please see David Goldberg's classic paper
19083 @uref{http://@/www.validlab.com/@/goldberg/@/paper.pdf, What Every Computer
19084 Scientist Should Know About Floating-Point Arithmetic}.
19086 @node Exiting Portably
19087 @section Exiting Portably
19088 @cindex exiting portably
19090 A C or C++ program can exit with status @var{N} by returning
19091 @var{N} from the @code{main} function.  Portable programs are supposed
19092 to exit either with status 0 or @code{EXIT_SUCCESS} to succeed, or with
19093 status @code{EXIT_FAILURE} to fail, but in practice it is portable to
19094 fail by exiting with status 1, and test programs that assume Posix can
19095 fail by exiting with status values from 1 through 255.  Programs on
19096 SunOS 2.0 (1985) through 3.5.2 (1988) incorrectly exited with zero
19097 status when @code{main} returned nonzero, but ancient systems like these
19098 are no longer of practical concern.
19100 A program can also exit with status @var{N} by passing @var{N} to the
19101 @code{exit} function, and a program can fail by calling the @code{abort}
19102 function.  If a program is specialized to just some platforms, it can fail
19103 by calling functions specific to those platforms, e.g., @code{_exit}
19104 (Posix) and @code{_Exit} (C99).  However, like other functions, an exit
19105 function should be declared, typically by including a header.  For
19106 example, if a C program calls @code{exit}, it should include @file{stdlib.h}
19107 either directly or via the default includes (@pxref{Default Includes}).
19109 A program can fail due to undefined behavior such as dereferencing a null
19110 pointer, but this is not recommended as undefined behavior allows an
19111 implementation to do whatever it pleases and this includes exiting
19112 successfully.
19115 @c ================================================== Manual Configuration
19117 @node Manual Configuration
19118 @chapter Manual Configuration
19120 A few kinds of features can't be guessed automatically by running test
19121 programs.  For example, the details of the object-file format, or
19122 special options that need to be passed to the compiler or linker.  You
19123 can check for such features using ad-hoc means, such as having
19124 @command{configure} check the output of the @code{uname} program, or
19125 looking for libraries that are unique to particular systems.  However,
19126 Autoconf provides a uniform method for handling unguessable features.
19128 @menu
19129 * Specifying Target Triplets::  Specifying target triplets
19130 * Canonicalizing::              Getting the canonical system type
19131 * Using System Type::           What to do with the system type
19132 @end menu
19134 @node Specifying Target Triplets
19135 @section Specifying target triplets
19136 @cindex System type
19137 @cindex Target triplet
19138 @c This node used to be named Specifying Names.  The @anchor allows old
19139 @c links to still work.
19140 @anchor{Specifying Names}
19142 Autoconf-generated
19143 @command{configure} scripts can make decisions based on a canonical name
19144 for the system type, or @dfn{target triplet}, which has the form:
19145 @samp{@var{cpu}-@var{vendor}-@var{os}}, where @var{os} can be
19146 @samp{@var{system}} or @samp{@var{kernel}-@var{system}}
19148 @command{configure} can usually guess the canonical name for the type of
19149 system it's running on.  To do so it runs a script called
19150 @command{config.guess}, which infers the name using the @code{uname}
19151 command or symbols predefined by the C preprocessor.
19153 Alternately, the user can specify the system type with command line
19154 arguments to @command{configure} (@pxref{System Type}.  Doing so is
19155 necessary when
19156 cross-compiling.  In the most complex case of cross-compiling, three
19157 system types are involved.  The options to specify them are:
19159 @table @option
19160 @item --build=@var{build-type}
19161 the type of system on which the package is being configured and
19162 compiled.  It defaults to the result of running @command{config.guess}.
19164 @item --host=@var{host-type}
19165 the type of system on which the package runs.  By default it is the
19166 same as the build machine.  Specifying it enables the cross-compilation
19167 mode.
19169 @item --target=@var{target-type}
19170 the type of system for which any compiler tools in the package
19171 produce code (rarely needed).  By default, it is the same as host.
19172 @end table
19174 If you mean to override the result of @command{config.guess}, use
19175 @option{--build}, not @option{--host}, since the latter enables
19176 cross-compilation.  For historical reasons,
19177 whenever you specify @option{--host},
19178 be sure to specify @option{--build} too; this will be fixed in the
19179 future.  So, to enter cross-compilation mode, use a command like this
19181 @example
19182 ./configure --build=i686-pc-linux-gnu --host=m68k-coff
19183 @end example
19185 @noindent
19186 Note that if you do not specify @option{--host}, @command{configure}
19187 fails if it can't run the code generated by the specified compiler.  For
19188 example, configuring as follows fails:
19190 @example
19191 ./configure CC=m68k-coff-gcc
19192 @end example
19194 When cross-compiling, @command{configure} will warn about any tools
19195 (compilers, linkers, assemblers) whose name is not prefixed with the
19196 host type.  This is an aid to users performing cross-compilation.
19197 Continuing the example above, if a cross-compiler named @command{cc} is
19198 used with a native @command{pkg-config}, then libraries found by
19199 @command{pkg-config} will likely cause subtle build failures; but using
19200 the names @command{m68k-coff-cc} and @command{m68k-coff-pkg-config}
19201 avoids any confusion.  Avoiding the warning is as simple as creating the
19202 correct symlinks naming the cross tools.
19204 @cindex @command{config.sub}
19205 @command{configure} recognizes short aliases for many system types; for
19206 example, @samp{decstation} can be used instead of
19207 @samp{mips-dec-ultrix4.2}.  @command{configure} runs a script called
19208 @command{config.sub} to canonicalize system type aliases.
19210 This section deliberately omits the description of the obsolete
19211 interface; see @ref{Hosts and Cross-Compilation}.
19214 @node Canonicalizing
19215 @section Getting the Canonical System Type
19216 @cindex System type
19217 @cindex Canonical system type
19219 The following macros make the system type available to @command{configure}
19220 scripts.
19222 @ovindex build_alias
19223 @ovindex host_alias
19224 @ovindex target_alias
19226 The variables @samp{build_alias}, @samp{host_alias}, and
19227 @samp{target_alias} are always exactly the arguments of @option{--build},
19228 @option{--host}, and @option{--target}; in particular, they are left empty
19229 if the user did not use them, even if the corresponding
19230 @code{AC_CANONICAL} macro was run.  Any configure script may use these
19231 variables anywhere.  These are the variables that should be used when in
19232 interaction with the user.
19234 If you need to recognize some special environments based on their system
19235 type, run the following macros to get canonical system names.  These
19236 variables are not set before the macro call.
19238 If you use these macros, you must distribute @command{config.guess} and
19239 @command{config.sub} along with your source code.  @xref{Output}, for
19240 information about the @code{AC_CONFIG_AUX_DIR} macro which you can use
19241 to control in which directory @command{configure} looks for those scripts.
19244 @defmac AC_CANONICAL_BUILD
19245 @acindex{CANONICAL_BUILD}
19246 @ovindex build
19247 @ovindex build_cpu
19248 @ovindex build_vendor
19249 @ovindex build_os
19250 Compute the canonical build-system type variable, @code{build}, and its
19251 three individual parts @code{build_cpu}, @code{build_vendor}, and
19252 @code{build_os}.
19254 If @option{--build} was specified, then @code{build} is the
19255 canonicalization of @code{build_alias} by @command{config.sub},
19256 otherwise it is determined by the shell script @command{config.guess}.
19257 @end defmac
19259 @defmac AC_CANONICAL_HOST
19260 @acindex{CANONICAL_HOST}
19261 @ovindex host
19262 @ovindex host_cpu
19263 @ovindex host_vendor
19264 @ovindex host_os
19265 Compute the canonical host-system type variable, @code{host}, and its
19266 three individual parts @code{host_cpu}, @code{host_vendor}, and
19267 @code{host_os}.
19269 If @option{--host} was specified, then @code{host} is the
19270 canonicalization of @code{host_alias} by @command{config.sub},
19271 otherwise it defaults to @code{build}.
19272 @end defmac
19274 @defmac AC_CANONICAL_TARGET
19275 @acindex{CANONICAL_TARGET}
19276 @ovindex target
19277 @ovindex target_cpu
19278 @ovindex target_vendor
19279 @ovindex target_os
19280 Compute the canonical target-system type variable, @code{target}, and its
19281 three individual parts @code{target_cpu}, @code{target_vendor}, and
19282 @code{target_os}.
19284 If @option{--target} was specified, then @code{target} is the
19285 canonicalization of @code{target_alias} by @command{config.sub},
19286 otherwise it defaults to @code{host}.
19287 @end defmac
19289 Note that there can be artifacts due to the backward compatibility
19290 code.  See @xref{Hosts and Cross-Compilation}, for more.
19292 @node Using System Type
19293 @section Using the System Type
19295 In @file{configure.ac} the system type is generally used by one or more
19296 @code{case} statements to select system-specifics.  Shell wildcards can
19297 be used to match a group of system types.
19299 For example, an extra assembler code object file could be chosen, giving
19300 access to a CPU cycle counter register.  @code{$(CYCLE_OBJ)} in the
19301 following would be used in a makefile to add the object to a
19302 program or library.
19304 @example
19305 AS_CASE([$host],
19306   [alpha*-*-*], [CYCLE_OBJ=rpcc.o],
19307   [i?86-*-*],   [CYCLE_OBJ=rdtsc.o],
19308   [CYCLE_OBJ=""]
19310 AC_SUBST([CYCLE_OBJ])
19311 @end example
19313 @code{AC_CONFIG_LINKS} (@pxref{Configuration Links}) is another good way
19314 to select variant source files, for example optimized code for some
19315 CPUs.  The configured CPU type doesn't always indicate exact CPU types,
19316 so some runtime capability checks may be necessary too.
19318 @example
19319 case $host in
19320   alpha*-*-*)   AC_CONFIG_LINKS([dither.c:alpha/dither.c]) ;;
19321   powerpc*-*-*) AC_CONFIG_LINKS([dither.c:powerpc/dither.c]) ;;
19322   *-*-*)        AC_CONFIG_LINKS([dither.c:generic/dither.c]) ;;
19323 esac
19324 @end example
19326 The host system type can also be used to find cross-compilation tools
19327 with @code{AC_CHECK_TOOL} (@pxref{Generic Programs}).
19329 The above examples all show @samp{$host}, since this is where the code
19330 is going to run.  Only rarely is it necessary to test @samp{$build}
19331 (which is where the build is being done).
19333 Whenever you're tempted to use @samp{$host} it's worth considering
19334 whether some sort of probe would be better.  New system types come along
19335 periodically or previously missing features are added.  Well-written
19336 probes can adapt themselves to such things, but hard-coded lists of
19337 names can't.  Here are some guidelines,
19339 @itemize @bullet
19340 @item
19341 Availability of libraries and library functions should always be checked
19342 by probing.
19343 @item
19344 Variant behavior of system calls is best identified with runtime tests
19345 if possible, but bug workarounds or obscure difficulties might have to
19346 be driven from @samp{$host}.
19347 @item
19348 Assembler code is inevitably highly CPU-specific and is best selected
19349 according to @samp{$host_cpu}.
19350 @item
19351 Assembler variations like underscore prefix on globals or ELF versus
19352 COFF type directives are however best determined by probing, perhaps
19353 even examining the compiler output.
19354 @end itemize
19356 @samp{$target} is for use by a package creating a compiler or similar.
19357 For ordinary packages it's meaningless and should not be used.  It
19358 indicates what the created compiler should generate code for, if it can
19359 cross-compile.  @samp{$target} generally selects various hard-coded CPU
19360 and system conventions, since usually the compiler or tools under
19361 construction themselves determine how the target works.
19364 @c ===================================================== Site Configuration.
19366 @node Site Configuration
19367 @chapter Site Configuration
19369 @command{configure} scripts support several kinds of local configuration
19370 decisions.  There are ways for users to specify where external software
19371 packages are, include or exclude optional features, install programs
19372 under modified names, and set default values for @command{configure}
19373 options.
19375 @menu
19376 * Help Formatting::             Customizing @samp{configure --help}
19377 * External Software::           Working with other optional software
19378 * Package Options::             Selecting optional features
19379 * Pretty Help Strings::         Formatting help string
19380 * Option Checking::             Controlling checking of @command{configure} options
19381 * Site Details::                Configuring site details
19382 * Transforming Names::          Changing program names when installing
19383 * Site Defaults::               Giving @command{configure} local defaults
19384 @end menu
19386 @node Help Formatting
19387 @section Controlling Help Output
19389 Users consult @samp{configure --help} to learn of configuration
19390 decisions specific to your package.  By default, @command{configure}
19391 breaks this output into sections for each type of option; within each
19392 section, help strings appear in the order @file{configure.ac} defines
19393 them:
19395 @example
19396 Optional Features:
19397   @dots{}
19398   --enable-bar            include bar
19400 Optional Packages:
19401   @dots{}
19402   --with-foo              use foo
19403 @end example
19405 @defmac AC_PRESERVE_HELP_ORDER
19406 @acindex{PRESERVE_HELP_ORDER}
19408 Request an alternate @option{--help} format, in which options of all
19409 types appear together, in the order defined.  Call this macro before any
19410 @code{AC_ARG_ENABLE} or @code{AC_ARG_WITH}.
19412 @example
19413 Optional Features and Packages:
19414   @dots{}
19415   --enable-bar            include bar
19416   --with-foo              use foo
19417 @end example
19419 @end defmac
19421 @node External Software
19422 @section Working With External Software
19423 @cindex External software
19425 Some packages require, or can optionally use, other software packages
19426 that are already installed.  The user can give @command{configure}
19427 command line options to specify which such external software to use.
19428 The options have one of these forms:
19430 @c FIXME: Can't use @ovar here, Texinfo 4.0 goes lunatic and emits something
19431 @c awful.
19432 @example
19433 --with-@var{package}[=@var{arg}]
19434 --without-@var{package}
19435 @end example
19437 For example, @option{--with-gnu-ld} means work with the @acronym{GNU} linker
19438 instead of some other linker.  @option{--with-x} means work with The X
19439 Window System.
19441 The user can give an argument by following the package name with
19442 @samp{=} and the argument.  Giving an argument of @samp{no} is for
19443 packages that are used by default; it says to @emph{not} use the
19444 package.  An argument that is neither @samp{yes} nor @samp{no} could
19445 include a name or number of a version of the other package, to specify
19446 more precisely which other package this program is supposed to work
19447 with.  If no argument is given, it defaults to @samp{yes}.
19448 @option{--without-@var{package}} is equivalent to
19449 @option{--with-@var{package}=no}.
19451 Normally @command{configure} scripts complain about
19452 @option{--with-@var{package}} options that they do not support.
19453 @xref{Option Checking}, for details, and for how to override the
19454 defaults.
19456 For each external software package that may be used, @file{configure.ac}
19457 should call @code{AC_ARG_WITH} to detect whether the @command{configure}
19458 user asked to use it.  Whether each package is used or not by default,
19459 and which arguments are valid, is up to you.
19461 @anchor{AC_ARG_WITH}
19462 @defmac AC_ARG_WITH (@var{package}, @var{help-string}, @
19463   @ovar{action-if-given}, @ovar{action-if-not-given})
19464 @acindex{ARG_WITH}
19465 If the user gave @command{configure} the option @option{--with-@var{package}}
19466 or @option{--without-@var{package}}, run shell commands
19467 @var{action-if-given}.  If neither option was given, run shell commands
19468 @var{action-if-not-given}.  The name @var{package} indicates another
19469 software package that this program should work with.  It should consist
19470 only of alphanumeric characters, dashes, and dots.
19472 The option's argument is available to the shell commands
19473 @var{action-if-given} in the shell variable @code{withval}, which is
19474 actually just the value of the shell variable named
19475 @code{with_@var{package}}, with any non-alphanumeric characters in
19476 @var{package} changed into @samp{_}.  You may use that variable instead,
19477 if you wish.
19479 The argument @var{help-string} is a description of the option that
19480 looks like this:
19481 @example
19482   --with-readline         support fancy command line editing
19483 @end example
19485 @noindent
19486 @var{help-string} may be more than one line long, if more detail is
19487 needed.  Just make sure the columns line up in @samp{configure
19488 --help}.  Avoid tabs in the help string.  The easiest way to provide the
19489 proper leading whitespace is to format your @var{help-string} with the macro
19490 @code{AS_HELP_STRING} (@pxref{Pretty Help Strings}).
19492 The following example shows how to use the @code{AC_ARG_WITH} macro in
19493 a common situation.  You want to let the user decide whether to enable
19494 support for an external library (e.g., the readline library); if the user
19495 specified neither @option{--with-readline} nor @option{--without-readline},
19496 you want to enable support for readline only if the library is available
19497 on the system.
19499 @c FIXME: Remove AS_IF when the problem of AC_REQUIRE within `if' is solved.
19500 @example
19501 AC_ARG_WITH([readline],
19502   [AS_HELP_STRING([--with-readline],
19503     [support fancy command line editing @@<:@@default=check@@:>@@])],
19504   [],
19505   [with_readline=check])
19507 LIBREADLINE=
19508 AS_IF([test "x$with_readline" != xno],
19509   [AC_CHECK_LIB([readline], [main],
19510     [AC_SUBST([LIBREADLINE], ["-lreadline -lncurses"])
19511      AC_DEFINE([HAVE_LIBREADLINE], [1],
19512                [Define if you have libreadline])
19513     ],
19514     [if test "x$with_readline" != xcheck; then
19515        AC_MSG_FAILURE(
19516          [--with-readline was given, but test for readline failed])
19517      fi
19518     ], -lncurses)])
19519 @end example
19521 The next example shows how to use @code{AC_ARG_WITH} to give the user the
19522 possibility to enable support for the readline library, in case it is still
19523 experimental and not well tested, and is therefore disabled by default.
19525 @c FIXME: Remove AS_IF when the problem of AC_REQUIRE within `if' is solved.
19526 @example
19527 AC_ARG_WITH([readline],
19528   [AS_HELP_STRING([--with-readline],
19529     [enable experimental support for readline])],
19530   [],
19531   [with_readline=no])
19533 LIBREADLINE=
19534 AS_IF([test "x$with_readline" != xno],
19535   [AC_CHECK_LIB([readline], [main],
19536     [AC_SUBST([LIBREADLINE], ["-lreadline -lncurses"])
19537      AC_DEFINE([HAVE_LIBREADLINE], [1],
19538                [Define if you have libreadline])
19539     ],
19540     [AC_MSG_FAILURE(
19541        [--with-readline was given, but test for readline failed])],
19542     [-lncurses])])
19543 @end example
19545 The last example shows how to use @code{AC_ARG_WITH} to give the user the
19546 possibility to disable support for the readline library, given that it is
19547 an important feature and that it should be enabled by default.
19549 @c FIXME: Remove AS_IF when the problem of AC_REQUIRE within `if' is solved.
19550 @example
19551 AC_ARG_WITH([readline],
19552   [AS_HELP_STRING([--without-readline],
19553     [disable support for readline])],
19554   [],
19555   [with_readline=yes])
19557 LIBREADLINE=
19558 AS_IF([test "x$with_readline" != xno],
19559   [AC_CHECK_LIB([readline], [main],
19560     [AC_SUBST([LIBREADLINE], ["-lreadline -lncurses"])
19561      AC_DEFINE([HAVE_LIBREADLINE], [1],
19562                [Define if you have libreadline])
19563     ],
19564     [AC_MSG_FAILURE(
19565        [readline test failed (--without-readline to disable)])],
19566     [-lncurses])])
19567 @end example
19569 These three examples can be easily adapted to the case where
19570 @code{AC_ARG_ENABLE} should be preferred to @code{AC_ARG_WITH} (see
19571 @ref{Package Options}).
19572 @end defmac
19574 @node Package Options
19575 @section Choosing Package Options
19576 @cindex Package options
19577 @cindex Options, package
19579 If a software package has optional compile-time features, the user can
19580 give @command{configure} command line options to specify whether to
19581 compile them.  The options have one of these forms:
19583 @c FIXME: Can't use @ovar here, Texinfo 4.0 goes lunatic and emits something
19584 @c awful.
19585 @example
19586 --enable-@var{feature}[=@var{arg}]
19587 --disable-@var{feature}
19588 @end example
19590 These options allow users to choose which optional features to build and
19591 install.  @option{--enable-@var{feature}} options should never make a
19592 feature behave differently or cause one feature to replace another.
19593 They should only cause parts of the program to be built rather than left
19594 out.
19596 The user can give an argument by following the feature name with
19597 @samp{=} and the argument.  Giving an argument of @samp{no} requests
19598 that the feature @emph{not} be made available.  A feature with an
19599 argument looks like @option{--enable-debug=stabs}.  If no argument is
19600 given, it defaults to @samp{yes}.  @option{--disable-@var{feature}} is
19601 equivalent to @option{--enable-@var{feature}=no}.
19603 Normally @command{configure} scripts complain about
19604 @option{--enable-@var{package}} options that they do not support.
19605 @xref{Option Checking}, for details, and for how to override the
19606 defaults.
19608 For each optional feature, @file{configure.ac} should call
19609 @code{AC_ARG_ENABLE} to detect whether the @command{configure} user asked
19610 to include it.  Whether each feature is included or not by default, and
19611 which arguments are valid, is up to you.
19613 @anchor{AC_ARG_ENABLE}
19614 @defmac AC_ARG_ENABLE (@var{feature}, @var{help-string}, @
19615   @ovar{action-if-given}, @ovar{action-if-not-given})
19616 @acindex{ARG_ENABLE}
19617 If the user gave @command{configure} the option
19618 @option{--enable-@var{feature}} or @option{--disable-@var{feature}}, run
19619 shell commands @var{action-if-given}.  If neither option was given, run
19620 shell commands @var{action-if-not-given}.  The name @var{feature}
19621 indicates an optional user-level facility.  It should consist only of
19622 alphanumeric characters, dashes, and dots.
19624 The option's argument is available to the shell commands
19625 @var{action-if-given} in the shell variable @code{enableval}, which is
19626 actually just the value of the shell variable named
19627 @code{enable_@var{feature}}, with any non-alphanumeric characters in
19628 @var{feature} changed into @samp{_}.  You may use that variable instead,
19629 if you wish.  The @var{help-string} argument is like that of
19630 @code{AC_ARG_WITH} (@pxref{External Software}).
19632 You should format your @var{help-string} with the macro
19633 @code{AS_HELP_STRING} (@pxref{Pretty Help Strings}).
19635 See the examples suggested with the definition of @code{AC_ARG_WITH}
19636 (@pxref{External Software}) to get an idea of possible applications of
19637 @code{AC_ARG_ENABLE}.
19638 @end defmac
19640 @node Pretty Help Strings
19641 @section Making Your Help Strings Look Pretty
19642 @cindex Help strings
19644 Properly formatting the @samp{help strings} which are used in
19645 @code{AC_ARG_WITH} (@pxref{External Software}) and @code{AC_ARG_ENABLE}
19646 (@pxref{Package Options}) can be challenging.  Specifically, you want
19647 your own @samp{help strings} to line up in the appropriate columns of
19648 @samp{configure --help} just like the standard Autoconf @samp{help
19649 strings} do.  This is the purpose of the @code{AS_HELP_STRING} macro.
19651 @anchor{AS_HELP_STRING}
19652 @defmac AS_HELP_STRING (@var{left-hand-side}, @var{right-hand-side} @
19653   @dvar{indent-column, 26}, @dvar{wrap-column, 79})
19654 @asindex{HELP_STRING}
19656 Expands into a help string that looks pretty when the user executes
19657 @samp{configure --help}.  It is typically used in @code{AC_ARG_WITH}
19658 (@pxref{External Software}) or @code{AC_ARG_ENABLE} (@pxref{Package
19659 Options}).  The following example makes this clearer.
19661 @example
19662 AC_ARG_WITH([foo],
19663   [AS_HELP_STRING([--with-foo],
19664      [use foo (default is no)])],
19665   [use_foo=$withval],
19666   [use_foo=no])
19667 @end example
19669 Then the last few lines of @samp{configure --help} appear like
19670 this:
19672 @example
19673 --enable and --with options recognized:
19674   --with-foo              use foo (default is no)
19675 @end example
19677 Macro expansion is performed on the first argument.  However, the second
19678 argument of @code{AS_HELP_STRING} is treated as a whitespace separated
19679 list of text to be reformatted, and is not subject to macro expansion.
19680 Since it is not expanded, it should not be double quoted.
19681 @xref{Autoconf Language}, for a more detailed explanation.
19683 The @code{AS_HELP_STRING} macro is particularly helpful when the
19684 @var{left-hand-side} and/or @var{right-hand-side} are composed of macro
19685 arguments, as shown in the following example.  Be aware that
19686 @var{left-hand-side} may not expand to unbalanced quotes,
19687 although quadrigraphs can be used.
19689 @example
19690 AC_DEFUN([MY_ARG_WITH],
19691   [AC_ARG_WITH(m4_translit([[$1]], [_], [-]),
19692      [AS_HELP_STRING([--with-m4_translit([$1], [_], [-])],
19693                      [use $1 (default is $2)])],
19694      [use_[]$1=$withval],
19695      [use_[]$1=$2])])
19696 MY_ARG_WITH([a_b], [no])
19697 @end example
19698 @noindent
19699 Here, the last few lines of @samp{configure --help} will include:
19701 @example
19702 --enable and --with options recognized:
19703   --with-a-b              use a_b (default is no)
19704 @end example
19706 The parameters @var{indent-column} and @var{wrap-column} were introduced
19707 in Autoconf 2.62.  Generally, they should not be specified; they exist
19708 for fine-tuning of the wrapping.
19709 @example
19710 AS_HELP_STRING([--option], [description of option])
19711 @result{}  --option                description of option
19712 AS_HELP_STRING([--option], [description of option], [15], [30])
19713 @result{}  --option     description of
19714 @result{}               option
19715 @end example
19716 @end defmac
19719 @node Option Checking
19720 @section Controlling Checking of @command{configure} Options
19721 @cindex Options, Package
19723 The @command{configure} script checks its command-line options against a
19724 list of known options, like @option{--help} or @option{--config-cache}.
19725 An unknown option ordinarily indicates a mistake by the user and
19726 @command{configure} halts with an error.  However, by default unknown
19727 @option{--with-@var{package}} and @option{--enable-@var{feature}}
19728 options elicit only a warning, to support configuring entire source
19729 trees.
19731 Source trees often contain multiple packages with a top-level
19732 @command{configure} script that uses the @code{AC_CONFIG_SUBDIRS} macro
19733 (@pxref{Subdirectories}).  Because the packages generally support
19734 different @option{--with-@var{package}} and
19735 @option{--enable-@var{feature}} options, the @acronym{GNU} Coding
19736 Standards say they must accept unrecognized options without halting.
19737 Even a warning message is undesirable here, so @code{AC_CONFIG_SUBDIRS}
19738 automatically disables the warnings.
19740 This default behavior may be modified in two ways.  First, the installer
19741 can invoke @code{configure --disable-option-checking} to disable
19742 these warnings, or invoke @code{configure --enable-option-checking=fatal}
19743 options to turn them into fatal errors, respectively.  Second, the
19744 maintainer can use @code{AC_DISABLE_OPTION_CHECKING}.
19746 @defmac AC_DISABLE_OPTION_CHECKING
19747 @acindex{DISABLE_OPTION_CHECKING}
19749 By default, disable warnings related to any unrecognized
19750 @option{--with-@var{package}} or @option{--enable-@var{feature}}
19751 options.  This is implied by @code{AC_CONFIG_SUBDIRS}.
19753 The installer can override this behavior by passing
19754 @option{--enable-option-checking} (enable warnings) or
19755 @option{--enable-option-checking=fatal} (enable errors) to
19756 @command{configure}.
19757 @end defmac
19760 @node Site Details
19761 @section Configuring Site Details
19762 @cindex Site details
19764 Some software packages require complex site-specific information.  Some
19765 examples are host names to use for certain services, company names, and
19766 email addresses to contact.  Since some configuration scripts generated
19767 by Metaconfig ask for such information interactively, people sometimes
19768 wonder how to get that information in Autoconf-generated configuration
19769 scripts, which aren't interactive.
19771 Such site configuration information should be put in a file that is
19772 edited @emph{only by users}, not by programs.  The location of the file
19773 can either be based on the @code{prefix} variable, or be a standard
19774 location such as the user's home directory.  It could even be specified
19775 by an environment variable.  The programs should examine that file at
19776 runtime, rather than at compile time.  Runtime configuration is more
19777 convenient for users and makes the configuration process simpler than
19778 getting the information while configuring.  @xref{Directory Variables, ,
19779 Variables for Installation Directories, standards, @acronym{GNU} Coding
19780 Standards}, for more information on where to put data files.
19782 @node Transforming Names
19783 @section Transforming Program Names When Installing
19784 @cindex Transforming program names
19785 @cindex Program names, transforming
19787 Autoconf supports changing the names of programs when installing them.
19788 In order to use these transformations, @file{configure.ac} must call the
19789 macro @code{AC_ARG_PROGRAM}.
19791 @defmac AC_ARG_PROGRAM
19792 @acindex{ARG_PROGRAM}
19793 @ovindex program_transform_name
19794 Place in output variable @code{program_transform_name} a sequence of
19795 @code{sed} commands for changing the names of installed programs.
19797 If any of the options described below are given to @command{configure},
19798 program names are transformed accordingly.  Otherwise, if
19799 @code{AC_CANONICAL_TARGET} has been called and a @option{--target} value
19800 is given, the target type followed by a dash is used as a prefix.
19801 Otherwise, no program name transformation is done.
19802 @end defmac
19804 @menu
19805 * Transformation Options::      @command{configure} options to transform names
19806 * Transformation Examples::     Sample uses of transforming names
19807 * Transformation Rules::        Makefile uses of transforming names
19808 @end menu
19810 @node Transformation Options
19811 @subsection Transformation Options
19813 You can specify name transformations by giving @command{configure} these
19814 command line options:
19816 @table @option
19817 @item --program-prefix=@var{prefix}
19818 prepend @var{prefix} to the names;
19820 @item --program-suffix=@var{suffix}
19821 append @var{suffix} to the names;
19823 @item --program-transform-name=@var{expression}
19824 perform @code{sed} substitution @var{expression} on the names.
19825 @end table
19827 @node Transformation Examples
19828 @subsection Transformation Examples
19830 These transformations are useful with programs that can be part of a
19831 cross-compilation development environment.  For example, a
19832 cross-assembler running on a Sun 4 configured with
19833 @option{--target=i960-vxworks} is normally installed as
19834 @file{i960-vxworks-as}, rather than @file{as}, which could be confused
19835 with a native Sun 4 assembler.
19837 You can force a program name to begin with @file{g}, if you don't want
19838 @acronym{GNU} programs installed on your system to shadow other programs with
19839 the same name.  For example, if you configure @acronym{GNU} @code{diff} with
19840 @option{--program-prefix=g}, then when you run @samp{make install} it is
19841 installed as @file{/usr/local/bin/gdiff}.
19843 As a more sophisticated example, you could use
19845 @example
19846 --program-transform-name='s/^/g/; s/^gg/g/; s/^gless/less/'
19847 @end example
19848 @noindent
19850 to prepend @samp{g} to most of the program names in a source tree,
19851 excepting those like @code{gdb} that already have one and those like
19852 @code{less} and @code{lesskey} that aren't @acronym{GNU} programs.  (That is
19853 assuming that you have a source tree containing those programs that is
19854 set up to use this feature.)
19856 One way to install multiple versions of some programs simultaneously is
19857 to append a version number to the name of one or both.  For example, if
19858 you want to keep Autoconf version 1 around for awhile, you can configure
19859 Autoconf version 2 using @option{--program-suffix=2} to install the
19860 programs as @file{/usr/local/bin/autoconf2},
19861 @file{/usr/local/bin/autoheader2}, etc.  Nevertheless, pay attention
19862 that only the binaries are renamed, therefore you'd have problems with
19863 the library files which might overlap.
19865 @node Transformation Rules
19866 @subsection Transformation Rules
19868 Here is how to use the variable @code{program_transform_name} in a
19869 @file{Makefile.in}:
19871 @example
19872 PROGRAMS = cp ls rm
19873 transform = @@program_transform_name@@
19874 install:
19875         for p in $(PROGRAMS); do \
19876           $(INSTALL_PROGRAM) $$p $(DESTDIR)$(bindir)/`echo $$p | \
19877                                               sed '$(transform)'`; \
19878         done
19880 uninstall:
19881         for p in $(PROGRAMS); do \
19882           rm -f $(DESTDIR)$(bindir)/`echo $$p | sed '$(transform)'`; \
19883         done
19884 @end example
19886 It is guaranteed that @code{program_transform_name} is never empty, and
19887 that there are no useless separators.  Therefore you may safely embed
19888 @code{program_transform_name} within a sed program using @samp{;}:
19890 @example
19891 transform = @@program_transform_name@@
19892 transform_exe = s/$(EXEEXT)$$//;$(transform);s/$$/$(EXEEXT)/
19893 @end example
19895 Whether to do the transformations on documentation files (Texinfo or
19896 @code{man}) is a tricky question; there seems to be no perfect answer,
19897 due to the several reasons for name transforming.  Documentation is not
19898 usually particular to a specific architecture, and Texinfo files do not
19899 conflict with system documentation.  But they might conflict with
19900 earlier versions of the same files, and @code{man} pages sometimes do
19901 conflict with system documentation.  As a compromise, it is probably
19902 best to do name transformations on @code{man} pages but not on Texinfo
19903 manuals.
19905 @node Site Defaults
19906 @section Setting Site Defaults
19907 @cindex Site defaults
19908 @cindex config.site
19910 Autoconf-generated @command{configure} scripts allow your site to provide
19911 default values for some configuration values.  You do this by creating
19912 site- and system-wide initialization files.
19914 @evindex CONFIG_SITE
19915 If the environment variable @code{CONFIG_SITE} is set, @command{configure}
19916 uses its value as the name of a shell script to read.  Otherwise, it
19917 reads the shell script @file{@var{prefix}/share/config.site} if it exists,
19918 then @file{@var{prefix}/etc/config.site} if it exists.  Thus,
19919 settings in machine-specific files override those in machine-independent
19920 ones in case of conflict.
19922 Site files can be arbitrary shell scripts, but only certain kinds of
19923 code are really appropriate to be in them.  Because @command{configure}
19924 reads any cache file after it has read any site files, a site file can
19925 define a default cache file to be shared between all Autoconf-generated
19926 @command{configure} scripts run on that system (@pxref{Cache Files}).  If
19927 you set a default cache file in a site file, it is a good idea to also
19928 set the output variable @code{CC} in that site file, because the cache
19929 file is only valid for a particular compiler, but many systems have
19930 several available.
19932 You can examine or override the value set by a command line option to
19933 @command{configure} in a site file; options set shell variables that have
19934 the same names as the options, with any dashes turned into underscores.
19935 The exceptions are that @option{--without-} and @option{--disable-} options
19936 are like giving the corresponding @option{--with-} or @option{--enable-}
19937 option and the value @samp{no}.  Thus, @option{--cache-file=localcache}
19938 sets the variable @code{cache_file} to the value @samp{localcache};
19939 @option{--enable-warnings=no} or @option{--disable-warnings} sets the variable
19940 @code{enable_warnings} to the value @samp{no}; @option{--prefix=/usr} sets the
19941 variable @code{prefix} to the value @samp{/usr}; etc.
19943 Site files are also good places to set default values for other output
19944 variables, such as @code{CFLAGS}, if you need to give them non-default
19945 values: anything you would normally do, repetitively, on the command
19946 line.  If you use non-default values for @var{prefix} or
19947 @var{exec_prefix} (wherever you locate the site file), you can set them
19948 in the site file if you specify it with the @code{CONFIG_SITE}
19949 environment variable.
19951 You can set some cache values in the site file itself.  Doing this is
19952 useful if you are cross-compiling, where it is impossible to check features
19953 that require running a test program.  You could ``prime the cache'' by
19954 setting those values correctly for that system in
19955 @file{@var{prefix}/etc/config.site}.  To find out the names of the cache
19956 variables you need to set, look for shell variables with @samp{_cv_} in
19957 their names in the affected @command{configure} scripts, or in the Autoconf
19958 M4 source code for those macros.
19960 The cache file is careful to not override any variables set in the site
19961 files.  Similarly, you should not override command-line options in the
19962 site files.  Your code should check that variables such as @code{prefix}
19963 and @code{cache_file} have their default values (as set near the top of
19964 @command{configure}) before changing them.
19966 Here is a sample file @file{/usr/share/local/@/gnu/share/@/config.site}.  The
19967 command @samp{configure --prefix=/usr/share/local/gnu} would read this
19968 file (if @code{CONFIG_SITE} is not set to a different file).
19970 @example
19971 # /usr/share/local/gnu/share/config.site for configure
19973 # Change some defaults.
19974 test "$prefix" = NONE && prefix=/usr/share/local/gnu
19975 test "$exec_prefix" = NONE && exec_prefix=/usr/local/gnu
19976 test "$sharedstatedir" = '$@{prefix@}/com' && sharedstatedir=/var
19977 test "$localstatedir" = '$@{prefix@}/var' && localstatedir=/var
19979 # Give Autoconf 2.x generated configure scripts a shared default
19980 # cache file for feature test results, architecture-specific.
19981 if test "$cache_file" = /dev/null; then
19982   cache_file="$prefix/var/config.cache"
19983   # A cache file is only valid for one C compiler.
19984   CC=gcc
19986 @end example
19988 @cindex Filesystem Hierarchy Standard
19989 @cindex FHS
19991 Another use of @file{config.site} is for priming the directory variables
19992 in a manner consistent with the Filesystem Hierarchy Standard
19993 (@acronym{FHS}).  Once the following file is installed at
19994 @file{/usr/share/config.site}, a user can execute simply
19995 @code{./configure --prefix=/usr} to get all the directories chosen in
19996 the locations recommended by @acronym{FHS}.
19998 @example
19999 # /usr/share/config.site for FHS defaults when installing below /usr,
20000 # and the respective settings were not changed on the command line.
20001 if test "$prefix" = /usr; then
20002   test "$sysconfdir" = '$@{prefix@}/etc' && sysconfdir=/etc
20003   test "$sharedstatedir" = '$@{prefix@}/com' && sharedstatedir=/var
20004   test "$localstatedir" = '$@{prefix@}/var' && localstatedir=/var
20006 @end example
20008 @cindex lib64
20009 @cindex 64-bit libraries
20010 Likewise, on platforms where 64-bit libraries are built by default, then
20011 installed in @file{/usr/local/@/lib64} instead of @file{/usr/local/@/lib},
20012 it is appropriate to install @file{/usr/local/@/share/config.site}:
20014 @example
20015 # /usr/local/share/config.site for platforms that prefer
20016 # the directory /usr/local/lib64 over /usr/local/lib.
20017 test "$libdir" = '$@{exec_prefix@}/lib' && libdir='$@{exec_prefix@}/lib64'
20018 @end example
20021 @c ============================================== Running configure Scripts.
20023 @node Running configure Scripts
20024 @chapter Running @command{configure} Scripts
20025 @cindex @command{configure}
20027 Below are instructions on how to configure a package that uses a
20028 @command{configure} script, suitable for inclusion as an @file{INSTALL}
20029 file in the package.  A plain-text version of @file{INSTALL} which you
20030 may use comes with Autoconf.
20032 @menu
20033 * Basic Installation::          Instructions for typical cases
20034 * Compilers and Options::       Selecting compilers and optimization
20035 * Multiple Architectures::      Compiling for multiple architectures at once
20036 * Installation Names::          Installing in different directories
20037 * Optional Features::           Selecting optional features
20038 * Particular Systems::          Particular systems
20039 * System Type::                 Specifying the system type
20040 * Sharing Defaults::            Setting site-wide defaults for @command{configure}
20041 * Defining Variables::          Specifying the compiler etc.
20042 * configure Invocation::        Changing how @command{configure} runs
20043 @end menu
20045 @set autoconf
20046 @include install.texi
20049 @c ============================================== config.status Invocation
20051 @node config.status Invocation
20052 @chapter config.status Invocation
20053 @cindex @command{config.status}
20055 The @command{configure} script creates a file named @file{config.status},
20056 which actually configures, @dfn{instantiates}, the template files.  It
20057 also records the configuration options that were specified when the
20058 package was last configured in case reconfiguring is needed.
20060 Synopsis:
20061 @example
20062 ./config.status @ovar{option}@dots{} @ovar{tag}@dots{}
20063 @end example
20065 It configures each @var{tag}; if none are specified, all the templates
20066 are instantiated.  A @var{tag} refers to a file or other tag associated
20067 with a configuration action, as specified by an @code{AC_CONFIG_@var{ITEMS}}
20068 macro (@pxref{Configuration Actions}).  The files must be specified
20069 without their dependencies, as in
20071 @example
20072 ./config.status foobar
20073 @end example
20075 @noindent
20078 @example
20079 ./config.status foobar:foo.in:bar.in
20080 @end example
20082 The supported options are:
20084 @table @option
20085 @item --help
20086 @itemx -h
20087 Print a summary of the command line options, the list of the template
20088 files, and exit.
20090 @item --version
20091 @itemx -V
20092 Print the version number of Autoconf and the configuration settings,
20093 and exit.
20095 @item --silent
20096 @itemx --quiet
20097 @itemx -q
20098 Do not print progress messages.
20100 @item --debug
20101 @itemx -d
20102 Don't remove the temporary files.
20104 @item --file=@var{file}[:@var{template}]
20105 Require that @var{file} be instantiated as if
20106 @samp{AC_CONFIG_FILES(@var{file}:@var{template})} was used.  Both
20107 @var{file} and @var{template} may be @samp{-} in which case the standard
20108 output and/or standard input, respectively, is used.  If a
20109 @var{template} file name is relative, it is first looked for in the build
20110 tree, and then in the source tree.  @xref{Configuration Actions}, for
20111 more details.
20113 This option and the following ones provide one way for separately
20114 distributed packages to share the values computed by @command{configure}.
20115 Doing so can be useful if some of the packages need a superset of the
20116 features that one of them, perhaps a common library, does.  These
20117 options allow a @file{config.status} file to create files other than the
20118 ones that its @file{configure.ac} specifies, so it can be used for a
20119 different package, or for extracting a subset of values.  For example,
20121 @example
20122 echo '@@CC@@' | ./config.status --file=-
20123 @end example
20125 @noindent
20126 provides the value of @code{@@CC@@} on standard output.
20128 @item --header=@var{file}[:@var{template}]
20129 Same as @option{--file} above, but with @samp{AC_CONFIG_HEADERS}.
20131 @item --recheck
20132 Ask @file{config.status} to update itself and exit (no instantiation).
20133 This option is useful if you change @command{configure}, so that the
20134 results of some tests might be different from the previous run.  The
20135 @option{--recheck} option reruns @command{configure} with the same arguments
20136 you used before, plus the @option{--no-create} option, which prevents
20137 @command{configure} from running @file{config.status} and creating
20138 @file{Makefile} and other files, and the @option{--no-recursion} option,
20139 which prevents @command{configure} from running other @command{configure}
20140 scripts in subdirectories.  (This is so other Make rules can
20141 run @file{config.status} when it changes; @pxref{Automatic Remaking},
20142 for an example).
20143 @end table
20145 @file{config.status} checks several optional environment variables that
20146 can alter its behavior:
20148 @anchor{CONFIG_SHELL}
20149 @defvar CONFIG_SHELL
20150 @evindex CONFIG_SHELL
20151 The shell with which to run @command{configure} for the @option{--recheck}
20152 option.  It must be Bourne-compatible.  The default is a shell that
20153 supports @code{LINENO} if available, and @file{/bin/sh} otherwise.
20154 Invoking @command{configure} by hand bypasses this setting, so you may
20155 need to use a command like @samp{CONFIG_SHELL=/bin/bash /bin/bash ./configure}
20156 to insure that the same shell is used everywhere.  The absolute name of the
20157 shell should be passed.
20158 @end defvar
20160 @defvar CONFIG_STATUS
20161 @evindex CONFIG_STATUS
20162 The file name to use for the shell script that records the
20163 configuration.  The default is @file{./config.status}.  This variable is
20164 useful when one package uses parts of another and the @command{configure}
20165 scripts shouldn't be merged because they are maintained separately.
20166 @end defvar
20168 You can use @file{./config.status} in your makefiles.  For example, in
20169 the dependencies given above (@pxref{Automatic Remaking}),
20170 @file{config.status} is run twice when @file{configure.ac} has changed.
20171 If that bothers you, you can make each run only regenerate the files for
20172 that rule:
20173 @example
20174 @group
20175 config.h: stamp-h
20176 stamp-h: config.h.in config.status
20177         ./config.status config.h
20178         echo > stamp-h
20180 Makefile: Makefile.in config.status
20181         ./config.status Makefile
20182 @end group
20183 @end example
20185 The calling convention of @file{config.status} has changed; see
20186 @ref{Obsolete config.status Use}, for details.
20189 @c =================================================== Obsolete Constructs
20191 @node Obsolete Constructs
20192 @chapter Obsolete Constructs
20193 @cindex Obsolete constructs
20195 Autoconf changes, and throughout the years some constructs have been
20196 obsoleted.  Most of the changes involve the macros, but in some cases
20197 the tools themselves, or even some concepts, are now considered
20198 obsolete.
20200 You may completely skip this chapter if you are new to Autoconf.  Its
20201 intention is mainly to help maintainers updating their packages by
20202 understanding how to move to more modern constructs.
20204 @menu
20205 * Obsolete config.status Use::  Obsolete convention for @command{config.status}
20206 * acconfig Header::             Additional entries in @file{config.h.in}
20207 * autoupdate Invocation::       Automatic update of @file{configure.ac}
20208 * Obsolete Macros::             Backward compatibility macros
20209 * Autoconf 1::                  Tips for upgrading your files
20210 * Autoconf 2.13::               Some fresher tips
20211 @end menu
20213 @node Obsolete config.status Use
20214 @section Obsolete @file{config.status} Invocation
20216 @file{config.status} now supports arguments to specify the files to
20217 instantiate; see @ref{config.status Invocation}, for more details.
20218 Before, environment variables had to be used.
20220 @defvar CONFIG_COMMANDS
20221 @evindex CONFIG_COMMANDS
20222 The tags of the commands to execute.  The default is the arguments given
20223 to @code{AC_OUTPUT} and @code{AC_CONFIG_COMMANDS} in
20224 @file{configure.ac}.
20225 @end defvar
20227 @defvar CONFIG_FILES
20228 @evindex CONFIG_FILES
20229 The files in which to perform @samp{@@@var{variable}@@} substitutions.
20230 The default is the arguments given to @code{AC_OUTPUT} and
20231 @code{AC_CONFIG_FILES} in @file{configure.ac}.
20232 @end defvar
20234 @defvar CONFIG_HEADERS
20235 @evindex CONFIG_HEADERS
20236 The files in which to substitute C @code{#define} statements.  The
20237 default is the arguments given to @code{AC_CONFIG_HEADERS}; if that
20238 macro was not called, @file{config.status} ignores this variable.
20239 @end defvar
20241 @defvar CONFIG_LINKS
20242 @evindex CONFIG_LINKS
20243 The symbolic links to establish.  The default is the arguments given to
20244 @code{AC_CONFIG_LINKS}; if that macro was not called,
20245 @file{config.status} ignores this variable.
20246 @end defvar
20248 In @ref{config.status Invocation}, using this old interface, the example
20249 would be:
20251 @example
20252 @group
20253 config.h: stamp-h
20254 stamp-h: config.h.in config.status
20255         CONFIG_COMMANDS= CONFIG_LINKS= CONFIG_FILES= \
20256           CONFIG_HEADERS=config.h ./config.status
20257         echo > stamp-h
20259 Makefile: Makefile.in config.status
20260         CONFIG_COMMANDS= CONFIG_LINKS= CONFIG_HEADERS= \
20261           CONFIG_FILES=Makefile ./config.status
20262 @end group
20263 @end example
20265 @noindent
20266 (If @file{configure.ac} does not call @code{AC_CONFIG_HEADERS}, there is
20267 no need to set @code{CONFIG_HEADERS} in the @command{make} rules.  Equally
20268 for @code{CONFIG_COMMANDS}, etc.)
20271 @node acconfig Header
20272 @section @file{acconfig.h}
20274 @cindex @file{acconfig.h}
20275 @cindex @file{config.h.top}
20276 @cindex @file{config.h.bot}
20278 In order to produce @file{config.h.in}, @command{autoheader} needs to
20279 build or to find templates for each symbol.  Modern releases of Autoconf
20280 use @code{AH_VERBATIM} and @code{AH_TEMPLATE} (@pxref{Autoheader
20281 Macros}), but in older releases a file, @file{acconfig.h}, contained the
20282 list of needed templates.  @command{autoheader} copied comments and
20283 @code{#define} and @code{#undef} statements from @file{acconfig.h} in
20284 the current directory, if present.  This file used to be mandatory if
20285 you @code{AC_DEFINE} any additional symbols.
20287 Modern releases of Autoconf also provide @code{AH_TOP} and
20288 @code{AH_BOTTOM} if you need to prepend/append some information to
20289 @file{config.h.in}.  Ancient versions of Autoconf had a similar feature:
20290 if @file{./acconfig.h} contains the string @samp{@@TOP@@},
20291 @command{autoheader} copies the lines before the line containing
20292 @samp{@@TOP@@} into the top of the file that it generates.  Similarly,
20293 if @file{./acconfig.h} contains the string @samp{@@BOTTOM@@},
20294 @command{autoheader} copies the lines after that line to the end of the
20295 file it generates.  Either or both of those strings may be omitted.  An
20296 even older alternate way to produce the same effect in ancient versions
20297 of Autoconf is to create the files @file{@var{file}.top} (typically
20298 @file{config.h.top}) and/or @file{@var{file}.bot} in the current
20299 directory.  If they exist, @command{autoheader} copies them to the
20300 beginning and end, respectively, of its output.
20302 In former versions of Autoconf, the files used in preparing a software
20303 package for distribution were:
20304 @example
20305 @group
20306 configure.ac --.   .------> autoconf* -----> configure
20307                +---+
20308 [aclocal.m4] --+   `---.
20309 [acsite.m4] ---'       |
20310                        +--> [autoheader*] -> [config.h.in]
20311 [acconfig.h] ----.     |
20312                  +-----'
20313 [config.h.top] --+
20314 [config.h.bot] --'
20315 @end group
20316 @end example
20318 Using only the @code{AH_} macros, @file{configure.ac} should be
20319 self-contained, and should not depend upon @file{acconfig.h} etc.
20322 @node autoupdate Invocation
20323 @section Using @command{autoupdate} to Modernize @file{configure.ac}
20324 @cindex @command{autoupdate}
20326 The @command{autoupdate} program updates a @file{configure.ac} file that
20327 calls Autoconf macros by their old names to use the current macro names.
20328 In version 2 of Autoconf, most of the macros were renamed to use a more
20329 uniform and descriptive naming scheme.  @xref{Macro Names}, for a
20330 description of the new scheme.  Although the old names still work
20331 (@pxref{Obsolete Macros}, for a list of the old macros and the corresponding
20332 new names), you can make your @file{configure.ac} files more readable
20333 and make it easier to use the current Autoconf documentation if you
20334 update them to use the new macro names.
20336 @evindex SIMPLE_BACKUP_SUFFIX
20337 If given no arguments, @command{autoupdate} updates @file{configure.ac},
20338 backing up the original version with the suffix @file{~} (or the value
20339 of the environment variable @code{SIMPLE_BACKUP_SUFFIX}, if that is
20340 set).  If you give @command{autoupdate} an argument, it reads that file
20341 instead of @file{configure.ac} and writes the updated file to the
20342 standard output.
20344 @noindent
20345 @command{autoupdate} accepts the following options:
20347 @table @option
20348 @item --help
20349 @itemx -h
20350 Print a summary of the command line options and exit.
20352 @item --version
20353 @itemx -V
20354 Print the version number of Autoconf and exit.
20356 @item --verbose
20357 @itemx -v
20358 Report processing steps.
20360 @item --debug
20361 @itemx -d
20362 Don't remove the temporary files.
20364 @item --force
20365 @itemx -f
20366 Force the update even if the file has not changed.  Disregard the cache.
20368 @item --include=@var{dir}
20369 @itemx -I @var{dir}
20370 Also look for input files in @var{dir}.  Multiple invocations accumulate.
20371 Directories are browsed from last to first.
20373 @item --prepend-include=@var{dir}
20374 @itemx -B @var{dir}
20375 Prepend directory @var{dir} to the search path.  This is used to include
20376 the language-specific files before any third-party macros.
20377 @end table
20379 @node Obsolete Macros
20380 @section Obsolete Macros
20382 Several macros are obsoleted in Autoconf, for various reasons (typically
20383 they failed to quote properly, couldn't be extended for more recent
20384 issues, etc.).  They are still supported, but deprecated: their use
20385 should be avoided.
20387 During the jump from Autoconf version 1 to version 2, most of the
20388 macros were renamed to use a more uniform and descriptive naming scheme,
20389 but their signature did not change.  @xref{Macro Names}, for a
20390 description of the new naming scheme.  Below, if there is just the mapping
20391 from old names to new names for these macros, the reader is invited to
20392 refer to the definition of the new macro for the signature and the
20393 description.
20395 @defmac AC_AIX
20396 @acindex{AIX}
20397 @cvindex _ALL_SOURCE
20398 This macro is a platform-specific subset of
20399 @code{AC_USE_SYSTEM_EXTENSIONS} (@pxref{AC_USE_SYSTEM_EXTENSIONS}).
20400 @end defmac
20402 @defmac AC_ALLOCA
20403 @acindex{ALLOCA}
20404 Replaced by @code{AC_FUNC_ALLOCA} (@pxref{AC_FUNC_ALLOCA}).
20405 @end defmac
20407 @defmac AC_ARG_ARRAY
20408 @acindex{ARG_ARRAY}
20409 Removed because of limited usefulness.
20410 @end defmac
20412 @defmac AC_C_CROSS
20413 @acindex{C_CROSS}
20414 This macro is obsolete; it does nothing.
20415 @end defmac
20417 @defmac AC_C_LONG_DOUBLE
20418 @acindex{C_LONG_DOUBLE}
20419 @cvindex HAVE_LONG_DOUBLE
20420 If the C compiler supports a working @code{long double} type with more
20421 range or precision than the @code{double} type, define
20422 @code{HAVE_LONG_DOUBLE}.
20424 You should use @code{AC_TYPE_LONG_DOUBLE} or
20425 @code{AC_TYPE_LONG_DOUBLE_WIDER} instead.  @xref{Particular Types}.
20426 @end defmac
20428 @defmac AC_CANONICAL_SYSTEM
20429 @acindex{CANONICAL_SYSTEM}
20430 Determine the system type and set output variables to the names of the
20431 canonical system types.  @xref{Canonicalizing}, for details about the
20432 variables this macro sets.
20434 The user is encouraged to use either @code{AC_CANONICAL_BUILD}, or
20435 @code{AC_CANONICAL_HOST}, or @code{AC_CANONICAL_TARGET}, depending on
20436 the needs.  Using @code{AC_CANONICAL_TARGET} is enough to run the two
20437 other macros (@pxref{Canonicalizing}).
20438 @end defmac
20440 @defmac AC_CHAR_UNSIGNED
20441 @acindex{CHAR_UNSIGNED}
20442 Replaced by @code{AC_C_CHAR_UNSIGNED} (@pxref{AC_C_CHAR_UNSIGNED}).
20443 @end defmac
20445 @defmac AC_CHECK_TYPE (@var{type}, @var{default})
20446 @acindex{CHECK_TYPE}
20447 Autoconf, up to 2.13, used to provide this version of
20448 @code{AC_CHECK_TYPE}, deprecated because of its flaws.  First, although
20449 it is a member of the @code{CHECK} clan, it does
20450 more than just checking.  Secondly, missing types are defined
20451 using @code{#define}, not @code{typedef}, and this can lead to
20452 problems in the case of pointer types.
20454 This use of @code{AC_CHECK_TYPE} is obsolete and discouraged; see
20455 @ref{Generic Types}, for the description of the current macro.
20457 If the type @var{type} is not defined, define it to be the C (or C++)
20458 builtin type @var{default}, e.g., @samp{short int} or @samp{unsigned int}.
20460 This macro is equivalent to:
20462 @example
20463 AC_CHECK_TYPE([@var{type}], [],
20464   [AC_DEFINE_UNQUOTED([@var{type}], [@var{default}],
20465      [Define to `@var{default}'
20466       if <sys/types.h> does not define.])])
20467 @end example
20469 In order to keep backward compatibility, the two versions of
20470 @code{AC_CHECK_TYPE} are implemented, selected using these heuristics:
20472 @enumerate
20473 @item
20474 If there are three or four arguments, the modern version is used.
20476 @item
20477 If the second argument appears to be a C or C++ type, then the
20478 obsolete version is used.  This happens if the argument is a C or C++
20479 @emph{builtin} type or a C identifier ending in @samp{_t}, optionally
20480 followed by one of @samp{[(* } and then by a string of zero or more
20481 characters taken from the set @samp{[]()* _a-zA-Z0-9}.
20483 @item
20484 If the second argument is spelled with the alphabet of valid C and C++
20485 types, the user is warned and the modern version is used.
20487 @item
20488 Otherwise, the modern version is used.
20489 @end enumerate
20491 @noindent
20492 You are encouraged either to use a valid builtin type, or to use the
20493 equivalent modern code (see above), or better yet, to use
20494 @code{AC_CHECK_TYPES} together with
20496 @example
20497 #ifndef HAVE_LOFF_T
20498 typedef loff_t off_t;
20499 #endif
20500 @end example
20501 @end defmac
20502 @c end of AC_CHECK_TYPE
20504 @defmac AC_CHECKING (@var{feature-description})
20505 @acindex{CHECKING}
20506 Same as
20508 @example
20509 AC_MSG_NOTICE([checking @var{feature-description}@dots{}]
20510 @end example
20512 @noindent
20513 @xref{AC_MSG_NOTICE}.
20514 @end defmac
20516 @defmac AC_COMPILE_CHECK (@var{echo-text}, @var{includes}, @
20517   @var{function-body}, @var{action-if-true}, @ovar{action-if-false})
20518 @acindex{COMPILE_CHECK}
20519 This is an obsolete version of @code{AC_TRY_COMPILE} itself replaced by
20520 @code{AC_COMPILE_IFELSE} (@pxref{Running the Compiler}), with the
20521 addition that it prints @samp{checking for @var{echo-text}} to the
20522 standard output first, if @var{echo-text} is non-empty.  Use
20523 @code{AC_MSG_CHECKING} and @code{AC_MSG_RESULT} instead to print
20524 messages (@pxref{Printing Messages}).
20525 @end defmac
20527 @defmac AC_CONST
20528 @acindex{CONST}
20529 Replaced by @code{AC_C_CONST} (@pxref{AC_C_CONST}).
20530 @end defmac
20532 @defmac AC_CROSS_CHECK
20533 @acindex{CROSS_CHECK}
20534 Same as @code{AC_C_CROSS}, which is obsolete too, and does nothing
20535 @code{:-)}.
20536 @end defmac
20538 @defmac AC_CYGWIN
20539 @acindex{CYGWIN}
20540 @evindex CYGWIN
20541 Check for the Cygwin environment in which case the shell variable
20542 @code{CYGWIN} is set to @samp{yes}.  Don't use this macro, the dignified
20543 means to check the nature of the host is using @code{AC_CANONICAL_HOST}
20544 (@pxref{Canonicalizing}).  As a matter of fact this macro is defined as:
20546 @example
20547 AC_REQUIRE([AC_CANONICAL_HOST])[]dnl
20548 case $host_os in
20549   *cygwin* ) CYGWIN=yes;;
20550          * ) CYGWIN=no;;
20551 esac
20552 @end example
20554 Beware that the variable @env{CYGWIN} has a special meaning when
20555 running Cygwin, and should not be changed.  That's yet another reason
20556 not to use this macro.
20557 @end defmac
20559 @defmac AC_DECL_SYS_SIGLIST
20560 @acindex{DECL_SYS_SIGLIST}
20561 @cvindex SYS_SIGLIST_DECLARED
20562 Same as:
20564 @example
20565 AC_CHECK_DECLS([sys_siglist], [], [],
20566 [#include <signal.h>
20567 /* NetBSD declares sys_siglist in unistd.h.  */
20568 #ifdef HAVE_UNISTD_H
20569 # include <unistd.h>
20570 #endif
20572 @end example
20574 @noindent
20575 @xref{AC_CHECK_DECLS}.
20576 @end defmac
20578 @defmac AC_DECL_YYTEXT
20579 @acindex{DECL_YYTEXT}
20580 Does nothing, now integrated in @code{AC_PROG_LEX} (@pxref{AC_PROG_LEX}).
20581 @end defmac
20583 @defmac AC_DIR_HEADER
20584 @acindex{DIR_HEADER}
20585 @cvindex DIRENT
20586 @cvindex SYSNDIR
20587 @cvindex SYSDIR
20588 @cvindex NDIR
20589 Like calling @code{AC_FUNC_CLOSEDIR_VOID}
20590 (@pxref{AC_FUNC_CLOSEDIR_VOID}) and @code{AC_HEADER_DIRENT}
20591 (@pxref{AC_HEADER_DIRENT}),
20592 but defines a different set of C preprocessor macros to indicate which
20593 header file is found:
20595 @multitable {@file{sys/ndir.h}} {Old Symbol} {@code{HAVE_SYS_NDIR_H}}
20596 @item Header            @tab Old Symbol     @tab New Symbol
20597 @item @file{dirent.h}   @tab @code{DIRENT}  @tab @code{HAVE_DIRENT_H}
20598 @item @file{sys/ndir.h} @tab @code{SYSNDIR} @tab @code{HAVE_SYS_NDIR_H}
20599 @item @file{sys/dir.h}  @tab @code{SYSDIR}  @tab @code{HAVE_SYS_DIR_H}
20600 @item @file{ndir.h}     @tab @code{NDIR}    @tab @code{HAVE_NDIR_H}
20601 @end multitable
20602 @end defmac
20604 @defmac AC_DYNIX_SEQ
20605 @acindex{DYNIX_SEQ}
20606 If on DYNIX/ptx, add @option{-lseq} to output variable
20607 @code{LIBS}.  This macro used to be defined as
20609 @example
20610 AC_CHECK_LIB([seq], [getmntent], [LIBS="-lseq $LIBS"])
20611 @end example
20613 @noindent
20614 now it is just @code{AC_FUNC_GETMNTENT} (@pxref{AC_FUNC_GETMNTENT}).
20615 @end defmac
20617 @defmac AC_EXEEXT
20618 @acindex{EXEEXT}
20619 @ovindex EXEEXT
20620 Defined the output variable @code{EXEEXT} based on the output of the
20621 compiler, which is now done automatically.  Typically set to empty
20622 string if Posix and @samp{.exe} if a @acronym{DOS} variant.
20623 @end defmac
20625 @defmac AC_EMXOS2
20626 @acindex{EMXOS2}
20627 Similar to @code{AC_CYGWIN} but checks for the EMX environment on OS/2
20628 and sets @code{EMXOS2}.  Don't use this macro, the dignified means to
20629 check the nature of the host is using @code{AC_CANONICAL_HOST}
20630 (@pxref{Canonicalizing}).
20631 @end defmac
20633 @defmac AC_ENABLE (@var{feature}, @var{action-if-given}, @
20634   @ovar{action-if-not-given})
20635 @acindex{ENABLE}
20636 This is an obsolete version of @code{AC_ARG_ENABLE} that does not
20637 support providing a help string (@pxref{AC_ARG_ENABLE}).
20638 @end defmac
20640 @defmac AC_ERROR
20641 @acindex{ERROR}
20642 Replaced by @code{AC_MSG_ERROR} (@pxref{AC_MSG_ERROR}).
20643 @end defmac
20645 @defmac AC_FIND_X
20646 @acindex{FIND_X}
20647 Replaced by @code{AC_PATH_X} (@pxref{AC_PATH_X}).
20648 @end defmac
20650 @defmac AC_FIND_XTRA
20651 @acindex{FIND_XTRA}
20652 Replaced by @code{AC_PATH_XTRA} (@pxref{AC_PATH_XTRA}).
20653 @end defmac
20655 @defmac AC_FOREACH
20656 @acindex{FOREACH}
20657 Replaced by @code{m4_foreach_w} (@pxref{m4_foreach_w}).
20658 @end defmac
20660 @defmac AC_FUNC_CHECK
20661 @acindex{FUNC_CHECK}
20662 Replaced by @code{AC_CHECK_FUNC} (@pxref{AC_CHECK_FUNC}).
20663 @end defmac
20665 @anchor{AC_FUNC_SETVBUF_REVERSED}
20666 @defmac AC_FUNC_SETVBUF_REVERSED
20667 @acindex{FUNC_SETVBUF_REVERSED}
20668 @cvindex SETVBUF_REVERSED
20669 @c @fuindex setvbuf
20670 @prindex @code{setvbuf}
20671 Do nothing.  Formerly, this macro checked whether @code{setvbuf} takes
20672 the buffering type as its second argument and the buffer pointer as the
20673 third, instead of the other way around, and defined
20674 @code{SETVBUF_REVERSED}.  However, the last systems to have the problem
20675 were those based on SVR2, which became obsolete in 1987, and the macro
20676 is no longer needed.
20677 @end defmac
20679 @defmac AC_FUNC_WAIT3
20680 @acindex{FUNC_WAIT3}
20681 @cvindex HAVE_WAIT3
20682 @c @fuindex wait3
20683 @prindex @code{wait3}
20684 If @code{wait3} is found and fills in the contents of its third argument
20685 (a @samp{struct rusage *}), which @acronym{HP-UX} does not do, define
20686 @code{HAVE_WAIT3}.
20688 These days portable programs should use @code{waitpid}, not
20689 @code{wait3}, as @code{wait3} has been removed from Posix.
20690 @end defmac
20692 @defmac AC_GCC_TRADITIONAL
20693 @acindex{GCC_TRADITIONAL}
20694 Replaced by @code{AC_PROG_GCC_TRADITIONAL} (@pxref{AC_PROG_GCC_TRADITIONAL}).
20695 @end defmac
20697 @defmac AC_GETGROUPS_T
20698 @acindex{GETGROUPS_T}
20699 Replaced by @code{AC_TYPE_GETGROUPS} (@pxref{AC_TYPE_GETGROUPS}).
20700 @end defmac
20702 @defmac AC_GETLOADAVG
20703 @acindex{GETLOADAVG}
20704 Replaced by @code{AC_FUNC_GETLOADAVG} (@pxref{AC_FUNC_GETLOADAVG}).
20705 @end defmac
20707 @defmac AC_GNU_SOURCE
20708 @acindex{GNU_SOURCE}
20709 @cvindex _GNU_SOURCE
20710 This macro is a platform-specific subset of
20711 @code{AC_USE_SYSTEM_EXTENSIONS} (@pxref{AC_USE_SYSTEM_EXTENSIONS}).
20712 @end defmac
20714 @defmac AC_HAVE_FUNCS
20715 @acindex{HAVE_FUNCS}
20716 Replaced by @code{AC_CHECK_FUNCS} (@pxref{AC_CHECK_FUNCS}).
20717 @end defmac
20719 @defmac AC_HAVE_HEADERS
20720 @acindex{HAVE_HEADERS}
20721 Replaced by @code{AC_CHECK_HEADERS} (@pxref{AC_CHECK_HEADERS}).
20722 @end defmac
20724 @defmac AC_HAVE_LIBRARY (@var{library}, @ovar{action-if-found}, @
20725   @ovar{action-if-not-found}, @ovar{other-libraries})
20726 @acindex{HAVE_LIBRARY}
20727 This macro is equivalent to calling @code{AC_CHECK_LIB} with a
20728 @var{function} argument of @code{main}.  In addition, @var{library} can
20729 be written as any of @samp{foo}, @option{-lfoo}, or @samp{libfoo.a}.  In
20730 all of those cases, the compiler is passed @option{-lfoo}.  However,
20731 @var{library} cannot be a shell variable; it must be a literal name.
20732 @xref{AC_CHECK_LIB}.
20733 @end defmac
20735 @defmac AC_HAVE_POUNDBANG
20736 @acindex{HAVE_POUNDBANG}
20737 Replaced by @code{AC_SYS_INTERPRETER} (@pxref{AC_SYS_INTERPRETER}).
20738 @end defmac
20740 @defmac AC_HEADER_CHECK
20741 @acindex{HEADER_CHECK}
20742 Replaced by @code{AC_CHECK_HEADER} (@pxref{AC_CHECK_HEADER}).
20743 @end defmac
20745 @defmac AC_HEADER_EGREP
20746 @acindex{HEADER_EGREP}
20747 Replaced by @code{AC_EGREP_HEADER} (@pxref{AC_EGREP_HEADER}).
20748 @end defmac
20750 @defmac AC_HELP_STRING
20751 @acindex{HELP_STRING}
20752 Replaced by @code{AS_HELP_STRING} (@pxref{AS_HELP_STRING}).
20753 @end defmac
20755 @defmac AC_INIT (@var{unique-file-in-source-dir})
20756 @acindex{INIT}
20757 Formerly @code{AC_INIT} used to have a single argument, and was
20758 equivalent to:
20760 @example
20761 AC_INIT
20762 AC_CONFIG_SRCDIR(@var{unique-file-in-source-dir})
20763 @end example
20764 See @ref{AC_INIT} and @ref{AC_CONFIG_SRCDIR}.
20765 @end defmac
20767 @defmac AC_INLINE
20768 @acindex{INLINE}
20769 Replaced by @code{AC_C_INLINE} (@pxref{AC_C_INLINE}).
20770 @end defmac
20772 @defmac AC_INT_16_BITS
20773 @acindex{INT_16_BITS}
20774 @cvindex INT_16_BITS
20775 If the C type @code{int} is 16 bits wide, define @code{INT_16_BITS}.
20776 Use @samp{AC_CHECK_SIZEOF(int)} instead (@pxref{AC_CHECK_SIZEOF}).
20777 @end defmac
20779 @defmac AC_IRIX_SUN
20780 @acindex{IRIX_SUN}
20781 If on @sc{irix} (Silicon Graphics Unix), add @option{-lsun} to output
20782 @code{LIBS}.  If you were using it to get @code{getmntent}, use
20783 @code{AC_FUNC_GETMNTENT} instead.  If you used it for the NIS versions
20784 of the password and group functions, use @samp{AC_CHECK_LIB(sun,
20785 getpwnam)}.  Up to Autoconf 2.13, it used to be
20787 @example
20788 AC_CHECK_LIB([sun], [getmntent], [LIBS="-lsun $LIBS"])
20789 @end example
20791 @noindent
20792 now it is defined as
20794 @example
20795 AC_FUNC_GETMNTENT
20796 AC_CHECK_LIB([sun], [getpwnam])
20797 @end example
20799 @noindent
20800 See @ref{AC_FUNC_GETMNTENT} and @ref{AC_CHECK_LIB}.
20801 @end defmac
20803 @defmac AC_ISC_POSIX
20804 @acindex{ISC_POSIX}
20805 @ovindex LIBS
20806 This macro adds @option{-lcposix} to output variable @code{LIBS} if
20807 necessary for Posix facilities.  Sun dropped support for the obsolete
20808 @sc{interactive} Systems Corporation Unix on 2006-07-23.  New programs
20809 need not use this macro.  It is implemented as
20810 @code{AC_SEARCH_LIBS([strerror], [cposix])} (@pxref{AC_SEARCH_LIBS}).
20811 @end defmac
20813 @defmac AC_LANG_C
20814 @acindex{LANG_C}
20815 Same as @samp{AC_LANG([C])} (@pxref{AC_LANG}).
20816 @end defmac
20818 @defmac AC_LANG_CPLUSPLUS
20819 @acindex{LANG_CPLUSPLUS}
20820 Same as @samp{AC_LANG([C++])} (@pxref{AC_LANG}).
20821 @end defmac
20823 @defmac AC_LANG_FORTRAN77
20824 @acindex{LANG_FORTRAN77}
20825 Same as @samp{AC_LANG([Fortran 77])} (@pxref{AC_LANG}).
20826 @end defmac
20828 @defmac AC_LANG_RESTORE
20829 @acindex{LANG_RESTORE}
20830 Select the @var{language} that is saved on the top of the stack, as set
20831 by @code{AC_LANG_SAVE}, remove it from the stack, and call
20832 @code{AC_LANG(@var{language})}.  @xref{Language Choice}, for the
20833 preferred way to change languages.
20834 @end defmac
20836 @defmac AC_LANG_SAVE
20837 @acindex{LANG_SAVE}
20838 Remember the current language (as set by @code{AC_LANG}) on a stack.
20839 The current language does not change.  @code{AC_LANG_PUSH} is preferred
20840 (@pxref{AC_LANG_PUSH}).
20841 @end defmac
20843 @defmac AC_LINK_FILES (@var{source}@dots{}, @var{dest}@dots{})
20844 @acindex{LINK_FILES}
20845 This is an obsolete version of @code{AC_CONFIG_LINKS}
20846 (@pxref{AC_CONFIG_LINKS}.  An updated version of:
20848 @example
20849 AC_LINK_FILES(config/$machine.h config/$obj_format.h,
20850               host.h            object.h)
20851 @end example
20853 @noindent
20856 @example
20857 AC_CONFIG_LINKS([host.h:config/$machine.h
20858                 object.h:config/$obj_format.h])
20859 @end example
20860 @end defmac
20862 @defmac AC_LN_S
20863 @acindex{LN_S}
20864 Replaced by @code{AC_PROG_LN_S} (@pxref{AC_PROG_LN_S}).
20865 @end defmac
20867 @defmac AC_LONG_64_BITS
20868 @acindex{LONG_64_BITS}
20869 @cvindex LONG_64_BITS
20870 Define @code{LONG_64_BITS} if the C type @code{long int} is 64 bits wide.
20871 Use the generic macro @samp{AC_CHECK_SIZEOF([long int])} instead
20872 (@pxref{AC_CHECK_SIZEOF}).
20873 @end defmac
20875 @defmac AC_LONG_DOUBLE
20876 @acindex{LONG_DOUBLE}
20877 If the C compiler supports a working @code{long double} type with more
20878 range or precision than the @code{double} type, define
20879 @code{HAVE_LONG_DOUBLE}.
20881 You should use @code{AC_TYPE_LONG_DOUBLE} or
20882 @code{AC_TYPE_LONG_DOUBLE_WIDER} instead.  @xref{Particular Types}.
20883 @end defmac
20885 @defmac AC_LONG_FILE_NAMES
20886 @acindex{LONG_FILE_NAMES}
20887 Replaced by
20888 @example
20889 AC_SYS_LONG_FILE_NAMES
20890 @end example
20891 @noindent
20892 @xref{AC_SYS_LONG_FILE_NAMES}.
20893 @end defmac
20895 @defmac AC_MAJOR_HEADER
20896 @acindex{MAJOR_HEADER}
20897 Replaced by @code{AC_HEADER_MAJOR} (@pxref{AC_HEADER_MAJOR}).
20898 @end defmac
20900 @defmac AC_MEMORY_H
20901 @acindex{MEMORY_H}
20902 @cvindex NEED_MEMORY_H
20903 Used to define @code{NEED_MEMORY_H} if the @code{mem} functions were
20904 defined in @file{memory.h}.  Today it is equivalent to
20905 @samp{AC_CHECK_HEADERS([memory.h])} (@pxref{AC_CHECK_HEADERS}).  Adjust
20906 your code to depend upon
20907 @code{HAVE_MEMORY_H}, not @code{NEED_MEMORY_H}; see @ref{Standard
20908 Symbols}.
20909 @end defmac
20911 @defmac AC_MINGW32
20912 @acindex{MINGW32}
20913 Similar to @code{AC_CYGWIN} but checks for the MinGW compiler
20914 environment and sets @code{MINGW32}.  Don't use this macro, the
20915 dignified means to check the nature of the host is using
20916 @code{AC_CANONICAL_HOST} (@pxref{Canonicalizing}).
20917 @end defmac
20919 @defmac AC_MINIX
20920 @acindex{MINIX}
20921 @cvindex _MINIX
20922 @cvindex _POSIX_SOURCE
20923 @cvindex _POSIX_1_SOURCE
20924 This macro is a platform-specific subset of
20925 @code{AC_USE_SYSTEM_EXTENSIONS} (@pxref{AC_USE_SYSTEM_EXTENSIONS}).
20926 @end defmac
20928 @defmac AC_MINUS_C_MINUS_O
20929 @acindex{MINUS_C_MINUS_O}
20930 Replaced by @code{AC_PROG_CC_C_O} (@pxref{AC_PROG_CC_C_O}).
20931 @end defmac
20933 @defmac AC_MMAP
20934 @acindex{MMAP}
20935 Replaced by @code{AC_FUNC_MMAP} (@pxref{AC_FUNC_MMAP}).
20936 @end defmac
20938 @defmac AC_MODE_T
20939 @acindex{MODE_T}
20940 Replaced by @code{AC_TYPE_MODE_T} (@pxref{AC_TYPE_MODE_T}).
20941 @end defmac
20943 @defmac AC_OBJEXT
20944 @acindex{OBJEXT}
20945 @ovindex OBJEXT
20946 Defined the output variable @code{OBJEXT} based on the output of the
20947 compiler, after .c files have been excluded.  Typically set to @samp{o}
20948 if Posix, @samp{obj} if a @acronym{DOS} variant.
20949 Now the compiler checking macros handle
20950 this automatically.
20951 @end defmac
20953 @defmac AC_OBSOLETE (@var{this-macro-name}, @ovar{suggestion})
20954 @acindex{OBSOLETE}
20955 Make M4 print a message to the standard error output warning that
20956 @var{this-macro-name} is obsolete, and giving the file and line number
20957 where it was called.  @var{this-macro-name} should be the name of the
20958 macro that is calling @code{AC_OBSOLETE}.  If @var{suggestion} is given,
20959 it is printed at the end of the warning message; for example, it can be
20960 a suggestion for what to use instead of @var{this-macro-name}.
20962 For instance
20964 @example
20965 AC_OBSOLETE([$0], [; use AC_CHECK_HEADERS(unistd.h) instead])dnl
20966 @end example
20968 @noindent
20969 You are encouraged to use @code{AU_DEFUN} instead, since it gives better
20970 services to the user (@pxref{AU_DEFUN}).
20971 @end defmac
20973 @defmac AC_OFF_T
20974 @acindex{OFF_T}
20975 Replaced by @code{AC_TYPE_OFF_T} (@pxref{AC_TYPE_OFF_T}).
20976 @end defmac
20978 @defmac AC_OUTPUT (@ovar{file}@dots{}, @ovar{extra-cmds}, @ovar{init-cmds})
20979 @acindex{OUTPUT}
20980 The use of @code{AC_OUTPUT} with arguments is deprecated.  This obsoleted
20981 interface is equivalent to:
20983 @example
20984 @group
20985 AC_CONFIG_FILES(@var{file}@dots{})
20986 AC_CONFIG_COMMANDS([default],
20987                    @var{extra-cmds}, @var{init-cmds})
20988 AC_OUTPUT
20989 @end group
20990 @end example
20992 @noindent
20993 See @ref{AC_CONFIG_FILES}, @ref{AC_CONFIG_COMMANDS}, and @ref{AC_OUTPUT}.
20994 @end defmac
20996 @defmac AC_OUTPUT_COMMANDS (@var{extra-cmds}, @ovar{init-cmds})
20997 @acindex{OUTPUT_COMMANDS}
20998 Specify additional shell commands to run at the end of
20999 @file{config.status}, and shell commands to initialize any variables
21000 from @command{configure}.  This macro may be called multiple times.  It is
21001 obsolete, replaced by @code{AC_CONFIG_COMMANDS} (@pxref{AC_CONFIG_COMMANDS}).
21003 Here is an unrealistic example:
21005 @example
21006 fubar=27
21007 AC_OUTPUT_COMMANDS([echo this is extra $fubar, and so on.],
21008                    [fubar=$fubar])
21009 AC_OUTPUT_COMMANDS([echo this is another, extra, bit],
21010                    [echo init bit])
21011 @end example
21013 Aside from the fact that @code{AC_CONFIG_COMMANDS} requires an
21014 additional key, an important difference is that
21015 @code{AC_OUTPUT_COMMANDS} is quoting its arguments twice, unlike
21016 @code{AC_CONFIG_COMMANDS}.  This means that @code{AC_CONFIG_COMMANDS}
21017 can safely be given macro calls as arguments:
21019 @example
21020 AC_CONFIG_COMMANDS(foo, [my_FOO()])
21021 @end example
21023 @noindent
21024 Conversely, where one level of quoting was enough for literal strings
21025 with @code{AC_OUTPUT_COMMANDS}, you need two with
21026 @code{AC_CONFIG_COMMANDS}.  The following lines are equivalent:
21028 @example
21029 @group
21030 AC_OUTPUT_COMMANDS([echo "Square brackets: []"])
21031 AC_CONFIG_COMMANDS([default], [[echo "Square brackets: []"]])
21032 @end group
21033 @end example
21034 @end defmac
21036 @defmac AC_PID_T
21037 @acindex{PID_T}
21038 Replaced by @code{AC_TYPE_PID_T} (@pxref{AC_TYPE_PID_T}).
21039 @end defmac
21041 @defmac AC_PREFIX
21042 @acindex{PREFIX}
21043 Replaced by @code{AC_PREFIX_PROGRAM} (@pxref{AC_PREFIX_PROGRAM}).
21044 @end defmac
21046 @defmac AC_PROGRAMS_CHECK
21047 @acindex{PROGRAMS_CHECK}
21048 Replaced by @code{AC_CHECK_PROGS} (@pxref{AC_CHECK_PROGS}).
21049 @end defmac
21051 @defmac AC_PROGRAMS_PATH
21052 @acindex{PROGRAMS_PATH}
21053 Replaced by @code{AC_PATH_PROGS} (@pxref{AC_PATH_PROGS}).
21054 @end defmac
21056 @defmac AC_PROGRAM_CHECK
21057 @acindex{PROGRAM_CHECK}
21058 Replaced by @code{AC_CHECK_PROG} (@pxref{AC_CHECK_PROG}).
21059 @end defmac
21061 @defmac AC_PROGRAM_EGREP
21062 @acindex{PROGRAM_EGREP}
21063 Replaced by @code{AC_EGREP_CPP} (@pxref{AC_EGREP_CPP}).
21064 @end defmac
21066 @defmac AC_PROGRAM_PATH
21067 @acindex{PROGRAM_PATH}
21068 Replaced by @code{AC_PATH_PROG} (@pxref{AC_PATH_PROG}).
21069 @end defmac
21071 @defmac AC_REMOTE_TAPE
21072 @acindex{REMOTE_TAPE}
21073 Removed because of limited usefulness.
21074 @end defmac
21076 @defmac AC_RESTARTABLE_SYSCALLS
21077 @acindex{RESTARTABLE_SYSCALLS}
21078 This macro was renamed @code{AC_SYS_RESTARTABLE_SYSCALLS}.  However,
21079 these days portable programs should use @code{sigaction} with
21080 @code{SA_RESTART} if they want restartable system calls.  They should
21081 not rely on @code{HAVE_RESTARTABLE_SYSCALLS}, since nowadays whether a
21082 system call is restartable is a dynamic issue, not a configuration-time
21083 issue.
21084 @end defmac
21086 @defmac AC_RETSIGTYPE
21087 @acindex{RETSIGTYPE}
21088 Replaced by @code{AC_TYPE_SIGNAL} (@pxref{AC_TYPE_SIGNAL}), which itself
21089 is obsolete when assuming C89 or better.
21090 @end defmac
21092 @defmac AC_RSH
21093 @acindex{RSH}
21094 Removed because of limited usefulness.
21095 @end defmac
21097 @defmac AC_SCO_INTL
21098 @acindex{SCO_INTL}
21099 @ovindex LIBS
21100 If on SCO Unix, add @option{-lintl} to output variable @code{LIBS}.  This
21101 macro used to do this:
21103 @example
21104 AC_CHECK_LIB([intl], [strftime], [LIBS="-lintl $LIBS"])
21105 @end example
21107 @noindent
21108 Now it just calls @code{AC_FUNC_STRFTIME} instead (@pxref{AC_FUNC_STRFTIME}).
21109 @end defmac
21111 @defmac AC_SETVBUF_REVERSED
21112 @acindex{SETVBUF_REVERSED}
21113 Replaced by
21114 @example
21115 AC_FUNC_SETVBUF_REVERSED
21116 @end example
21117 @noindent
21118 @xref{AC_FUNC_SETVBUF_REVERSED}.
21119 @end defmac
21121 @defmac AC_SET_MAKE
21122 @acindex{SET_MAKE}
21123 Replaced by @code{AC_PROG_MAKE_SET} (@pxref{AC_PROG_MAKE_SET}).
21124 @end defmac
21126 @defmac AC_SIZEOF_TYPE
21127 @acindex{SIZEOF_TYPE}
21128 Replaced by @code{AC_CHECK_SIZEOF} (@pxref{AC_CHECK_SIZEOF}).
21129 @end defmac
21131 @defmac AC_SIZE_T
21132 @acindex{SIZE_T}
21133 Replaced by @code{AC_TYPE_SIZE_T} (@pxref{AC_TYPE_SIZE_T}).
21134 @end defmac
21136 @defmac AC_STAT_MACROS_BROKEN
21137 @acindex{STAT_MACROS_BROKEN}
21138 Replaced by @code{AC_HEADER_STAT} (@pxref{AC_HEADER_STAT}).
21139 @end defmac
21141 @defmac AC_STDC_HEADERS
21142 @acindex{STDC_HEADERS}
21143 Replaced by @code{AC_HEADER_STDC} (@pxref{AC_HEADER_STDC}).
21144 @end defmac
21146 @defmac AC_STRCOLL
21147 @acindex{STRCOLL}
21148 Replaced by @code{AC_FUNC_STRCOLL} (@pxref{AC_FUNC_STRCOLL}).
21149 @end defmac
21151 @defmac AC_STRUCT_ST_BLKSIZE
21152 @acindex{STRUCT_ST_BLKSIZE}
21153 @cvindex HAVE_STRUCT_STAT_ST_BLKSIZE
21154 @cvindex HAVE_ST_BLKSIZE
21155 If @code{struct stat} contains an @code{st_blksize} member, define
21156 @code{HAVE_STRUCT_STAT_ST_BLKSIZE}.  The former name,
21157 @code{HAVE_ST_BLKSIZE} is to be avoided, as its support will cease in
21158 the future.  This macro is obsoleted, and should be replaced by
21160 @example
21161 AC_CHECK_MEMBERS([struct stat.st_blksize])
21162 @end example
21163 @noindent
21164 @xref{AC_CHECK_MEMBERS}.
21165 @end defmac
21167 @defmac AC_STRUCT_ST_RDEV
21168 @acindex{STRUCT_ST_RDEV}
21169 @cvindex HAVE_ST_RDEV
21170 @cvindex HAVE_STRUCT_STAT_ST_RDEV
21171 If @code{struct stat} contains an @code{st_rdev} member, define
21172 @code{HAVE_STRUCT_STAT_ST_RDEV}.  The former name for this macro,
21173 @code{HAVE_ST_RDEV}, is to be avoided as it will cease to be supported
21174 in the future.  Actually, even the new macro is obsolete and should be
21175 replaced by:
21176 @example
21177 AC_CHECK_MEMBERS([struct stat.st_rdev])
21178 @end example
21179 @noindent
21180 @xref{AC_CHECK_MEMBERS}.
21181 @end defmac
21183 @defmac AC_ST_BLKSIZE
21184 @acindex{ST_BLKSIZE}
21185 Replaced by @code{AC_CHECK_MEMBERS} (@pxref{AC_CHECK_MEMBERS}).
21186 @end defmac
21188 @defmac AC_ST_BLOCKS
21189 @acindex{ST_BLOCKS}
21190 Replaced by @code{AC_STRUCT_ST_BLOCKS} (@pxref{AC_STRUCT_ST_BLOCKS}).
21191 @end defmac
21193 @defmac AC_ST_RDEV
21194 @acindex{ST_RDEV}
21195 Replaced by @code{AC_CHECK_MEMBERS} (@pxref{AC_CHECK_MEMBERS}).
21196 @end defmac
21198 @defmac AC_SYS_RESTARTABLE_SYSCALLS
21199 @acindex{SYS_RESTARTABLE_SYSCALLS}
21200 @cvindex HAVE_RESTARTABLE_SYSCALLS
21201 If the system automatically restarts a system call that is interrupted
21202 by a signal, define @code{HAVE_RESTARTABLE_SYSCALLS}.  This macro does
21203 not check whether system calls are restarted in general---it checks whether a
21204 signal handler installed with @code{signal} (but not @code{sigaction})
21205 causes system calls to be restarted.  It does not check whether system calls
21206 can be restarted when interrupted by signals that have no handler.
21208 These days portable programs should use @code{sigaction} with
21209 @code{SA_RESTART} if they want restartable system calls.  They should
21210 not rely on @code{HAVE_RESTARTABLE_SYSCALLS}, since nowadays whether a
21211 system call is restartable is a dynamic issue, not a configuration-time
21212 issue.
21213 @end defmac
21215 @defmac AC_SYS_SIGLIST_DECLARED
21216 @acindex{SYS_SIGLIST_DECLARED}
21217 This macro was renamed @code{AC_DECL_SYS_SIGLIST}.  However, even that
21218 name is obsolete, as the same functionality is now acheived via
21219 @code{AC_CHECK_DECLS} (@pxref{AC_CHECK_DECLS}).
21220 @end defmac
21222 @defmac AC_TEST_CPP
21223 @acindex{TEST_CPP}
21224 This macro was renamed @code{AC_TRY_CPP}, which in turn was replaced by
21225 @code{AC_PREPROC_IFELSE} (@pxref{AC_PREPROC_IFELSE}).
21226 @end defmac
21228 @defmac AC_TEST_PROGRAM
21229 @acindex{TEST_PROGRAM}
21230 This macro was renamed @code{AC_TRY_RUN}, which in turn was replaced by
21231 @code{AC_RUN_IFELSE} (@pxref{AC_RUN_IFELSE}).
21232 @end defmac
21234 @defmac AC_TIMEZONE
21235 @acindex{TIMEZONE}
21236 Replaced by @code{AC_STRUCT_TIMEZONE} (@pxref{AC_STRUCT_TIMEZONE}).
21237 @end defmac
21239 @defmac AC_TIME_WITH_SYS_TIME
21240 @acindex{TIME_WITH_SYS_TIME}
21241 Replaced by @code{AC_HEADER_TIME} (@pxref{AC_HEADER_TIME}).
21242 @end defmac
21244 @defmac AC_TRY_COMPILE (@var{includes}, @var{function-body}, @
21245   @ovar{action-if-true}, @ovar{action-if-false})
21246 @acindex{TRY_COMPILE}
21247 Same as:
21249 @example
21250 AC_COMPILE_IFELSE(
21251   [AC_LANG_PROGRAM([[@var{includes}]],
21252      [[@var{function-body}]])],
21253   [@var{action-if-true}],
21254   [@var{action-if-false}])
21255 @end example
21257 @noindent
21258 @xref{Running the Compiler}.
21260 This macro double quotes both @var{includes} and @var{function-body}.
21262 For C and C++, @var{includes} is any @code{#include} statements needed
21263 by the code in @var{function-body} (@var{includes} is ignored if
21264 the currently selected language is Fortran or Fortran 77).  The compiler
21265 and compilation flags are determined by the current language
21266 (@pxref{Language Choice}).
21267 @end defmac
21269 @defmac AC_TRY_CPP (@var{input}, @ovar{action-if-true}, @ovar{action-if-false})
21270 @acindex{TRY_CPP}
21271 Same as:
21273 @example
21274 AC_PREPROC_IFELSE(
21275   [AC_LANG_SOURCE([[@var{input}]])],
21276   [@var{action-if-true}],
21277   [@var{action-if-false}])
21278 @end example
21280 @noindent
21281 @xref{Running the Preprocessor}.
21283 This macro double quotes the @var{input}.
21284 @end defmac
21286 @defmac AC_TRY_LINK (@var{includes}, @var{function-body}, @
21287   @ovar{action-if-true}, @ovar{action-if-false})
21288 @acindex{TRY_LINK}
21289 Same as:
21291 @example
21292 AC_LINK_IFELSE(
21293   [AC_LANG_PROGRAM([[@var{includes}]],
21294      [[@var{function-body}]])],
21295   [@var{action-if-true}],
21296   [@var{action-if-false}])
21297 @end example
21299 @noindent
21300 @xref{Running the Compiler}.
21302 This macro double quotes both @var{includes} and @var{function-body}.
21304 Depending on the current language (@pxref{Language Choice}), create a
21305 test program to see whether a function whose body consists of
21306 @var{function-body} can be compiled and linked.  If the file compiles
21307 and links successfully, run shell commands @var{action-if-found},
21308 otherwise run @var{action-if-not-found}.
21310 This macro double quotes both @var{includes} and @var{function-body}.
21312 For C and C++, @var{includes} is any @code{#include} statements needed
21313 by the code in @var{function-body} (@var{includes} is ignored if
21314 the currently selected language is Fortran or Fortran 77).  The compiler
21315 and compilation flags are determined by the current language
21316 (@pxref{Language Choice}), and in addition @code{LDFLAGS} and
21317 @code{LIBS} are used for linking.
21318 @end defmac
21320 @defmac AC_TRY_LINK_FUNC (@var{function}, @ovar{action-if-found}, @
21321   @ovar{action-if-not-found})
21322 @acindex{TRY_LINK_FUNC}
21323 This macro is equivalent to
21324 @example
21325 AC_LINK_IFELSE([AC_LANG_CALL([], [@var{function}])],
21326   [@var{action-if-found}], [@var{action-if-not-found}])
21327 @end example
21328 @noindent
21329 @xref{AC_LINK_IFELSE}.
21330 @end defmac
21332 @defmac AC_TRY_RUN (@var{program}, @ovar{action-if-true}, @
21333   @ovar{action-if-false}, @ovar{action-if-cross-compiling})
21334 @acindex{TRY_RUN}
21335 Same as:
21337 @example
21338 AC_RUN_IFELSE(
21339   [AC_LANG_SOURCE([[@var{program}]])],
21340   [@var{action-if-true}],
21341   [@var{action-if-false}],
21342   [@var{action-if-cross-compiling}])
21343 @end example
21345 @noindent
21346 @xref{Runtime}.
21347 @end defmac
21349 @anchor{AC_TYPE_SIGNAL}
21350 @defmac AC_TYPE_SIGNAL
21351 @acindex{TYPE_SIGNAL}
21352 @cvindex RETSIGTYPE
21353 @hdrindex{signal.h}
21354 If @file{signal.h} declares @code{signal} as returning a pointer to a
21355 function returning @code{void}, define @code{RETSIGTYPE} to be
21356 @code{void}; otherwise, define it to be @code{int}.  These days, it is
21357 portable to assume C89, and that signal handlers return @code{void},
21358 without needing to use this macro or @code{RETSIGTYPE}.
21360 When targetting older K&R C, it is possible to define signal handlers as
21361 returning type @code{RETSIGTYPE}, and omit a return statement:
21363 @example
21364 @group
21365 RETSIGTYPE
21366 hup_handler ()
21368 @dots{}
21370 @end group
21371 @end example
21372 @end defmac
21374 @defmac AC_UID_T
21375 @acindex{UID_T}
21376 Replaced by @code{AC_TYPE_UID_T} (@pxref{AC_TYPE_UID_T}).
21377 @end defmac
21379 @defmac AC_UNISTD_H
21380 @acindex{UNISTD_H}
21381 Same as @samp{AC_CHECK_HEADERS([unistd.h])} (@pxref{AC_CHECK_HEADERS}).
21382 @end defmac
21384 @defmac AC_USG
21385 @acindex{USG}
21386 @cvindex USG
21387 Define @code{USG} if the @acronym{BSD} string functions are defined in
21388 @file{strings.h}.  You should no longer depend upon @code{USG}, but on
21389 @code{HAVE_STRING_H}; see @ref{Standard Symbols}.
21390 @end defmac
21392 @defmac AC_UTIME_NULL
21393 @acindex{UTIME_NULL}
21394 Replaced by @code{AC_FUNC_UTIME_NULL} (@pxref{AC_FUNC_UTIME_NULL}).
21395 @end defmac
21397 @defmac AC_VALIDATE_CACHED_SYSTEM_TUPLE (@ovar{cmd})
21398 @acindex{VALIDATE_CACHED_SYSTEM_TUPLE}
21399 If the cache file is inconsistent with the current host, target and
21400 build system types, it used to execute @var{cmd} or print a default
21401 error message.  This is now handled by default.
21402 @end defmac
21404 @defmac AC_VERBOSE (@var{result-description})
21405 @acindex{VERBOSE}
21406 Replaced by @code{AC_MSG_RESULT} (@pxref{AC_MSG_RESULT}).
21407 @end defmac
21409 @defmac AC_VFORK
21410 @acindex{VFORK}
21411 Replaced by @code{AC_FUNC_FORK} (@pxref{AC_FUNC_FORK}).
21412 @end defmac
21414 @defmac AC_VPRINTF
21415 @acindex{VPRINTF}
21416 Replaced by @code{AC_FUNC_VPRINTF} (@pxref{AC_FUNC_VPRINTF}).
21417 @end defmac
21419 @defmac AC_WAIT3
21420 @acindex{WAIT3}
21421 This macro was renamed @code{AC_FUNC_WAIT3}.  However, these days
21422 portable programs should use @code{waitpid}, not @code{wait3}, as
21423 @code{wait3} has been removed from Posix.
21424 @end defmac
21426 @defmac AC_WARN
21427 @acindex{WARN}
21428 Replaced by @code{AC_MSG_WARN} (@pxref{AC_MSG_WARN}).
21429 @end defmac
21431 @defmac AC_WITH (@var{package}, @var{action-if-given}, @
21432   @ovar{action-if-not-given})
21433 @acindex{WITH}
21434 This is an obsolete version of @code{AC_ARG_WITH} that does not
21435 support providing a help string (@pxref{AC_ARG_WITH}).
21436 @end defmac
21438 @defmac AC_WORDS_BIGENDIAN
21439 @acindex{WORDS_BIGENDIAN}
21440 Replaced by @code{AC_C_BIGENDIAN} (@pxref{AC_C_BIGENDIAN}).
21441 @end defmac
21443 @defmac AC_XENIX_DIR
21444 @acindex{XENIX_DIR}
21445 @ovindex LIBS
21446 This macro used to add @option{-lx} to output variable @code{LIBS} if on
21447 Xenix.  Also, if @file{dirent.h} is being checked for, added
21448 @option{-ldir} to @code{LIBS}.  Now it is merely an alias of
21449 @code{AC_HEADER_DIRENT} instead, plus some code to detect whether
21450 running @sc{xenix} on which you should not depend:
21452 @example
21453 AC_MSG_CHECKING([for Xenix])
21454 AC_EGREP_CPP([yes],
21455 [#if defined M_XENIX && !defined M_UNIX
21456   yes
21457 #endif],
21458              [AC_MSG_RESULT([yes]); XENIX=yes],
21459              [AC_MSG_RESULT([no]); XENIX=])
21460 @end example
21461 @noindent
21462 Don't use this macro, the dignified means to check the nature of the
21463 host is using @code{AC_CANONICAL_HOST} (@pxref{Canonicalizing}).
21464 @end defmac
21466 @defmac AC_YYTEXT_POINTER
21467 @acindex{YYTEXT_POINTER}
21468 This macro was renamed @code{AC_DECL_YYTEXT}, which in turn was
21469 integrated into @code{AC_PROG_LEX} (@pxref{AC_PROG_LEX}).
21470 @end defmac
21472 @node Autoconf 1
21473 @section Upgrading From Version 1
21474 @cindex Upgrading autoconf
21475 @cindex Autoconf upgrading
21477 Autoconf version 2 is mostly backward compatible with version 1.
21478 However, it introduces better ways to do some things, and doesn't
21479 support some of the ugly things in version 1.  So, depending on how
21480 sophisticated your @file{configure.ac} files are, you might have to do
21481 some manual work in order to upgrade to version 2.  This chapter points
21482 out some problems to watch for when upgrading.  Also, perhaps your
21483 @command{configure} scripts could benefit from some of the new features in
21484 version 2; the changes are summarized in the file @file{NEWS} in the
21485 Autoconf distribution.
21487 @menu
21488 * Changed File Names::          Files you might rename
21489 * Changed Makefiles::           New things to put in @file{Makefile.in}
21490 * Changed Macros::              Macro calls you might replace
21491 * Changed Results::             Changes in how to check test results
21492 * Changed Macro Writing::       Better ways to write your own macros
21493 @end menu
21495 @node Changed File Names
21496 @subsection Changed File Names
21498 If you have an @file{aclocal.m4} installed with Autoconf (as opposed to
21499 in a particular package's source directory), you must rename it to
21500 @file{acsite.m4}.  @xref{autoconf Invocation}.
21502 If you distribute @file{install.sh} with your package, rename it to
21503 @file{install-sh} so @command{make} builtin rules don't inadvertently
21504 create a file called @file{install} from it.  @code{AC_PROG_INSTALL}
21505 looks for the script under both names, but it is best to use the new name.
21507 If you were using @file{config.h.top}, @file{config.h.bot}, or
21508 @file{acconfig.h}, you still can, but you have less clutter if you
21509 use the @code{AH_} macros.  @xref{Autoheader Macros}.
21511 @node Changed Makefiles
21512 @subsection Changed Makefiles
21514 Add @samp{@@CFLAGS@@}, @samp{@@CPPFLAGS@@}, and @samp{@@LDFLAGS@@} in
21515 your @file{Makefile.in} files, so they can take advantage of the values
21516 of those variables in the environment when @command{configure} is run.
21517 Doing this isn't necessary, but it's a convenience for users.
21519 Also add @samp{@@configure_input@@} in a comment to each input file for
21520 @code{AC_OUTPUT}, so that the output files contain a comment saying
21521 they were produced by @command{configure}.  Automatically selecting the
21522 right comment syntax for all the kinds of files that people call
21523 @code{AC_OUTPUT} on became too much work.
21525 Add @file{config.log} and @file{config.cache} to the list of files you
21526 remove in @code{distclean} targets.
21528 If you have the following in @file{Makefile.in}:
21530 @example
21531 prefix = /usr/local
21532 exec_prefix = $(prefix)
21533 @end example
21535 @noindent
21536 you must change it to:
21538 @example
21539 prefix = @@prefix@@
21540 exec_prefix = @@exec_prefix@@
21541 @end example
21543 @noindent
21544 The old behavior of replacing those variables without @samp{@@}
21545 characters around them has been removed.
21547 @node Changed Macros
21548 @subsection Changed Macros
21550 Many of the macros were renamed in Autoconf version 2.  You can still
21551 use the old names, but the new ones are clearer, and it's easier to find
21552 the documentation for them.  @xref{Obsolete Macros}, for a table showing the
21553 new names for the old macros.  Use the @command{autoupdate} program to
21554 convert your @file{configure.ac} to using the new macro names.
21555 @xref{autoupdate Invocation}.
21557 Some macros have been superseded by similar ones that do the job better,
21558 but are not call-compatible.  If you get warnings about calling obsolete
21559 macros while running @command{autoconf}, you may safely ignore them, but
21560 your @command{configure} script generally works better if you follow
21561 the advice that is printed about what to replace the obsolete macros with.  In
21562 particular, the mechanism for reporting the results of tests has
21563 changed.  If you were using @command{echo} or @code{AC_VERBOSE} (perhaps
21564 via @code{AC_COMPILE_CHECK}), your @command{configure} script's output
21565 looks better if you switch to @code{AC_MSG_CHECKING} and
21566 @code{AC_MSG_RESULT}.  @xref{Printing Messages}.  Those macros work best
21567 in conjunction with cache variables.  @xref{Caching Results}.
21571 @node Changed Results
21572 @subsection Changed Results
21574 If you were checking the results of previous tests by examining the
21575 shell variable @code{DEFS}, you need to switch to checking the values of
21576 the cache variables for those tests.  @code{DEFS} no longer exists while
21577 @command{configure} is running; it is only created when generating output
21578 files.  This difference from version 1 is because properly quoting the
21579 contents of that variable turned out to be too cumbersome and
21580 inefficient to do every time @code{AC_DEFINE} is called.  @xref{Cache
21581 Variable Names}.
21583 For example, here is a @file{configure.ac} fragment written for Autoconf
21584 version 1:
21586 @example
21587 AC_HAVE_FUNCS(syslog)
21588 case "$DEFS" in
21589 *-DHAVE_SYSLOG*) ;;
21590 *) # syslog is not in the default libraries.  See if it's in some other.
21591   saved_LIBS="$LIBS"
21592   for lib in bsd socket inet; do
21593     AC_CHECKING(for syslog in -l$lib)
21594     LIBS="-l$lib $saved_LIBS"
21595     AC_HAVE_FUNCS(syslog)
21596     case "$DEFS" in
21597     *-DHAVE_SYSLOG*) break ;;
21598     *) ;;
21599     esac
21600     LIBS="$saved_LIBS"
21601   done ;;
21602 esac
21603 @end example
21605 Here is a way to write it for version 2:
21607 @example
21608 AC_CHECK_FUNCS([syslog])
21609 if test "x$ac_cv_func_syslog" = xno; then
21610   # syslog is not in the default libraries.  See if it's in some other.
21611   for lib in bsd socket inet; do
21612     AC_CHECK_LIB([$lib], [syslog], [AC_DEFINE([HAVE_SYSLOG])
21613       LIBS="-l$lib $LIBS"; break])
21614   done
21616 @end example
21618 If you were working around bugs in @code{AC_DEFINE_UNQUOTED} by adding
21619 backslashes before quotes, you need to remove them.  It now works
21620 predictably, and does not treat quotes (except back quotes) specially.
21621 @xref{Setting Output Variables}.
21623 All of the Boolean shell variables set by Autoconf macros now use
21624 @samp{yes} for the true value.  Most of them use @samp{no} for false,
21625 though for backward compatibility some use the empty string instead.  If
21626 you were relying on a shell variable being set to something like 1 or
21627 @samp{t} for true, you need to change your tests.
21629 @node Changed Macro Writing
21630 @subsection Changed Macro Writing
21632 When defining your own macros, you should now use @code{AC_DEFUN}
21633 instead of @code{define}.  @code{AC_DEFUN} automatically calls
21634 @code{AC_PROVIDE} and ensures that macros called via @code{AC_REQUIRE}
21635 do not interrupt other macros, to prevent nested @samp{checking@dots{}}
21636 messages on the screen.  There's no actual harm in continuing to use the
21637 older way, but it's less convenient and attractive.  @xref{Macro
21638 Definitions}.
21640 You probably looked at the macros that came with Autoconf as a guide for
21641 how to do things.  It would be a good idea to take a look at the new
21642 versions of them, as the style is somewhat improved and they take
21643 advantage of some new features.
21645 If you were doing tricky things with undocumented Autoconf internals
21646 (macros, variables, diversions), check whether you need to change
21647 anything to account for changes that have been made.  Perhaps you can
21648 even use an officially supported technique in version 2 instead of
21649 kludging.  Or perhaps not.
21651 To speed up your locally written feature tests, add caching to them.
21652 See whether any of your tests are of general enough usefulness to
21653 encapsulate them into macros that you can share.
21656 @node Autoconf 2.13
21657 @section Upgrading From Version 2.13
21658 @cindex Upgrading autoconf
21659 @cindex Autoconf upgrading
21661 The introduction of the previous section (@pxref{Autoconf 1}) perfectly
21662 suits this section@enddots{}
21664 @quotation
21665 Autoconf version 2.50 is mostly backward compatible with version 2.13.
21666 However, it introduces better ways to do some things, and doesn't
21667 support some of the ugly things in version 2.13.  So, depending on how
21668 sophisticated your @file{configure.ac} files are, you might have to do
21669 some manual work in order to upgrade to version 2.50.  This chapter
21670 points out some problems to watch for when upgrading.  Also, perhaps
21671 your @command{configure} scripts could benefit from some of the new
21672 features in version 2.50; the changes are summarized in the file
21673 @file{NEWS} in the Autoconf distribution.
21674 @end quotation
21676 @menu
21677 * Changed Quotation::           Broken code which used to work
21678 * New Macros::                  Interaction with foreign macros
21679 * Hosts and Cross-Compilation::  Bugward compatibility kludges
21680 * AC_LIBOBJ vs LIBOBJS::        LIBOBJS is a forbidden token
21681 * AC_ACT_IFELSE vs AC_TRY_ACT::  A more generic scheme for testing sources
21682 @end menu
21684 @node Changed Quotation
21685 @subsection Changed Quotation
21687 The most important changes are invisible to you: the implementation of
21688 most macros have completely changed.  This allowed more factorization of
21689 the code, better error messages, a higher uniformity of the user's
21690 interface etc.  Unfortunately, as a side effect, some construct which
21691 used to (miraculously) work might break starting with Autoconf 2.50.
21692 The most common culprit is bad quotation.
21694 For instance, in the following example, the message is not properly
21695 quoted:
21697 @example
21698 AC_INIT
21699 AC_CHECK_HEADERS(foo.h, ,
21700   AC_MSG_ERROR(cannot find foo.h, bailing out))
21701 AC_OUTPUT
21702 @end example
21704 @noindent
21705 Autoconf 2.13 simply ignores it:
21707 @example
21708 $ @kbd{autoconf-2.13; ./configure --silent}
21709 creating cache ./config.cache
21710 configure: error: cannot find foo.h
21712 @end example
21714 @noindent
21715 while Autoconf 2.50 produces a broken @file{configure}:
21717 @example
21718 $ @kbd{autoconf-2.50; ./configure --silent}
21719 configure: error: cannot find foo.h
21720 ./configure: exit: bad non-numeric arg `bailing'
21721 ./configure: exit: bad non-numeric arg `bailing'
21723 @end example
21725 The message needs to be quoted, and the @code{AC_MSG_ERROR} invocation
21726 too!
21728 @example
21729 AC_INIT([Example], [1.0], [bug-example@@example.org])
21730 AC_CHECK_HEADERS([foo.h], [],
21731   [AC_MSG_ERROR([cannot find foo.h, bailing out])])
21732 AC_OUTPUT
21733 @end example
21735 Many many (and many more) Autoconf macros were lacking proper quotation,
21736 including no less than@dots{} @code{AC_DEFUN} itself!
21738 @example
21739 $ @kbd{cat configure.in}
21740 AC_DEFUN([AC_PROG_INSTALL],
21741 [# My own much better version
21743 AC_INIT
21744 AC_PROG_INSTALL
21745 AC_OUTPUT
21746 $ @kbd{autoconf-2.13}
21747 autoconf: Undefined macros:
21748 ***BUG in Autoconf--please report*** AC_FD_MSG
21749 ***BUG in Autoconf--please report*** AC_EPI
21750 configure.in:1:AC_DEFUN([AC_PROG_INSTALL],
21751 configure.in:5:AC_PROG_INSTALL
21752 $ @kbd{autoconf-2.50}
21754 @end example
21757 @node New Macros
21758 @subsection New Macros
21760 @cindex undefined macro
21761 @cindex @code{_m4_divert_diversion}
21763 While Autoconf was relatively dormant in the late 1990s, Automake
21764 provided Autoconf-like macros for a while.  Starting with Autoconf 2.50
21765 in 2001, Autoconf provided
21766 versions of these macros, integrated in the @code{AC_} namespace,
21767 instead of @code{AM_}.  But in order to ease the upgrading via
21768 @command{autoupdate}, bindings to such @code{AM_} macros are provided.
21770 Unfortunately older versions of Automake (e.g., Automake 1.4)
21771 did not quote the names of these macros.
21772 Therefore, when @command{m4} finds something like
21773 @samp{AC_DEFUN(AM_TYPE_PTRDIFF_T, @dots{})} in @file{aclocal.m4},
21774 @code{AM_TYPE_PTRDIFF_T} is
21775 expanded, replaced with its Autoconf definition.
21777 Fortunately Autoconf catches pre-@code{AC_INIT} expansions, and
21778 complains, in its own words:
21780 @example
21781 $ @kbd{cat configure.ac}
21782 AC_INIT([Example], [1.0], [bug-example@@example.org])
21783 AM_TYPE_PTRDIFF_T
21784 $ @kbd{aclocal-1.4}
21785 $ @kbd{autoconf}
21786 aclocal.m4:17: error: m4_defn: undefined macro: _m4_divert_diversion
21787 aclocal.m4:17: the top level
21788 autom4te: m4 failed with exit status: 1
21790 @end example
21792 Modern versions of Automake no longer define most of these
21793 macros, and properly quote the names of the remaining macros.
21794 If you must use an old Automake, do not depend upon macros from Automake
21795 as it is simply not its job
21796 to provide macros (but the one it requires itself):
21798 @example
21799 $ @kbd{cat configure.ac}
21800 AC_INIT([Example], [1.0], [bug-example@@example.org])
21801 AM_TYPE_PTRDIFF_T
21802 $ @kbd{rm aclocal.m4}
21803 $ @kbd{autoupdate}
21804 autoupdate: `configure.ac' is updated
21805 $ @kbd{cat configure.ac}
21806 AC_INIT([Example], [1.0], [bug-example@@example.org])
21807 AC_CHECK_TYPES([ptrdiff_t])
21808 $ @kbd{aclocal-1.4}
21809 $ @kbd{autoconf}
21811 @end example
21814 @node Hosts and Cross-Compilation
21815 @subsection Hosts and Cross-Compilation
21816 @cindex Cross compilation
21818 Based on the experience of compiler writers, and after long public
21819 debates, many aspects of the cross-compilation chain have changed:
21821 @itemize @minus
21822 @item
21823 the relationship between the build, host, and target architecture types,
21825 @item
21826 the command line interface for specifying them to @command{configure},
21828 @item
21829 the variables defined in @command{configure},
21831 @item
21832 the enabling of cross-compilation mode.
21833 @end itemize
21835 @sp 1
21837 The relationship between build, host, and target have been cleaned up:
21838 the chain of default is now simply: target defaults to host, host to
21839 build, and build to the result of @command{config.guess}.  Nevertheless,
21840 in order to ease the transition from 2.13 to 2.50, the following
21841 transition scheme is implemented.  @emph{Do not rely on it}, as it will
21842 be completely disabled in a couple of releases (we cannot keep it, as it
21843 proves to cause more problems than it cures).
21845 They all default to the result of running @command{config.guess}, unless
21846 you specify either @option{--build} or @option{--host}.  In this case,
21847 the default becomes the system type you specified.  If you specify both,
21848 and they're different, @command{configure} enters cross compilation
21849 mode, so it doesn't run any tests that require execution.
21851 Hint: if you mean to override the result of @command{config.guess},
21852 prefer @option{--build} over @option{--host}.  In the future,
21853 @option{--host} will not override the name of the build system type.
21854 Whenever you specify @option{--host}, be sure to specify @option{--build}
21855 too.
21857 @sp 1
21859 For backward compatibility, @command{configure} accepts a system
21860 type as an option by itself.  Such an option overrides the
21861 defaults for build, host, and target system types.  The following
21862 configure statement configures a cross toolchain that runs on
21863 Net@acronym{BSD}/alpha but generates code for @acronym{GNU} Hurd/sparc,
21864 which is also the build platform.
21866 @example
21867 ./configure --host=alpha-netbsd sparc-gnu
21868 @end example
21870 @sp 1
21872 In Autoconf 2.13 and before, the variables @code{build}, @code{host},
21873 and @code{target} had a different semantics before and after the
21874 invocation of @code{AC_CANONICAL_BUILD} etc.  Now, the argument of
21875 @option{--build} is strictly copied into @code{build_alias}, and is left
21876 empty otherwise.  After the @code{AC_CANONICAL_BUILD}, @code{build} is
21877 set to the canonicalized build type.  To ease the transition, before,
21878 its contents is the same as that of @code{build_alias}.  Do @emph{not}
21879 rely on this broken feature.
21881 For consistency with the backward compatibility scheme exposed above,
21882 when @option{--host} is specified but @option{--build} isn't, the build
21883 system is assumed to be the same as @option{--host}, and
21884 @samp{build_alias} is set to that value.  Eventually, this
21885 historically incorrect behavior will go away.
21887 @sp 1
21889 The former scheme to enable cross-compilation proved to cause more harm
21890 than good, in particular, it used to be triggered too easily, leaving
21891 regular end users puzzled in front of cryptic error messages.
21892 @command{configure} could even enter cross-compilation mode only
21893 because the compiler was not functional.  This is mainly because
21894 @command{configure} used to try to detect cross-compilation, instead of
21895 waiting for an explicit flag from the user.
21897 Now, @command{configure} enters cross-compilation mode if and only if
21898 @option{--host} is passed.
21900 That's the short documentation.  To ease the transition between 2.13 and
21901 its successors, a more complicated scheme is implemented.  @emph{Do not
21902 rely on the following}, as it will be removed in the near future.
21904 If you specify @option{--host}, but not @option{--build}, when
21905 @command{configure} performs the first compiler test it tries to run
21906 an executable produced by the compiler.  If the execution fails, it
21907 enters cross-compilation mode.  This is fragile.  Moreover, by the time
21908 the compiler test is performed, it may be too late to modify the
21909 build-system type: other tests may have already been performed.
21910 Therefore, whenever you specify @option{--host}, be sure to specify
21911 @option{--build} too.
21913 @example
21914 ./configure --build=i686-pc-linux-gnu --host=m68k-coff
21915 @end example
21917 @noindent
21918 enters cross-compilation mode.  The former interface, which
21919 consisted in setting the compiler to a cross-compiler without informing
21920 @command{configure} is obsolete.  For instance, @command{configure}
21921 fails if it can't run the code generated by the specified compiler if you
21922 configure as follows:
21924 @example
21925 ./configure CC=m68k-coff-gcc
21926 @end example
21929 @node AC_LIBOBJ vs LIBOBJS
21930 @subsection @code{AC_LIBOBJ} vs.@: @code{LIBOBJS}
21932 Up to Autoconf 2.13, the replacement of functions was triggered via the
21933 variable @code{LIBOBJS}.  Since Autoconf 2.50, the macro
21934 @code{AC_LIBOBJ} should be used instead (@pxref{Generic Functions}).
21935 Starting at Autoconf 2.53, the use of @code{LIBOBJS} is an error.
21937 This change is mandated by the unification of the @acronym{GNU} Build System
21938 components.  In particular, the various fragile techniques used to parse
21939 a @file{configure.ac} are all replaced with the use of traces.  As a
21940 consequence, any action must be traceable, which obsoletes critical
21941 variable assignments.  Fortunately, @code{LIBOBJS} was the only problem,
21942 and it can even be handled gracefully (read, ``without your having to
21943 change something'').
21945 There were two typical uses of @code{LIBOBJS}: asking for a replacement
21946 function, and adjusting @code{LIBOBJS} for Automake and/or Libtool.
21948 @sp 1
21950 As for function replacement, the fix is immediate: use
21951 @code{AC_LIBOBJ}.  For instance:
21953 @example
21954 LIBOBJS="$LIBOBJS fnmatch.o"
21955 LIBOBJS="$LIBOBJS malloc.$ac_objext"
21956 @end example
21958 @noindent
21959 should be replaced with:
21961 @example
21962 AC_LIBOBJ([fnmatch])
21963 AC_LIBOBJ([malloc])
21964 @end example
21966 @sp 1
21968 @ovindex LIBOBJDIR
21969 When used with Automake 1.10 or newer, a suitable value for
21970 @code{LIBOBJDIR} is set so that the @code{LIBOBJS} and @code{LTLIBOBJS}
21971 can be referenced from any @file{Makefile.am}.  Even without Automake,
21972 arranging for @code{LIBOBJDIR} to be set correctly enables
21973 referencing @code{LIBOBJS} and @code{LTLIBOBJS} in another directory.
21974 The @code{LIBOBJDIR} feature is experimental.
21977 @node AC_ACT_IFELSE vs AC_TRY_ACT
21978 @subsection @code{AC_@var{ACT}_IFELSE} vs.@: @code{AC_TRY_@var{ACT}}
21979 @c the anchor keeps the old node name, to try to avoid breaking links
21980 @anchor{AC_FOO_IFELSE vs AC_TRY_FOO}
21982 Since Autoconf 2.50, internal codes uses @code{AC_PREPROC_IFELSE},
21983 @code{AC_COMPILE_IFELSE}, @code{AC_LINK_IFELSE}, and
21984 @code{AC_RUN_IFELSE} on one hand and @code{AC_LANG_SOURCES},
21985 and @code{AC_LANG_PROGRAM} on the other hand instead of the deprecated
21986 @code{AC_TRY_CPP}, @code{AC_TRY_COMPILE}, @code{AC_TRY_LINK}, and
21987 @code{AC_TRY_RUN}.  The motivations where:
21988 @itemize @minus
21989 @item
21990 a more consistent interface: @code{AC_TRY_COMPILE} etc.@: were double
21991 quoting their arguments;
21993 @item
21994 the combinatoric explosion is solved by decomposing on the one hand the
21995 generation of sources, and on the other hand executing the program;
21997 @item
21998 this scheme helps supporting more languages than plain C and C++.
21999 @end itemize
22001 In addition to the change of syntax, the philosophy has changed too:
22002 while emphasis was put on speed at the expense of accuracy, today's
22003 Autoconf promotes accuracy of the testing framework at, ahem@dots{}, the
22004 expense of speed.
22007 As a perfect example of what is @emph{not} to be done, here is how to
22008 find out whether a header file contains a particular declaration, such
22009 as a typedef, a structure, a structure member, or a function.  Use
22010 @code{AC_EGREP_HEADER} instead of running @code{grep} directly on the
22011 header file; on some systems the symbol might be defined in another
22012 header file that the file you are checking includes.
22014 As a (bad) example, here is how you should not check for C preprocessor
22015 symbols, either defined by header files or predefined by the C
22016 preprocessor: using @code{AC_EGREP_CPP}:
22018 @example
22019 @group
22020 AC_EGREP_CPP(yes,
22021 [#ifdef _AIX
22022   yes
22023 #endif
22024 ], is_aix=yes, is_aix=no)
22025 @end group
22026 @end example
22028 The above example, properly written would (i) use
22029 @code{AC_LANG_PROGRAM}, and (ii) run the compiler:
22031 @example
22032 @group
22033 AC_COMPILE_IFELSE([AC_LANG_PROGRAM(
22034 [[#ifndef _AIX
22035  error: This isn't AIX!
22036 #endif
22037 ]])],
22038                    [is_aix=yes],
22039                    [is_aix=no])
22040 @end group
22041 @end example
22044 @c ============================= Generating Test Suites with Autotest
22046 @node Using Autotest
22047 @chapter Generating Test Suites with Autotest
22049 @cindex Autotest
22051 @display
22052 @strong{N.B.: This section describes a feature which is still
22053 stabilizing.  Although we believe that Autotest is useful as-is, this
22054 documentation describes an interface which might change in the future:
22055 do not depend upon Autotest without subscribing to the Autoconf mailing
22056 lists.}
22057 @end display
22059 It is paradoxical that portable projects depend on nonportable tools
22060 to run their test suite.  Autoconf by itself is the paragon of this
22061 problem: although it aims at perfectly portability, up to 2.13 its
22062 test suite was using Deja@acronym{GNU}, a rich and complex testing
22063 framework, but which is far from being standard on Posix systems.
22064 Worse yet, it was likely to be missing on the most fragile platforms,
22065 the very platforms that are most likely to torture Autoconf and
22066 exhibit deficiencies.
22068 To circumvent this problem, many package maintainers have developed their
22069 own testing framework, based on simple shell scripts whose sole outputs
22070 are exit status values describing whether the test succeeded.  Most of
22071 these tests share common patterns, and this can result in lots of
22072 duplicated code and tedious maintenance.
22074 Following exactly the same reasoning that yielded to the inception of
22075 Autoconf, Autotest provides a test suite generation framework, based on
22076 M4 macros building a portable shell script.  The suite itself is
22077 equipped with automatic logging and tracing facilities which greatly
22078 diminish the interaction with bug reporters, and simple timing reports.
22080 Autoconf itself has been using Autotest for years, and we do attest that
22081 it has considerably improved the strength of the test suite and the
22082 quality of bug reports.  Other projects are known to use some generation
22083 of Autotest, such as Bison, Free Recode, Free Wdiff, @acronym{GNU} Tar, each of
22084 them with different needs, and this usage has validated Autotest as a general
22085 testing framework.
22087 Nonetheless, compared to Deja@acronym{GNU}, Autotest is inadequate for
22088 interactive tool testing, which is probably its main limitation.
22090 @menu
22091 * Using an Autotest Test Suite::  Autotest and the user
22092 * Writing Testsuites::          Autotest macros
22093 * testsuite Invocation::        Running @command{testsuite} scripts
22094 * Making testsuite Scripts::    Using autom4te to create @command{testsuite}
22095 @end menu
22097 @node Using an Autotest Test Suite
22098 @section Using an Autotest Test Suite
22100 @menu
22101 * testsuite Scripts::           The concepts of Autotest
22102 * Autotest Logs::               Their contents
22103 @end menu
22105 @node testsuite Scripts
22106 @subsection @command{testsuite} Scripts
22108 @cindex @command{testsuite}
22110 Generating testing or validation suites using Autotest is rather easy.
22111 The whole validation suite is held in a file to be processed through
22112 @command{autom4te}, itself using @acronym{GNU} M4 under the scene, to
22113 produce a stand-alone Bourne shell script which then gets distributed.
22114 Neither @command{autom4te} nor @acronym{GNU} M4 are needed at
22115 the installer's end.
22117 @cindex test group
22118 Each test of the validation suite should be part of some test group.  A
22119 @dfn{test group} is a sequence of interwoven tests that ought to be
22120 executed together, usually because one test in the group creates data
22121 files than a later test in the same group needs to read.  Complex test
22122 groups make later debugging more tedious.  It is much better to
22123 keep only a few tests per test group.  Ideally there is only one test
22124 per test group.
22126 For all but the simplest packages, some file such as @file{testsuite.at}
22127 does not fully hold all test sources, as these are often easier to
22128 maintain in separate files.  Each of these separate files holds a single
22129 test group, or a sequence of test groups all addressing some common
22130 functionality in the package.  In such cases, @file{testsuite.at}
22131 merely initializes the validation suite, and sometimes does elementary
22132 health checking, before listing include statements for all other test
22133 files.  The special file @file{package.m4}, containing the
22134 identification of the package, is automatically included if found.
22136 A convenient alternative consists in moving all the global issues
22137 (local Autotest macros, elementary health checking, and @code{AT_INIT}
22138 invocation) into the file @code{local.at}, and making
22139 @file{testsuite.at} be a simple list of @code{m4_include} of sub test
22140 suites.  In such case, generating the whole test suite or pieces of it
22141 is only a matter of choosing the @command{autom4te} command line
22142 arguments.
22144 The validation scripts that Autotest produces are by convention called
22145 @command{testsuite}.  When run, @command{testsuite} executes each test
22146 group in turn, producing only one summary line per test to say if that
22147 particular test succeeded or failed.  At end of all tests, summarizing
22148 counters get printed.  One debugging directory is left for each test
22149 group which failed, if any: such directories are named
22150 @file{testsuite.dir/@var{nn}}, where @var{nn} is the sequence number of
22151 the test group, and they include:
22153 @itemize @bullet
22154 @item a debugging script named @file{run} which reruns the test in
22155 @dfn{debug mode} (@pxref{testsuite Invocation}).  The automatic generation
22156 of debugging scripts has the purpose of easing the chase for bugs.
22158 @item all the files created with @code{AT_DATA}
22160 @item a log of the run, named @file{testsuite.log}
22161 @end itemize
22163 In the ideal situation, none of the tests fail, and consequently no
22164 debugging directory is left behind for validation.
22166 It often happens in practice that individual tests in the validation
22167 suite need to get information coming out of the configuration process.
22168 Some of this information, common for all validation suites, is provided
22169 through the file @file{atconfig}, automatically created by
22170 @code{AC_CONFIG_TESTDIR}.  For configuration informations which your
22171 testing environment specifically needs, you might prepare an optional
22172 file named @file{atlocal.in}, instantiated by @code{AC_CONFIG_FILES}.
22173 The configuration process produces @file{atconfig} and @file{atlocal}
22174 out of these two input files, and these two produced files are
22175 automatically read by the @file{testsuite} script.
22177 Here is a diagram showing the relationship between files.
22179 @noindent
22180 Files used in preparing a software package for distribution:
22182 @example
22183                 [package.m4] -->.
22184                                  \
22185 subfile-1.at ->.  [local.at] ---->+
22186     ...         \                  \
22187 subfile-i.at ---->-- testsuite.at -->-- autom4te* -->testsuite
22188     ...         /
22189 subfile-n.at ->'
22190 @end example
22192 @noindent
22193 Files used in configuring a software package:
22195 @example
22196                                      .--> atconfig
22197                                     /
22198 [atlocal.in] -->  config.status* --<
22199                                     \
22200                                      `--> [atlocal]
22201 @end example
22203 @noindent
22204 Files created during the test suite execution:
22206 @example
22207 atconfig -->.                    .--> testsuite.log
22208              \                  /
22209               >-- testsuite* --<
22210              /                  \
22211 [atlocal] ->'                    `--> [testsuite.dir]
22212 @end example
22215 @node Autotest Logs
22216 @subsection Autotest Logs
22218 When run, the test suite creates a log file named after itself, e.g., a
22219 test suite named @command{testsuite} creates @file{testsuite.log}.  It
22220 contains a lot of information, usually more than maintainers actually
22221 need, but therefore most of the time it contains all that is needed:
22223 @table @asis
22224 @item command line arguments
22225 @c akim s/to consist in/to consist of/
22226 A bad but unfortunately widespread habit consists of
22227 setting environment variables before the command, such as in
22228 @samp{CC=my-home-grown-cc ./testsuite}.  The test suite does not
22229 know this change, hence (i) it cannot report it to you, and (ii)
22230 it cannot preserve the value of @code{CC} for subsequent runs.
22231 Autoconf faced exactly the same problem, and solved it by asking
22232 users to pass the variable definitions as command line arguments.
22233 Autotest requires this rule, too, but has no means to enforce it; the log
22234 then contains a trace of the variables that were changed by the user.
22236 @item @file{ChangeLog} excerpts
22237 The topmost lines of all the @file{ChangeLog} files found in the source
22238 hierarchy.  This is especially useful when bugs are reported against
22239 development versions of the package, since the version string does not
22240 provide sufficient information to know the exact state of the sources
22241 the user compiled.  Of course, this relies on the use of a
22242 @file{ChangeLog}.
22244 @item build machine
22245 Running a test suite in a cross-compile environment is not an easy task,
22246 since it would mean having the test suite run on a machine @var{build},
22247 while running programs on a machine @var{host}.  It is much simpler to
22248 run both the test suite and the programs on @var{host}, but then, from
22249 the point of view of the test suite, there remains a single environment,
22250 @var{host} = @var{build}.  The log contains relevant information on the
22251 state of the build machine, including some important environment
22252 variables.
22253 @c FIXME: How about having an M4sh macro to say `hey, log the value
22254 @c of `@dots{}'?  This would help both Autoconf and Autotest.
22256 @item tested programs
22257 The absolute file name and answers to @option{--version} of the tested
22258 programs (see @ref{Writing Testsuites}, @code{AT_TESTED}).
22260 @item configuration log
22261 The contents of @file{config.log}, as created by @command{configure},
22262 are appended.  It contains the configuration flags and a detailed report
22263 on the configuration itself.
22264 @end table
22267 @node Writing Testsuites
22268 @section Writing @file{testsuite.at}
22270 The @file{testsuite.at} is a Bourne shell script making use of special
22271 Autotest M4 macros.  It often contains a call to @code{AT_INIT} near
22272 its beginning followed by one call to @code{m4_include} per source file
22273 for tests.  Each such included file, or the remainder of
22274 @file{testsuite.at} if include files are not used, contain a sequence of
22275 test groups.  Each test group begins with a call to @code{AT_SETUP},
22276 then an arbitrary number of shell commands or calls to @code{AT_CHECK},
22277 and then completes with a call to @code{AT_CLEANUP}.  Multiple test
22278 groups can be categorized by a call to @code{AT_BANNER}.
22280 All of the public Autotest macros have all-uppercase names in the
22281 namespace @samp{^AT_} to prevent them from accidentally conflicting with
22282 other text; Autoconf also reserves the namespace @samp{^_AT_} for
22283 internal macros.  All shell variables used in the testsuite for internal
22284 purposes have mostly-lowercase names starting with @samp{at_}.  Autotest
22285 also uses here-doc delimiters in the namespace @samp{^_AT[A-Z]}, and
22286 makes use of the file system namespace @samp{^at-}.
22288 Since Autoconf is built on top of M4sugar (@pxref{Programming in
22289 M4sugar}) and M4sh (@pxref{Programming in M4sh}), you must also be aware
22290 of those namespaces (@samp{^_?\(m4\|AS\)_}).  In general, you
22291 @emph{should not use} the namespace of a package that does not own the
22292 macro or shell code you are writing.
22294 @defmac AT_INIT (@ovar{name})
22295 @atindex{INIT}
22296 @c FIXME: Not clear, plus duplication of the information.
22297 Initialize Autotest.  Giving a @var{name} to the test suite is
22298 encouraged if your package includes several test suites.  Before this
22299 macro is called, @code{AT_PACKAGE_STRING} and
22300 @code{AT_PACKAGE_BUGREPORT} must be defined, which are used to display
22301 information about the testsuite to the user.  Typically, these macros
22302 are provided by a file @file{package.m4} built by @command{make}
22303 (@pxref{Making testsuite Scripts}), in order to inherit the package
22304 name, version, and bug reporting address from @file{configure.ac}.
22305 @end defmac
22307 @defmac AT_COPYRIGHT (@var{copyright-notice})
22308 @atindex{COPYRIGHT}
22309 @cindex Copyright Notice
22310 State that, in addition to the Free Software Foundation's copyright on
22311 the Autotest macros, parts of your test suite are covered by
22312 @var{copyright-notice}.
22314 The @var{copyright-notice} shows up in both the head of
22315 @command{testsuite} and in @samp{testsuite --version}.
22316 @end defmac
22318 @defmac AT_TESTED (@var{executables})
22319 @atindex{TESTED}
22320 Log the file name and answer to @option{--version} of each program in
22321 space-separated list @var{executables}.  Several invocations register
22322 new executables, in other words, don't fear registering one program
22323 several times.
22324 @end defmac
22326 Autotest test suites rely on @env{PATH} to find the tested program.
22327 This avoids the need to generate absolute names of the various tools, and
22328 makes it possible to test installed programs.  Therefore, knowing which
22329 programs are being exercised is crucial to understanding problems in
22330 the test suite itself, or its occasional misuses.  It is a good idea to
22331 also subscribe foreign programs you depend upon, to avoid incompatible
22332 diagnostics.
22334 @sp 1
22336 @defmac AT_BANNER (@var{test-category-name})
22337 @atindex{BANNER}
22338 This macro identifies the start of a category of related test groups.
22339 When the resulting @file{testsuite} is invoked with more than one test
22340 group to run, its output will include a banner containing
22341 @var{test-category-name} prior to any tests run from that category.  The
22342 banner should be no more than about 40 or 50 characters.  A blank banner
22343 will not print, effectively ending a category and letting subsequent
22344 test groups behave as though they are uncategorized when run in
22345 isolation.
22346 @end defmac
22348 @defmac AT_SETUP (@var{test-group-name})
22349 @atindex{SETUP}
22350 This macro starts a group of related tests, all to be executed in the
22351 same subshell.  It accepts a single argument, which holds a few words
22352 (no more than about 30 or 40 characters) quickly describing the purpose
22353 of the test group being started.  @var{test-group-name} must not expand
22354 to unbalanced quotes, although quadrigraphs can be used.
22355 @end defmac
22357 @defmac AT_KEYWORDS (@var{keywords})
22358 @atindex{KEYWORDS}
22359 Associate the space-separated list of @var{keywords} to the enclosing
22360 test group.  This makes it possible to run ``slices'' of the test suite.
22361 For instance, if some of your test groups exercise some @samp{foo}
22362 feature, then using @samp{AT_KEYWORDS(foo)} lets you run
22363 @samp{./testsuite -k foo} to run exclusively these test groups.  The
22364 @var{title} of the test group is automatically recorded to
22365 @code{AT_KEYWORDS}.
22367 Several invocations within a test group accumulate new keywords.  In
22368 other words, don't fear registering the same keyword several times in a
22369 test group.
22370 @end defmac
22372 @defmac AT_CAPTURE_FILE (@var{file})
22373 @atindex{CAPTURE_FILE}
22374 If the current test group fails, log the contents of @var{file}.
22375 Several identical calls within one test group have no additional effect.
22376 @end defmac
22378 @defmac AT_XFAIL_IF (@var{shell-condition})
22379 @atindex{XFAIL_IF}
22380 Determine whether the test is expected to fail because it is a known
22381 bug (for unsupported features, you should skip the test).
22382 @var{shell-condition} is a shell expression such as a @code{test}
22383 command; you can instantiate this macro many times from within the
22384 same test group, and one of the conditions is enough to turn
22385 the test into an expected failure.
22386 @end defmac
22388 @defmac AT_CLEANUP
22389 @atindex{CLEANUP}
22390 End the current test group.
22391 @end defmac
22393 @sp 1
22395 @defmac AT_DATA (@var{file}, @var{contents})
22396 @atindex{DATA}
22397 Initialize an input data @var{file} with given @var{contents}.  Of
22398 course, the @var{contents} have to be properly quoted between square
22399 brackets to protect against included commas or spurious M4
22400 expansion.  The contents must end with an end of line.  @var{file} must
22401 be a single shell word that expands into a single file name.
22402 @end defmac
22404 @defmac AT_CHECK (@var{commands}, @dvar{status, 0}, @ovar{stdout}, @
22405   @ovar{stderr}, @ovar{run-if-fail}, @ovar{run-if-pass})
22406 @defmacx AT_CHECK_NOESCAPE (@var{commands}, @dvar{status, 0}, @ovar{stdout}, @
22407   @ovar{stderr}, @ovar{run-if-fail}, @ovar{run-if-pass})
22408 @atindex{CHECK}
22409 @atindex{CHECK_NOESCAPE}
22410 Execute a test by performing given shell @var{commands}.  These commands
22411 should normally exit with @var{status}, while producing expected
22412 @var{stdout} and @var{stderr} contents.  If @var{commands} exit with
22413 unexpected status 77, then the rest of the test group is skipped.  If
22414 @var{commands} exit with unexpected status 99, then the test group is
22415 immediately failed.  Otherwise, if this test
22416 fails, run shell commands @var{run-if-fail} or, if this test passes, run shell
22417 commands @var{run-if-pass}.
22419 This macro must be invoked in between @code{AT_SETUP} and @code{AT_CLEANUP}.
22421 If @var{status} is the literal @samp{ignore}, then the corresponding
22422 exit status is not checked, except for the special cases of 77 (skip)
22423 and 99 (hard failure).  The existence of hard failures allows one to
22424 mark a test as an expected failure with @code{AT_XFAIL_IF} because a
22425 feature has not yet been implemented, but to still distinguish between
22426 gracefully handling the missing feature and dumping core.  A hard
22427 failure also inhibits post-test actions in @var{run-if-fail}.
22429 If the value of the @var{stdout} or @var{stderr} parameter is one of the
22430 literals in the following table, then the test treats the output
22431 according to the rules of that literal.  Otherwise, the value of the
22432 parameter is treated as text that must exactly match the output given by
22433 @var{commands} on standard out and standard error (including an empty
22434 parameter for no output); any differences are captured in the testsuite
22435 log and the test is failed.  The difference between @code{AT_CHECK} and
22436 @code{AT_CHECK_NOESCAPE} is that only the latter performs shell
22437 expansions on comparison text given in the @var{stdout} and @var{stderr}
22438 arguments.
22440 @table @samp
22441 @item ignore
22442 The content of the output is ignored, but still captured in the test
22443 group log (if the testsuite is run with option @option{-v}, the test
22444 group log is displayed as the test is run; if the test group later
22445 fails, the test group log is also copied into the overall testsuite
22446 log).  This action is valid for both @var{stdout} and @var{stderr}.
22448 @item ignore-nolog
22449 The content of the output is ignored, and nothing is captured in the log
22450 files.  If @var{commands} are likely to produce binary output (including
22451 long lines) or large amounts of output, then logging the output can make
22452 it harder to locate details related to subsequent tests within the
22453 group, and could potentially corrupt terminal display of a user running
22454 @command{testsuite -v}.
22456 @item stdout
22457 For the @var{stdout} parameter, capture the content of standard output
22458 to both the file @file{stdout} and the test group log.  Subsequent
22459 commands in the test group can then post-process the file.  This action
22460 is often used when it is desired to use @command{grep} to look for a
22461 substring in the output, or when the output must be post-processed to
22462 normalize error messages into a common form.
22464 @item stderr
22465 Like @samp{stdout}, except that it only works for the @var{stderr}
22466 parameter, and the standard error capture file will be named
22467 @file{stderr}.
22469 @item stdout-nolog
22470 @itemx stderr-nolog
22471 Like @samp{stdout} or @samp{stderr}, except that the captured output is
22472 not duplicated into the test group log.  This action is particularly
22473 useful for an intermediate check that produces large amounts of data,
22474 which will be followed by another check that filters down to the
22475 relevant data, as it makes it easier to locate details in the log.
22477 @item expout
22478 For the @var{stdout} parameter, compare standard output contents with
22479 the previously created file @file{expout}, and list any differences in
22480 the testsuite log.
22482 @item experr
22483 Like @samp{expout}, except that it only works for the @var{stderr}
22484 parameter, and the standard error contents are compared with
22485 @file{experr}.
22486 @end table
22487 @end defmac
22490 @node testsuite Invocation
22491 @section Running @command{testsuite} Scripts
22492 @cindex @command{testsuite}
22494 Autotest test suites support the following arguments:
22496 @table @option
22497 @item --help
22498 @itemx -h
22499 Display the list of options and exit successfully.
22501 @item --version
22502 @itemx -V
22503 Display the version of the test suite and exit successfully.
22505 @item --directory=@var{dir}
22506 @itemx -C @var{dir}
22507 Change the current directory to @var{dir} before creating any files.
22508 Useful for running the testsuite in a subdirectory from a top-level
22509 Makefile.
22511 @item --jobs@r{[}=@var{n}@r{]}
22512 @itemx -j@ovar{n}
22513 Run @var{n} tests in parallel, if possible.  If @var{n} is not given,
22514 run all given tests in parallel.  Note that there should be no space
22515 before the argument to @option{-j}, as @option{-j @var{number}} denotes
22516 the separate arguments @option{-j} and @option{@var{number}}, see below.
22518 In parallel mode, the standard input device of the testsuite script is
22519 not available to commands inside a test group.  Furthermore, banner
22520 lines are not printed, and the summary line for each test group is
22521 output after the test group completes.  Summary lines may appear
22522 unordered.  If verbose and trace output are enabled (see below), they
22523 may appear intermixed from concurrently running tests.
22525 Parallel mode requires the @command{mkfifo} command to work, and will be
22526 silently disabled otherwise.
22528 @item --clean
22529 @itemx -c
22530 Remove all the files the test suite might have created and exit.  Meant
22531 for @code{clean} Make targets.
22533 @item --list
22534 @itemx -l
22535 List all the tests (or only the selection), including their possible
22536 keywords.
22537 @end table
22539 @sp 1
22541 By default all tests are performed (or described with
22542 @option{--list}) in the default environment first silently, then
22543 verbosely, but the environment, set of tests, and verbosity level can be
22544 tuned:
22546 @table @samp
22547 @item @var{variable}=@var{value}
22548 Set the environment @var{variable} to @var{value}.  Use this rather
22549 than @samp{FOO=foo ./testsuite} as debugging scripts would then run in a
22550 different environment.
22552 @cindex @code{AUTOTEST_PATH}
22553 The variable @code{AUTOTEST_PATH} specifies the testing path to prepend
22554 to @env{PATH}.  Relative directory names (not starting with
22555 @samp{/}) are considered to be relative to the top level of the
22556 package being built.  All directories are made absolute, first
22557 starting from the top level @emph{build} tree, then from the
22558 @emph{source} tree.  For instance @samp{./testsuite
22559 AUTOTEST_PATH=tests:bin} for a @file{/src/foo-1.0} source package built
22560 in @file{/tmp/foo} results in @samp{/tmp/foo/tests:/tmp/foo/bin} and
22561 then @samp{/src/foo-1.0/tests:/src/foo-1.0/bin} being prepended to
22562 @env{PATH}.
22564 @item @var{number}
22565 @itemx @var{number}-@var{number}
22566 @itemx @var{number}-
22567 @itemx -@var{number}
22568 Add the corresponding test groups, with obvious semantics, to the
22569 selection.
22571 @item --keywords=@var{keywords}
22572 @itemx -k @var{keywords}
22573 Add to the selection the test groups with title or keywords (arguments
22574 to @code{AT_SETUP} or @code{AT_KEYWORDS}) that match @emph{all} keywords
22575 of the comma separated list @var{keywords}, case-insensitively.  Use
22576 @samp{!} immediately before the keyword to invert the selection for this
22577 keyword.  By default, the keywords match whole words; enclose them in
22578 @samp{.*} to also match parts of words.
22580 For example, running
22582 @example
22583 @kbd{./testsuite -k 'autoupdate,.*FUNC.*'}
22584 @end example
22586 @noindent
22587 selects all tests tagged @samp{autoupdate} @emph{and} with tags
22588 containing @samp{FUNC} (as in @samp{AC_CHECK_FUNC}, @samp{AC_FUNC_ALLOCA},
22589 etc.), while
22591 @example
22592 @kbd{./testsuite -k '!autoupdate' -k '.*FUNC.*'}
22593 @end example
22595 @noindent
22596 selects all tests not tagged @samp{autoupdate} @emph{or} with tags
22597 containing @samp{FUNC}.
22599 @item --errexit
22600 @itemx -e
22601 If any test fails, immediately abort testing.  It implies
22602 @option{--debug}: post test group clean up, and top-level logging
22603 are inhibited.  This option is meant for the full test
22604 suite, it is not really useful for generated debugging scripts.
22605 If the testsuite is run in parallel mode using @option{--jobs},
22606 then concurrently running tests will finish before exiting.
22608 @item --verbose
22609 @itemx -v
22610 Force more verbosity in the detailed output of what is being done.  This
22611 is the default for debugging scripts.
22613 @item --debug
22614 @itemx -d
22615 Do not remove the files after a test group was performed ---but they are
22616 still removed @emph{before}, therefore using this option is sane when
22617 running several test groups.  Create debugging scripts.  Do not
22618 overwrite the top-level
22619 log (in order to preserve supposedly existing full log file).  This is
22620 the default for debugging scripts, but it can also be useful to debug
22621 the testsuite itself.
22623 @item --trace
22624 @itemx -x
22625 Trigger shell tracing of the test groups.
22626 @end table
22629 @node Making testsuite Scripts
22630 @section Making @command{testsuite} Scripts
22632 For putting Autotest into movement, you need some configuration and
22633 makefile machinery.  We recommend, at least if your package uses deep or
22634 shallow hierarchies, that you use @file{tests/} as the name of the
22635 directory holding all your tests and their makefile.  Here is a
22636 check list of things to do.
22638 @itemize @minus
22640 @item
22641 @cindex @file{package.m4}
22642 @atindex{PACKAGE_STRING}
22643 @atindex{PACKAGE_BUGREPORT}
22644 @atindex{PACKAGE_NAME}
22645 @atindex{PACKAGE_TARNAME}
22646 @atindex{PACKAGE_VERSION}
22647 @atindex{PACKAGE_URL}
22648 Make sure to create the file @file{package.m4}, which defines the
22649 identity of the package.  It must define @code{AT_PACKAGE_STRING}, the
22650 full signature of the package, and @code{AT_PACKAGE_BUGREPORT}, the
22651 address to which bug reports should be sent.  For sake of completeness,
22652 we suggest that you also define @code{AT_PACKAGE_NAME},
22653 @code{AT_PACKAGE_TARNAME}, @code{AT_PACKAGE_VERSION}, and
22654 @code{AT_PACKAGE_URL}.
22655 @xref{Initializing configure}, for a description of these variables.
22656 Be sure to distribute @file{package.m4} and to put it into the source
22657 hierarchy: the test suite ought to be shipped!  See below for an example
22658 @file{Makefile} excerpt.
22660 @item
22661 Invoke @code{AC_CONFIG_TESTDIR}.
22663 @defmac AC_CONFIG_TESTDIR (@var{directory}, @dvar{test-path, directory})
22664 @acindex{CONFIG_TESTDIR}
22665 An Autotest test suite is to be configured in @var{directory}.  This
22666 macro requires the instantiation of @file{@var{directory}/atconfig} from
22667 @file{@var{directory}/atconfig.in}, and sets the default
22668 @code{AUTOTEST_PATH} to @var{test-path} (@pxref{testsuite Invocation}).
22669 @end defmac
22671 @item
22672 Still within @file{configure.ac}, as appropriate, ensure that some
22673 @code{AC_CONFIG_FILES} command includes substitution for
22674 @file{tests/atlocal}.
22676 @item
22677 The appropriate @file{Makefile} should be modified so the validation in
22678 your package is triggered by @samp{make check}.  An example is provided
22679 below.
22680 @end itemize
22682 With Automake, here is a minimal example for inclusion in
22683 @file{tests/Makefile.am}, in order to link @samp{make check} with a
22684 validation suite.
22686 @example
22687 # The `:;' works around a Bash 3.2 bug when the output is not writeable.
22688 $(srcdir)/package.m4: $(top_srcdir)/configure.ac
22689         :;@{ \
22690           echo '# Signature of the current package.' && \
22691           echo 'm4_define([AT_PACKAGE_NAME],' && \
22692           echo '  [@@PACKAGE_NAME@@])' && \
22693           echo 'm4_define([AT_PACKAGE_TARNAME],' && \
22694           echo '  [@@PACKAGE_TARNAME@@])' && \
22695           echo 'm4_define([AT_PACKAGE_VERSION],' && \
22696           echo '  [@@PACKAGE_VERSION@@])' && \
22697           echo 'm4_define([AT_PACKAGE_STRING],' && \
22698           echo '  [@@PACKAGE_STRING@@])' && \
22699           echo 'm4_define([AT_PACKAGE_BUGREPORT],' && \
22700           echo '  [@@PACKAGE_BUGREPORT@@])'; \
22701           echo 'm4_define([AT_PACKAGE_URL],' && \
22702           echo '  [@@PACKAGE_URL@@])'; \
22703         @} >'$(srcdir)/package.m4'
22705 EXTRA_DIST = testsuite.at $(srcdir)/package.m4 $(TESTSUITE) atlocal.in
22706 TESTSUITE = $(srcdir)/testsuite
22708 check-local: atconfig atlocal $(TESTSUITE)
22709         $(SHELL) '$(TESTSUITE)' $(TESTSUITEFLAGS)
22711 installcheck-local: atconfig atlocal $(TESTSUITE)
22712         $(SHELL) '$(TESTSUITE)' AUTOTEST_PATH='$(bindir)' \
22713           $(TESTSUITEFLAGS)
22715 clean-local:
22716         test ! -f '$(TESTSUITE)' || \
22717          $(SHELL) '$(TESTSUITE)' --clean
22719 AUTOM4TE = $(SHELL) $(srcdir)/build-aux/missing --run autom4te
22720 AUTOTEST = $(AUTOM4TE) --language=autotest
22721 $(TESTSUITE): $(srcdir)/testsuite.at $(srcdir)/package.m4
22722         $(AUTOTEST) -I '$(srcdir)' -o $@@.tmp $@@.at
22723         mv $@@.tmp $@@
22724 @end example
22726 Note that the built testsuite is distributed; this is necessary because
22727 users might not have Autoconf installed, and thus would not be able to
22728 rebuild it.  Likewise, the use of @file{missing} provides the user with
22729 a nicer error message if they modify a source file to the testsuite, and
22730 accidentally trigger the rebuild rules.
22732 You might want to list explicitly the dependencies, i.e., the list of
22733 the files @file{testsuite.at} includes.
22735 If you don't use Automake, you should include the above example in
22736 @file{tests/@/Makefile.in}, along with additional lines inspired from
22737 the following:
22739 @example
22740 subdir = tests
22742 atconfig: $(top_builddir)/config.status
22743         cd $(top_builddir) && \
22744            $(SHELL) ./config.status $(subdir)/$@@
22746 atlocal: $(srcdir)/atlocal.in $(top_builddir)/config.status
22747         cd $(top_builddir) && \
22748            $(SHELL) ./config.status $(subdir)/$@@
22749 @end example
22751 @noindent
22752 and manage to have @code{$(EXTRA_DIST)} distributed.  You will also want
22753 to distribute the file @file{build-aux/@/missing} from the Automake
22754 project; a copy of this file resides in the Autoconf source.
22756 With all this in place, and if you have not initialized @samp{TESTSUITEFLAGS}
22757 within your makefile, you can fine-tune test suite execution with this
22758 variable, for example:
22760 @example
22761 make check TESTSUITEFLAGS='-v -d -x 75 -k AC_PROG_CC CFLAGS=-g'
22762 @end example
22766 @c =============================== Frequent Autoconf Questions, with answers
22768 @node FAQ
22769 @chapter Frequent Autoconf Questions, with answers
22771 Several questions about Autoconf come up occasionally.  Here some of them
22772 are addressed.
22774 @menu
22775 * Distributing::                Distributing @command{configure} scripts
22776 * Why GNU M4::                  Why not use the standard M4?
22777 * Bootstrapping::               Autoconf and @acronym{GNU} M4 require each other?
22778 * Why Not Imake::               Why @acronym{GNU} uses @command{configure} instead of Imake
22779 * Defining Directories::        Passing @code{datadir} to program
22780 * Autom4te Cache::              What is it?  Can I remove it?
22781 * Present But Cannot Be Compiled::  Compiler and Preprocessor Disagree
22782 * Expanded Before Required::    Expanded Before Required
22783 @end menu
22785 @node Distributing
22786 @section Distributing @command{configure} Scripts
22787 @cindex License
22789 @display
22790 What are the restrictions on distributing @command{configure}
22791 scripts that Autoconf generates?  How does that affect my
22792 programs that use them?
22793 @end display
22795 There are no restrictions on how the configuration scripts that Autoconf
22796 produces may be distributed or used.  In Autoconf version 1, they were
22797 covered by the @acronym{GNU} General Public License.  We still encourage
22798 software authors to distribute their work under terms like those of the
22799 @acronym{GPL}, but doing so is not required to use Autoconf.
22801 Of the other files that might be used with @command{configure},
22802 @file{config.h.in} is under whatever copyright you use for your
22803 @file{configure.ac}.  @file{config.sub} and @file{config.guess} have an
22804 exception to the @acronym{GPL} when they are used with an Autoconf-generated
22805 @command{configure} script, which permits you to distribute them under the
22806 same terms as the rest of your package.  @file{install-sh} is from the X
22807 Consortium and is not copyrighted.
22809 @node Why GNU M4
22810 @section Why Require @acronym{GNU} M4?
22812 @display
22813 Why does Autoconf require @acronym{GNU} M4?
22814 @end display
22816 Many M4 implementations have hard-coded limitations on the size and
22817 number of macros that Autoconf exceeds.  They also lack several
22818 builtin macros that it would be difficult to get along without in a
22819 sophisticated application like Autoconf, including:
22821 @example
22822 m4_builtin
22823 m4_indir
22824 m4_bpatsubst
22825 __file__
22826 __line__
22827 @end example
22829 Autoconf requires version 1.4.5 or later of @acronym{GNU} M4.
22831 Since only software maintainers need to use Autoconf, and since @acronym{GNU}
22832 M4 is simple to configure and install, it seems reasonable to require
22833 @acronym{GNU} M4 to be installed also.  Many maintainers of @acronym{GNU} and
22834 other free software already have most of the @acronym{GNU} utilities
22835 installed, since they prefer them.
22837 @node Bootstrapping
22838 @section How Can I Bootstrap?
22839 @cindex Bootstrap
22841 @display
22842 If Autoconf requires @acronym{GNU} M4 and @acronym{GNU} M4 has an Autoconf
22843 @command{configure} script, how do I bootstrap?  It seems like a chicken
22844 and egg problem!
22845 @end display
22847 This is a misunderstanding.  Although @acronym{GNU} M4 does come with a
22848 @command{configure} script produced by Autoconf, Autoconf is not required
22849 in order to run the script and install @acronym{GNU} M4.  Autoconf is only
22850 required if you want to change the M4 @command{configure} script, which few
22851 people have to do (mainly its maintainer).
22853 @node Why Not Imake
22854 @section Why Not Imake?
22855 @cindex Imake
22857 @display
22858 Why not use Imake instead of @command{configure} scripts?
22859 @end display
22861 Several people have written addressing this question, so I include
22862 adaptations of their explanations here.
22864 The following answer is based on one written by Richard Pixley:
22866 @quotation
22867 Autoconf generated scripts frequently work on machines that it has
22868 never been set up to handle before.  That is, it does a good job of
22869 inferring a configuration for a new system.  Imake cannot do this.
22871 Imake uses a common database of host specific data.  For X11, this makes
22872 sense because the distribution is made as a collection of tools, by one
22873 central authority who has control over the database.
22875 @acronym{GNU} tools are not released this way.  Each @acronym{GNU} tool has a
22876 maintainer; these maintainers are scattered across the world.  Using a
22877 common database would be a maintenance nightmare.  Autoconf may appear
22878 to be this kind of database, but in fact it is not.  Instead of listing
22879 host dependencies, it lists program requirements.
22881 If you view the @acronym{GNU} suite as a collection of native tools, then the
22882 problems are similar.  But the @acronym{GNU} development tools can be
22883 configured as cross tools in almost any host+target permutation.  All of
22884 these configurations can be installed concurrently.  They can even be
22885 configured to share host independent files across hosts.  Imake doesn't
22886 address these issues.
22888 Imake templates are a form of standardization.  The @acronym{GNU} coding
22889 standards address the same issues without necessarily imposing the same
22890 restrictions.
22891 @end quotation
22894 Here is some further explanation, written by Per Bothner:
22896 @quotation
22897 One of the advantages of Imake is that it easy to generate large
22898 makefiles using the @samp{#include} and macro mechanisms of @command{cpp}.
22899 However, @code{cpp} is not programmable: it has limited conditional
22900 facilities, and no looping.  And @code{cpp} cannot inspect its
22901 environment.
22903 All of these problems are solved by using @code{sh} instead of
22904 @code{cpp}.  The shell is fully programmable, has macro substitution,
22905 can execute (or source) other shell scripts, and can inspect its
22906 environment.
22907 @end quotation
22910 Paul Eggert elaborates more:
22912 @quotation
22913 With Autoconf, installers need not assume that Imake itself is already
22914 installed and working well.  This may not seem like much of an advantage
22915 to people who are accustomed to Imake.  But on many hosts Imake is not
22916 installed or the default installation is not working well, and requiring
22917 Imake to install a package hinders the acceptance of that package on
22918 those hosts.  For example, the Imake template and configuration files
22919 might not be installed properly on a host, or the Imake build procedure
22920 might wrongly assume that all source files are in one big directory
22921 tree, or the Imake configuration might assume one compiler whereas the
22922 package or the installer needs to use another, or there might be a
22923 version mismatch between the Imake expected by the package and the Imake
22924 supported by the host.  These problems are much rarer with Autoconf,
22925 where each package comes with its own independent configuration
22926 processor.
22928 Also, Imake often suffers from unexpected interactions between
22929 @command{make} and the installer's C preprocessor.  The fundamental problem
22930 here is that the C preprocessor was designed to preprocess C programs,
22931 not makefiles.  This is much less of a problem with Autoconf,
22932 which uses the general-purpose preprocessor M4, and where the
22933 package's author (rather than the installer) does the preprocessing in a
22934 standard way.
22935 @end quotation
22938 Finally, Mark Eichin notes:
22940 @quotation
22941 Imake isn't all that extensible, either.  In order to add new features to
22942 Imake, you need to provide your own project template, and duplicate most
22943 of the features of the existing one.  This means that for a sophisticated
22944 project, using the vendor-provided Imake templates fails to provide any
22945 leverage---since they don't cover anything that your own project needs
22946 (unless it is an X11 program).
22948 On the other side, though:
22950 The one advantage that Imake has over @command{configure}:
22951 @file{Imakefile} files tend to be much shorter (likewise, less redundant)
22952 than @file{Makefile.in} files.  There is a fix to this, however---at least
22953 for the Kerberos V5 tree, we've modified things to call in common
22954 @file{post.in} and @file{pre.in} makefile fragments for the
22955 entire tree.  This means that a lot of common things don't have to be
22956 duplicated, even though they normally are in @command{configure} setups.
22957 @end quotation
22960 @node Defining Directories
22961 @section How Do I @code{#define} Installation Directories?
22963 @display
22964 My program needs library files, installed in @code{datadir} and
22965 similar.  If I use
22967 @example
22968 AC_DEFINE_UNQUOTED([DATADIR], [$datadir],
22969   [Define to the read-only architecture-independent
22970    data directory.])
22971 @end example
22973 @noindent
22974 I get
22976 @example
22977 #define DATADIR "$@{prefix@}/share"
22978 @end example
22979 @end display
22981 As already explained, this behavior is on purpose, mandated by the
22982 @acronym{GNU} Coding Standards, see @ref{Installation Directory
22983 Variables}.  There are several means to achieve a similar goal:
22985 @itemize @minus
22986 @item
22987 Do not use @code{AC_DEFINE} but use your makefile to pass the
22988 actual value of @code{datadir} via compilation flags.
22989 @xref{Installation Directory Variables}, for the details.
22991 @item
22992 This solution can be simplified when compiling a program: you may either
22993 extend the @code{CPPFLAGS}:
22995 @example
22996 CPPFLAGS = -DDATADIR='"$(datadir)"' @@CPPFLAGS@@
22997 @end example
22999 @noindent
23000 If you are using Automake, you should use @code{AM_CPPFLAGS} instead:
23002 @example
23003 AM_CPPFLAGS = -DDATADIR='"$(datadir)"'
23004 @end example
23006 @noindent
23007 Alternatively, create a dedicated header file:
23009 @example
23010 DISTCLEANFILES = myprog-paths.h
23011 myprog-paths.h: Makefile
23012         echo '#define DATADIR "$(datadir)"' >$@@
23013 @end example
23015 @item
23016 Use @code{AC_DEFINE} but have @command{configure} compute the literal
23017 value of @code{datadir} and others.  Many people have wrapped macros to
23018 automate this task; for an example, see the macro @code{AC_DEFINE_DIR} from
23019 the @uref{http://@/autoconf-archive@/.cryp.to/, Autoconf Macro
23020 Archive}.
23022 This solution does not conform to the @acronym{GNU} Coding Standards.
23024 @item
23025 Note that all the previous solutions hard wire the absolute name of
23026 these directories in the executables, which is not a good property.  You
23027 may try to compute the names relative to @code{prefix}, and try to
23028 find @code{prefix} at runtime, this way your package is relocatable.
23029 @end itemize
23032 @node Autom4te Cache
23033 @section What is @file{autom4te.cache}?
23035 @display
23036 What is this directory @file{autom4te.cache}?  Can I safely remove it?
23037 @end display
23039 In the @acronym{GNU} Build System, @file{configure.ac} plays a central
23040 role and is read by many tools: @command{autoconf} to create
23041 @file{configure}, @command{autoheader} to create @file{config.h.in},
23042 @command{automake} to create @file{Makefile.in}, @command{autoscan} to
23043 check the completeness of @file{configure.ac}, @command{autoreconf} to
23044 check the @acronym{GNU} Build System components that are used.  To
23045 ``read @file{configure.ac}'' actually means to compile it with M4,
23046 which can be a long process for complex @file{configure.ac}.
23048 This is why all these tools, instead of running directly M4, invoke
23049 @command{autom4te} (@pxref{autom4te Invocation}) which, while answering to
23050 a specific demand, stores additional information in
23051 @file{autom4te.cache} for future runs.  For instance, if you run
23052 @command{autoconf}, behind the scenes, @command{autom4te} also
23053 stores information for the other tools, so that when you invoke
23054 @command{autoheader} or @command{automake} etc., reprocessing
23055 @file{configure.ac} is not needed.  The speed up is frequently 30%,
23056 and is increasing with the size of @file{configure.ac}.
23058 But it is and remains being simply a cache: you can safely remove it.
23060 @sp 1
23062 @display
23063 Can I permanently get rid of it?
23064 @end display
23066 The creation of this cache can be disabled from
23067 @file{~/.autom4te.cfg}, see @ref{Customizing autom4te}, for more
23068 details.  You should be aware that disabling the cache slows down the
23069 Autoconf test suite by 40%.  The more @acronym{GNU} Build System
23070 components are used, the more the cache is useful; for instance
23071 running @samp{autoreconf -f} on the Core Utilities is twice slower without
23072 the cache @emph{although @option{--force} implies that the cache is
23073 not fully exploited}, and eight times slower than without
23074 @option{--force}.
23077 @node Present But Cannot Be Compiled
23078 @section Header Present But Cannot Be Compiled
23080 The most important guideline to bear in mind when checking for
23081 features is to mimic as much as possible the intended use.
23082 Unfortunately, old versions of @code{AC_CHECK_HEADER} and
23083 @code{AC_CHECK_HEADERS} failed to follow this idea, and called
23084 the preprocessor, instead of the compiler, to check for headers.  As a
23085 result, incompatibilities between headers went unnoticed during
23086 configuration, and maintainers finally had to deal with this issue
23087 elsewhere.
23089 The transition began with Autoconf 2.56.  As of Autoconf 2.64 both
23090 checks are performed, and @command{configure} complains loudly if the
23091 compiler and the preprocessor do not agree.  However, only the compiler
23092 result is considered.
23094 Consider the following example:
23096 @smallexample
23097 $ @kbd{cat number.h}
23098 typedef int number;
23099 $ @kbd{cat pi.h}
23100 const number pi = 3;
23101 $ @kbd{cat configure.ac}
23102 AC_INIT([Example], [1.0], [bug-example@@example.org])
23103 AC_CHECK_HEADERS([pi.h])
23104 $ @kbd{autoconf -Wall}
23105 $ @kbd{./configure}
23106 checking for gcc... gcc
23107 checking for C compiler default output file name... a.out
23108 checking whether the C compiler works... yes
23109 checking whether we are cross compiling... no
23110 checking for suffix of executables...
23111 checking for suffix of object files... o
23112 checking whether we are using the GNU C compiler... yes
23113 checking whether gcc accepts -g... yes
23114 checking for gcc option to accept ISO C89... none needed
23115 checking how to run the C preprocessor... gcc -E
23116 checking for grep that handles long lines and -e... grep
23117 checking for egrep... grep -E
23118 checking for ANSI C header files... yes
23119 checking for sys/types.h... yes
23120 checking for sys/stat.h... yes
23121 checking for stdlib.h... yes
23122 checking for string.h... yes
23123 checking for memory.h... yes
23124 checking for strings.h... yes
23125 checking for inttypes.h... yes
23126 checking for stdint.h... yes
23127 checking for unistd.h... yes
23128 checking pi.h usability... no
23129 checking pi.h presence... yes
23130 configure: WARNING: pi.h: present but cannot be compiled
23131 configure: WARNING: pi.h:     check for missing prerequisite headers?
23132 configure: WARNING: pi.h: see the Autoconf documentation
23133 configure: WARNING: pi.h:     section "Present But Cannot Be Compiled"
23134 configure: WARNING: pi.h: proceeding with the compiler's result
23135 configure: WARNING:     ## -------------------------------------- ##
23136 configure: WARNING:     ## Report this to bug-example@@example.org ##
23137 configure: WARNING:     ## -------------------------------------- ##
23138 checking for pi.h... yes
23139 @end smallexample
23141 @noindent
23142 The proper way the handle this case is using the fourth argument
23143 (@pxref{Generic Headers}):
23145 @example
23146 $ @kbd{cat configure.ac}
23147 AC_INIT([Example], [1.0], [bug-example@@example.org])
23148 AC_CHECK_HEADERS([number.h pi.h], [], [],
23149 [[#ifdef HAVE_NUMBER_H
23150 # include <number.h>
23151 #endif
23153 $ @kbd{autoconf -Wall}
23154 $ @kbd{./configure}
23155 checking for gcc... gcc
23156 checking for C compiler default output... a.out
23157 checking whether the C compiler works... yes
23158 checking whether we are cross compiling... no
23159 checking for suffix of executables...
23160 checking for suffix of object files... o
23161 checking whether we are using the GNU C compiler... yes
23162 checking whether gcc accepts -g... yes
23163 checking for gcc option to accept ANSI C... none needed
23164 checking for number.h... yes
23165 checking for pi.h... yes
23166 @end example
23168 See @ref{Particular Headers}, for a list of headers with their
23169 prerequisites.
23171 @node Expanded Before Required
23172 @section Expanded Before Required
23174 @cindex expanded before required
23175 Older versions of Autoconf silently built files with incorrect ordering
23176 between dependent macros if an outer macro first expanded, then later
23177 indirectly required, an inner macro.  Starting with Autoconf 2.64, this
23178 situation no longer generates out-of-order code, but results in
23179 duplicate output and a syntax warning:
23181 @example
23182 $ @kbd{cat configure.ac}
23183 @result{}AC_DEFUN([TESTA], [[echo in A
23184 @result{}if test -n "$SEEN_A" ; then echo duplicate ; fi
23185 @result{}SEEN_A=:]])
23186 @result{}AC_DEFUN([TESTB], [AC_REQUIRE([TESTA])[echo in B
23187 @result{}if test -z "$SEEN_A" ; then echo bug ; fi]])
23188 @result{}AC_DEFUN([TESTC], [AC_REQUIRE([TESTB])[echo in C]])
23189 @result{}AC_DEFUN([OUTER], [[echo in OUTER]
23190 @result{}TESTA
23191 @result{}TESTC])
23192 @result{}AC_INIT
23193 @result{}OUTER
23194 @result{}AC_OUTPUT
23195 $ @kbd{autoconf}
23196 @result{}configure.ac:11: warning: AC_REQUIRE:
23197 @result{} `TESTA' was expanded before it was required
23198 @result{}configure.ac:4: TESTB is expanded from...
23199 @result{}configure.ac:6: TESTC is expanded from...
23200 @result{}configure.ac:7: OUTER is expanded from...
23201 @result{}configure.ac:11: the top level
23202 @end example
23204 @noindent
23205 To avoid this warning, decide what purpose the macro in question serves.
23206 If it only needs to be expanded once (for example, if it provides
23207 initialization text used by later macros), then the simplest fix is to
23208 change the macro to be declared with @code{AC_DEFUN_ONCE}
23209 (@pxref{One-Shot Macros}), although this only works in Autoconf 2.64 and
23210 newer.  A more portable fix is to change all
23211 instances of direct calls to instead go through @code{AC_REQUIRE}
23212 (@pxref{Prerequisite Macros}).  If, instead, the macro is parameterized
23213 by arguments or by the current definition of other macros in the m4
23214 environment, then the macro should always be directly expanded instead
23215 of required.
23217 For another case study, consider this example trimmed down from an
23218 actual package.  Originally, the package contained shell code and
23219 multiple macro invocations at the top level of @file{configure.ac}:
23221 @example
23222 AC_DEFUN([FOO], [AC_COMPILE_IFELSE([@dots{}])])
23223 foobar=
23224 AC_PROG_CC
23226 @end example
23228 @noindent
23229 but that was getting complex, so the author wanted to offload some of
23230 the text into a new macro in another file included via
23231 @file{aclocal.m4}.  The na@"ive approach merely wraps the text in a new
23232 macro:
23234 @example
23235 AC_DEFUN([FOO], [AC_COMPILE_IFELSE([@dots{}])])
23236 AC_DEFUN([BAR], [
23237 foobar=
23238 AC_PROG_CC
23242 @end example
23244 @noindent
23245 With older versions of Autoconf, the setting of @samp{foobar=} occurs
23246 before the single compiler check, as the author intended.  But with
23247 Autoconf 2.64, this issues the ``expanded before it was required''
23248 warning for @code{AC_PROG_CC}, and outputs two copies of the compiler
23249 check, one before @samp{foobar=}, and one after.  To understand why this
23250 is happening, remember that the use of @code{AC_COMPILE_IFELSE} includes
23251 a call to @code{AC_REQUIRE([AC_PROG_CC])} under the hood.  According to
23252 the documented semantics of @code{AC_REQUIRE}, this means that
23253 @code{AC_PROG_CC} @emph{must} occur before the body of the outermost
23254 @code{AC_DEFUN}, which in this case is @code{BAR}, thus preceeding the
23255 use of @samp{foobar=}.  The older versions of Autoconf were broken with
23256 regards to the rules of @code{AC_REQUIRE}, which explains why the code
23257 changed from one over to two copies of @code{AC_PROG_CC} when upgrading
23258 autoconf.  In other words, the author was unknowingly relying on a bug
23259 exploit to get the desired results, and that exploit broke once the bug
23260 was fixed.
23262 So, what recourse does the author have, to restore their intended
23263 semantics of setting @samp{foobar=} prior to a single compiler check,
23264 regardless of whether Autoconf 2.63 or 2.64 is used?  One idea is to
23265 remember that only @code{AC_DEFUN} is impacted by @code{AC_REQUIRE};
23266 there is always the possibility of using the lower-level
23267 @code{m4_define}:
23269 @example
23270 AC_DEFUN([FOO], [AC_COMPILE_IFELSE([@dots{}])])
23271 m4_define([BAR], [
23272 foobar=
23273 AC_PROG_CC
23277 @end example
23279 @noindent
23280 This works great if everything is in the same file.  However, it does
23281 not help in the case where the author wants to have @command{aclocal}
23282 find the definition of @code{BAR} from its own file, since
23283 @command{aclocal} requires the use of @code{AC_DEFUN}.  In this case, a
23284 better fix is to recognize that if @code{BAR} also uses
23285 @code{AC_REQUIRE}, then there will no longer be direct expansion prior
23286 to a subsequent require.  Then, by creating yet another helper macro,
23287 the author can once again guarantee a single invocation of
23288 @code{AC_PROG_CC}, which will still occur after @code{foobar=}.  The
23289 author can also use @code{AC_BEFORE} to make sure no other macro
23290 appearing before @code{BAR} has triggered an unwanted expansion of
23291 @code{AC_PROG_CC}.
23293 @example
23294 AC_DEFUN([FOO], [AC_COMPILE_IFELSE([@dots{}])])
23295 AC_DEFUN([BEFORE_CC], [
23296 foobar=
23298 AC_DEFUN([BAR], [
23299 AC_BEFORE([$0], [AC_PROG_CC])dnl
23300 AC_REQUIRE([BEFORE_CC])dnl
23301 AC_REQUIRE([AC_PROG_CC])dnl
23305 @end example
23308 @c ===================================================== History of Autoconf.
23310 @node History
23311 @chapter History of Autoconf
23312 @cindex History of autoconf
23314 You may be wondering, Why was Autoconf originally written?  How did it
23315 get into its present form?  (Why does it look like gorilla spit?)  If
23316 you're not wondering, then this chapter contains no information useful
23317 to you, and you might as well skip it.  If you @emph{are} wondering,
23318 then let there be light@enddots{}
23320 @menu
23321 * Genesis::                     Prehistory and naming of @command{configure}
23322 * Exodus::                      The plagues of M4 and Perl
23323 * Leviticus::                   The priestly code of portability arrives
23324 * Numbers::                     Growth and contributors
23325 * Deuteronomy::                 Approaching the promises of easy configuration
23326 @end menu
23328 @node Genesis
23329 @section Genesis
23331 In June 1991 I was maintaining many of the @acronym{GNU} utilities for the
23332 Free Software Foundation.  As they were ported to more platforms and
23333 more programs were added, the number of @option{-D} options that users
23334 had to select in the makefile (around 20) became burdensome.
23335 Especially for me---I had to test each new release on a bunch of
23336 different systems.  So I wrote a little shell script to guess some of
23337 the correct settings for the fileutils package, and released it as part
23338 of fileutils 2.0.  That @command{configure} script worked well enough that
23339 the next month I adapted it (by hand) to create similar @command{configure}
23340 scripts for several other @acronym{GNU} utilities packages.  Brian Berliner
23341 also adapted one of my scripts for his @acronym{CVS} revision control system.
23343 Later that summer, I learned that Richard Stallman and Richard Pixley
23344 were developing similar scripts to use in the @acronym{GNU} compiler tools;
23345 so I adapted my @command{configure} scripts to support their evolving
23346 interface: using the file name @file{Makefile.in} as the templates;
23347 adding @samp{+srcdir}, the first option (of many); and creating
23348 @file{config.status} files.
23350 @node Exodus
23351 @section Exodus
23353 As I got feedback from users, I incorporated many improvements, using
23354 Emacs to search and replace, cut and paste, similar changes in each of
23355 the scripts.  As I adapted more @acronym{GNU} utilities packages to use
23356 @command{configure} scripts, updating them all by hand became impractical.
23357 Rich Murphey, the maintainer of the @acronym{GNU} graphics utilities, sent me
23358 mail saying that the @command{configure} scripts were great, and asking if
23359 I had a tool for generating them that I could send him.  No, I thought,
23360 but I should!  So I started to work out how to generate them.  And the
23361 journey from the slavery of hand-written @command{configure} scripts to the
23362 abundance and ease of Autoconf began.
23364 Cygnus @command{configure}, which was being developed at around that time,
23365 is table driven; it is meant to deal mainly with a discrete number of
23366 system types with a small number of mainly unguessable features (such as
23367 details of the object file format).  The automatic configuration system
23368 that Brian Fox had developed for Bash takes a similar approach.  For
23369 general use, it seems to me a hopeless cause to try to maintain an
23370 up-to-date database of which features each variant of each operating
23371 system has.  It's easier and more reliable to check for most features on
23372 the fly---especially on hybrid systems that people have hacked on
23373 locally or that have patches from vendors installed.
23375 I considered using an architecture similar to that of Cygnus
23376 @command{configure}, where there is a single @command{configure} script that
23377 reads pieces of @file{configure.in} when run.  But I didn't want to have
23378 to distribute all of the feature tests with every package, so I settled
23379 on having a different @command{configure} made from each
23380 @file{configure.in} by a preprocessor.  That approach also offered more
23381 control and flexibility.
23383 I looked briefly into using the Metaconfig package, by Larry Wall,
23384 Harlan Stenn, and Raphael Manfredi, but I decided not to for several
23385 reasons.  The @command{Configure} scripts it produces are interactive,
23386 which I find quite inconvenient; I didn't like the ways it checked for
23387 some features (such as library functions); I didn't know that it was
23388 still being maintained, and the @command{Configure} scripts I had
23389 seen didn't work on many modern systems (such as System V R4 and NeXT);
23390 it wasn't flexible in what it could do in response to a feature's
23391 presence or absence; I found it confusing to learn; and it was too big
23392 and complex for my needs (I didn't realize then how much Autoconf would
23393 eventually have to grow).
23395 I considered using Perl to generate my style of @command{configure}
23396 scripts, but decided that M4 was better suited to the job of simple
23397 textual substitutions: it gets in the way less, because output is
23398 implicit.  Plus, everyone already has it.  (Initially I didn't rely on
23399 the @acronym{GNU} extensions to M4.)  Also, some of my friends at the
23400 University of Maryland had recently been putting M4 front ends on
23401 several programs, including @code{tvtwm}, and I was interested in trying
23402 out a new language.
23404 @node Leviticus
23405 @section Leviticus
23407 Since my @command{configure} scripts determine the system's capabilities
23408 automatically, with no interactive user intervention, I decided to call
23409 the program that generates them Autoconfig.  But with a version number
23410 tacked on, that name would be too long for old Unix file systems,
23411 so I shortened it to Autoconf.
23413 In the fall of 1991 I called together a group of fellow questers after
23414 the Holy Grail of portability (er, that is, alpha testers) to give me
23415 feedback as I encapsulated pieces of my handwritten scripts in M4 macros
23416 and continued to add features and improve the techniques used in the
23417 checks.  Prominent among the testers were Fran@,{c}ois Pinard, who came up
23418 with the idea of making an Autoconf shell script to run M4
23419 and check for unresolved macro calls; Richard Pixley, who suggested
23420 running the compiler instead of searching the file system to find
23421 include files and symbols, for more accurate results; Karl Berry, who
23422 got Autoconf to configure @TeX{} and added the macro index to the
23423 documentation; and Ian Lance Taylor, who added support for creating a C
23424 header file as an alternative to putting @option{-D} options in a
23425 makefile, so he could use Autoconf for his @acronym{UUCP} package.
23426 The alpha testers cheerfully adjusted their files again and again as the
23427 names and calling conventions of the Autoconf macros changed from
23428 release to release.  They all contributed many specific checks, great
23429 ideas, and bug fixes.
23431 @node Numbers
23432 @section Numbers
23434 In July 1992, after months of alpha testing, I released Autoconf 1.0,
23435 and converted many @acronym{GNU} packages to use it.  I was surprised by how
23436 positive the reaction to it was.  More people started using it than I
23437 could keep track of, including people working on software that wasn't
23438 part of the @acronym{GNU} Project (such as TCL, FSP, and Kerberos V5).
23439 Autoconf continued to improve rapidly, as many people using the
23440 @command{configure} scripts reported problems they encountered.
23442 Autoconf turned out to be a good torture test for M4 implementations.
23443 Unix M4 started to dump core because of the length of the
23444 macros that Autoconf defined, and several bugs showed up in @acronym{GNU}
23445 M4 as well.  Eventually, we realized that we needed to use some
23446 features that only @acronym{GNU} M4 has.  4.3@acronym{BSD} M4, in
23447 particular, has an impoverished set of builtin macros; the System V
23448 version is better, but still doesn't provide everything we need.
23450 More development occurred as people put Autoconf under more stresses
23451 (and to uses I hadn't anticipated).  Karl Berry added checks for X11.
23452 david zuhn contributed C++ support.  Fran@,{c}ois Pinard made it diagnose
23453 invalid arguments.  Jim Blandy bravely coerced it into configuring
23454 @acronym{GNU} Emacs, laying the groundwork for several later improvements.
23455 Roland McGrath got it to configure the @acronym{GNU} C Library, wrote the
23456 @command{autoheader} script to automate the creation of C header file
23457 templates, and added a @option{--verbose} option to @command{configure}.
23458 Noah Friedman added the @option{--autoconf-dir} option and
23459 @code{AC_MACRODIR} environment variable.  (He also coined the term
23460 @dfn{autoconfiscate} to mean ``adapt a software package to use
23461 Autoconf''.)  Roland and Noah improved the quoting protection in
23462 @code{AC_DEFINE} and fixed many bugs, especially when I got sick of
23463 dealing with portability problems from February through June, 1993.
23465 @node Deuteronomy
23466 @section Deuteronomy
23468 A long wish list for major features had accumulated, and the effect of
23469 several years of patching by various people had left some residual
23470 cruft.  In April 1994, while working for Cygnus Support, I began a major
23471 revision of Autoconf.  I added most of the features of the Cygnus
23472 @command{configure} that Autoconf had lacked, largely by adapting the
23473 relevant parts of Cygnus @command{configure} with the help of david zuhn
23474 and Ken Raeburn.  These features include support for using
23475 @file{config.sub}, @file{config.guess}, @option{--host}, and
23476 @option{--target}; making links to files; and running @command{configure}
23477 scripts in subdirectories.  Adding these features enabled Ken to convert
23478 @acronym{GNU} @code{as}, and Rob Savoye to convert Deja@acronym{GNU}, to using
23479 Autoconf.
23481 I added more features in response to other peoples' requests.  Many
23482 people had asked for @command{configure} scripts to share the results of
23483 the checks between runs, because (particularly when configuring a large
23484 source tree, like Cygnus does) they were frustratingly slow.  Mike
23485 Haertel suggested adding site-specific initialization scripts.  People
23486 distributing software that had to unpack on MS-DOS asked for a way to
23487 override the @file{.in} extension on the file names, which produced file
23488 names like @file{config.h.in} containing two dots.  Jim Avera did an
23489 extensive examination of the problems with quoting in @code{AC_DEFINE}
23490 and @code{AC_SUBST}; his insights led to significant improvements.
23491 Richard Stallman asked that compiler output be sent to @file{config.log}
23492 instead of @file{/dev/null}, to help people debug the Emacs
23493 @command{configure} script.
23495 I made some other changes because of my dissatisfaction with the quality
23496 of the program.  I made the messages showing results of the checks less
23497 ambiguous, always printing a result.  I regularized the names of the
23498 macros and cleaned up coding style inconsistencies.  I added some
23499 auxiliary utilities that I had developed to help convert source code
23500 packages to use Autoconf.  With the help of Fran@,{c}ois Pinard, I made
23501 the macros not interrupt each others' messages.  (That feature revealed
23502 some performance bottlenecks in @acronym{GNU} M4, which he hastily
23503 corrected!)  I reorganized the documentation around problems people want
23504 to solve.  And I began a test suite, because experience had shown that
23505 Autoconf has a pronounced tendency to regress when we change it.
23507 Again, several alpha testers gave invaluable feedback, especially
23508 Fran@,{c}ois Pinard, Jim Meyering, Karl Berry, Rob Savoye, Ken Raeburn,
23509 and Mark Eichin.
23511 Finally, version 2.0 was ready.  And there was much rejoicing.  (And I
23512 have free time again.  I think.  Yeah, right.)
23515 @c ========================================================== Appendices
23518 @node GNU Free Documentation License
23519 @appendix GNU Free Documentation License
23521 @include fdl.texi
23523 @node Indices
23524 @appendix Indices
23526 @menu
23527 * Environment Variable Index::  Index of environment variables used
23528 * Output Variable Index::       Index of variables set in output files
23529 * Preprocessor Symbol Index::   Index of C preprocessor symbols defined
23530 * Autoconf Macro Index::        Index of Autoconf macros
23531 * M4 Macro Index::              Index of M4, M4sugar, and M4sh macros
23532 * Autotest Macro Index::        Index of Autotest macros
23533 * Program & Function Index::    Index of those with portability problems
23534 * Concept Index::               General index
23535 @end menu
23537 @node Environment Variable Index
23538 @appendixsec Environment Variable Index
23540 This is an alphabetical list of the environment variables that Autoconf
23541 checks.
23543 @printindex ev
23545 @node Output Variable Index
23546 @appendixsec Output Variable Index
23548 This is an alphabetical list of the variables that Autoconf can
23549 substitute into files that it creates, typically one or more
23550 makefiles.  @xref{Setting Output Variables}, for more information
23551 on how this is done.
23553 @printindex ov
23555 @node Preprocessor Symbol Index
23556 @appendixsec Preprocessor Symbol Index
23558 This is an alphabetical list of the C preprocessor symbols that the
23559 Autoconf macros define.  To work with Autoconf, C source code needs to
23560 use these names in @code{#if} or @code{#ifdef} directives.
23562 @printindex cv
23564 @node Autoconf Macro Index
23565 @appendixsec Autoconf Macro Index
23567 This is an alphabetical list of the Autoconf macros.
23568 @ifset shortindexflag
23569 To make the list easier to use, the macros are listed without their
23570 preceding @samp{AC_}.
23571 @end ifset
23573 @printindex AC
23575 @node M4 Macro Index
23576 @appendixsec M4 Macro Index
23578 This is an alphabetical list of the M4, M4sugar, and M4sh macros.
23579 @ifset shortindexflag
23580 To make the list easier to use, the macros are listed without their
23581 preceding @samp{m4_} or @samp{AS_}.
23582 @end ifset
23584 @printindex MS
23586 @node Autotest Macro Index
23587 @appendixsec Autotest Macro Index
23589 This is an alphabetical list of the Autotest macros.
23590 @ifset shortindexflag
23591 To make the list easier to use, the macros are listed without their
23592 preceding @samp{AT_}.
23593 @end ifset
23595 @printindex AT
23597 @node Program & Function Index
23598 @appendixsec Program and Function Index
23600 This is an alphabetical list of the programs and functions whose
23601 portability is discussed in this document.
23603 @printindex pr
23605 @node Concept Index
23606 @appendixsec Concept Index
23608 This is an alphabetical list of the files, tools, and concepts
23609 introduced in this document.
23611 @printindex cp
23613 @bye
23615 @c  LocalWords:  texinfo setfilename autoconf texi settitle setchapternewpage
23616 @c  LocalWords:  setcontentsaftertitlepage finalout ARG ovar varname dvar acx
23617 @c  LocalWords:  makeinfo dvi defcodeindex ev ov CPP cv Autotest mv defindex fn
23618 @c  LocalWords:  shortindexflag iftex ifset acindex ACindex ifclear ahindex fu
23619 @c  LocalWords:  asindex MSindex atindex ATindex auindex hdrindex prindex FIXME
23620 @c  LocalWords:  msindex alloca fnindex Aaarg indices FSF's dircategory ifnames
23621 @c  LocalWords:  direntry autoscan autoreconf autoheader autoupdate config FDs
23622 @c  LocalWords:  testsuite titlepage Elliston Demaille vskip filll ifnottex hmm
23623 @c  LocalWords:  insertcopying Autoconf's detailmenu Automake Libtool Posix ois
23624 @c  LocalWords:  Systemology Checkpointing Changequote INTERCAL changequote dfn
23625 @c  LocalWords:  Quadrigraphs builtins Shellology acconfig Bugward LIBOBJ Imake
23626 @c  LocalWords:  LIBOBJS IFELSE cindex flushright Pinard Metaconfig uref Simons
23627 @c  LocalWords:  distclean uninstall noindent versioning Tromey dir
23628 @c  LocalWords:  SAMS samp aclocal acsite underquoted emph itemx prepend SUBST
23629 @c  LocalWords:  evindex automake Gettext autopoint gettext symlink libtoolize
23630 @c  LocalWords:  defmac INIT tarname ovindex cvindex BUGREPORT PREREQ asis PROG
23631 @c  LocalWords:  SRCDIR srcdir globbing afterwards cmds foos fooo foooo init cd
23632 @c  LocalWords:  builddir timestamp src Imakefile chmod defvar CFLAGS CPPFLAGS
23633 @c  LocalWords:  CXXFLAGS DEFS DHAVE defvarx FCFLAGS FFLAGS LDFLAGS bindir GCC
23634 @c  LocalWords:  datadir datarootdir docdir dvidir htmldir libdir ifnothtml kbd
23635 @c  LocalWords:  includedir infodir libexecdir localedir localstatedir mandir
23636 @c  LocalWords:  oldincludedir pdfdir PDF psdir PostScript sbindir sysconfdir
23637 @c  LocalWords:  sharedstatedir DDATADIR sed tmp pkgdatadir VPATH conf unistd
23638 @c  LocalWords:  undef endif builtin FUNCS ifndef STACKSEG getb GETB YMP fubar
23639 @c  LocalWords:  PRE dest SUBDIRS subdirs fi struct STDC stdlib stddef INTTYPES
23640 @c  LocalWords:  inttypes STDINT stdint AWK AIX Solaris NeXT env EGREP FGREP yy
23641 @c  LocalWords:  LEXLIB YYTEXT lfl nonportable Automake's LN RANLIB byacc INETD
23642 @c  LocalWords:  inetd prog PROGS progs ranlib lmp lXt lX nsl gethostbyname UX
23643 @c  LocalWords:  NextStep isinf isnan glibc IRIX sunmath lm lsunmath pre sizeof
23644 @c  LocalWords:  ld inline malloc putenv setenv FreeBSD realloc SunOS MinGW
23645 @c  LocalWords:  snprintf vsnprintf sprintf vsprintf sscanf gcc strerror ifdef
23646 @c  LocalWords:  strnlen sysconf PAGESIZE unsetenv va fallback memcpy dst FUNC
23647 @c  LocalWords:  PowerPC GNUC libPW pragma Olibcalls CHOWN chown CLOSEDIR VFORK
23648 @c  LocalWords:  closedir FNMATCH fnmatch vfork FSEEKO LARGEFILE fseeko SVR sc
23649 @c  LocalWords:  largefile GETGROUPS getgroups GETLOADAVG DGUX UMAX NLIST KMEM
23650 @c  LocalWords:  SETGID getloadavg nlist GETMNTENT irix
23651 @c  LocalWords:  getmntent UnixWare GETPGRP getpgid getpgrp Posix's pid LSTAT
23652 @c  LocalWords:  lstat rpl MEMCMP memcmp OpenStep MBRTOWC mbrtowc MKTIME mktime
23653 @c  LocalWords:  localtime MMAP mmap OBSTACK obstack obstacks ARGTYPES timeval
23654 @c  LocalWords:  SETPGRP setpgrp defmacx Hurd SETVBUF setvbuf STRCOLL strcoll
23655 @c  LocalWords:  STRTOD strtod DECL STRFTIME strftime SCO UTIME utime VPRINTF
23656 @c  LocalWords:  DOPRNT vprintf doprnt sp unfixable LIBSOURCE LIBSOURCES Eggert
23657 @c  LocalWords:  linux netinet ia Tru XFree DIRENT NDIR dirent ndir multitable
23658 @c  LocalWords:  NAMLEN strlen namlen MKDEV SYSMACROS makedev RESOLV resolv DNS
23659 @c  LocalWords:  inet structs NAMESER arpa NETDB netdb UTekV UTS GCC's kB
23660 @c  LocalWords:  STDBOOL BOOL stdbool conformant cplusplus bool Bool stdarg tm
23661 @c  LocalWords:  ctype strchr strrchr rindex bcopy memmove memchr WEXITSTATUS
23662 @c  LocalWords:  WIFEXITED TIOCGWINSZ GWINSZ termios preprocess preprocessable
23663 @c  LocalWords:  DECLS strdup calloc BLKSIZE blksize RDEV rdev TZNAME tzname pw
23664 @c  LocalWords:  passwd gecos pwd MBSTATE mbstate wchar RETSIGTYPE hup UID uid
23665 @c  LocalWords:  gid ptrdiff uintmax EXEEXT OBJEXT Ae conftest AXP str
23666 @c  LocalWords:  ALIGNOF WERROR Werror cpp HP's WorkShop egcs un fied stdc CXX
23667 @c  LocalWords:  varargs BIGENDIAN Endianness SPARC endianness grep'ed CONST FC
23668 @c  LocalWords:  const STRINGIZE stringizing PARAMS unprotoize protos KCC cxx
23669 @c  LocalWords:  xlC aCC CXXCPP FREEFORM xlf FLIBS FCLIBS ish SRCEXT XTRA LFS
23670 @c  LocalWords:  ISC lcposix MINIX Minix conditionalized inlines hw dD confdefs
23671 @c  LocalWords:  fputs stdout PREPROC ar UFS HFS QNX realtime fstype STATVFS se
23672 @c  LocalWords:  statvfs STATFS statfs func machfile hdr lelf raboof DEFUN GTK
23673 @c  LocalWords:  GTKMM Grmph ified ine defn baz EOF qar Ahhh changecom algol io
23674 @c  LocalWords:  changeword quadrigraphs quadrigraph dnl SGI atoi overquoting
23675 @c  LocalWords:  Aas Wcross sep args namespace undefine bpatsubst popdef dquote
23676 @c  LocalWords:  bregexp Overquote overquotation meisch maisch meische maische
23677 @c  LocalWords:  miscian DIRNAME dirname MKDIR CATFILE XMKMF TRAVOLTA celsius
23678 @c  LocalWords:  EMX emxos Emacsen Korn DYNIX subshell posix Ksh ksh Pdksh Zsh
23679 @c  LocalWords:  pdksh zsh Allbery Lipe Kubota UWS zorglub stderr eval esac lfn
23680 @c  LocalWords:  drivespec Posixy DJGPP doschk prettybird LPT pfew Zsh's yu yaa
23681 @c  LocalWords:  yM uM aM firebird IP subdir misparses ok Unpatched abc bc zA
23682 @c  LocalWords:  CDPATH DUALCASE LINENO prepass Subshells lineno NULLCMD cmp wc
23683 @c  LocalWords:  MAILPATH scanset arg NetBSD Almquist printf expr cp
23684 @c  LocalWords:  Oliva awk Aaaaarg cmd regex xfoo GNV OpenVMS VM
23685 @c  LocalWords:  sparc Proulx nbar nfoo maxdepth acdilrtu TWG mc
23686 @c  LocalWords:  mkdir exe uname OpenBSD Fileutils mktemp umask TMPDIR guid os
23687 @c  LocalWords:  fooXXXXXX Unicos utimes hpux hppa unescaped
23688 @c  LocalWords:  pmake DOS's gmake ifoo DESTDIR autoconfiscated pc coff mips gg
23689 @c  LocalWords:  dec ultrix cpu wildcards rpcc rdtsc powerpc readline
23690 @c  LocalWords:  withval vxworks gless localcache usr LOFF loff CYGWIN Cygwin
23691 @c  LocalWords:  cygwin SIGLIST siglist SYSNDIR SYSDIR ptx lseq rusage elif MSC
23692 @c  LocalWords:  lfoo POUNDBANG lsun NIS getpwnam SYSCALLS RSH INTL lintl aix
23693 @c  LocalWords:  intl lx ldir syslog bsd EPI toolchain netbsd objext de KNR nn
23694 @c  LocalWords:  fication LTLIBOBJS Wdiff TESTDIR atconfig atlocal akim XFAIL
23695 @c  LocalWords:  ChangeLog prepended errexit smallexample TESTSUITEFLAGS GPL er
23696 @c  LocalWords:  installcheck autotest indir Pixley Bothner Eichin Kerberos adl
23697 @c  LocalWords:  DISTCLEANFILES preprocessor's fileutils Stallman Murphey Stenn
23698 @c  LocalWords:  Manfredi Autoconfig TCL FSP david zuhn Blandy MACRODIR Raeburn
23699 @c  LocalWords:  autoconfiscate Savoye Haertel Avera Meyering fdl appendixsec
23700 @c  LocalWords:  printindex american LIBOBJDIR LibdirTest ERLCFLAGS OBJCFLAGS
23701 @c  LocalWords:  VER Gnulib online xyes strcpy TYPEOF typeof OBJC objcc objc ln
23702 @c  LocalWords:  GOBJC OTP ERLC erl valloc decr dumpdef errprint incr
23703 @c  LocalWords:  esyscmd len maketemp pushdef substr syscmd sysval translit txt
23704 @c  LocalWords:  sinclude foreach myvar tolower toupper uniq BASENAME STDIN
23705 @c  LocalWords:  Dynix descrips basename aname cname macroexpands xno xcheck
23706 @c  LocalWords:  LIBREADLINE lreadline lncurses libreadline
23708 @c Local Variables:
23709 @c fill-column: 72
23710 @c ispell-local-dictionary: "american"
23711 @c indent-tabs-mode: nil
23712 @c whitespace-check-buffer-indent: nil
23713 @c End: