CVS, Automake與Autoconf簡介---ZT

發表于:2007-05-26來源:作者:點擊數: 標簽:
第一部分CVS簡介 cvs(ConcurrentVersionSystem)是一個 版本控制 系統,什么是版本控制系統呢?簡單的說,它可以記錄程序代碼修改的過程,有一個完整的歷史記錄(history)。辟如說,當你在修改程序代碼的時候,不小心寫出了一個 bug ,但是你可能很久以后

第一部分 CVS簡介 
cvs ( Concurrent Version System )是一個版本控制系統,什么是版本控制系統呢?簡單的說,它可以記錄程序代碼修改的過程,有一個完整的歷史記錄( history )。辟如說,當你在修改程序代碼的時候, 不小心寫出了一個 bug,但是你可能很久以后才發現多出了這個 bug, 這個時候,cvs 就能很有效的幫助你找出到底是在哪一次的修改中,出現了這個 bug。 
也許你會說, 那我每次都把程序保存起來, 用tar 做好備份不就行了,當然, 你可以這樣做, 但是這太浪費空間了! cvs 在版本更改間, 只儲存不同的部分, 這樣就可以省下很多空間。 
在另一個場合里, 更能顯示出 cvs 的好處 ,比如多人一起開發軟件的時候。 cvs支持遠程訪問, 用戶可以對他要修改的文件加上正在編輯的標志, 讓別人知道他要修改這個文件了。 當然, 一個較大的開發隊伍,一般還會需要一個 mailing list 用來溝通。畢竟cvs 只是一個管理程序代碼的工具, 他并不扮演溝通的角色。 cvs的同類軟件還有rcs和sccs。RCS ( Revision Control System ) 可以從FSF獲得。SCCS ( Source Code Control System ) 由AT&T在SystemV中引入,現在已經被加入X/Open標準( Unix 98? )。比起這些軟件,CVS的要優秀得多,特別是在支持多人遠程開發方面。由于CVS出現較新,所以使用上反而沒有它們普及。當然,如果您熟悉rcs,您會發現學習cvs非常容易。 

名詞 
repository: 意為倉庫。在 cvs 里, 它就是你真正存放各歷史版本的地方。 pserver: cvs 遠程服務器,cvs 有兩種工作模式, 一種是 local, 一種是 remote。 一般通過inetd啟動pserver。 
CVSROOT: 當使用 cvs 的時候, 要設定 CVSROOT這個環境變量, 或是用 -d 選項來指定該參數,該參數指明你的倉庫放在哪里。 

本地( local )cvs 
首先, 確定一個 cvsroot,比如: 
export CVSROOT="/home/joe/cvsroot/" 建立該目錄: 
mkdir /home/joe/cvsroot 
接著,運行cvs init : 
cvs init 
cvs init 會幫你把 cvsroot 初始化。接著, 建立一個要放文件的目錄 ( 相當于一個Project ): mkdir /home/joe/cvsroot/cvsdoc 
cd /home/joe/work 
cvs checkout cvsdoc( 或者簡寫為: cvs co cvsdoc ) 你會看到下面的信息: cvs checkout: Updating cvsdoc cvs checkout 會把當前最新的版本拷貝到你的當前目錄下。 
記住, 不要自己建立 /home/joe/work/cvsdoc, 該目錄下還會有一些用于管理的 cvs 相關的信息。 
接著, 進入 cvsdoc 目錄, 編輯 cvs.doc 這個文件檔案,輸入一些信息。 
然后,運行: 
cvs add cvs.txt cvs commit -m "Initial revision." cvs add 就會把 cvs.txt 加入 cvs 維護的文件列表中去。 
cvs commit 檢查當前目錄下所有的在文件列表中的文件,并把對他們的改動加入到倉庫中。-m 表示這次 commit 的 message,一般說明此次修改的相關信息。 
現在修改一下 cvs.txt,并且,在文件檔案的最上面加上 $Id$ 的字樣。 
改完之后, 再 commit 一次: 
cvs commit -m "Adding new stuff." 
現在看看我們所做的修改: 
cvs log cvs.txt 
可以看到: 
RCS file: /home/joe/cvsroot/cvsdoc/cvs.txt,v 
Working file: cvs.txt 
head: 1.2 
branch: 
locks: strict 
access list: 
symbolic names: 
keyword substitution: kv 
total revisions: 2; selected revisions: 2 
description: 
---------------------------- 
revision 1.2 
date: 2000/09/11 11:55:06; author: joe; state: Exp; lines: +2 -0 

