青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

不會(huì)飛的鳥

2010年12月10日 ... 不鳥他們!?。?我要用自己開發(fā)的分布式文件系統(tǒng)、分布式調(diào)度系統(tǒng)、分布式檢索系統(tǒng), 做自己的搜索引擎?。?!大魚有大志!??! ---楊書童

例解 autoconf 和 automake 生成 Makefile 文件

本文介紹了在 linux 系統(tǒng)中,通過 Gnu autoconf 和 automake 生成 Makefile 的方法。主要探討了生成 Makefile 的來龍去脈及其機(jī)理,接著詳細(xì)介紹了配置 Configure.in 的方法及其規(guī)則。

引子

無論是在Linux還是在Unix環(huán)境中,make都是一個(gè)非常重要的編譯命令。不管是自己進(jìn)行項(xiàng)目開發(fā)還是安裝應(yīng)用軟件,我們都經(jīng)常要用到make或 make install。利用make工具,我們可以將大型的開發(fā)項(xiàng)目分解成為多個(gè)更易于管理的模塊,對(duì)于一個(gè)包括幾百個(gè)源文件的應(yīng)用程序,使用make和 makefile工具就可以輕而易舉的理順各個(gè)源文件之間紛繁復(fù)雜的相互關(guān)系。

但是如果通過查閱make的幫助文檔來手工編寫Makefile,對(duì)任何程序員都是一場挑戰(zhàn)。幸而有GNU 提供的Autoconf及Automake這兩套工具使得編寫makefile不再是一個(gè)難題。

本文將介紹如何利用 GNU Autoconf 及 Automake 這兩套工具來協(xié)助我們自動(dòng)產(chǎn)生 Makefile文件,并且讓開發(fā)出來的軟件可以像大多數(shù)源碼包那樣,只需"./configure", "make","make install" 就可以把程序安裝到系統(tǒng)中。





回頁首


模擬需求

假設(shè)源文件按如下目錄存放,如圖1所示,運(yùn)用autoconf和automake生成makefile文件。


圖 1文件目錄結(jié)構(gòu)
圖 1文件目錄結(jié)構(gòu)

假設(shè)src是我們?cè)次募夸?,include目錄存放其他庫的頭文件,lib目錄存放用到的庫文件,然后開始按模塊存放,每個(gè)模塊都有一個(gè)對(duì)應(yīng)的目錄,模塊下再分子模塊,如apple、orange。每個(gè)子目錄下又分core,include,shell三個(gè)目錄,其中core和shell目錄存放.c文件,include的存放.h文件,其他類似。

樣例程序功能:基于多線程的數(shù)據(jù)讀寫保護(hù)(聯(lián)系作者獲取整個(gè)autoconf和automake生成的Makefile工程和源碼,E-mail:normalnotebook@126.com)。





回頁首


工具簡介

所必須的軟件:autoconf/automake/m4/perl/libtool(其中l(wèi)ibtool非必須)。

autoconf是一個(gè)用于生成可以自動(dòng)地配置軟件源碼包,用以適應(yīng)多種UNIX類系統(tǒng)的shell腳本工具,其中autoconf需要用到 m4,便于生成腳本。automake是一個(gè)從Makefile.am文件自動(dòng)生成Makefile.in的工具。為了生成Makefile.in,automake還需用到perl,由于automake創(chuàng)建的發(fā)布完全遵循GNU標(biāo)準(zhǔn),所以在創(chuàng)建中不需要perl。libtool是一款方便生成各種程序庫的工具。

目前automake支持三種目錄層次:flat、shallow和deep。

1) flat指的是所有文件都位于同一個(gè)目錄中。

就是所有源文件、頭文件以及其他庫文件都位于當(dāng)前目錄中,且沒有子目錄。Termutils就是這一類。

2) shallow指的是主要的源代碼都儲(chǔ)存在頂層目錄,其他各個(gè)部分則儲(chǔ)存在子目錄中。

就是主要源文件在當(dāng)前目錄中,而其它一些實(shí)現(xiàn)各部分功能的源文件位于各自不同的目錄。automake本身就是這一類。

3) deep指的是所有源代碼都被儲(chǔ)存在子目錄中;頂層目錄主要包含配置信息。

就是所有源文件及自己寫的頭文件位于當(dāng)前目錄的一個(gè)子目錄中,而當(dāng)前目錄里沒有任何源文件。 GNU cpio和GNU tar就是這一類。

flat類型是最簡單的,deep類型是最復(fù)雜的。不難看出,我們的模擬需求正是基于第三類deep型,也就是說我們要做挑戰(zhàn)性的事情:)。注:我們的測試程序是基于多線程的簡單程序。





