Autoconf/automake step by step

 

Autoconf/automake 在开源社区里,它的重要性可以说不下于gcc,目前除了Xfree86外,几乎所有的开源项目都使用Autoconf/automake,甚至Xfree86的开发人员已经计划抛弃imake,而采用Autoconf/automake作为工程管理工具了。

 

Autoconf/automake冗长的手册让我犯晕。虽然我曾耐着性子浏览过一遍,但是决大部分内容,在日常工作根本用不上。加上建立工程的机会并不多,等到下一次要建立时,上次学到的知识早忘光了,还得去看手册,真是麻烦。

 

大多数时候,我更需要的是step by step的指南,只有在特殊情况下,要使用Autoconf/automake的高级功能时候,我才愿意去查手册。最近刚好建过几个工程,记个笔记吧,以便下次查阅。

 

一、建立可执行文件工程。

l         前提:

项目目录:helloworld

源文  件:helloworld/src/helloworld.c

 

l         用autoscan产生configure.in的框架:

[root@linux helloworld]# autoscan

[root@linux helloworld]# mv configure.scan configure.in

 

打开configure.in,我们可以看到:


#                                               -*- Autoconf -*-

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

 

AC_PREREQ(2.59)

AC_INIT(FULL-PACKAGE-NAME, VERSION, BUG-REPORT-ADDRESS)

AC_CONFIG_SRCDIR([src/helloworld.c])

AC_CONFIG_HEADER([config.h])

 

# Checks for programs.

AC_PROG_CC

 

# Checks for libraries.

 

# Checks for header files.

 

# Checks for typedefs, structures, and compiler characteristics.

 

# Checks for library functions.

AC_OUTPUT


这个文件并不能直接使用,要做几处修改才行。

AC_INIT的参数要换成实际的参数。

AC_OUTPUT中要指明实际要生成的文件。

增加automake的初始化宏。

我们把它修改为:


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

 

AC_PREREQ(2.59)

AC_INIT(helloworld, 0.1, jim@jim.com)

AC_CONFIG_SRCDIR([src/helloworld.c])

AC_CONFIG_HEADER([config.h])

AM_INIT_AUTOMAKE(helloworld, 0.1)

 

# Checks for programs.

AC_PROG_CC

 

# Checks for libraries.

 

# Checks for header files.

 

# Checks for typedefs, structures, and compiler characteristics.

 

# Checks for library functions.

AC_OUTPUT([

Makefile

src/Makefile

])


 

l         建立根顶层目录中的Makefile.am,用SUBDIRS指明子目录。


SUBDIRS=src


 

l         建立src目录中的Makefile.am,这里我们生成的可执行文件名为helloworld,安装目录为${prefix}/bin。如果只想编译,不想安装到系统中,可以用noinst_PROGRAMS代替bin_PROGRAMS。


bin_PROGRAMS=helloworld

helloworld_SOURCES=helloworld.c


 

l         在顶层目录中建立几个空文件。

[root@linux helloworld]# touch NEWS README ChangeLog AUTHORS

l         拷贝automake必要的文件。

[root@linux helloworld]# cp -f /usr/share/automake-1.9/depcomp .

[root@linux helloworld]# cp -f /usr/share/automake-1.9/compile .

 

l         建立autogen.sh


#!/bin/bash

aclocal

autoheader

autoconf

automake -a

./configure


[root@linux helloworld]# chmod 755 autogen.sh

l         测试一下

[root@linux helloworld]# ./autogen.sh ;make;make install

OK了

 

二、建立共享库工程。

l         前提:

项目目录:helloworld

源文  件:helloworld/src/helloworld.c

头文  件:helloworld/src/helloworld.h

l         用autoscan产生configure.in的框架:

[root@linux helloworld]# autoscan

[root@linux helloworld]# mv configure.scan configure.in

 

打开configure.in,我们可以看到:


#                                               -*- Autoconf -*-

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

 

AC_PREREQ(2.59)

AC_INIT(FULL-PACKAGE-NAME, VERSION, BUG-REPORT-ADDRESS)

AC_CONFIG_SRCDIR([src/helloworld.c])

AC_CONFIG_HEADER([config.h])

 

# Checks for programs.

AC_PROG_CC

 

# Checks for libraries.

 

# Checks for header files.

 

# Checks for typedefs, structures, and compiler characteristics.

 

# Checks for library functions.

AC_OUTPUT


这个文件并不能直接使用,要做几处修改才行。

AC_INIT的参数要换成实际的参数。

AC_OUTPUT中要指明实际要生成的文件。

增加automake的初始化宏。

增加libtool检查。

我们把它修改为:


#                                               -*- Autoconf -*-

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

 

AC_PREREQ(2.59)

AC_INIT(helloworld, 0.1, jim@jim.com)

AC_CONFIG_SRCDIR([src/helloworld.c])

AC_CONFIG_HEADER([config.h])

AM_INIT_AUTOMAKE(helloworld, 0.1)

 

# Checks for programs.

AC_PROG_CC

AC_LIBTOOL_DLOPEN

AC_PROG_LIBTOOL

 

# Checks for libraries.

 

# Checks for header files.

 

# Checks for typedefs, structures, and compiler characteristics.

 

# Checks for library functions.

AC_OUTPUT([

Makefile

src/Makefile

])


 

l         建立根顶层目录中的Makefile.am,用SUBDIRS指明子目录。


SUBDIRS=src


 

l         建立src目录中的Makefile.am,这里我们生成的共享文件名为libhelloworld.la,安装目录为${prefix}/lib,头文件安装到${prefix}/include/helloworld/。


lib_LTLIBRARIES       = libhelloworld.la

 

libhelloworld_la_SOURCES=helloworld.c

libhelloworld_la_CFLAGS=-I./

libhelloworld_la_LDFLAGS=

 

helloworldincludedir=$(includedir)/helloworld

helloworldinclude_HEADERS= helloworld.h


 

l         在顶层目录中建立几个空文件。

[root@linux helloworld]# touch NEWS README ChangeLog AUTHORS

l         拷贝automake和libtool必要的文件。

[root@linux helloworld]# cp -f /usr/share/automake-1.9/depcomp .

[root@linux helloworld]# cp -f /usr/share/automake-1.9/compile .

[root@linux helloworld]# cp -f /usr/share/libtool/ltmain.sh .

l         建立autogen.sh


#!/bin/bash

aclocal

autoheader

autoconf

automake -a

./configure


[root@linux helloworld]# chmod 755 autogen.sh

l         测试一下

[root@linux helloworld]# ./autogen.sh ;make;make install

OK了