automake生成静态库文件_Automake 详解

automake生成静态库文件_Automake 详解automake配置一、安装命令:sudoapt-getinstallautomake二、配置过程1、使用Autoscan工具生成configure.ac文件命令:autoscan生成configure.scanAutoscan工具用来扫描源代码以搜寻一般的可移植性问题,比如检查编译器、库和头文件等,并创建configure.scan文件,它会在给定目录及其子目录树中检查源文件,若没有给出目…

大家好,欢迎来到IT知识分享网。automake生成静态库文件_Automake 详解

automake配置

一、安装

命令:sudo apt-get install

automake

二、配置过程

1、 使用Autoscan工具生成configure.ac文件

命令:

autoscan

生成configure.scan

Autoscan工具用来扫描源代码以搜寻一般的可移植性问题,比如检查编译器、库和头文件等,

并创建configure.scan文件,它会在给定目录及其子目录树中检查源文件,若没有给出目录,

就在当前目录及其子目录树中进行检查。

#

-*- Autoconf -*-

# Process this file with autoconf

to produce a configure script.

AC_PREREQ([2.65])

// automake版本

AC_INIT(hello, 1.0,

kingplesk@gmail.com)             // 设置软件包信息

AM_INIT_AUTOMAKE(hello, 1.0)

// 这个需要手动添加,它是automake必备的宏

AC_CONFIG_SRCDIR([hello.c])

//

检查此文件

AC_CONFIG_HEADERS([config.h])

// config.h 文件, 这个地方我们不需要config.h文件所以把它注释掉

#

Checks for programs.

AC_PROG_CC

// 采用默认编译器

#

Checks for

libraries.

AC_CHECK_LIB(pthread,

pthread_create)                //  检查线程库,是否有pthread_create

AC_PROG_LIBTOOL                                      //   生成动态库需此选项

AC_PROG_RANLIB

//   生成静态库需此选项

# Checks for header

files.