回頁首


生成 Makefile 的來龍去脈

首先進(jìn)入 project 目錄,在該目錄下運(yùn)行一系列命令,創(chuàng)建和修改幾個(gè)文件,就可以生成符合該平臺(tái)的Makefile文件,操作過程如下:

1) 運(yùn)行autoscan命令

2) 將configure.scan 文件重命名為configure.in,并修改configure.in文件

3) 在project目錄下新建Makefile.am文件,并在core和shell目錄下也新建makefile.am文件

4) 在project目錄下新建NEWS、 README、 ChangeLog 、AUTHORS文件

5) 將/usr/share/automake-1.X/目錄下的depcomp和complie文件拷貝到本目錄下

6) 運(yùn)行aclocal命令

7) 運(yùn)行autoconf命令

8) 運(yùn)行automake -a命令

9) 運(yùn)行./confiugre腳本

可以通過圖2看出產(chǎn)生Makefile的流程,如圖所示:


圖 2生成Makefile流程圖
圖 2生成Makefile流程圖




回頁首


Configure.in的八股文

當(dāng)我們利用autoscan工具生成confiugre.scan文件時(shí),我們需要將confiugre.scan重命名為confiugre.in文件。confiugre.in調(diào)用一系列autoconf宏來測試程序需要的或用到的特性是否存在,以及這些特性的功能。

下面我們就來目睹一下confiugre.scan的廬山真面目:


# 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([config.h.in])
            AC_CONFIG_HEADER([config.h])
            # Checks for programs.
            AC_PROG_CC
            # Checks for libraries.
            # FIXME: Replace `main' with a function in `-lpthread':
            AC_CHECK_LIB([pthread], [main])
            # Checks for header files.
            # Checks for typedefs, structures, and compiler characteristics.
            # Checks for library functions.
            AC_OUTPUT
            

每個(gè)configure.scan文件都是以AC_INIT開頭,以AC_OUTPUT結(jié)束。我們不難從文件中看出confiugre.in文件的一般布局:


AC_INIT
            測試程序
            測試函數(shù)庫
            測試頭文件
            測試類型定義
            測試結(jié)構(gòu)
            測試編譯器特性
            測試庫函數(shù)
            測試系統(tǒng)調(diào)用
            AC_OUTPUT
            

上面的調(diào)用次序只是建議性質(zhì)的,但我們還是強(qiáng)烈建議不要隨意改變對(duì)宏調(diào)用的次序。

現(xiàn)在就開始修改該文件:


$mv configure.scan configure.in
            $vim configure.in
            

修改后的結(jié)果如下:


            #                                -*- Autoconf -*-
            # Process this file with autoconf to produce a configure script.
            AC_PREREQ(2.59)
            AC_INIT(test, 1.0, normalnotebook@126.com)
            AC_CONFIG_SRCDIR([src/ModuleA/apple/core/test.c])
            AM_CONFIG_HEADER(config.h)
            AM_INIT_AUTOMAKE(test,1.0)
            # Checks for programs.
            AC_PROG_CC
            # Checks for libraries.
            # FIXME: Replace `main' with a function in `-lpthread':
            AC_CHECK_LIB([pthread], [pthread_rwlock_init])
            AC_PROG_RANLIB
            # Checks for header files.
            # Checks for typedefs, structures, and compiler characteristics.
            # Checks for library functions.
            AC_OUTPUT([Makefile
            src/lib/Makefile
            src/ModuleA/apple/core/Makefile
            src/ModuleA/apple/shell/Makefile
            ])
            

其中要將AC_CONFIG_HEADER([config.h])修改為:AM_CONFIG_HEADER(config.h), 并加入AM_INIT_AUTOMAKE(test,1.0)。由于我們的測試程序是基于多線程的程序,所以要加入AC_PROG_RANLIB,不然運(yùn)行automake命令時(shí)會(huì)出錯(cuò)。在AC_OUTPUT輸入要?jiǎng)?chuàng)建的Makefile文件名。

由于我們?cè)诔绦蛑惺褂昧俗x寫鎖,所以需要對(duì)庫文件進(jìn)行檢查,即AC_CHECK_LIB([pthread], [main]),該宏的含義如下:



其中,LIBS是link的一個(gè)選項(xiàng),詳細(xì)請(qǐng)參看后續(xù)的Makefile文件。由于我們?cè)诔绦蛑惺褂昧俗x寫鎖,所以我們測試pthread庫中是否存在pthread_rwlock_init函數(shù)。