---------------------------- 
revision 1.1 
date: 2000/09/11 11:52:32; author: joe; state: Exp; 
initial version 
================================================================== 
你會看到每次修改加進去的 message。這對開發者,特別是一個大的項目的開發者,其幫助是不言而喻的。 
cvs diff -r 1.1 -r 1.2 cvs.txt 
可以看到: 
Index: cvs.txt 
================================================================== RCS file: /home/joe/cvsroot/cvsdoc/cvs.txt,v 
retrieving revision 1.1 
retrieving revision 1.2 
diff -r1.1 -r1.2 
0a1 
> $Id: cvs.txt,v 1.2 2000/09/11 11:55:06 joe Exp $ 
1a3 
> hehe,sencond time edit it! 
這樣會顯示 1.1 和 1.2 版的 diff, 原本有 1.1 版的人, 只需要用這個 patch 就可以了升級到1.2了! 
再編輯 cvs.txt, 可以發現最上面的 Id 變長了? 加了一代串文字: 
$Id: cvs.txt,v 1.2 2000/09/11 11:55:06 joe Exp $ 這顯示這個版本的一些相關信息。 
遠程( remote )cvs 
如果我們要做一個比較大的項目,上面講的本地cvs服務就太簡單了,我們要讓眾多的人可以遠程開發程序! 比如我們要用cvs組織起我們的minigui項目。 檢查 /etc/services 有沒有這兩行,沒有請加入: 
cvspserver 2401/tcp #CVS network server cvspserver 2401/udp #CVS network server 
在 /etc/inetd.conf 加入: 
cvspserver stream tcp nowait root /usr/local/bin/cvs cvs --allow-root=/home/minigui pserver 
mkdir /home/minigui 
要是該設置生效,請重啟inetd。 
添加用戶anoncvs, 這是要給匿名cvs 用戶使用的帳號,其組為nogroup。 新加一個名為 minigui的 group。 添加參與 minigui開發的用戶的帳號, 當然, 把他們的 group 設為 minigui。 
cvs -d /home/minigui init 
cd /root/minigui, 這是原來已經存在的版本, 現在我們要把它的東西放進 cvs 倉庫里: 比如,我們把minigui的庫minigui03放到倉庫中: 

cd minigui03;cvs import –m “the lib” minigui03 joe start 

會看到cvs把一個個文件放到倉庫中。 
cvs import 的語法為: 

cvs import -m "log msg" projname vendortag releasetag 

vendortag 和releasetag 一般不需要關心,我們這里使用一個用戶名和一個start 標志。 
我們把其它相關的project也放到cvs倉庫中: 

cd miniguiapps03 ; cvs import –m “the apps” miniguiapps03 joe start 
cd miniguiexec03 ; cvs import –m “the demos” miniguiexec03 joe start 

這樣,我們就把minigui的一個cvs服務器建立好了。 
注意, 一個 user 要遠程訪問某些project, 他必須擁有適當的權限。比如,minigui03這個目錄應該屬于組minigui,且組可寫。才能使minigui組里的用戶可以遠程參與minigui庫的開發。 