AC_CHECK_HEADERS([arpa/inet.h)                       //  头文件

# Checks for typedefs,

structures, and compiler characteristics.

# Checks for

library functions.

AC_TYPE_SIZE_T

AC_TYPE_UINT32_T

AC_OUTPUT(Makefile)

// 要输出的文件名

下面给出本文件的简要说明(所有以”#”号开始的行为注释):

(1)AC_PREREQ宏声明本文件要求的autoconf版本,本例使用的版本为2.59。

(2)AC_INIT宏用来定义软件的名称和版本等信息,”FULL-PACKAGE-NAME”为软件包名称,”VERSION”为软件版本号,”BUG-REPORT-ADDRESS”为BUG报告地址(一般为软件作者邮件地址)。

(3)AC_CONFIG_SRCDIR宏用来侦测所指定的源码文件是否存在,来确定源码目录的有效性。此处为当前目录下的hello.c。

(4)AC_CONFIG_HEADER宏用于生成config.h文件,以便autoheader使用。

(5)AC_PROG_CC用来指定编译器,如果不指定,选用默认gcc。

(6)AC_OUTPUT用来设定

configure

所要产生的文件,如果是makefile,configure会把它检查出来的结果带入makefile.in文件产生合适的makefile。使用Automake时,

还需要一些其他的参数,这些额外的宏用aclocal工具产生。

2、

使用aclocal工具生成aclocal.m4

命令: aclocal

aclocal根据configure.ac生成aclocal.m4

3、 使用autoconf工具生成configure文件

命令:

autoconf

将configure.ac中的宏展开,生成configure脚本。这个过程可能要用到aclocal.m4中定义的宏。

4、

使用autoheader 工具生成 config.h config.h.in

命令:autoheader

5、

生成动态库:

sudo apt-get install libtool

5.1、 修改configure.in文件

添加 AC_PROG_LIBTOOL

5.2、

修改Makefile.am文件

lib_LTLIBRARIES=librx.la

librx_la_SOURCES=rx.c

5.3、 libtoolize –automake

6、 创建Makefile.am文件

命令: vi Makefiel.am

Automake工具会根据configure.in中的参量把Makefile.am转换成Makefile.in文件。所以在使用automake之前我们需要自己创建Makefile.am文件

AUTOMAKE_OPTIONS=foreign

// 软件等级

bin_PROGRAMS=hello

—>

对于可执行文件和静态库类型,如果只想编译,不想安装到系统中,可以用noinst_PROGRAMS代替bin_PROGRAMS.

hello_SOURCES=hello.c

// 源文件名

(1)AUTOMAKE_OPTIONS为设置Automake的选项。由于GNU对自己发布的软件有严格的规范,比如必须附带许可证声明文件COPYING等,否则Automake执行时会报错。Automake提供了3种软件等级:foreign、gnu和gnits,供用户选择,默认等级为gnu。本例使需用foreign等级,它只检测必须的文件。

(2)bin_PROGRAMS定义要产生的执行文件名。如果要产生多个执行文件,每个文件名用空格隔开。

(3)hello_SOURCES定义”hello”这个执行程序所需要的原始文件。如果”hello”这个程序是由多个原始文件所产生的,则必须把它所用到的所有原始文件都列出来,并用空格隔开。例如:若目标体”hello”需要”hello.c”、”hello.h”两个依赖文件,则定义hello_SOURCES=hello.c

hello.h。

7、 使用Automake生成Makefile.in文件

命令: automake

下面使用Automake生成”Makefile.in”文件,使用选项”–add-missing”可以让Automake自动添加一些必需的脚本文件。

8、

执行./configure 生成Makefile

命令: ./configure

$ ./configure

–prefix=$PWD/out –host=arm-linux

‘–prefix’是最常用的选项.制作出的’Makefile’会查看随此选项传递的参数,当一个包在安装时可以彻底的重新安置他的结构独立部分.

举一个例子,当安装一个包,例如说Emacs,下面的命令将会使Emacs Lisp file被安装到”/opt/gnu/share”:

$ ./configure –prefix=/opt/gnu

–exec-prefix=EPREFIX

与’–prefix’选项类似,但是他是用来设置结构倚赖的文件的安装位置.编译好的’emacs’二进制文件就是这样一个问件.如果没有设置这个选项的话,默认使用的选项值将被设为和’–prefix’选项值一样.

–bindir=DIR

指定二进制文件的安装位置.这里的二进制文件定义为可以被用户直接执行的程序.

–sbindir=DIR

指定超级二进制文件的安装位置.这是一些通常只能由超级用户执行的程序.

–libexecdir=DIR

指定可执行支持文件的安装位置.与二进制文件相反,这些文件从来不直接由用户执行,但是可以被上面提到的二进制文件所执行.

三、

Makefile.am的编写

文件结构:

linux_app (顶层目录)

|——src 目录(存放源代码文件)

|—— basic

|——  comm

|——  app_comm.c

|——  net

|——

app_net.c

|——  io

|——  app_io.c

(需使用libopencc.so libiconv.so)

|——  time

|——  app_time.c

|——

app_main.c

|—— lib

目录(存放需使用的库文件)

|——

libopencc.so

|—— libiconv.so

|—— include

目录(存放程序中使用的头文件)

|—— app

|—— app_comm.h

app_net.h app_io.h app_time.h

|—— opencc

|——

opencc.h

|—— iconv

|—— iconv.h

|——conf

目录(配置选项)

|——

app.conf

命令: vi

conf/Makefile.am

# 这个数据文件移动的目录

# configdir =

# 数据文件名

# config_DATA =

命令: vi src/Makefile.am

# 进入的目录

SUBDIRS

= conf src

命令: vi src/Makefile.am

SUBDIRS=basic

// 进入此目录编译Makefile

bin_PROGRAMS=app

// 生成可执行文件

app_SOURCES=app_main.c                       //

所依赖的源文件

INCLUDES=-I$(top_srcdir)/include/app         // 源文件所需头文件目录

app_LDFLAGS=-L$(top_srcdir)/src/basic        // 所需库路径

app_LDFLAGS+=-L$(top_srcdir)/lib             // 所需库路径

LIBS=-lbasic

-liconv -lopencc                // 当系统安装了此库,会默认从系统库链接,会出现错误。

命令:vi

src/basic/Makfile.am

# 直接编译该目录下所有源文件,生成动态库文件。

lib_LTLIBRARIES=libbasic.la                  // 生成动态库

libbasic_la_SOURCES=time/app_time.c log/app_log.c comm/app_comm.c io/app_io.c

net/app_net.c pthread/app_pthread.c

INCLUDES=-I$(top_srcdir)/include/app

INCLUDES+=-I$(top_srcdir)/include/opencc

INCLUDES+=-I$(top_srcdir)/include/iconv

命令: vi

src/basic/io/Makefile.am

# 生成静态库文件

noinst_LIBRARIES = libio.a

libio_a_SOURCES = app_io.c

INCLUDES=-I$(top_srcdir)/include/app

INCLUDES+=-I$(top_srcdir)/include/opencc

INCLUDES+=-I$(top_srcdir)/include/iconv

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/11375.html

(0)

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信