由于我們是基于deep類型來創(chuàng)建makefile文件,所以我們需要在四處創(chuàng)建Makefile文件。即:project目錄下,lib目錄下,core和shell目錄下。

Autoconf提供了很多內(nèi)置宏來做相關(guān)的檢測,限于篇幅關(guān)系,我們?cè)谶@里對(duì)其他宏不做詳細(xì)的解釋,具體請(qǐng)參看參考文獻(xiàn)1和參考文獻(xiàn)2,也可參看autoconf信息頁。





回頁首


實(shí)戰(zhàn)Makefile.am

Makefile.am是一種比Makefile更高層次的規(guī)則。只需指定要生成什么目標(biāo),它由什么源文件生成,要安裝到什么目錄等構(gòu)成。

表一列出了可執(zhí)行文件、靜態(tài)庫、頭文件和數(shù)據(jù)文件,四種書寫Makefile.am文件個(gè)一般格式。


表 1Makefile.am一般格式
表 1Makefile.am一般格式

對(duì)于可執(zhí)行文件和靜態(tài)庫類型,如果只想編譯,不想安裝到系統(tǒng)中,可以用noinst_PROGRAMS代替bin_PROGRAMS,noinst_LIBRARIES代替lib_LIBRARIES。

Makefile.am還提供了一些全局變量供所有的目標(biāo)體使用:


表 2 Makefile.am中可用的全局變量
表 2 Makefile.am中可用的全局變量

在Makefile.am中盡量使用相對(duì)路徑,系統(tǒng)預(yù)定義了兩個(gè)基本路徑:


表 3Makefile.am中可用的路徑變量
表 3Makefile.am中可用的路徑變量

在上文中我們提到過安裝路徑,automake設(shè)置了默認(rèn)的安裝路徑:

1) 標(biāo)準(zhǔn)安裝路徑

默認(rèn)安裝路徑為:$(prefix) = /usr/local,可以通過./configure --prefix=<new_path>的方法來覆蓋。

其它的預(yù)定義目錄還包括:bindir = $(prefix)/bin, libdir = $(prefix)/lib, datadir = $(prefix)/share, sysconfdir = $(prefix)/etc等等。

2) 定義一個(gè)新的安裝路徑

比如test, 可定義testdir = $(prefix)/test, 然后test_DATA =test1 test2,則test1,test2會(huì)作為數(shù)據(jù)文件安裝到$(prefix)/ /test目錄下。

我們首先需要在工程頂層目錄下(即project/)創(chuàng)建一個(gè)Makefile.am來指明包含的子目錄:


SUBDIRS=src/lib src/ModuleA/apple/shell src/ModuleA/apple/core
            CURRENTPATH=$(shell /bin/pwd)
            INCLUDES=-I$(CURRENTPATH)/src/include -I$(CURRENTPATH)/src/ModuleA/apple/include
            export INCLUDES
            

由于每個(gè)源文件都會(huì)用到相同的頭文件,所以我們?cè)谧铐攲拥腗akefile.am中包含了編譯源文件時(shí)所用到的頭文件,并導(dǎo)出,見藍(lán)色部分代碼。

我們將lib目錄下的swap.c文件編譯成libswap.a文件,被apple/shell/apple.c文件調(diào)用,那么lib目錄下的Makefile.am如下所示:


noinst_LIBRARIES=libswap.a
            libswap_a_SOURCES=swap.c
            INCLUDES=-I$(top_srcdir)/src/includ
            

細(xì)心的讀者可能就會(huì)問:怎么表1中給出的是bin_LIBRARIES,而這里是noinst_LIBRARIES?這是因?yàn)槿绻幌刖幾g,而不想安裝到系統(tǒng)中,就用noinst_LIBRARIES代替bin_LIBRARIES,對(duì)于可執(zhí)行文件就用noinst_PROGRAMS代替bin_PROGRAMS。對(duì)于安裝的情況,庫將會(huì)安裝到$(prefix)/lib目錄下,可執(zhí)行文件將會(huì)安裝到${prefix}/bin。如果想安裝該庫,則Makefile.am示例如下:


bin_LIBRARIES=libswap.a
            libswap_a_SOURCES=swap.c
            INCLUDES=-I$(top_srcdir)/src/include
            swapincludedir=$(includedir)/swap
            swapinclude_HEADERS=$(top_srcdir)/src/include/swap.h
            

最后兩行的意思是將swap.h安裝到${prefix}/include /swap目錄下。