現在試試看從遠程訪問 cvs 服務器。 
首先, 在你的機器上建立一個工作目錄, 譬如是 /home/joe/work 
cd /home/joe/work 
cvs -d :pserver:joe@www.minigui.org:/home/minigui login 
cvs -d :pserver:joe@www.minigui.org:/home/minigui co minigui03 
cvs -d :pserver:joe@www.minigui.org:/home/minigui co miniguiapps03 
cvs -d :pserver:joe@www.minigui.org:/home/minigui co miniguiexec03 
cvs -d :pserver:joe@www.minigui.org:/home/minigui logout 

當你敲入login行時,系統會提示你輸入password, 打進去。 www.minigui.org是cvs服務器所在的機器。 該指定被執行后,該 cvsroot 
(:pserver:joe@www.minigui.org:/home/minigui) 和加密后的密碼會被存在 ~/.cvspass 里。 
底下幾行取出各個project。最后logout。 

cd minigui03 

做了一些修改后,可以commit出去: 

cvs commit -m "little change" 
上面是一般開發者的登陸方法,對于匿名cvs, 可以讓其不需要輸入口令即可登陸,但是不能讓其commint。這需要: 
1. 將要開放的project設為全局可讀寫,因為cvs服務器在操作時要在相應目錄下設置讀寫瑣(即需要創建一些臨時文件),所以即使是check out 操作,也需要目錄可寫。 
2. 為了讓匿名用戶只有check out權限,可以在CVSROOT目錄下建立一個readers文件,其中每一行是一個用戶,這些用戶只具有只讀權限。比如: 
anonymous 
anoncvs 
guest 
jbrowse 
3. 利用passwd文件,使匿名用戶不能用其它方式登陸。典型為: 
在文件CVSROOT/passwd 中: 
anoncvs:XR4EZcEs0szik 
在文件/etc/passwd 中為: 
anoncvs:!:1729:105:Anonymous CVS User:/home/minigui:/bin/false 
CVSROOT/passwd文件是cvs提供的一個專用于存放cvs密碼的文件。它的典型格式為: 
joe:XR4EZcEs0szik:jane 
表示cvs用戶joe其實是內部用戶jane,其cvs密碼加密后被存放在第二個字段,這樣就將cvs服務與系統的其它部分分離開來,大大地提高了系統的安全性。 
上面介紹的是使用需要嚴格的安全認證的pserver服務器,如果您在局域網內開發程序,則可以使用rsh或者ssh,設置非常簡單,服務器端只要開放著rsh或ssh服務器,客戶端設置兩個環境變量:CVS_RSH與CVSROOT,可以將它們的設置寫入預處理腳本,比如使用ssh連接: 

$export CVS_RSH="ssh" 
$export CVSROOT=":ext:joe@www.minigui.org:/home/minigui" 

$ cvs co miniguiexec03 
joe@192.9.200.75's password: 

輸入密碼,就可以得到一份miniguiexec03的拷貝了。 


總結 
以上只是一個簡介,cvs還有很多高級功能,如果您需要更詳細的信息,請看cvs 的info或者到gnu上下載html版本的manual。 

第二部分 使用Automake,Autoconf生成Makefile 
在Unix上寫過程序的人尤其是用 C 來開發程序的人一般都遇到過 Makefile,用 make 來開發和編譯程序的確很方便,可是要寫出一個Makefile就不那么簡單了。GNU Make 那份幾百頁的文件,讓許多人害怕。當然,現在關于make的文檔比較多,不過寫一個Makefile總是一件很煩人的事情,GNU Autoconf 及 Automake 這兩個軟件就是幫助程序開發者輕松產生Makefile 文件的?,F在的GNU軟件如Apache, MySQL Minigui等都是利用Autoconf,Automake實現自動編譯的。用戶只要使用 “./configure”, “make”, “make install” 就可以把程序安裝到系統中。 

簡介 
Makefile 基本上就是『目標』(target), 『關聯』(dependencies) 和『動作』三者所組成的一系列規則。而 make 就是根據 Makefile 的規則決定如何編譯 (compile) 和連接 (link) 程序或者其它動作。當然,make 可做的不只是編譯和連接程序,例如 FreeBSD 的 port collection 中,Makefile還可以做到自動下載遠程程序,解壓縮 (extract) , 打補丁 (patch),設定,然后編譯,安裝到系統中。 

