autoconf is a tool that belongs to the autotools suite, also known as the GNU build system. This tool allows the developer to automate the configuration that is necessary to compile a piece of software. This tool automatically configures Makefile files that are interpreted by the Make utility. When a program is built with the help of autoconf, the first step is to call the configure script:
[name@server $] ./configure
autoconf then verifies the versions of the software that is installed on the computer, and ensures that all dependencies are present to compile our program.
After that, you call make as usual:
[name@server $] make
Finally, the keyword install installs the files at the right places. If you don't want to install the software for all users of the server, but only for yourself, you normally need to specify where to install your software. You can (usually) do this in the following manner:
[name@server $] mkdir $HOME/SOFTWARE
to install in the directory SOFTWARE. After that you only need to Create a module to show the system the paths to your newly installed software.
A basic compilation of a program using autoconf can thus be as simple as
[name@server $] ./configure && make && make install --prefix=$HOME/SOFTWARE
Frequently used options for configure scripts
configure scripts generally accept a large number of options. They vary from project to project. Nevertheless certain options are very common and deserve mentioning. In all cases you can run
[name@server $] ./configure --help
to get a detailed list of all supported options.
An options that is always available is --prefix. This options allows you to define the directory where the command make install installs the application or the library. For example, to install an application into the subdirectory programs within your home directory, you could use
[name@server $] ./configure --prefix=$HOME/programs/
Most configuration scripts allow you to enable or to disable certain features of the program or library that you compile. Those options are generally of the type --enable-feature or --disable-feature. Within advanced computing, those options often include for example parallelization using threads or using MPI. You could thus have
[name@server $] ./configure --enable-mpi
[name@server $] ./configure --enable-threads
Often there are also options like --with-... to configure some features specifically. It is generally recommended to not use such options and let autoconf find the parameters automatically. Nevertheless it is sometimes necessary to specify some parameters using --with-... options. For example, you could specify
[name@server $] ./configure --enable-mpi --with-mpi-dir=$MPIDIR
Options defined by variables
You can generally specify the compiler that is used and the options that should be passed to it by declaring variables after the ./configure command. For example, to define the C compiler and the options to give it, you could run
[name@server $] ./configure CC=icc CFLAGS="-O3 -xHost"
The most commonly used variables include
|CFLAGS||Options to pass to the C compiler|
|CPPFLAGS||Options to pass to the preprocessor and to C, C++, Objective C, and Objective C++ compilers|
|CXXFLAGS||Options to pass to the C++ compiler|
|DEFS||Allows the definition of a preprocessor macro|
|FCFLAGS||Options to pass to the Fortran compiler|
|FFLAGS||Options to pass to the Fortran 77 compiler|
|LDFLAGS||Options to pass to the linker|
|LIBS||Libraries to link|
A more exhaustive list of variables and typical options is available in the autoconf documentation.