接下來,對(duì)于可執(zhí)行文件類型的情況,我們將討論如何寫Makefile.am?對(duì)于編譯apple/core目錄下的文件,我們寫成的Makefile.am如下所示:


noinst_PROGRAMS=test
            test_SOURCES=test.c
            test_LDADD=$(top_srcdir)/src/ModuleA/apple/shell/apple.o $(top_srcdir)/src/lib/libswap.a
            test_LDFLAGS=-D_GNU_SOURCE
            DEFS+=-D_GNU_SOURCE
            #LIBS=-lpthread
            

由于我們的test.c文件在鏈接時(shí),需要apple.o和libswap.a文件,所以我們需要在test_LDADD中包含這兩個(gè)文件。對(duì)于Linux下的信號(hào)量/讀寫鎖文件進(jìn)行編譯,需要在編譯選項(xiàng)中指明-D_GNU_SOURCE。所以在test_LDFLAGS中指明。而test_LDFLAGS只是鏈接時(shí)的選項(xiàng),編譯時(shí)同樣需要指明該選項(xiàng),所以需要DEFS來指明編譯選項(xiàng),由于DEFS已經(jīng)有初始值,所以這里用+=的形式指明。從這里可以看出,Makefile.am中的語法與Makefile的語法一致,也可以采用條件表達(dá)式。如果你的程序還包含其他的庫,除了用AC_CHECK_LIB宏來指明外,還可以用LIBS來指明。

如果你只想編譯某一個(gè)文件,那么Makefile.am如何寫呢?這個(gè)文件也很簡單,寫法跟可執(zhí)行文件的差不多,如下例所示:


noinst_PROGRAMS=apple
            apple_SOURCES=apple.c
            DEFS+=-D_GNU_SOURCE
            

我們這里只是欺騙automake,假裝要生成apple文件,讓它為我們生成依賴關(guān)系和執(zhí)行命令。所以當(dāng)你運(yùn)行完automake命令后,然后修改apple/shell/下的Makefile.in文件,直接將LINK語句刪除,即:


…….
            clean-noinstPROGRAMS:
            -test -z "$(noinst_PROGRAMS)" || rm -f $(noinst_PROGRAMS)
            apple$(EXEEXT): $(apple_OBJECTS) $(apple_DEPENDENCIES)
            @rm -f apple$(EXEEXT)
            #$(LINK) $(apple_LDFLAGS) $(apple_OBJECTS) $(apple_LDADD) $(LIBS)
            …….
            

通過上述處理,就可以達(dá)到我們的目的。從圖1中不難看出為什么要修改Makefile.in的原因,而不是修改其他的文件。

posted on 2009-06-21 16:25 不會(huì)飛的鳥 閱讀(243) 評(píng)論(0)  編輯 收藏 引用