Makefile 基本結構雖然很簡單,但是妥善運用這些規則就可以變換出許多不同的花樣。卻也因為這樣,許多人剛開始學寫Makefile 時會覺得沒有規范可以遵循,每個人寫出來的Makefile都不大一樣,不知道從哪里下手,而且常常會受到開發環境的限制,只要環境參數不同或者路徑更改,可能 Makefile 就得跟著修改。雖然有GNU Makefile Conventions (GNU Makefile慣例)制訂出一些在進行 GNU 程序設計時寫 Makefile 的一些標準和規范,但是其內容很長而且很復雜,并且經常作一些調整,為了減輕程序開發人員維護Makefile 的負擔,就出現了Automake。 

利用Automake,編程者只需要寫一些預先定義好的宏 (macro),提交給Automake處理,就會產生一個可以供 Autoconf 使用的 Makefile.in文件。再配合使用 Autoconf產生的自動配置文件 configure 即可產生一份符合 GNU Makefile 慣例的 Makeifle 了。 


  

需要的軟件 
在開始使用 Automake 之前,首先確認你的系統安裝有如下軟件: 

1. GNU Automake 
2. GNU Autoconf 
3. GNU m4 
4. perl 
5. GNU Libtool (如果你需要產生 shared library) 

最好也使用 GNU C/C++ 編譯器 、GNU Make 以及其它 GNU 的工具程序來作為開發的環境,這些工具都是屬于 Open Source Software 不但免費而且功能強大。如果你是使用 Red Hat Linux 可以找到所有上述軟件的 rpm 文件?!?nbsp;

一個簡單的例子 
Automake 所產生的 Makefile 除了可以做到程序的編譯和連接,也可以用來生成文檔(如 manual page, info 文件等),還可以有把源碼文件包裝起來以供發布,所以程序源代碼所存放的目錄結構最好符合GNU 的標準慣例,接下來就用一個hello.c 來做為例子。 

在工作目錄下建立一個新的子目錄devel,再在 devel 下建立一個"hello"' 的子目錄,這個目錄將 
作為存放 hello這個程序及其相關文件的地方: 

% mkdir devel;cd devel;mkdir hello;cd hello 

用編輯器寫一個hello.c文件, 

#include <stdio.h> 
int main(int argc, char** argv) 

printf(“Hello, GNU!n”); 
return 0; 


接下來就要用 Autoconf 及 Automake 來產生 Makefile 文件了, 

1. 用 autoscan 產生一個 configure.in 的原型,執行autoscan 后會產生一個configure.scan 的文件,可以用它作為 configure.in文件的藍本。 
  
% autoscan 
% ls 
configure.scan hello.c 

2. 編輯 configure.scan文件,如下所示,並且改名為configure.in 

dnl Process this file with Autoconf to produce a configure script. 
AC_INIT(hello.c) 
AM_INIT_AUTOMAKE(hello, 1.0) 
dnl Checks for programs. 
AC_PROG_CC 
dnl Checks for libraries. 
dnl Checks for header files. 
dnl Checks for typedefs, structures, and compiler characteristics. 
dnl Checks for library functions. 
AC_OUTPUT(Makefile) 

3. 執行 aclocal 和 Autoconf ,分別會產生 aclocal.m4 及 configure 兩個文件 

% aclocal 
% Autoconf 
% ls 
aclocal.m4 configure configure.in hello.c 

4. 編輯 Makefile.am 文件,內容如下 

AUTOMAKE_OPTIONS= foreign 
bin_PROGRAMS= hello 
hello_SOURCES= hello.c 

5. 執行 Automake --add-missing ,Automake 會根據Makefile.am 文件產生一些文件,包含最重要的Makefile.in 

