autoconf
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

ax_enable_builddir : automatic subdir builds


From: Guido Draheim
Subject: ax_enable_builddir : automatic subdir builds
Date: Tue, 25 Mar 2003 04:54:59 +0100
User-agent: Mozilla/5.0 (X11; U; Linux i686; de-AT; rv:1.1) Gecko/20020826

I had that idea for a long time but I knew that it would require
some iterations of testing before it works smoothly. Finally, there
was enough time lately to give it a try and here it is - a new macro.

* what is it?
Per default, autoconf/automake builds are done within the source
directory. The macro changes the default to build in a subdirectory
instead, just like you would do
(mkdir linux && cd linux && sh configure && make)

* benefits
there are a number of benefits to use a subdir build, many of which
were covered in earlier threads on the autotools mailinglists. To
hilight some:
- multi user access to the same source repository
- multi arch builds in the same repo in a networked /home
  (shared for both linux and solaris workstations on your campus)
- multi arch builds using cross-compilers, esp. cross mingw,
  from a single source repo
Making a subdir to be the default has simple benefit: you do
not not forget to add $(srcdir) in rules during development
cycles that would prevent any of the above possibilities.
Usually platform portability is tested later in the devel
process, where multi builddir != srcdir is quite nice. As a
real world example: sourceforge compilefarm uses a shared
home for all machines attached and reachable from the login.

* the invokation
using the macro without an argument uses $host as the subdir
name. Using the sourceforge compilefarm example: each
platform will get its own builddir automatically, with the
linux, solaris, freebsd, darwin parts built in their own
area.

Using $host does also match with the recommended style of
crossgcc setup: just use configure --host=i386-mingw32
and the autoconf parts will automatically find any
i386-mingw32-gcc in the path - and start using it.

* the implementation
it just fits into the normal autoconf processing - it just
moves (!!) the config.log and other configure files into
the new subdir, and it modifies some helper variables of
autoconf so that later macro (really: their shell code)
believes it was run as an off-sourcedir configure in
the first place.

* the sourcedir Makefile
For convenience with the usual build procedure, a toplevel
Makefile is created in the sourcedir. This allows still to
run `sh configure && make && make install` as described in
many software documentations. The toplevel Makefile does
have a set of rules that will do nothing else than recurse
into the subdirectory of your buildfiles.

The toplevel subdir-build makefile is derived from the
toplevel sourcedir makefile.in with a simple sed-script,
and the last operation is an appendix of pairs of
$host -> subdir which will be scanned by the executions.
A `tail Makefile` will then tell you what platforms
you have configured (and built?) already.

* multi-variant builds
That's my other intention: to provide an easier way to
create multi-variant builds. The toplevel configure.ac
does have a --with-variant=... option, and the argument
of the ac-macro is expanded to be now
AX_ENABLE_BUILDDIR($host-$with_variant) and the $variant
result to select some other options in the rest of it.

Each configured variant will be listed in the toplevel
Makefile, i.e. there are now multiple $host -> $build
entries in the configure-table, e.g.
$ tail Makefile
#### CONFIGURATIONS FOR TOPLEVEL MAKEFILE:
#### i686-pc-linux-gnu |./Release/i686-pc-linux-gnu
#### i686-pc-linux-gnu |./Release/i686-pc-linux-gnu-fig

When using the normal build-target then only the
last-configured variant for a $host is selected. But
the sed-script to derive the sourcedir makefile from
the sourcedir makefile.in has some other magic: it
creates an "<target>-all" for each make "<target>"
that will run that <target> in _all_ build directories
of the current $host.

In the example, it will recurse into both "fig" and
non-"fig" variant. A final `make install-all` will
install all variants in one go that are valid for
this platform. The config.guess $host can be overridden
with HOST= settings btw, e.g. for crosscompiler setups.

* what else?
I dunno, I am using it now in multiple projects. Btw,
if you want no subdir build then you can always just
--disable-builddir or may be you want to set your own
--enable-build=myowndirname - that's alreay in the
ac-macro as of now. Perhaps you have another idea what
to do with this macro, then please let me hear of it.

http://ac-archive.sf.net/guidod/ax_enable_builddir.html

-- cheers, guido





reply via email to

[Prev in Thread] Current Thread [Next in Thread]