最近一直在类unix系统上(Ubuntu和Mac OS)上调研第三方的一些开源库,要涉及到开源库的编译安装工作,接触最多的就是./configure & make & make install。
以前我们在Windows上进行开发的过程中,使用Visual Studio打开sln直接一个按钮就编译生成最终的可执行文件,具体的编译过程不得而知,而在类unix系统中这些过程都得自己来搞,麻烦是麻烦了些,但是能学到深层次的知识。
GNU构建系统(GNU Build System)主要是指通过autoconf、automake和libtool这三个工具构建出来的软件结构体系,又名Autotools。
GNU构建系统是利用脚本和make程序在特定的平台上构建软件的过程。一般过程是./configure,make,make install 三部曲。这种方式成为一种习惯,被广泛使用。
一般github上的开源项目都提供了使用这套构建系统的入口,要么是使用make程序,要么是使用更高级点的cmake。
下图(来自维基百科)展示了GNU构建体系编辑和使用的流程:浅蓝色矩形作为处理工具的输入,椭圆作为处理工具,最终的浅绿色矩形为最终的可执行文件输出。
最关键的一部就是生成makefile文件,之后调研make & make install只是常规的步骤。
其中congure.ac、makefile.am是库作者最好必须提供的。
在ubuntu上可以使用 sudo apt-get autoconf automake libtool来安装AutoTools。
接下来,我们来看两个开源库例子:
- gperftools:google性能工具集合,包括heap checker、heap profiler、tcmalloc以及cpu profiler。
里面有个shell脚本文件autogen.h,用于产生configure脚本,进而使用configure脚本来生成makefile文件,autogen.h内容如下:
仔细点看,不是使用的我们上面所说的autoconf,而是autoreconf,从最开始的一幅图可知,autoconf接收aclocal.m4以及configure.ac作为输入,这事先需要使用aclocal工具来生成aclocal.m4,是有个先后顺序的,如果autoconf接收的输入多了,先后顺序也就会增多,不方便管理。而此时autoreconf则显现出作用,它是一个辅助工具,可以将上述所述的先后顺序自动地以正确的顺序调用,而不用关心具体的细节,简直是方便了太多。
执行autoconf(这里执行的是autogen.sh脚本)就生成了我们的configure脚本,直接调用./configure就可以生成我们的makefile了,当然,如果需要定义一些细节,则可以在./configure后添加选项参数(./configure -help查看可以自定义哪些选项),最后就是make&make install了。
- thrift:apache的rpc框架
提供的文件和上面的gperftools差不多,多了CMakeLists.txt告知我们可以使用cmake的方式来构建,但最终还是要生成makefile文件,这里有一个shell脚本文件bootstrap.sh需要重点看下:
可以看到,最后执行的autoscan、aclocal、autoheader、autoconf、automake,说的还是最开始图中所说的那个流程,都能走到生成makefile的一步。
./configure & make & make install三部曲,万变不离其宗!
上面通过梳理学习,了解了开源项目的大致文档结构,如果我们自己搞开源库,也可以这样来组织,可参考例解 autoconf 和 automake 生成 Makefile 文件。