% Automake --add-missing 
Automake: configure.in: installing `./install-sh' 
Automake: configure.in: installing `./mkinstalldirs' 
Automake: configure.in: installing `./missing' 

6. 最后執行 ./configure: 

% ./configure 
creating cache ./config.cache 
checking for a BSD compatible install... /usr/bin/install -c 
checking whether build environment is sane... yes 
checking whether make sets ${MAKE}... yes 
checking for working aclocal... found 
checking for working Autoconf... found 
checking for working Automake... found 
checking for working autoheader... found 
checking for working makeinfo... found 
checking for gcc... gcc 
checking whether the C compiler (gcc ) works... yes 
checking whether the C compiler (gcc ) is a cross-compiler... no 
checking whether we are using GNU C... yes 
checking whether gcc accepts -g... yes 
updating cache ./config.cache 
creating ./config.status 
creating Makefile 

$ ls 
Makefile aclocal.m4 config.status hello.c mkinstalldirs 
Makefile.am config.cache configure install-sh 
Makefile.in config.log configure.in missing 

現在你的目錄下已經產生了一個 Makefile 文件,輸入make指令就可以編譯 hello.c 了! 

% make 
gcc -DPACKAGE="hello" -DVERSION="1.0" -I. -I. -g -O2 -c hello.c 
gcc -g -O2 -o hello hello.o 

你還可以試試 “make clean“,”make install“,”make dist“: 
[root@localhost hello]# make clean 
test -z "hello " || rm -f hello 
rm -f *.o core *.core 
[root@localhost hello]# make install 
gcc -DPACKAGE="hello" -DVERSION="1.0" -I. -I. -g -O2 -c hello.c 
gcc -g -O2 -o hello hello.o 
make[1]: Entering directory `/home/joe/devel/hello' 
/bin/sh ./mkinstalldirs /usr/local/bin 
/usr/bin/install -c hello /usr/local/bin/hello 
make[1]: Nothing to be done for `install-data-am'. 
make[1]: Leaving directory `/home/joe/devel/hello' 
[root@localhost hello]# make dist 
rm -rf hello-1.0 
mkdir hello-1.0 
chmod 777 hello-1.0 
here=`cd . && pwd`; 
top_distdir=`cd hello-1.0 && pwd`; 
distdir=`cd hello-1.0 && pwd`; 
cd . 
&& Automake --include-deps --build-dir=$here --srcdir-name=. --output-dir=$top_distdir --foreign Makefile 
chmod -R a+r hello-1.0 
GZIP=--best gtar chozf hello-1.0.tar.gz hello-1.0 
rm -rf hello-1.0 
一切工作得很好! 當然,在make install時由于需要向系統目錄拷貝文件,您需要有root權限。 

更進一步 
上述產生Makefile 的過程和以往自行編寫的方式非常不一樣,使用 Automake 只需用到一些已經定義好的宏就可以了。我們把宏及目標 (target)寫在Makefile.am 文件內,Automake 讀入 Makefile.am 文件后會把這一串已經定義好的宏展開并產生相對應的 
Makefile.in 文件,然后再由configure這個 shell script 根據 Makefile.in 產生合適的Makefile。 
具體流程如下所示: 
代碼 --> [autoscan*] --> [configure.scan] --> configure.in 
configure.in --. .------> Autoconf* -----> configure 
+---+ 
[aclocal.m4] --+ `---. 
[acsite.m4] ---' | 
+--> [autoheader*] -> [config.h.in] 
[acconfig.h] ----. | 
+-----' 
[config.h.top] --+ 
[config.h.bot] --' 

Makefile.am -- [Autoconf*] -------> Makefile.in 

.-------------> config.cache 
configure* ------------+-------------> config.log 

[config.h.in] -. v .-> [config.h] -. 
+--> config.status* -+ +--> make* 
Makefile.in ---' `-> Makefile ---' 