只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲一区二区在线看| 中文久久精品| 亚洲精品国产拍免费91在线| 欧美亚一区二区| 国产精品美女主播| 国产精品久久久久91| 国产精品每日更新在线播放网址| 欧美日韩在线播放三区四区| 欧美日韩精品一区| 国产亚洲一区在线| 亚洲高清中文字幕| 日韩视频一区二区| 久久国产欧美精品| 欧美国产日韩精品| 日韩亚洲欧美在线观看| 午夜精品理论片| 久色婷婷小香蕉久久| 欧美日韩视频第一区| 国产午夜精品久久久久久久| 精品福利免费观看| 亚洲欧美第一页| 欧美激情免费在线| 一本色道88久久加勒比精品| 久久国产精品电影| 国产精品入口夜色视频大尺度 | 欧美中文字幕第一页| 久久一区中文字幕| 精品成人乱色一区二区| 亚洲免费综合| 最新亚洲视频| 久久免费99精品久久久久久| 亚洲国产欧洲综合997久久| 亚洲性图久久| 欧美亚洲第一页| 亚洲专区一区| 亚洲天堂av在线免费观看| 欧美日韩成人激情| 日韩亚洲精品视频| 亚洲国产另类久久久精品极度| 久久久久天天天天| 在线成人亚洲| 久久一区二区精品| 免费观看在线综合色| 91久久在线| 亚洲视频狠狠| 国产亚洲一区二区三区在线播放| 欧美影院视频| 欧美国产精品人人做人人爱| 日韩视频在线观看国产| 亚洲香蕉网站| 国产一区二区三区免费不卡| 久久久久久9999| 欧美日韩视频| 欧美大片在线观看| 欧美日韩伊人| 久久婷婷国产综合国色天香| 米奇777超碰欧美日韩亚洲| 一区二区三区欧美在线观看| 亚洲欧美日韩另类| 99伊人成综合| 99精品国产99久久久久久福利| 国产精品视频大全| 一本久久a久久精品亚洲| 黄色成人av| 亚洲一区二区不卡免费| 亚洲第一精品夜夜躁人人躁| 亚洲一级电影| 亚洲一区欧美| 亚洲欧美日韩专区| 美腿丝袜亚洲色图| 欧美国产亚洲另类动漫| 亚洲国产精品va| 久久精品二区| 久久这里只有| 伊人久久婷婷色综合98网| 欧美一区影院| 久久人人爽爽爽人久久久| 国产自产女人91一区在线观看| 午夜精品久久久久久久久久久| 久久av资源网站| 国产一区二区久久| 欧美在线视频网站| 免费成年人欧美视频| 一区二区日韩精品| 亚洲精品欧洲| 亚洲精品在线观看免费| 亚洲缚视频在线观看| 国产女人精品视频| 欧美人与性动交cc0o| 免费在线亚洲欧美| 久久成人18免费网站| 小黄鸭视频精品导航| 亚洲在线成人| 国产在线播放一区二区三区| 国产精品婷婷| 国产日韩精品在线播放| 国产精品午夜在线观看| 国产欧美精品在线观看| 国产亚洲一区二区三区在线播放| 国产精品毛片va一区二区三区| 欧美日韩国产精品专区| 欧美日韩精品不卡| 欧美日韩在线第一页| 免费久久久一本精品久久区| 久久国产精彩视频| 久久久亚洲国产天美传媒修理工 | 欧美网站大全在线观看| 欧美大片一区| 国产精品久久久久一区| 国产欧美日韩亚州综合| 国产热re99久久6国产精品| 国产伦精品一区二区三区在线观看| 欧美日韩黄色一区二区| 国产精品美女久久久久久免费| 国产乱码精品一区二区三区不卡 | 中文亚洲免费| 久久精品日韩欧美| 日韩视频一区二区| 久久国产99| 欧美三级特黄| 99精品视频免费观看| 久热精品在线| 亚洲欧美国产高清| 欧美另类视频| 亚洲每日在线| 欧美国产日本在线| 香蕉久久夜色精品国产使用方法 | 中国成人亚色综合网站| 一区二区精品在线观看| 午夜精品国产| 久久久久看片| 亚洲精品一区二| 久久精视频免费在线久久完整在线看| 亚洲午夜精品一区二区| 久久精品成人一区二区三区蜜臀 | 免费成人高清视频| 欧美日韩中文字幕在线视频| 国产亚洲va综合人人澡精品| 亚洲激情午夜| 国产精品免费看| 久久久噜噜噜久久久| 国产精品久久久久久久久久妞妞 | 欧美电影在线免费观看网站| 国产日韩欧美91| 欧美亚洲网站| 亚洲三级视频| 欧美国产视频日韩| 亚洲国产女人aaa毛片在线| 久久超碰97人人做人人爱| 99re66热这里只有精品4| 欧美欧美天天天天操| 亚洲第一主播视频| 欧美成人在线免费视频| 久久人人超碰| av成人免费| 中文日韩电影网站| 国产欧美日韩免费| 亚洲视频在线二区| 亚洲一区三区视频在线观看| 欧美成ee人免费视频| 亚洲精品乱码久久久久久久久 | 欧美激情第1页| 久久亚洲私人国产精品va| 激情亚洲成人| 亚洲精品123区| 国产精品成人在线观看| 久久久夜色精品亚洲| 美女91精品| 午夜在线视频观看日韩17c| 亚洲欧美日韩一区二区在线| 国产欧美一区二区精品性色| 久久夜色撩人精品| 国产精品扒开腿爽爽爽视频 | 国产三区二区一区久久| 免播放器亚洲一区| 亚洲国产色一区| 国产嫩草影院久久久久| 欧美激情第4页| 99热免费精品| 99av国产精品欲麻豆| 久久gogo国模裸体人体| 亚洲美女视频| 欧美高清在线播放| 免费不卡欧美自拍视频| 国产色综合网| 久久久久在线观看| 国产午夜亚洲精品不卡| 中文久久精品| 午夜在线成人av| 国产欧美日韩亚洲| 亚洲免费在线观看视频| 亚洲欧美国产精品桃花| 久久一区精品| 亚洲欧洲日本国产| 一区二区三区产品免费精品久久75 | 欧美在线免费观看| 国产精品一区二区欧美| 亚洲欧美日本国产有色| 国产精品亚洲美女av网站| 欧美在线视频二区|