再也不担心构建问题了
希望这篇文章可以理清这个工具,了解其使用。
前言
说真的,autotools工具让我很头疼,各种类似的工具
autolocal
,
automake
以及生产各种相似的文件
Makefile.in
,
Makefile.am
想生成个
Makefile
真是麻烦啊,但是很多开源软件的C或C++代码,很多都采用这种构建方式, 挺烦人的。
简单的编译和安装一般比较简单,三步走,如下,当时一旦出错,让人摸不着头脑,如果对autotools工具不了解,就一脸懵逼,无从下手。
./configure && make && make install
一 构建演化
首先要了解为什么要有autoconf,automake这类工具,那是因为我们c或c++代码在编译的时候通过Makefile构建的,Makefile有个好处,其中一个文件更新之后,自动只编译依赖这个文件的文件,其他的没有关系的文件不用重新编译,从而加快构建过程。
1.1 简单 Make
如上图简单的情况,我们可以通过make直接构建:
make
1.2 复杂的Make
简单的Makefile文件还是比较容易编写的,但是复杂的Makefile文件就挺麻烦的,比如我们依赖的头文件在哪里,我们依赖的库应该怎么写;特别是不同的操作系统接口越来越多的差异,导致生成Makefile很复杂,我们通过手工写一个配置脚本configure来生成解决问题:
如上图,复杂一点,我们可以通过如下的命令构建:
./configure && make
configure 的作用是来检查系统环境,比如采用什么编译器,比如一些库是否支持等。通常会生成makefile和config.h。 configure脚本运行时扫描当前环境,生成一个名为config.status的子脚本。子脚本将 http:// Makefile.in 文件转换为适应于当前系统环境的Makefile文件。
1.3 autoconf
随着Linux系统的问世,各种版本很复杂,我们在一个系统上可以编译的程序,在另外一个系统可能根本无法编译通过,为了维护多个系统版本,比如我们以前的代码需要在HP-UNIX,AIX,LINUX等多个平台上运行,都需要适配,是通过一个脚本来解决的,但是如果更多平台,这个脚本越来越复杂,底层的细节越来越多。
1991年,David Mackenzie开发了Autoconf工具,用来自动生成configure脚本,屏蔽了底层的不同操作系统的差异,库版本的差异。节省了开发人员的时间。
用户定义几个宏,通过autoconf自动构建configure工具。工具包里面还有autoscan工具,可以自动扫描项目,生成configure.scan文件,里面自动默认添加许多宏,包括系统配置的基本选项,进一步节省我们的时间,只需要将configure.scan改名为configure.ac,再进行简单的修修,就可以了。 整个流程如下:
1.4 automake
以上感觉还好,并没有多复杂,但是现实的要复杂的多,有些makefile文件的生成并不是由configure生成的,据说是为了简化makefile生成,发明了一个automake的工具,作用利用 http:// Makefile.am 来生成 http:// Makefile.in 和Makefile。
automake相当于对autoconf的扩展,里面用到了一些宏,配合使用的话,需要再configure.ac中添加AM_INIT_AUTOMAKE这个宏,这个宏是在automake里面定义的。
我们需要一个autolocal(aclocal - create aclocal.m4 by scanning configure.ac)的工具来扫描configure.ac来生成autoconf运行时候需要的宏,autolocal会生成一个aclocal.m4的文件,autoconf运行的时候通过它找到了宏定义;
autoconf 利用 http:// configure.in 和aclocal.m4来生成configure脚本文件。
configure脚本文件的作用是能设置源程序来适应各种不同的操作系统平台,并且根据不同的系统来产生合适的Makefile,从而可以使你的源代码能在不同的操作系统平台上被编译出来。 流程图如下:
)
图中:绿色部分是需要人工输入,外部的;黄色部分:表示是自动生成的。 整体给我的感觉,让整个构建过程越来越复杂了,不是简单了。
二 实践
简单实践下整个过程,下次直接跟着做就可以了。
说明步骤:
三 为什么要研究这玩意
autotool看上去挺烦的,自己也是在工作中遇到一个问题,报错: 先用autoconf从configure.ac生成configure,然后执行时候报错:
syntax error near unexpected token LIBPCREVERSION
PKG_CHECK_MODULES(...
具体如下图:
当时查这个宏应该通过autoconf自动展开,现实是没有展开,直接复制到configure里面了,导致执行configure命令报错。
所以问题的根源在于: autoconf没有找到PKG_CHECK_MODULES这个m4宏的定义,所以没有展开,导致configure的文件生成有问题,解决办法:
autoreconf -I /usr/share/aclocal
如果不行,记得清理下,autotool生成的很多文件,可以参考上面图片产生的文件,运行下:
make maintainer-clean
再执行:
autoreconf --force --install