上圖表示在整個過程中要使用的文件及產生出來的文件,有星號 (*) 代表可執行文件。在此示例中可由 Autoconf 及 Automake 工具所產生的額外文件有 configure.scan、aclocal.m4、configure、Makefile.in,需要加入設置的有configure.in 及 Makefile.am。 開發者要書寫的文件集中為confiugre.in和Makefile.am,在minigui項目中,我們把一系列的命令集中到一個批處理文件中:autogen.sh: 

#!/bin/sh 
aclocal 
autoheader 
Automake --add-missing 
Autoconf 

只要執行該批處理文件,結合configure.in和Makefile.am,就可以生成需要的Makefile了。 

編輯 configure.in 文件 
Autoconf 是用來產生 'configure'文件的工具。'configure' 是一個 shell script,它可以自動設定一些編譯參數使程序能夠條件編譯以符合各種不同平臺的Unix 系統。Autoconf會讀取configure.in 文件然后產生'configure' 這個 shell script。 

configure.in 文件內容是一系列GNU m4 的宏,這些宏經Autoconf處理后會變成檢查系統特性的shell scripts。 configure.in文件中宏的順序并沒有特別的規定,但是每一個configure.in 文件必須在所有其它宏前加入 AC_INIT 宏,然后在所有其它宏的最后加上 AC_OUTPUT宏。一般可先用 autoscan 掃描原始文件以產生一個 configure.scan 文件,再對 configure.scan 做些修改成 configure.in 文件。在例子中所用到的宏如下: 

dnl 
這個宏后面的內容不會被處理,可以視為注釋 

AC_INIT(FILE) 
該宏用來檢查源代碼所在路徑,autoscan 會自動產生,一般無須修改它。 

AM_INIT_AUTOMAKE(PACKAGE,VERSION) 
這個是使用 Automake 所必備的宏,PACKAGE 是所要產生軟件的名稱,VERSION 是版本編號。 

AC_PROG_CC 
檢查系統可用的C編譯器,若源代碼是用C寫的就需要這個宏。 

AC_OUTPUT(FILE) 
設置 configure 所要產生的文件,若是Makefile ,configure 便會把它檢查出來的結果填充到Makefile.in 文件后產生合適的 Makefile。 

實際上,在使用 Automake 時,還需要一些其他的宏,這些額外的宏我們用 aclocal來幫助產生。執行 aclocal會產生aclocal.m4 文件,如果沒有特別的用途,不需要修改它,用 aclocal 所產生的宏會告訴 Automake如何動作。 

有了 configure.in 及 aclocal.m4兩個文件以后,便可以執行 Autoconf來產生 configure 文件了。 

編輯Makefile.am 文件 
接下來要編輯Makefile.am 文件,Automake 會根據 configure.in 中的宏并在perl的幫助下把Makefile.am 轉成 Makefile.in 文件。 Makefile.am 文件定義所要產生的目標: 

AUTOMAKE_OPTIONS 
設置 Automake 的選項。Automake 主要是幫助開發 GNU 軟件的人員來維護軟件,所以在執行Automake 時,會檢查目錄下是否存在標準 GNU 軟件中應具備的文件,例如 'NEWS'、'AUTHOR'、 
'ChangeLog' 等文件。設置為foreign 時,Automake 會改用一般軟件的標準來檢查。 

bin_PROGRAMS 
定義要產生的執行文件名。如果要產生多個執行文件,每個文件名用空白符隔開。 

hello_SOURCES 
定義 'hello' 這個執行程序所需要的原始文件。如果 'hello'這個程序是由多個原始文件所產生, 
必須把它所用到的所有原始文件都列出來,以空白符隔開。假設 'hello' 還需要 'hello.c'、'main.c'、'hello.h' 三個文件的話,則定義 
hello_SOURCES= hello.c main.c hello.h 
如果定義多個執行文件,則對每個執行程序都要定義相對的filename_SOURCES。 

