Linux学习之Makefile和Configure文件说明
2014-04-11 21:58
176 查看
一、概述和基础知识
在Linux下得到一个以源代码形式发布的包(一般为.tar.gz或.tar.bz2格式),我们可以用 ./confiugure、make、make install来编译安装,其中在运行./configure的时候还可以根据自己的需要加入不同的参数(可用./configure --help来查看参数表)。
先说说执行./configure后会生成什么东西?运行后系统会根据用户的实际情况生成config.h和多个Makefile。其中 Makefile是运行make时所用的模板;而config.h则会以宏(Marco)的形式记录用户的自定义参数,编译器可以根据config.h来 对源代码进行预编译(pre-compile),从而生成个性化的执行档。
二、我们的“软件”
现在我们可以动手设计一个自己的“软件”了,为了更切合实际,将使用多个源程序,首先建立一个目录tt,用来放我们的东西,然后在tt下建立一个src目录,一般来说源代码都放在src中(好像已经成为一个不成文的规矩了:P)。整体架构如下:
<tt>
|-configure.in
|-Makefile.am
|-acconfig.h
|-<src>
|-tt.c
|-qq.c
|-qq.h
|-Makefile.am
1. configure.in 这是最重要的文档,整个安装过程都靠它来主导。
2. Makefile.am automake会根据它来生成Makefile.in,再由./configure 把Makefile.in变成最终的Makefile,一般来说在顶级目录和各个子目录都应该有一个Makefile.am
3. acconfig.h autoheader会根据它来生成config.h.in,再由./configure 把config.h.in变成最终的config.h
4. tt.c qq.c qq.h 这是我们的源程序。
三、制作流程
请按照以下的执行顺序一步一步做:
第一步 编写configure.in
生成configure.in的方法有两个,一个是自己从零开始写,另一个方法是用autoscan,执行autoscan后会生成configure.scan,其中包含了一些模板内容,使用时只要把名字改成.in就可以。
configure.in中使用的命令有两种,一种是以AC开头,表示是由autoconf提供,另一种是以AM开头,代表由automake提供。
在configure.in我们可以完成很多检测动作,比如检查编译所需的程式、头文件、库等等,总之功能是十分强大,不过我们这里只检测了编译器和头文件,详细用法请看 GNU Manuals Online
configure.in
#dnl 初始化autoconf,参数为入口函数所在的文件
AC_INIT(src/tt.c)
#dnl 初始化automake,参数为软件名称及版本号
AM_INIT_AUTOMAKE(tt, 0.1.0)
#dnl 告诉automake我们所用的配置文件,一般为config.h
AM_CONFIG_HEADER(config.h)
#dnl 这里是实现自定义参数的部份,见下面的说明
AC_ARG_ENABLE(popo, [ --enable-popo PoPo is present],,enable_popo=no)
if test "$enable_popo" = yes ; then
echo "PoPo is here!"
AC_DEFINE(POPO)
else
echo "PoPo isn't here!"
fi
#dnl 检测编译器
AC_PROG_CC
#dnl 检测Standard C的头文件
AC_HEADER_STDC
#dnl 输出文件,一般来说顶级目录和各子目录都应有Makefile输出
AC_OUTPUT(Makefile src/Makefile)
./configure的自定义参数有两种,一种是开关式(--enable-XXX或--disable-XXX),另一种是开放式,即后面要填入一串字符(--with-XXX=yyyy)参数。
上述代码中用的是开关式,第一个参数是参数名,第二个是说明(执行"./configure --help"后所显示出来的内容),最后一个参数是默认值。一般来说默认值和用户提示应该是互斥的,即默认值是no的话,应提示用户用enable进行修改,反之亦然。
从上面的代码中可以看到,如果$enable_popo为yes的话,就用AC_DEFINE来定义POPO这个宏(Macro),否则就不定义,我们在这里所使用到的宏,一定要在acconfig.h中声明。
第二步 运行aclocal 在tt目录下运行aclocal,将会生成aclocal.m4。
第三步 编写acconfig.h
在configure.in中使用到的宏(Macro),都应该在这个文件声明,一般用#undef来声明。
acconfig.h
#undef POPO
第四步 运行autoheader
运行autoheader后会根据configure.in、acconfig.h和系统预设的acconfig.h来生成config.h.in。
第五步 编写Makefile.am
一般来说,在顶级目录和各子目录都应有一个Makefile.am。
Makefile.am
AUTOMAKE_OPTIONS = foreign
SUBDIRS = src
第一行是告诉automake不要检测目录中是否存在AUTHORS、README等文件。
第二行是告诉automake处理src这个子目录。
src/Makefile.am
AUTOMAKE_OPTIONS = foreign
bin_PROGRAMS = tt
tt_SOURCES = tt.c qq.c qq.h
第一行作用同前。
第二行是目标执行档的名称。
第三行是生成tt这个执行档所需的所有源程序和头文件名称。
第六步 运行automake
接著可以执行automake了,在命令行下输入
automake -a 和
automake -a src/Makefile
使用"automake -a"或"automake --add-missing",会自动将install.sh、mkinstalldirs等文件补齐,否则会出错,切记!
第七步 运行autoconf
最后,可以执行autoconf了,完成后将会生成最终的configure!
第八步 编译&测试
用默认值编译:
[root@chiosoft tt]# ./configure
Checking for ......
PoPo isn't here!
Checking for ......
[root@chiosoft tt]# make
默认状态下,我们没有定义宏POPO,所以./configure时输出"PoPo isn't here!",运行时也只有QQ来报到。
再看看这个:
[root@chiosoft tt]# ./configure --help
......
--enable and --with options recognized:
--enable-popo PoPo is present
[root@chiosoft tt]# ./configure --enable-popo
Checking for ......
PoPo is here!
Checking for ......
[root@chiosoft tt]# make
在Linux下得到一个以源代码形式发布的包(一般为.tar.gz或.tar.bz2格式),我们可以用 ./confiugure、make、make install来编译安装,其中在运行./configure的时候还可以根据自己的需要加入不同的参数(可用./configure --help来查看参数表)。
先说说执行./configure后会生成什么东西?运行后系统会根据用户的实际情况生成config.h和多个Makefile。其中 Makefile是运行make时所用的模板;而config.h则会以宏(Marco)的形式记录用户的自定义参数,编译器可以根据config.h来 对源代码进行预编译(pre-compile),从而生成个性化的执行档。
二、我们的“软件”
现在我们可以动手设计一个自己的“软件”了,为了更切合实际,将使用多个源程序,首先建立一个目录tt,用来放我们的东西,然后在tt下建立一个src目录,一般来说源代码都放在src中(好像已经成为一个不成文的规矩了:P)。整体架构如下:
<tt>
|-configure.in
|-Makefile.am
|-acconfig.h
|-<src>
|-tt.c
|-qq.c
|-qq.h
|-Makefile.am
1. configure.in 这是最重要的文档,整个安装过程都靠它来主导。
2. Makefile.am automake会根据它来生成Makefile.in,再由./configure 把Makefile.in变成最终的Makefile,一般来说在顶级目录和各个子目录都应该有一个Makefile.am
3. acconfig.h autoheader会根据它来生成config.h.in,再由./configure 把config.h.in变成最终的config.h
4. tt.c qq.c qq.h 这是我们的源程序。
三、制作流程
请按照以下的执行顺序一步一步做:
第一步 编写configure.in
生成configure.in的方法有两个,一个是自己从零开始写,另一个方法是用autoscan,执行autoscan后会生成configure.scan,其中包含了一些模板内容,使用时只要把名字改成.in就可以。
configure.in中使用的命令有两种,一种是以AC开头,表示是由autoconf提供,另一种是以AM开头,代表由automake提供。
在configure.in我们可以完成很多检测动作,比如检查编译所需的程式、头文件、库等等,总之功能是十分强大,不过我们这里只检测了编译器和头文件,详细用法请看 GNU Manuals Online
configure.in
#dnl 初始化autoconf,参数为入口函数所在的文件
AC_INIT(src/tt.c)
#dnl 初始化automake,参数为软件名称及版本号
AM_INIT_AUTOMAKE(tt, 0.1.0)
#dnl 告诉automake我们所用的配置文件,一般为config.h
AM_CONFIG_HEADER(config.h)
#dnl 这里是实现自定义参数的部份,见下面的说明
AC_ARG_ENABLE(popo, [ --enable-popo PoPo is present],,enable_popo=no)
if test "$enable_popo" = yes ; then
echo "PoPo is here!"
AC_DEFINE(POPO)
else
echo "PoPo isn't here!"
fi
#dnl 检测编译器
AC_PROG_CC
#dnl 检测Standard C的头文件
AC_HEADER_STDC
#dnl 输出文件,一般来说顶级目录和各子目录都应有Makefile输出
AC_OUTPUT(Makefile src/Makefile)
./configure的自定义参数有两种,一种是开关式(--enable-XXX或--disable-XXX),另一种是开放式,即后面要填入一串字符(--with-XXX=yyyy)参数。
上述代码中用的是开关式,第一个参数是参数名,第二个是说明(执行"./configure --help"后所显示出来的内容),最后一个参数是默认值。一般来说默认值和用户提示应该是互斥的,即默认值是no的话,应提示用户用enable进行修改,反之亦然。
从上面的代码中可以看到,如果$enable_popo为yes的话,就用AC_DEFINE来定义POPO这个宏(Macro),否则就不定义,我们在这里所使用到的宏,一定要在acconfig.h中声明。
第二步 运行aclocal 在tt目录下运行aclocal,将会生成aclocal.m4。
第三步 编写acconfig.h
在configure.in中使用到的宏(Macro),都应该在这个文件声明,一般用#undef来声明。
acconfig.h
#undef POPO
第四步 运行autoheader
运行autoheader后会根据configure.in、acconfig.h和系统预设的acconfig.h来生成config.h.in。
第五步 编写Makefile.am
一般来说,在顶级目录和各子目录都应有一个Makefile.am。
Makefile.am
AUTOMAKE_OPTIONS = foreign
SUBDIRS = src
第一行是告诉automake不要检测目录中是否存在AUTHORS、README等文件。
第二行是告诉automake处理src这个子目录。
src/Makefile.am
AUTOMAKE_OPTIONS = foreign
bin_PROGRAMS = tt
tt_SOURCES = tt.c qq.c qq.h
第一行作用同前。
第二行是目标执行档的名称。
第三行是生成tt这个执行档所需的所有源程序和头文件名称。
第六步 运行automake
接著可以执行automake了,在命令行下输入
automake -a 和
automake -a src/Makefile
使用"automake -a"或"automake --add-missing",会自动将install.sh、mkinstalldirs等文件补齐,否则会出错,切记!
第七步 运行autoconf
最后,可以执行autoconf了,完成后将会生成最终的configure!
第八步 编译&测试
用默认值编译:
[root@chiosoft tt]# ./configure
Checking for ......
PoPo isn't here!
Checking for ......
[root@chiosoft tt]# make
默认状态下,我们没有定义宏POPO,所以./configure时输出"PoPo isn't here!",运行时也只有QQ来报到。
再看看这个:
[root@chiosoft tt]# ./configure --help
......
--enable and --with options recognized:
--enable-popo PoPo is present
[root@chiosoft tt]# ./configure --enable-popo
Checking for ......
PoPo is here!
Checking for ......
[root@chiosoft tt]# make
相关文章推荐
- Linux Makefile 生成 *.d 依赖文件及 gcc -M -MF -MP 等相关选项说明【转】
- Linux学习第四节课-文件管理基本概念及部分通配符变量说明
- 学习笔记linux c++ 0707(用autoscan自动生成makefile文件)
- linux下Makefile的学习之九(更新函数库文件)
- 一天一点学习Linux之文件与目录权限的基本概念【对工作目录(即当前目录)的说明】
- Linux学习笔记——例说makefile 头文件查找路径
- linux下make命令和makefile文件学习
- linux文件属性详细说明(网络转载,仅供学习之用)
- Makefile学习笔记1:Linux平台Makefile文件的编写基础篇(zz)
- Linux Makefile 生成 *.d 依赖文件及 gcc -M -MF -MP 等相关选项说明【转】
- linux驱动学习笔记--头文件的说明
- linux下autoscan, aclocal, autoconf, automake以及Makefile.am, Configure.in等文件和工具的使用
- [转]Linux学习笔记——例说makefile 头文件查找路径
- Linux学习之Makefile文件的编写
- linux下autoscan, aclocal, autoconf, automake以及Makefile.am, Configure.in等文件和工具的使用
- Linux学习笔记——例说makefile 头文件查找路径
- 安装linux学习六(4):Nginx配置文件详细说明
- Linux Makefile文件编写与使用学习
- Linux学习笔记——例说makefile 多个文件
- linux 编程学习笔记--编译多个文件