从 0 开始学习 Linux 系列之「10.Autoconf 打包软件」

Autoconf

版权声明:本文为 cdeveloper 原创文章,可以随意转载,但必须在明确位置注明出处!

Autoconf 简介

Autoconf 是一种用于生成 shell 脚本的工具,可自动配置软件源代码包,以适应多种类型的类似 Posix 的系统。你可以简单地把它看为打包源码的工具,例如你在 GNU 官网下载的那些 xxx.tar.gz 格式的软件包,我们使用这个工具最终目的就是将源代码打成一个包来提供给别人使用。本次就跟大家分享下如何打包一个基本的 Hello World 给别人使用,掌握这个步骤以后就可以类比来打包别的软件包了,首先我们来看看 Autoconf 的基本打包流程。

Autoconf 打包流程

我们使用 Autoconf 打包一个软件包主要依靠下面这张图:

Autoconf

这张图中主要使用了 5 个与 autoconf 相关的工具,我们分别来了解即可,不需要深入学习。

1. autoscan

autoscan 用来扫描源代码目录并生成 configure.scan 文件,这个文件包含了系统配置的基本选项,里面都是一些宏定义,在使用的时候需要将这个文件改名为 configure.ac,并修改相关的配置,我们后面在实际例子中介绍。

2. aclocal

aclocal 是一个 prel 脚本程序,aclocal 根据 configure.ac 文件的内容自动生成 aclocal.m4 文件,这个文件内容是 configure.ac 中的宏展开

3. autoconf

autoconf 用来产生 configure 文件,这个文件就是我们在手动编译一个软件是要做的第一步:./configure

4. autoheader

autoheader 自动生成相关的文件,这个功能在源码需要头文件时才使用。

5. automake

automake 可以将 Makefile.am 生成 Makfile.in,但是 Makefil.am 需要我们手动书写。

了解了这 5 个工具,下面我们就来打包一个实际的 Hello World !

实践:Autoconf 打包 Hello World

我们来以一个实际打包 hello.c 的例子来介绍 Autoconf 的基本用法。

安装 autoconf

首先确定你的系统有没有安装 autoconf,在命令行键入 autoconf,如果提示没有安装,则需要先安装:

sudo apt-get install autoconf

编辑 hello.c

我们编写一个 hello.c 作为测试:

#include <stdio.h>
int main(void) {
    printf("Hello World!\n");
    return 0;
}

下面就开始正式打包流程。

1. autoscan

从上面的图中可以看到,第一步我们需要使用 autoscan 来生成 configure.scan 文件:

autoscan

执行的结果除了 hello.c 还有另外 2 个文件:

autoscan

2. 修改 configure.ac

之后我们还需要将 configure.scan 改名configure.ac,并修改以下的 3 点内容:

#                                               -*- Autoconf -*-
# Process this file with autoconf to produce a configure script.

AC_PREREQ([2.69])

# 1. 修改:可执行文件名称,版本号,bug 邮箱
AC_INIT(hello, 1.0, chenghjy@gmail.com)

AC_CONFIG_SRCDIR([hello.c])
AC_CONFIG_HEADERS([config.h])

# 2. 我们后面使用 automake, 所以需要加上这个配置
AM_INIT_AUTOMAKE

# Checks for programs.
AC_PROG_CC

# Checks for libraries.

# Checks for header files.

# Checks for typedefs, structures, and compiler characteristics.

# Checks for library functions.

# 3. 输出文件指定为 Makefile
AC_OUTPUT(Makefile)

3. aclocal

从上图可以看到我们生成 configure 需要 [aclocal.m4] 文件,我们使用 aclocal 来生成:

aclocal

结果生成了 aclocal.m4 文件,如下图所示:

aclocal

4. autoconf

现在可以使用 autoconf 来生成 configure 啦:

autoconf

结果如下,生成了 configure

autoconf

我们直接执行 ./configure 看看是否能够配置成功:

./configure

# 结果
configure: error: cannot find install-sh, install.sh, or shtool in "." "./.." "./../.."

但是结果提示我们缺少一些 shell 脚本,因此我们还需要进行后面的配置。

5. autoheader

如果在 configure.ac 中需要头文件,则需要进行这一步,否则不需要,我们配置了所以需要:

autoheader
autoheader

6. 编写 Makefile.am