編輯好 Makefile.am 文件,就可以用 Automake --add-missing來產生 Makefile.in。加上 --add-missing 選項來告訴 Automake順便加入包裝一個軟件所必須的文件,如果你不使用該選項,Automake可能會抱怨缺少了什么文件。Automake產生出來的 Makefile.in 文件是完全符合 GNU Makefile 慣例的,只要執行 configure這個shell 
script 便可以產生合適的 Makefile 文件了。 

使用 Makefile 
利用 configure 所產生的 Makefile文件有幾個預先設定的目標可供使用,這里只用幾個簡述如下: 

make all 
產生設定的目標,既范例中的可執行文件。只敲入make 也可以,此時會開始編譯源代碼,然后連接并產生執行文件。 

make clean 
清除之前所編譯的可執行文件及目標文件(object file, *.o)。 

make distclean 
除了清除可執行文件和目標文件以外,也把 configure 所產生的 Makefile 清除掉。 通常在發布軟件前執行該命令。 

make install 
將程序安裝到系統中,若源碼編譯成功,且執行結果正確,便可以把程序安裝到系統預先設定的執行文件存放路徑中,若用 bin_PROGRAMS 宏的話,程序會被安裝到 /usr/local/bin下。 

make dist 
將程序和相關的文檔包裝為一個壓縮文檔以供發布 (distribution) 。執行完在目錄下會產生一個以 
PACKAGE-VERSION.tar.gz 為名稱的文件。PACKAGE 和 VERSION 這兩個參數是根據 configure.in 文中 
AM_INIT_AUTOMAKE(PACKAGE, VERSION) 的定義。在我們的例子中會產生 'hello-1.0.tar.gz' 的文件。 

make distcheck 
和 make dist 類似,但是加入檢查包裝以后的壓縮文件是否正常,這個目標除了把程序和相關文檔包裝成 tar.gz 文件外,還會自動把這個壓縮文件解開,執行 configure,并執行 make all ,確認編譯無錯誤以后,方顯示這個 tar.gz 文件已經準備好并可以發布了。當你看到: 
========================================== 
hello-1.0.tar.gz is ready for distribution 
========================================== 

就可以放心地發布您的軟件了,檢查過關的套件,基本上可以給任何具備 GNU 開發環境的人去重新編譯成功。 
要注意的是,利用 Autoconf 及 Automake 所產生出來的軟件套件是可以在沒有安裝 Autoconf 及 Automake 的環境使用的,因為 configure 是一個 shell script,它己被設計為可以在一般 Unix 的 sh 這個 shell 下執行。但是如果要修改 configure.in 及 Makefile.am 文件再產生新的 configure 及 Makefile.in 文件時就一定要有 Autoconf 及 Automake 了。 

相關資料 
通常我們掌握了一些入門知識就可以開始實踐了,在有新的需求時,參照相關的文檔和別人的例子解決問題,在實踐中不斷提高。 
Autoconf 和 Automake 功能十分強大,可以從它們附帶的 info 文檔中找到詳細的使用說明?;蛘吣矚ghtml,可以從gun站點上下載hmtl版本。你也可以從許多現有的GNU 軟件或 Open Source 軟件如Minigui中找到相關的 configure.in 或 Makefile.am 文件,他們是學習 Autoconf 及 Automake 更多技巧的最佳范例。

 metor78 回復于:2005-06-09 08:58:01
蜘蛛,well done,再接再厲

 東方蜘蛛 回復于:2005-06-09 09:14:36
:oops: 謝謝 :em04:

 wolfg 回復于:2005-06-22 23:30:20
好!

 sun_zy 回復于:2005-06-23 09:06:27
前一陣也看了看CVS的東西,幫老婆做個東西。 不過就是在linux上的。

這個好,學習ing……    thanks !

 sun_zy 回復于:2005-06-23 09:07:18
前一陣也看了看CVS的東西,幫老婆做個東西。 不過就是在linux上的。

這個好,學習ing……    thanks !

原文轉自:http://www.anti-gravitydesign.com

国产97人人超碰caoprom_尤物国产在线一区手机播放_精品国产一区二区三_色天使久久综合给合久久97