使用autotools工具用configure、make、make install编译安装linux工程的详细步骤
autotools是个系列工具,主要由autoconf、automake、perl语言环境和m4等组成,所包含的命令有5个:
下图是autotools使用的流程图:
autotools的安装:
- apt-get install autoconf automake autotools-dev m4
autotools使用简单实例如下:
- 准备程序源代码
内容如下:
- mkdir demo_conf
- vi hello.cpp
- #include <iostream>
- using namespace std;
- int main(){
- cout << "hello\n";
- }
- 使用autoscan命令,扫描工作目录,生成configure.scan 文件
- $ autoscan
- $ ls
- autoscan.log configure.scan hello.cpp
- 将configure.scan文件重命名为configure.ac(或configure.in),并做适当修改。在configure.ac文件中,#号开始的是行注释,其他都是m4宏命令;configure.ac里面的宏的主要作用是侦测系统
修改后的内容如下:
- $ mv configure.scan configure.ac
- vi configure.ac
configure.ac文件说明:- # -*- Autoconf -*-
- # Process this file with autoconf to produce a configure script.
- AC_PREREQ([2.68])
- AC_INIT(hello, 1.0, zhunian0322@163.com)
- AC_CONFIG_SRCDIR([hello.cpp])
- AC_CONFIG_HEADERS([config.h])
- AM_INIT_AUTOMAKE(hello,1.0)
- # Checks for programs.
- AC_PROG_CXX
- # Checks for libraries.
- # Checks for header files.
- # Checks for typedefs, structures, and compiler characteristics.
- # Checks for library functions.
- AC_CONFIG_FILES([Makefile])
- AC_OUTPUT
- AC_PREREQ 声明本文要求的autoconf版本.如本例中的版本2.68
- AC_INIT 用来定义软件的名称、版本、作者E-mail等
- AC_CONFIG_SRCDIR 用来侦测所制定的源码文件是否存在,确定源码目录的有效性。此处为当前目录下的hello.cpp
- AC_CONFIG_HEADERS 用于生成config.h文件,以便autoheader命令使用
- AM_INIT_AUTOMAKE 是通过手动添加的,他是automake所必备的宏,用于指定软件名和软件版本号
- AC_PROC_CXX 用来指定编译器。此处是g++ AC_PROC_CC是gcc
- AC_CONFIG_FILES 用于生成相应的Makefile文件
- AC_OUTPUT 用来设定configure 所要产生的文件,如果是Makefile,configure 会把它检查出来的结果带入makefile.in文件产生何时的Makefile。使用automake时,还需要一些其他的参数,这些额外的宏用aclocal工具产生
- 使用aclocal命令,扫描configure.ac文件生成aclocal.m4文件,该文件主要处理本地的宏定义,它根据已经安装的宏\用户定义宏和acinclude.m4文件中的宏将configure.ac文件需要的宏集中定义到aclocal.m4中
- $ aclocal
- $ ls
- aclocal.m4 autom4te.cache autoscan.log configure.ac hello.cpp
- 使用autoconf命令生成configure文件.这个命令将configure.ac文件中的宏展开,生成configure脚本。
- $ autoconf
- $ ls
- aclocal.m4 autom4te.cache autoscan.log configure configure.ac hello.cpp
- 使用autoheader命令生成config.h.in文件.该命令通常会中acconfig.h 文件中复制用户附加的符号定义
- $ autoheader
- $ ls
- aclocal.m4 autoscan.log configure hello.cpp
- autom4te.cache config.h.in configure.ac
- 手工创建Makefile.am 文件。automake工具会根据configure.in中的参量把Makefile.am转换成Makefile.in文件
增加一下内容:
- $ vi Makefile.am
Makefile.am文件内容说明- AUTUMAKE_OPTIONS = foreign
- bin_PROGRAMS = hello
- hello_SOURCES = hello.cpp
- AUTOMAKE_OPTIONS 为设置automake 的选项.由于GNU对自己发布的软件有严格的规范,比如必须附带许可证声明文件COPYING等,否则automake执行时会报错.automake提供了3种软件等级:foreign、gnu、gnits,供用户选择。默认级别是gnu。
- bin_PROGRAMS 定义要产生的执行文件名。如果要产生多个执行文件,每个文件名用空格隔开
- hello_SOURCES 定义“hello”这个可以执行程序所需的原始文件。如果“hello”这个程序是由多个源文件所产生的,则必须把它所用到的所有源文件都列出来,并用空格隔开。如果要定义多个可执行程序,那么需要对每个可执行程序建立对应的file_SOURCES
- 使用automake 命令生成Makefile.in 文件.使用选项"--add-missing" 可以让automake自动添加一些必须的脚本文件
Makefile.am: installing `./COPYING‘ using GNU General Public License v3 file; error while making link: Operation not supportedMakefile.am: Consider adding the COPYING file to the version control systemMakefile.am: for your code, to avoid questions about which license your project uses.Makefile.am: installing `./depcomp‘; error while making link: Operation not supported说明:
- $ automake --add-missing
- configure.ac:8: installing `./install-sh‘; error while making link: Operation not supported
- configure.ac:8: installing `./missing‘; error while making link: Operation not supported
- Makefile.am: installing `./INSTALL‘; error while making link: Operation not supported
- <pre name="code" class="plain">Makefile.am: required file `./NEWS‘ not found
- Makefile.am: required file `./README‘ not found
- Makefile.am: required file `./AUTHORS‘ not found
- Makefile.am: required file `./ChangeLog‘ not found
- configure.ac:8: installing `./install-sh‘; error while making link: Operation not supported
- configure.ac:8: installing `./missing‘; error while making link: Operation not supported
- Makefile.am: installing `./depcomp‘; error while making link: Operation not supported
- ##因为把工程放在FAT32分区上,而它不支持link.需要挪到ext3上
- Makefile.am: required file `./NEWS‘ not found
- Makefile.am: required file `./README‘ not found
- Makefile.am: required file `./AUTHORS‘ not found
- Makefile.am: required file `./ChangeLog‘ not found
- ##使用touch 命令创建这4个文件
- $ cp -rvf ../demo_conf/ /home/gino/
- $ cd /home/gino/demo_conf/
- $ touch NEWS
- $ touch README
- $ touch AUTHORS
- $ touch ChangeLog
- $ automake --add-missing
- $ ls
- aclocal.m4 autoscan.log config.h.in configure hello install-sh Makefile.in README
- AUTHORS ChangeLog config.log configure.ac hello.cpp Makefile missing stamp-h1
- autom4te.cache config.h config.status depcomp hello.o Makefile.am NEWS
-
使用configure命令,把Makefile.in 变成Makefile- $ ./configure
- checking for a BSD-compatible install... /usr/bin/install -c
- checking whether build environment is sane... yes
- checking for a thread-safe mkdir -p... /bin/mkdir -p
- checking for gawk... no
- checking for mawk... mawk
- checking whether make sets $(MAKE)... yes
- checking for g++... g++
- checking whether the C++ compiler works... yes
- checking for C++ compiler default output file name... a.out
- checking for suffix of executables...
- checking whether we are cross compiling... no
- checking for suffix of object files... o
- checking whether we are using the GNU C++ compiler... yes
- checking whether g++ accepts -g... yes
- checking for style of include used by make... GNU
- checking dependency style of g++... gcc3
- configure: creating ./config.status
- config.status: creating Makefile
- config.status: creating config.h
- config.status: config.h is unchanged
- config.status: executing depfiles commands
- make 命令,用来执行编译代码,默认执行"make all"命令.
- make clean 命令清除编译时的obj文件.
- make install 命令把目标文件安装到系统中.
- make uninstall 命令把目标文件从系统中卸载.
- make dist 命令将程序和相关的文档打包为一个压缩文档,以供发布.
- make -n 非执行模式,输出所有执行命令,但不执行.
- make -c 读取Makefile之前改变到指定目录
- make -h 显示所有make选项