source: trunk/src/binutils/etc/configure.info-1@ 2352

Last change on this file since 2352 was 610, checked in by bird, 22 years ago

This commit was generated by cvs2svn to compensate for changes in r609,
which included commits to RCS files with non-trunk default branches.

  • Property cvs2svn:cvs-rev set to 1.1.1.2
  • Property svn:eol-style set to native
  • Property svn:executable set to *
File size: 47.6 KB
Line 
1This is configure.info, produced by makeinfo version 4.3 from
2./configure.texi.
3
4INFO-DIR-SECTION GNU admin
5START-INFO-DIR-ENTRY
6* configure: (configure). The GNU configure and build system
7END-INFO-DIR-ENTRY
8
9 This file documents the GNU configure and build system.
10
11 Copyright (C) 1998 Cygnus Solutions.
12
13 Permission is granted to make and distribute verbatim copies of this
14manual provided the copyright notice and this permission notice are
15preserved on all copies.
16
17 Permission is granted to copy and distribute modified versions of
18this manual under the conditions for verbatim copying, provided that
19the entire resulting derived work is distributed under the terms of a
20permission notice identical to this one.
21
22 Permission is granted to copy and distribute translations of this
23manual into another language, under the above conditions for modified
24versions, except that this permission notice may be stated in a
25translation approved by the Foundation.
26
27
28File: configure.info, Node: Top, Next: Introduction, Up: (dir)
29
30GNU configure and build system
31******************************
32
33 The GNU configure and build system.
34
35* Menu:
36
37* Introduction:: Introduction.
38* Getting Started:: Getting Started.
39* Files:: Files.
40* Configuration Names:: Configuration Names.
41* Cross Compilation Tools:: Cross Compilation Tools.
42* Canadian Cross:: Canadian Cross.
43* Cygnus Configure:: Cygnus Configure.
44* Multilibs:: Multilibs.
45* FAQ:: Frequently Asked Questions.
46* Index:: Index.
47
48
49File: configure.info, Node: Introduction, Next: Getting Started, Prev: Top, Up: Top
50
51Introduction
52************
53
54 This document describes the GNU configure and build systems. It
55describes how autoconf, automake, libtool, and make fit together. It
56also includes a discussion of the older Cygnus configure system.
57
58 This document does not describe in detail how to use each of the
59tools; see the respective manuals for that. Instead, it describes
60which files the developer must write, which files are machine generated
61and how they are generated, and where certain common problems should be
62addressed.
63
64 This document draws on several sources, including the autoconf
65manual by David MacKenzie (*note autoconf overview: (autoconf)Top.),
66the automake manual by David MacKenzie and Tom Tromey (*note automake
67overview: (automake)Top.), the libtool manual by Gordon Matzigkeit
68(*note libtool overview: (libtool)Top.), and the Cygnus configure
69manual by K. Richard Pixley.
70
71* Menu:
72
73* Goals:: Goals.
74* Tools:: The tools.
75* History:: History.
76* Building:: Building.
77
78
79File: configure.info, Node: Goals, Next: Tools, Up: Introduction
80
81Goals
82=====
83
84 The GNU configure and build system has two main goals.
85
86 The first is to simplify the development of portable programs. The
87system permits the developer to concentrate on writing the program,
88simplifying many details of portability across Unix and even Windows
89systems, and permitting the developer to describe how to build the
90program using simple rules rather than complex Makefiles.
91
92 The second is to simplify the building of programs distributed as
93source code. All programs are built using a simple, standardized, two
94step process. The program builder need not install any special tools in
95order to build the program.
96
97
98File: configure.info, Node: Tools, Next: History, Prev: Goals, Up: Introduction
99
100Tools
101=====
102
103 The GNU configure and build system is comprised of several different
104tools. Program developers must build and install all of these tools.
105
106 People who just want to build programs from distributed sources
107normally do not need any special tools beyond a Unix shell, a make
108program, and a C compiler.
109
110autoconf
111 provides a general portability framework, based on testing the
112 features of the host system at build time.
113
114automake
115 a system for describing how to build a program, permitting the
116 developer to write a simplified `Makefile'.
117
118libtool
119 a standardized approach to building shared libraries.
120
121gettext
122 provides a framework for translation of text messages into other
123 languages; not really discussed in this document.
124
125m4
126 autoconf requires the GNU version of m4; the standard Unix m4 does
127 not suffice.
128
129perl
130 automake requires perl.
131
132
133File: configure.info, Node: History, Next: Building, Prev: Tools, Up: Introduction
134
135History
136=======
137
138 This is a very brief and probably inaccurate history.
139
140 As the number of Unix variants increased during the 1980s, it became
141harder to write programs which could run on all variants. While it was
142often possible to use `#ifdef' to identify particular systems,
143developers frequently did not have access to every system, and the
144characteristics of some systems changed from version to version.
145
146 By 1992, at least three different approaches had been developed:
147 * The Metaconfig program, by Larry Wall, Harlan Stenn, and Raphael
148 Manfredi.
149
150 * The Cygnus configure script, by K. Richard Pixley, and the gcc
151 configure script, by Richard Stallman. These use essentially the
152 same approach, and the developers communicated regularly.
153
154 * The autoconf program, by David MacKenzie.
155
156 The Metaconfig program is still used for Perl and a few other
157programs. It is part of the Dist package. I do not know if it is
158being developed.
159
160 In 1994, David MacKenzie and others modified autoconf to incorporate
161all the features of Cygnus configure. Since then, there has been a
162slow but steady conversion of GNU programs from Cygnus configure to
163autoconf. gcc has been converted, eliminating the gcc configure script.
164
165 GNU autoconf was regularly maintained until late 1996. As of this
166writing in June, 1998, it has no public maintainer.
167
168 Most programs are built using the make program, which requires the
169developer to write Makefiles describing how to build the programs.
170Since most programs are built in pretty much the same way, this led to a
171lot of duplication.
172
173 The X Window system is built using the imake tool, which uses a
174database of rules to eliminate the duplication. However, building a
175tool which was developed using imake requires that the builder have
176imake installed, violating one of the goals of the GNU system.
177
178 The new BSD make provides a standard library of Makefile fragments,
179which permits developers to write very simple Makefiles. However, this
180requires that the builder install the new BSD make program.
181
182 In 1994, David MacKenzie wrote the first version of automake, which
183permitted writing a simple build description which was converted into a
184Makefile which could be used by the standard make program. In 1995, Tom
185Tromey completely rewrote automake in Perl, and he continues to enhance
186it.
187
188 Various free packages built libraries, and by around 1995 several
189included support to build shared libraries on various platforms.
190However, there was no consistent approach. In early 1996, Gordon
191Matzigkeit began working on libtool, which provided a standardized
192approach to building shared libraries. This was integrated into
193automake from the start.
194
195 The development of automake and libtool was driven by the GNITS
196project, a group of GNU maintainers who designed standardized tools to
197help meet the GNU coding standards.
198
199
200File: configure.info, Node: Building, Prev: History, Up: Introduction
201
202Building
203========
204
205 Most readers of this document should already know how to build a
206tool by running `configure' and `make'. This section may serve as a
207quick introduction or reminder.
208
209 Building a tool is normally as simple as running `configure'
210followed by `make'. You should normally run `configure' from an empty
211directory, using some path to refer to the `configure' script in the
212source directory. The directory in which you run `configure' is called
213the "object directory".
214
215 In order to use a object directory which is different from the source
216directory, you must be using the GNU version of `make', which has the
217required `VPATH' support. Despite this restriction, using a different
218object directory is highly recommended:
219 * It keeps the files generated during the build from cluttering up
220 your sources.
221
222 * It permits you to remove the built files by simply removing the
223 entire build directory.
224
225 * It permits you to build from the same sources with several sets of
226 configure options simultaneously.
227
228 If you don't have GNU `make', you will have to run `configure' in
229the source directory. All GNU packages should support this; in
230particular, GNU packages should not assume the presence of GNU `make'.
231
232 After running `configure', you can build the tools by running `make'.
233
234 To install the tools, run `make install'. Installing the tools will
235copy the programs and any required support files to the "installation
236directory". The location of the installation directory is controlled
237by `configure' options, as described below.
238
239 In the Cygnus tree at present, the info files are built and
240installed as a separate step. To build them, run `make info'. To
241install them, run `make install-info'.
242
243 All `configure' scripts support a wide variety of options. The most
244interesting ones are `--with' and `--enable' options which are
245generally specific to particular tools. You can usually use the
246`--help' option to get a list of interesting options for a particular
247configure script.
248
249 The only generic options you are likely to use are the `--prefix'
250and `--exec-prefix' options. These options are used to specify the
251installation directory.
252
253 The directory named by the `--prefix' option will hold machine
254independent files such as info files.
255
256 The directory named by the `--exec-prefix' option, which is normally
257a subdirectory of the `--prefix' directory, will hold machine dependent
258files such as executables.
259
260 The default for `--prefix' is `/usr/local'. The default for
261`--exec-prefix' is the value used for `--prefix'.
262
263 The convention used in Cygnus releases is to use a `--prefix' option
264of `/usr/cygnus/RELEASE', where RELEASE is the name of the release, and
265to use a `--exec-prefix' option of `/usr/cygnus/RELEASE/H-HOST', where
266HOST is the configuration name of the host system (*note Configuration
267Names::).
268
269 Do not use either the source or the object directory as the
270installation directory. That will just lead to confusion.
271
272
273File: configure.info, Node: Getting Started, Next: Files, Prev: Introduction, Up: Top
274
275Getting Started
276***************
277
278 To start using the GNU configure and build system with your software
279package, you must write three files, and you must run some tools to
280manually generate additional files.
281
282* Menu:
283
284* Write configure.in:: Write configure.in.
285* Write Makefile.am:: Write Makefile.am.
286* Write acconfig.h:: Write acconfig.h.
287* Generate files:: Generate files.
288* Getting Started Example:: Example.
289
290
291File: configure.info, Node: Write configure.in, Next: Write Makefile.am, Up: Getting Started
292
293Write configure.in
294==================
295
296 You must first write the file `configure.in'. This is an autoconf
297input file, and the autoconf manual describes in detail what this file
298should look like.
299
300 You will write tests in your `configure.in' file to check for
301conditions that may change from one system to another, such as the
302presence of particular header files or functions.
303
304 For example, not all systems support the `gettimeofday' function.
305If you want to use the `gettimeofday' function when it is available,
306and to use some other function when it is not, you would check for this
307by putting `AC_CHECK_FUNCS(gettimeofday)' in `configure.in'.
308
309 When the configure script is run at build time, this will arrange to
310define the preprocessor macro `HAVE_GETTIMEOFDAY' to the value 1 if the
311`gettimeofday' function is available, and to not define the macro at
312all if the function is not available. Your code can then use `#ifdef'
313to test whether it is safe to call `gettimeofday'.
314
315 If you have an existing body of code, the `autoscan' program may
316help identify potential portability problems, and hence configure tests
317that you will want to use. *Note Invoking autoscan: (autoconf)Invoking
318autoscan.
319
320 Another handy tool for an existing body of code is `ifnames'. This
321will show you all the preprocessor conditionals that the code already
322uses. *Note Invoking ifnames: (autoconf)Invoking ifnames.
323
324 Besides the portability tests which are specific to your particular
325package, every `configure.in' file should contain the following macros.
326
327`AC_INIT'
328 This macro takes a single argument, which is the name of a file in
329 your package. For example, `AC_INIT(foo.c)'.
330
331`AC_PREREQ(VERSION)'
332 This macro is optional. It may be used to indicate the version of
333 `autoconf' that you are using. This will prevent users from
334 running an earlier version of `autoconf' and perhaps getting an
335 invalid `configure' script. For example, `AC_PREREQ(2.12)'.
336
337`AM_INIT_AUTOMAKE'
338 This macro takes two arguments: the name of the package, and a
339 version number. For example, `AM_INIT_AUTOMAKE(foo, 1.0)'. (This
340 macro is not needed if you are not using automake).
341
342`AM_CONFIG_HEADER'
343 This macro names the header file which will hold the preprocessor
344 macro definitions at run time. Normally this should be
345 `config.h'. Your sources would then use `#include "config.h"' to
346 include it.
347
348 This macro may optionally name the input file for that header
349 file; by default, this is `config.h.in', but that file name works
350 poorly on DOS filesystems. Therefore, it is often better to name
351 it explicitly as `config.in'.
352
353 This is what you should normally put in `configure.in':
354 AM_CONFIG_HEADER(config.h:config.in)
355
356 (If you are not using automake, use `AC_CONFIG_HEADER' rather than
357 `AM_CONFIG_HEADER').
358
359`AM_MAINTAINER_MODE'
360 This macro always appears in Cygnus configure scripts. Other
361 programs may or may not use it.
362
363 If this macro is used, the `--enable-maintainer-mode' option is
364 required to enable automatic rebuilding of generated files used by
365 the configure system. This of course requires that developers be
366 aware of, and use, that option.
367
368 If this macro is not used, then the generated files will always be
369 rebuilt automatically. This will cause problems if the wrong
370 versions of autoconf, automake, or others are in the builder's
371 `PATH'.
372
373 (If you are not using automake, you do not need to use this macro).
374
375`AC_EXEEXT'
376 Either this macro or `AM_EXEEXT' always appears in Cygnus configure
377 files. Other programs may or may not use one of them.
378
379 This macro looks for the executable suffix used on the host
380 system. On Unix systems, this is the empty string. On Windows
381 systems, this is `.exe'. This macro directs automake to use the
382 executable suffix as appropriate when creating programs. This
383 macro does not take any arguments.
384
385 The `AC_EXEEXT' form is new, and is part of a Cygnus patch to
386 autoconf to support compiling with Visual C++. Older programs use
387 `AM_EXEEXT' instead.
388
389 (Programs which do not use automake use neither `AC_EXEEXT' nor
390 `AM_EXEEXT').
391
392`AC_PROG_CC'
393 If you are writing C code, you will normally want to use this
394 macro. It locates the C compiler to use. It does not take any
395 arguments.
396
397 However, if this `configure.in' file is for a library which is to
398 be compiled by a cross compiler which may not fully work, then you
399 will not want to use `AC_PROG_CC'. Instead, you will want to use a
400 variant which does not call the macro `AC_PROG_CC_WORKS'. Examples
401 can be found in various `configure.in' files for libraries that are
402 compiled with cross compilers, such as libiberty or libgloss.
403 This is essentially a bug in autoconf, and there will probably be
404 a better workaround at some point.
405
406`AC_PROG_CXX'
407 If you are writing C++ code, you will want to use this macro. It
408 locates the C++ compiler to use. It does not take any arguments.
409 The same cross compiler comments apply as for `AC_PROG_CC'.
410
411`AM_PROG_LIBTOOL'
412 If you want to build libraries, and you want to permit them to be
413 shared, or you want to link against libraries which were built
414 using libtool, then you will need this macro. This macro is
415 required in order to use libtool.
416
417 By default, this will cause all libraries to be built as shared
418 libraries. To prevent this-to change the default-use
419 `AM_DISABLE_SHARED' before `AM_PROG_LIBTOOL'. The configure
420 options `--enable-shared' and `--disable-shared' may be used to
421 override the default at build time.
422
423`AC_DEFINE(_GNU_SOURCE)'
424 GNU packages should normally include this line before any other
425 feature tests. This defines the macro `_GNU_SOURCE' when
426 compiling, which directs the libc header files to provide the
427 standard GNU system interfaces including all GNU extensions. If
428 this macro is not defined, certain GNU extensions may not be
429 available.
430
431`AC_OUTPUT'
432 This macro takes a list of file names which the configure process
433 should produce. This is normally a list of one or more `Makefile'
434 files in different directories. If your package lives entirely in
435 a single directory, you would use simply `AC_OUTPUT(Makefile)'.
436 If you also have, for example, a `lib' subdirectory, you would use
437 `AC_OUTPUT(Makefile lib/Makefile)'.
438
439 If you want to use locally defined macros in your `configure.in'
440file, then you will need to write a `acinclude.m4' file which defines
441them (if not using automake, this file is called `aclocal.m4').
442Alternatively, you can put separate macros in an `m4' subdirectory, and
443put `ACLOCAL_AMFLAGS = -I m4' in your `Makefile.am' file so that the
444`aclocal' program will be able to find them.
445
446 The different macro prefixes indicate which tool defines the macro.
447Macros which start with `AC_' are part of autoconf. Macros which start
448with `AM_' are provided by automake or libtool.
449
450
451File: configure.info, Node: Write Makefile.am, Next: Write acconfig.h, Prev: Write configure.in, Up: Getting Started
452
453Write Makefile.am
454=================
455
456 You must write the file `Makefile.am'. This is an automake input
457file, and the automake manual describes in detail what this file should
458look like.
459
460 The automake commands in `Makefile.am' mostly look like variable
461assignments in a `Makefile'. automake recognizes special variable
462names, and automatically add make rules to the output as needed.
463
464 There will be one `Makefile.am' file for each directory in your
465package. For each directory with subdirectories, the `Makefile.am'
466file should contain the line
467 SUBDIRS = DIR DIR ...
468
469where each DIR is the name of a subdirectory.
470
471 For each `Makefile.am', there should be a corresponding `Makefile'
472in the `AC_OUTPUT' macro in `configure.in'.
473
474 Every `Makefile.am' written at Cygnus should contain the line
475 AUTOMAKE_OPTIONS = cygnus
476
477This puts automake into Cygnus mode. See the automake manual for
478details.
479
480 You may to include the version number of `automake' that you are
481using on the `AUTOMAKE_OPTIONS' line. For example,
482 AUTOMAKE_OPTIONS = cygnus 1.3
483
484This will prevent users from running an earlier version of `automake'
485and perhaps getting an invalid `Makefile.in'.
486
487 If your package builds a program, then in the directory where that
488program is built you will normally want a line like
489 bin_PROGRAMS = PROGRAM
490
491where PROGRAM is the name of the program. You will then want a line
492like
493 PROGRAM_SOURCES = FILE FILE ...
494
495where each FILE is the name of a source file to link into the program
496(e.g., `foo.c').
497
498 If your package builds a library, and you do not want the library to
499ever be built as a shared library, then in the directory where that
500library is built you will normally want a line like
501 lib_LIBRARIES = libNAME.a
502
503where `libNAME.a' is the name of the library. You will then want a
504line like
505 libNAME_a_SOURCES = FILE FILE ...
506
507where each FILE is the name of a source file to add to the library.
508
509 If your package builds a library, and you want to permit building the
510library as a shared library, then in the directory where that library is
511built you will normally want a line like
512 lib_LTLIBRARIES = libNAME.la
513 The use of `LTLIBRARIES', and the `.la' extension, indicate a
514library to be built using libtool. As usual, you will then want a line
515like
516 libNAME_la_SOURCES = FILE FILE ...
517
518 The strings `bin' and `lib' that appear above in `bin_PROGRAMS' and
519`lib_LIBRARIES' are not arbitrary. They refer to particular
520directories, which may be set by the `--bindir' and `--libdir' options
521to `configure'. If those options are not used, the default values are
522based on the `--prefix' or `--exec-prefix' options to `configure'. It
523is possible to use other names if the program or library should be
524installed in some other directory.
525
526 The `Makefile.am' file may also contain almost anything that may
527appear in a normal `Makefile'. automake also supports many other
528special variables, as well as conditionals.
529
530 See the automake manual for more information.
531
532
533File: configure.info, Node: Write acconfig.h, Next: Generate files, Prev: Write Makefile.am, Up: Getting Started
534
535Write acconfig.h
536================
537
538 If you are generating a portability header file, (i.e., you are using
539`AM_CONFIG_HEADER' in `configure.in'), then you will have to write a
540`acconfig.h' file. It will have to contain the following lines.
541
542 /* Name of package. */
543 #undef PACKAGE
544
545 /* Version of package. */
546 #undef VERSION
547
548 This requirement is really a bug in the system, and the requirement
549may be eliminated at some later date.
550
551 The `acconfig.h' file will also similar comment and `#undef' lines
552for any unusual macros in the `configure.in' file, including any macro
553which appears in a `AC_DEFINE' macro.
554
555 In particular, if you are writing a GNU package and therefore include
556`AC_DEFINE(_GNU_SOURCE)' in `configure.in' as suggested above, you will
557need lines like this in `acconfig.h':
558 /* Enable GNU extensions. */
559 #undef _GNU_SOURCE
560
561 Normally the `autoheader' program will inform you of any such
562requirements by printing an error message when it is run. However, if
563you do anything particular odd in your `configure.in' file, you will
564have to make sure that the right entries appear in `acconfig.h', since
565otherwise the results of the tests may not be available in the
566`config.h' file which your code will use.
567
568 (Thee `PACKAGE' and `VERSION' lines are not required if you are not
569using automake, and in that case you may not need a `acconfig.h' file
570at all).
571
572
573File: configure.info, Node: Generate files, Next: Getting Started Example, Prev: Write acconfig.h, Up: Getting Started
574
575Generate files
576==============
577
578 Once you have written `configure.in', `Makefile.am', `acconfig.h',
579and possibly `acinclude.m4', you must use autoconf and automake
580programs to produce the first versions of the generated files. This is
581done by executing the following sequence of commands.
582
583 aclocal
584 autoconf
585 autoheader
586 automake
587
588 The `aclocal' and `automake' commands are part of the automake
589package, and the `autoconf' and `autoheader' commands are part of the
590autoconf package.
591
592 If you are using a `m4' subdirectory for your macros, you will need
593to use the `-I m4' option when you run `aclocal'.
594
595 If you are not using the Cygnus tree, use the `-a' option when
596running `automake' command in order to copy the required support files
597into your source directory.
598
599 If you are using libtool, you must build and install the libtool
600package with the same `--prefix' and `--exec-prefix' options as you
601used with the autoconf and automake packages. You must do this before
602running any of the above commands. If you are not using the Cygnus
603tree, you will need to run the `libtoolize' program to copy the libtool
604support files into your directory.
605
606 Once you have managed to run these commands without getting any
607errors, you should create a new empty directory, and run the `configure'
608script which will have been created by `autoconf' with the
609`--enable-maintainer-mode' option. This will give you a set of
610Makefiles which will include rules to automatically rebuild all the
611generated files.
612
613 After doing that, whenever you have changed some of the input files
614and want to regenerated the other files, go to your object directory
615and run `make'. Doing this is more reliable than trying to rebuild the
616files manually, because there are complex order dependencies and it is
617easy to forget something.
618
619
620File: configure.info, Node: Getting Started Example, Prev: Generate files, Up: Getting Started
621
622Example
623=======
624
625 Let's consider a trivial example.
626
627 Suppose we want to write a simple version of `touch'. Our program,
628which we will call `poke', will take a single file name argument, and
629use the `utime' system call to set the modification and access times of
630the file to the current time. We want this program to be highly
631portable.
632
633 We'll first see what this looks like without using autoconf and
634automake, and then see what it looks like with them.
635
636* Menu:
637
638* Getting Started Example 1:: First Try.
639* Getting Started Example 2:: Second Try.
640* Getting Started Example 3:: Third Try.
641* Generate Files in Example:: Generate Files.
642
643
644File: configure.info, Node: Getting Started Example 1, Next: Getting Started Example 2, Up: Getting Started Example
645
646First Try
647---------
648
649 Here is our first try at `poke.c'. Note that we've written it
650without ANSI/ISO C prototypes, since we want it to be highly portable.
651
652 #include <stdio.h>
653 #include <stdlib.h>
654 #include <sys/types.h>
655 #include <utime.h>
656
657 int
658 main (argc, argv)
659 int argc;
660 char **argv;
661 {
662 if (argc != 2)
663 {
664 fprintf (stderr, "Usage: poke file\n");
665 exit (1);
666 }
667
668 if (utime (argv[1], NULL) < 0)
669 {
670 perror ("utime");
671 exit (1);
672 }
673
674 exit (0);
675 }
676
677 We also write a simple `Makefile'.
678
679 CC = gcc
680 CFLAGS = -g -O2
681
682 all: poke
683
684 poke: poke.o
685 $(CC) -o poke $(CFLAGS) $(LDFLAGS) poke.o
686
687 So far, so good.
688
689 Unfortunately, there are a few problems.
690
691 On older Unix systems derived from BSD 4.3, the `utime' system call
692does not accept a second argument of `NULL'. On those systems, we need
693to pass a pointer to `struct utimbuf' structure. Unfortunately, even
694older systems don't define that structure; on those systems, we need to
695pass an array of two `long' values.
696
697 The header file `stdlib.h' was invented by ANSI C, and older systems
698don't have a copy. We included it above to get a declaration of `exit'.
699
700 We can find some of these portability problems by running
701`autoscan', which will create a `configure.scan' file which we can use
702as a prototype for our `configure.in' file. I won't show the output,
703but it will notice the potential problems with `utime' and `stdlib.h'.
704
705 In our `Makefile', we don't provide any way to install the program.
706This doesn't matter much for such a simple example, but a real program
707will need an `install' target. For that matter, we will also want a
708`clean' target.
709
710
711File: configure.info, Node: Getting Started Example 2, Next: Getting Started Example 3, Prev: Getting Started Example 1, Up: Getting Started Example
712
713Second Try
714----------
715
716 Here is our second try at this program.
717
718 We modify `poke.c' to use preprocessor macros to control what
719features are available. (I've cheated a bit by using the same macro
720names which autoconf will use).
721
722 #include <stdio.h>
723
724 #ifdef STDC_HEADERS
725 #include <stdlib.h>
726 #endif
727
728 #include <sys/types.h>
729
730 #ifdef HAVE_UTIME_H
731 #include <utime.h>
732 #endif
733
734 #ifndef HAVE_UTIME_NULL
735
736 #include <time.h>
737
738 #ifndef HAVE_STRUCT_UTIMBUF
739
740 struct utimbuf
741 {
742 long actime;
743 long modtime;
744 };
745
746 #endif
747
748 static int
749 utime_now (file)
750 char *file;
751 {
752 struct utimbuf now;
753
754 now.actime = now.modtime = time (NULL);
755 return utime (file, &now);
756 }
757
758 #define utime(f, p) utime_now (f)
759
760 #endif /* HAVE_UTIME_NULL */
761
762 int
763 main (argc, argv)
764 int argc;
765 char **argv;
766 {
767 if (argc != 2)
768 {
769 fprintf (stderr, "Usage: poke file\n");
770 exit (1);
771 }
772
773 if (utime (argv[1], NULL) < 0)
774 {
775 perror ("utime");
776 exit (1);
777 }
778
779 exit (0);
780 }
781
782 Here is the associated `Makefile'. We've added support for the
783preprocessor flags we use. We've also added `install' and `clean'
784targets.
785
786 # Set this to your installation directory.
787 bindir = /usr/local/bin
788
789 # Uncomment this if you have the standard ANSI/ISO C header files.
790 # STDC_HDRS = -DSTDC_HEADERS
791
792 # Uncomment this if you have utime.h.
793 # UTIME_H = -DHAVE_UTIME_H
794
795 # Uncomment this if utime (FILE, NULL) works on your system.
796 # UTIME_NULL = -DHAVE_UTIME_NULL
797
798 # Uncomment this if struct utimbuf is defined in utime.h.
799 # UTIMBUF = -DHAVE_STRUCT_UTIMBUF
800
801 CC = gcc
802 CFLAGS = -g -O2
803
804 ALL_CFLAGS = $(STDC_HDRS) $(UTIME_H) $(UTIME_NULL) $(UTIMBUF) $(CFLAGS)
805
806 all: poke
807
808 poke: poke.o
809 $(CC) -o poke $(ALL_CFLAGS) $(LDFLAGS) poke.o
810
811 .c.o:
812 $(CC) -c $(ALL_CFLAGS) poke.c
813
814 install: poke
815 cp poke $(bindir)/poke
816
817 clean:
818 rm poke poke.o
819
820 Some problems with this approach should be clear.
821
822 Users who want to compile poke will have to know how `utime' works
823on their systems, so that they can uncomment the `Makefile' correctly.
824
825 The installation is done using `cp', but many systems have an
826`install' program which may be used, and which supports optional
827features such as stripping debugging information out of the installed
828binary.
829
830 The use of `Makefile' variables like `CC', `CFLAGS' and `LDFLAGS'
831follows the requirements of the GNU standards. This is convenient for
832all packages, since it reduces surprises for users. However, it is
833easy to get the details wrong, and wind up with a slightly nonstandard
834distribution.
835
836
837File: configure.info, Node: Getting Started Example 3, Next: Generate Files in Example, Prev: Getting Started Example 2, Up: Getting Started Example
838
839Third Try
840---------
841
842 For our third try at this program, we will write a `configure.in'
843script to discover the configuration features on the host system, rather
844than requiring the user to edit the `Makefile'. We will also write a
845`Makefile.am' rather than a `Makefile'.
846
847 The only change to `poke.c' is to add a line at the start of the
848file:
849 #include "config.h"
850
851 The new `configure.in' file is as follows.
852
853 AC_INIT(poke.c)
854 AM_INIT_AUTOMAKE(poke, 1.0)
855 AM_CONFIG_HEADER(config.h:config.in)
856 AC_PROG_CC
857 AC_HEADER_STDC
858 AC_CHECK_HEADERS(utime.h)
859 AC_EGREP_HEADER(utimbuf, utime.h, AC_DEFINE(HAVE_STRUCT_UTIMBUF))
860 AC_FUNC_UTIME_NULL
861 AC_OUTPUT(Makefile)
862
863 The first four macros in this file, and the last one, were described
864above; see *Note Write configure.in::. If we omit these macros, then
865when we run `automake' we will get a reminder that we need them.
866
867 The other macros are standard autoconf macros.
868
869`AC_HEADER_STDC'
870 Check for standard C headers.
871
872`AC_CHECK_HEADERS'
873 Check whether a particular header file exists.
874
875`AC_EGREP_HEADER'
876 Check for a particular string in a particular header file, in this
877 case checking for `utimbuf' in `utime.h'.
878
879`AC_FUNC_UTIME_NULL'
880 Check whether `utime' accepts a NULL second argument to set the
881 file change time to the current time.
882
883 See the autoconf manual for a more complete description.
884
885 The new `Makefile.am' file is as follows. Note how simple this is
886compared to our earlier `Makefile'.
887
888 bin_PROGRAMS = poke
889
890 poke_SOURCES = poke.c
891
892 This means that we should build a single program name `poke'. It
893should be installed in the binary directory, which we called `bindir'
894earlier. The program `poke' is built from the source file `poke.c'.
895
896 We must also write a `acconfig.h' file. Besides `PACKAGE' and
897`VERSION', which must be mentioned for all packages which use automake,
898we must include `HAVE_STRUCT_UTIMBUF', since we mentioned it in an
899`AC_DEFINE'.
900
901 /* Name of package. */
902 #undef PACKAGE
903
904 /* Version of package. */
905 #undef VERSION
906
907 /* Whether utime.h defines struct utimbuf. */
908 #undef HAVE_STRUCT_UTIMBUF
909
910
911File: configure.info, Node: Generate Files in Example, Prev: Getting Started Example 3, Up: Getting Started Example
912
913Generate Files
914--------------
915
916 We must now generate the other files, using the following commands.
917
918 aclocal
919 autoconf
920 autoheader
921 automake
922
923 When we run `autoheader', it will remind us of any macros we forgot
924to add to `acconfig.h'.
925
926 When we run `automake', it will want to add some files to our
927distribution. It will add them automatically if we use the
928`--add-missing' option.
929
930 By default, `automake' will run in GNU mode, which means that it
931will want us to create certain additional files; as of this writing, it
932will want `NEWS', `README', `AUTHORS', and `ChangeLog', all of which
933are files which should appear in a standard GNU distribution. We can
934either add those files, or run `automake' with the `--foreign' option.
935
936 Running these tools will generate the following files, all of which
937are described in the next chapter.
938
939 * `aclocal.m4'
940
941 * `configure'
942
943 * `config.in'
944
945 * `Makefile.in'
946
947 * `stamp-h.in'
948
949
950File: configure.info, Node: Files, Next: Configuration Names, Prev: Getting Started, Up: Top
951
952Files
953*****
954
955 As was seen in the previous chapter, the GNU configure and build
956system uses a number of different files. The developer must write a
957few files. The others are generated by various tools.
958
959 The system is rather flexible, and can be used in many different
960ways. In describing the files that it uses, I will describe the common
961case, and mention some other cases that may arise.
962
963* Menu:
964
965* Developer Files:: Developer Files.
966* Build Files:: Build Files.
967* Support Files:: Support Files.
968
969
970File: configure.info, Node: Developer Files, Next: Build Files, Up: Files
971
972Developer Files
973===============
974
975 This section describes the files written or generated by the
976developer of a package.
977
978* Menu:
979
980* Developer Files Picture:: Developer Files Picture.
981* Written Developer Files:: Written Developer Files.
982* Generated Developer Files:: Generated Developer Files.
983
984
985File: configure.info, Node: Developer Files Picture, Next: Written Developer Files, Up: Developer Files
986
987Developer Files Picture
988-----------------------
989
990 Here is a picture of the files which are written by the developer,
991the generated files which would be included with a complete source
992distribution, and the tools which create those files. The file names
993are plain text and the tool names are enclosed by `*' characters (e.g.,
994`autoheader' is the name of a tool, not the name of a file).
995
996 acconfig.h configure.in Makefile.am
997 | | |
998 | --------------+---------------------- |
999 | | | | |
1000 v v | acinclude.m4 | |
1001 *autoheader* | | v v
1002 | | v --->*automake*
1003 v |--->*aclocal* | |
1004 config.in | | | v
1005 | v | Makefile.in
1006 | aclocal.m4---
1007 | |
1008 v v
1009 *autoconf*
1010 |
1011 v
1012 configure
1013
1014
1015File: configure.info, Node: Written Developer Files, Next: Generated Developer Files, Prev: Developer Files Picture, Up: Developer Files
1016
1017Written Developer Files
1018-----------------------
1019
1020 The following files would be written by the developer.
1021
1022`configure.in'
1023 This is the configuration script. This script contains
1024 invocations of autoconf macros. It may also contain ordinary
1025 shell script code. This file will contain feature tests for
1026 portability issues. The last thing in the file will normally be
1027 an `AC_OUTPUT' macro listing which files to create when the
1028 builder runs the configure script. This file is always required
1029 when using the GNU configure system. *Note Write configure.in::.
1030
1031`Makefile.am'
1032 This is the automake input file. It describes how the code should
1033 be built. It consists of definitions of automake variables. It
1034 may also contain ordinary Makefile targets. This file is only
1035 needed when using automake (newer tools normally use automake, but
1036 there are still older tools which have not been converted, in
1037 which the developer writes `Makefile.in' directly). *Note Write
1038 Makefile.am::.
1039
1040`acconfig.h'
1041 When the configure script creates a portability header file, by
1042 using `AM_CONFIG_HEADER' (or, if not using automake,
1043 `AC_CONFIG_HEADER'), this file is used to describe macros which are
1044 not recognized by the `autoheader' command. This is normally a
1045 fairly uninteresting file, consisting of a collection of `#undef'
1046 lines with comments. Normally any call to `AC_DEFINE' in
1047 `configure.in' will require a line in this file. *Note Write
1048 acconfig.h::.
1049
1050`acinclude.m4'
1051 This file is not always required. It defines local autoconf
1052 macros. These macros may then be used in `configure.in'. If you
1053 don't need any local autoconf macros, then you don't need this
1054 file at all. In fact, in general, you never need local autoconf
1055 macros, since you can put everything in `configure.in', but
1056 sometimes a local macro is convenient.
1057
1058 Newer tools may omit `acinclude.m4', and instead use a
1059 subdirectory, typically named `m4', and define `ACLOCAL_AMFLAGS =
1060 -I m4' in `Makefile.am' to force `aclocal' to look there for macro
1061 definitions. The macro definitions are then placed in separate
1062 files in that directory.
1063
1064 The `acinclude.m4' file is only used when using automake; in older
1065 tools, the developer writes `aclocal.m4' directly, if it is needed.
1066
1067
1068File: configure.info, Node: Generated Developer Files, Prev: Written Developer Files, Up: Developer Files
1069
1070Generated Developer Files
1071-------------------------
1072
1073 The following files would be generated by the developer.
1074
1075 When using automake, these files are normally not generated manually
1076after the first time. Instead, the generated `Makefile' contains rules
1077to automatically rebuild the files as required. When
1078`AM_MAINTAINER_MODE' is used in `configure.in' (the normal case in
1079Cygnus code), the automatic rebuilding rules will only be defined if
1080you configure using the `--enable-maintainer-mode' option.
1081
1082 When using automatic rebuilding, it is important to ensure that all
1083the various tools have been built and installed on your `PATH'. Using
1084automatic rebuilding is highly recommended, so much so that I'm not
1085going to explain what you have to do if you don't use it.
1086
1087`configure'
1088 This is the configure script which will be run when building the
1089 package. This is generated by `autoconf' from `configure.in' and
1090 `aclocal.m4'. This is a shell script.
1091
1092`Makefile.in'
1093 This is the file which the configure script will turn into the
1094 `Makefile' at build time. This file is generated by `automake'
1095 from `Makefile.am'. If you aren't using automake, you must write
1096 this file yourself. This file is pretty much a normal `Makefile',
1097 with some configure substitutions for certain variables.
1098
1099`aclocal.m4'
1100 This file is created by the `aclocal' program, based on the
1101 contents of `configure.in' and `acinclude.m4' (or, as noted in the
1102 description of `acinclude.m4' above, on the contents of an `m4'
1103 subdirectory). This file contains definitions of autoconf macros
1104 which `autoconf' will use when generating the file `configure'.
1105 These autoconf macros may be defined by you in `acinclude.m4' or
1106 they may be defined by other packages such as automake, libtool or
1107 gettext. If you aren't using automake, you will normally write
1108 this file yourself; in that case, if `configure.in' uses only
1109 standard autoconf macros, this file will not be needed at all.
1110
1111`config.in'
1112 This file is created by `autoheader' based on `acconfig.h' and
1113 `configure.in'. At build time, the configure script will define
1114 some of the macros in it to create `config.h', which may then be
1115 included by your program. This permits your C code to use
1116 preprocessor conditionals to change its behaviour based on the
1117 characteristics of the host system. This file may also be called
1118 `config.h.in'.
1119
1120`stamp.h-in'
1121 This rather uninteresting file, which I omitted from the picture,
1122 is generated by `automake'. It always contains the string
1123 `timestamp'. It is used as a timestamp file indicating whether
1124 `config.in' is up to date. Using a timestamp file means that
1125 `config.in' can be marked as up to date without actually changing
1126 its modification time. This is useful since `config.in' depends
1127 upon `configure.in', but it is easy to change `configure.in' in a
1128 way which does not affect `config.in'.
1129
1130
1131File: configure.info, Node: Build Files, Next: Support Files, Prev: Developer Files, Up: Files
1132
1133Build Files
1134===========
1135
1136 This section describes the files which are created at configure and
1137build time. These are the files which somebody who builds the package
1138will see.
1139
1140 Of course, the developer will also build the package. The
1141distinction between developer files and build files is not that the
1142developer does not see the build files, but that somebody who only
1143builds the package does not have to worry about the developer files.
1144
1145* Menu:
1146
1147* Build Files Picture:: Build Files Picture.
1148* Build Files Description:: Build Files Description.
1149
1150
1151File: configure.info, Node: Build Files Picture, Next: Build Files Description, Up: Build Files
1152
1153Build Files Picture
1154-------------------
1155
1156 Here is a picture of the files which will be created at build time.
1157`config.status' is both a created file and a shell script which is run
1158to create other files, and the picture attempts to show that.
1159
1160 config.in *configure* Makefile.in
1161 | | |
1162 | v |
1163 | config.status |
1164 | | |
1165 *config.status*<======+==========>*config.status*
1166 | |
1167 v v
1168 config.h Makefile
1169
1170
1171File: configure.info, Node: Build Files Description, Prev: Build Files Picture, Up: Build Files
1172
1173Build Files Description
1174-----------------------
1175
1176 This is a description of the files which are created at build time.
1177
1178`config.status'
1179 The first step in building a package is to run the `configure'
1180 script. The `configure' script will create the file
1181 `config.status', which is itself a shell script. When you first
1182 run `configure', it will automatically run `config.status'. An
1183 `Makefile' derived from an automake generated `Makefile.in' will
1184 contain rules to automatically run `config.status' again when
1185 necessary to recreate certain files if their inputs change.
1186
1187`Makefile'
1188 This is the file which make will read to build the program. The
1189 `config.status' script will transform `Makefile.in' into
1190 `Makefile'.
1191
1192`config.h'
1193 This file defines C preprocessor macros which C code can use to
1194 adjust its behaviour on different systems. The `config.status'
1195 script will transform `config.in' into `config.h'.
1196
1197`config.cache'
1198 This file did not fit neatly into the picture, and I omitted it.
1199 It is used by the `configure' script to cache results between
1200 runs. This can be an important speedup. If you modify
1201 `configure.in' in such a way that the results of old tests should
1202 change (perhaps you have added a new library to `LDFLAGS'), then
1203 you will have to remove `config.cache' to force the tests to be
1204 rerun.
1205
1206 The autoconf manual explains how to set up a site specific cache
1207 file. This can speed up running `configure' scripts on your
1208 system.
1209
1210`stamp.h'
1211 This file, which I omitted from the picture, is similar to
1212 `stamp-h.in'. It is used as a timestamp file indicating whether
1213 `config.h' is up to date. This is useful since `config.h' depends
1214 upon `config.status', but it is easy for `config.status' to change
1215 in a way which does not affect `config.h'.
1216
1217
1218File: configure.info, Node: Support Files, Prev: Build Files, Up: Files
1219
1220Support Files
1221=============
1222
1223 The GNU configure and build system requires several support files to
1224be included with your distribution. You do not normally need to concern
1225yourself with these. If you are using the Cygnus tree, most are already
1226present. Otherwise, they will be installed with your source by
1227`automake' (with the `--add-missing' option) and `libtoolize'.
1228
1229 You don't have to put the support files in the top level directory.
1230You can put them in a subdirectory, and use the `AC_CONFIG_AUX_DIR'
1231macro in `configure.in' to tell `automake' and the `configure' script
1232where they are.
1233
1234 In this section, I describe the support files, so that you can know
1235what they are and why they are there.
1236
1237`ABOUT-NLS'
1238 Added by automake if you are using gettext. This is a
1239 documentation file about the gettext project.
1240
1241`ansi2knr.c'
1242 Used by an automake generated `Makefile' if you put `ansi2knr' in
1243 `AUTOMAKE_OPTIONS' in `Makefile.am'. This permits compiling ANSI
1244 C code with a K&R C compiler.
1245
1246`ansi2knr.1'
1247 The man page which goes with `ansi2knr.c'.
1248
1249`config.guess'
1250 A shell script which determines the configuration name for the
1251 system on which it is run.
1252
1253`config.sub'
1254 A shell script which canonicalizes a configuration name entered by
1255 a user.
1256
1257`elisp-comp'
1258 Used to compile Emacs LISP files.
1259
1260`install-sh'
1261 A shell script which installs a program. This is used if the
1262 configure script can not find an install binary.
1263
1264`ltconfig'
1265 Used by libtool. This is a shell script which configures libtool
1266 for the particular system on which it is used.
1267
1268`ltmain.sh'
1269 Used by libtool. This is the actual libtool script which is used,
1270 after it is configured by `ltconfig' to build a library.
1271
1272`mdate-sh'
1273 A shell script used by an automake generated `Makefile' to pretty
1274 print the modification time of a file. This is used to maintain
1275 version numbers for texinfo files.
1276
1277`missing'
1278 A shell script used if some tool is missing entirely. This is
1279 used by an automake generated `Makefile' to avoid certain sorts of
1280 timestamp problems.
1281
1282`mkinstalldirs'
1283 A shell script which creates a directory, including all parent
1284 directories. This is used by an automake generated `Makefile'
1285 during installation.
1286
1287`texinfo.tex'
1288 Required if you have any texinfo files. This is used when
1289 converting Texinfo files into DVI using `texi2dvi' and TeX.
1290
1291`ylwrap'
1292 A shell script used by an automake generated `Makefile' to run
1293 programs like `bison', `yacc', `flex', and `lex'. These programs
1294 default to producing output files with a fixed name, and the
1295 `ylwrap' script runs them in a subdirectory to avoid file name
1296 conflicts when using a parallel make program.
1297
1298
1299File: configure.info, Node: Configuration Names, Next: Cross Compilation Tools, Prev: Files, Up: Top
1300
1301Configuration Names
1302*******************
1303
1304 The GNU configure system names all systems using a "configuration
1305name". All such names used to be triplets (they may now contain four
1306parts in certain cases), and the term "configuration triplet" is still
1307seen.
1308
1309* Menu:
1310
1311* Configuration Name Definition:: Configuration Name Definition.
1312* Using Configuration Names:: Using Configuration Names.
1313
Note: See TracBrowser for help on using the repository browser.