上图中,我们如果要使用 automake 来生成 Makefile.in,则还需要 Makefile.am 文件,但是这个文件需要我们手动编写,具体如何编写,可以查看 automake 官方文档,在下面这个图片位置:

Makefile.am

因为我们的 hello 程序很简单,不需要依赖其他的库,所以这里只需要写 2 行:

bin_PROGRAMS = hello
hello_SOURCES = hello.c 

7. automake

上面写完了 Makefile.am 文件,现在就可以使用 automake 来生成 Makefile.in 啦:

automake

# 结果
configure.ac:10: error: required file './compile' not found
configure.ac:10:   'automake --add-missing' can install 'compile'
configure.ac:8: error: required file './install-sh' not found
configure.ac:8:   'automake --add-missing' can install 'install-sh'
configure.ac:8: error: required file './missing' not found
configure.ac:8:   'automake --add-missing' can install 'missing'
Makefile.am: error: required file './INSTALL' not found
Makefile.am:   'automake --add-missing' can install 'INSTALL'
Makefile.am: error: required file './NEWS' not found
Makefile.am: error: required file './README' not found
Makefile.am: error: required file './AUTHORS' not found
Makefile.am: error: required file './ChangeLog' not found
Makefile.am: error: required file './COPYING' not found
Makefile.am:   'automake --add-missing' can install 'COPYING'
Makefile.am: error: required file './depcomp' not found
Makefile.am:   'automake --add-missing' can install 'depcomp'

但是出现了一些错误,从提示信息中发现可以使用 automake --add-missing

automake --add-missing

# 结果
configure.ac:10: installing './compile'
configure.ac:8: installing './install-sh'
configure.ac:8: installing './missing'
Makefile.am: installing './INSTALL'
Makefile.am: error: required file './NEWS' not found
Makefile.am: error: required file './README' not found
Makefile.am: error: required file './AUTHORS' not found
Makefile.am: error: required file './ChangeLog' not found
Makefile.am: installing './COPYING' using GNU General Public License v3 file
Makefile.am:     Consider adding the COPYING file to the version control system
Makefile.am:     for your code, to avoid questions about which license your project uses
Makefile.am: installing './depcomp'

还是有错误,但是这个错误很好解决,它提示 NEWSREADMEAUTHORSChangeLog 这 4 个文件没有找到,其实这 4 个文件是一个正规软件发布的时候一般都带有的,我们这里新建这 4 个文件即可,就不写内容了:

touch NEWS README AUTHORS ChangeLog

# 再次执行,没有错误信息
automake --add-missing 

结果生成了 Makefile.in,这也就是我们配置的最终结果啦:

Makefile.in

可以看到目前我们的文件已经很多了,是不是有些正式发布的软件的样子了,其实正式的软件里面的大部分配置文件也是自动生成的。不过我们还差最后一步:打包

8. 打包

我们使用 make dist 命令直接打包:

# 先要配置得到 Makefile
./configure

# 打包
make dist

# ls 结果
hello-1.0.tar.gz

测试 hello-1.0.tar.gz

下面我们就来测试我们打包的 hello 程序是否可用,我们从配置到最后的卸载一共分为 6 步:

# 1. 配置:./configure 
./configure

# 2. 编译:make
make

# 3. 安装:install
sudo make install

# 4. 运行
hello

# 5. 结果,打印 Hello World! 说明成功啦!
Hello World!

# 6. 卸载:uninstall
sudo make uninstall

一路绿灯,说明我们打的包没有问题,那么这个实验也就到此结束了。

结语

本次我们学习如何在 Linux 下通过命令行和 Autoconf 来打包一个程序,我们也知道了从网上下载下的软件包中的那么多文件是怎么来的了,并且我们也实际练习了如何打包一个 Hello World! 给别人使用了。通过这个例子,希望你能够掌握 Autoconf 基本的用法,在以后遇到问题的时候,还望你能主动去 Autoconf 官网 查找资料,做一个主动学习的人。

最后,感谢你的阅读,我们下次再见 :)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,084评论 6 503
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,623评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,450评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,322评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,370评论 6 390
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,274评论 1 300
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,126评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,980评论 0 275
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,414评论 1 313
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,599评论 3 334
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,773评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,470评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,080评论 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,713评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,852评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,865评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,689评论 2 354

推荐阅读更多精彩内容