(原)用automake來代替IDE實現工程代碼編譯
Posted on 2008-11-17 17:20 eyesmart 閱讀(3274) 評論(9) 編輯 收藏 引用 所屬分類: Basic Knowledge 在網上查了很多關于automake的文章,有幾篇還是不錯的,但大部分的例子都局限于helloworld這樣的程序,我就把自己如何構建工程的過程寫下來,只把應用記錄下來,不涉及細節,以后會隨著應用的深入有所更新。
我的源代碼的組織結構是通用文件放在頂層文件夾中,與平臺環境相關的文件放在不同子目錄中,測試系統為ubuntu 8.10。
切換到當前文件夾,輸入$] : autoscan
生成一些文件,我們關注configure.scan.
$] : mv configure.scan configure.in
$] : vim configure.in
下面顯示內容
# -*- Autoconf -*-
# Process this file with autoconf to produce a configure script.
AC_PREREQ(2.61)
AC_INIT(mypro, 1.0, support@163.com) #需要改動,主要是程序的基本信息
AC_CONFIG_SRCDIR([Thread.h])
AC_CONFIG_HEADER([config.h])
AM_INIT_AUTOMAKE(mypro, 1.0) #一定要添加,名字任意取,但最好和以后填寫的程序名稱保持一致
# Checks for programs.
AC_PROG_CXX
AC_PROG_CC
# Checks for libraries.
# Checks for header files.
AC_HEADER_STDC
AC_CHECK_HEADERS([arpa/inet.h fcntl.h netdb.h netinet/in.h stdlib.h string.h sys/ioctl.h sys/socket.h syslog.h unistd.h])
# Checks for typedefs, structures, and compiler characteristics.
AC_HEADER_STDBOOL
AC_C_CONST
AC_C_INLINE
AC_TYPE_SIZE_T
AC_HEADER_TIME
AC_STRUCT_TM
# Checks for library functions.
AC_FUNC_FORK
AC_PROG_GCC_TRADITIONAL
AC_FUNC_MEMCMP
AC_FUNC_SELECT_ARGTYPES
AC_FUNC_VPRINTF
AC_CHECK_FUNCS([ftruncate gethostname inet_ntoa memmove memset select socket strchr strerror strstr])
AC_OUTPUT(Makefile) #添加Makefile
需要改動的就是這幾個地方,然后保存。
然后 $]: aclocal
如果生成m4文件則繼續,否則說明configure.in有問題
$] : autoconf 目的是生成configure
$] : autoreconf --install 目的是產生生成Makefile.in的必要文件
$] : autoheader 目的是生成config.h.in
由于Makefile由Makefile.in生成,而Makefile.in由Makefile.am來填充,所以需要建立Makefile.am
$] : vim Makefile.am 需要填充的內容如下:
AUTOMAKE_OPTIONS=foreign
bin_PROGRAMS=mypro
mypro_SOURCES=Main.cpp Device.cpp Server.cpp SocketBase.cpp Thread.cpp Posix/AsycIO.cpp Posix/PoSockDisp.cpp Posix/Daemon.cpp Posix/PoMutex.cpp
INCLUDES=-I.. -DTHIRTY_TWO_BIT
mypro_LDADD=libmylib.a -lpthread -lrt
第一行表示符合GNU Makefile標準的程度,一般用這個,其他的可以查閱相關文檔。
第二行表示程序的名稱,這是必須的。
第三行表示所有的源代碼文件,要注意名稱是 程序名+_SOURCES。
第四行中可以把查找頭文件的文件夾包含進來,格式就是gcc選項的格式,還可以包含宏定義。
最后一行是需要添加或者鏈接的庫,格式跟gcc的完全一樣,這個選項只能接受有關庫的參數,不接受其它參數。
保存后就可以生成Makefile.in了
$] : automake
OK !
然后你可以構建可執行程序了,./configure make
如果要編寫靜態庫,那么Makefile.am的參數就有些變化
AUTOMAKE_OPTIONS=foreign
lib_LIBRARIES=libmylib.a
libmylib_a_SOURCES= .................
INCLUDES=.................
其中參數名的格式一個要正確。其他的跟可執行文件的產生一樣。
如果要產生動態庫,必須要借助libtool,libtool產生.a和.so文件,放在當前文件夾.lib/目錄中,這個被隱藏了,同時也產生.la文件,當其他模塊需要鏈接庫時,只需要鏈接.la文件,然后由.la文件來決定如何鏈接這個庫,是靜態鏈接還是動態鏈接,由configure參數決定,這樣的方式據說是用來解決夸平臺問題,但我似乎并沒有從中受益多少,不過產生動態庫的makefile也沒有其他辦法,不過好在.a和.so都產生了,怎么用就在于個人了。要用libtool就要在configure.in中添加宏AC_PROG_LIBTOOL,
然后可以寫Makefile.am, 如下
AUTOMAKE_OPTIONS=foreign
lib_LTLIBRARIES=libmylib.la
libmylib_la_SOURCES=mylib.c
libmylib_la_LIBFLAGS=......
libmylib_la_LIBADD=.....
如果要在應用程序里鏈接這個庫,那么就在mypro_LDADD +=libmylib.la,是動態還是靜態要在configure的參數中指定。
我的源代碼的組織結構是通用文件放在頂層文件夾中,與平臺環境相關的文件放在不同子目錄中,測試系統為ubuntu 8.10。
切換到當前文件夾,輸入$] : autoscan
生成一些文件,我們關注configure.scan.
$] : mv configure.scan configure.in
$] : vim configure.in
下面顯示內容
# -*- Autoconf -*-
# Process this file with autoconf to produce a configure script.
AC_PREREQ(2.61)
AC_INIT(mypro, 1.0, support@163.com) #需要改動,主要是程序的基本信息
AC_CONFIG_SRCDIR([Thread.h])
AC_CONFIG_HEADER([config.h])
AM_INIT_AUTOMAKE(mypro, 1.0) #一定要添加,名字任意取,但最好和以后填寫的程序名稱保持一致
# Checks for programs.
AC_PROG_CXX
AC_PROG_CC
# Checks for libraries.
# Checks for header files.
AC_HEADER_STDC
AC_CHECK_HEADERS([arpa/inet.h fcntl.h netdb.h netinet/in.h stdlib.h string.h sys/ioctl.h sys/socket.h syslog.h unistd.h])
# Checks for typedefs, structures, and compiler characteristics.
AC_HEADER_STDBOOL
AC_C_CONST
AC_C_INLINE
AC_TYPE_SIZE_T
AC_HEADER_TIME
AC_STRUCT_TM
# Checks for library functions.
AC_FUNC_FORK
AC_PROG_GCC_TRADITIONAL
AC_FUNC_MEMCMP
AC_FUNC_SELECT_ARGTYPES
AC_FUNC_VPRINTF
AC_CHECK_FUNCS([ftruncate gethostname inet_ntoa memmove memset select socket strchr strerror strstr])
AC_OUTPUT(Makefile) #添加Makefile
需要改動的就是這幾個地方,然后保存。
然后 $]: aclocal
如果生成m4文件則繼續,否則說明configure.in有問題
$] : autoconf 目的是生成configure
$] : autoreconf --install 目的是產生生成Makefile.in的必要文件
$] : autoheader 目的是生成config.h.in
由于Makefile由Makefile.in生成,而Makefile.in由Makefile.am來填充,所以需要建立Makefile.am
$] : vim Makefile.am 需要填充的內容如下:
AUTOMAKE_OPTIONS=foreign
bin_PROGRAMS=mypro
mypro_SOURCES=Main.cpp Device.cpp Server.cpp SocketBase.cpp Thread.cpp Posix/AsycIO.cpp Posix/PoSockDisp.cpp Posix/Daemon.cpp Posix/PoMutex.cpp
INCLUDES=-I.. -DTHIRTY_TWO_BIT
mypro_LDADD=libmylib.a -lpthread -lrt
第一行表示符合GNU Makefile標準的程度,一般用這個,其他的可以查閱相關文檔。
第二行表示程序的名稱,這是必須的。
第三行表示所有的源代碼文件,要注意名稱是 程序名+_SOURCES。
第四行中可以把查找頭文件的文件夾包含進來,格式就是gcc選項的格式,還可以包含宏定義。
最后一行是需要添加或者鏈接的庫,格式跟gcc的完全一樣,這個選項只能接受有關庫的參數,不接受其它參數。
保存后就可以生成Makefile.in了
$] : automake
OK !
然后你可以構建可執行程序了,./configure make
如果要編寫靜態庫,那么Makefile.am的參數就有些變化
AUTOMAKE_OPTIONS=foreign
lib_LIBRARIES=libmylib.a
libmylib_a_SOURCES= .................
INCLUDES=.................
其中參數名的格式一個要正確。其他的跟可執行文件的產生一樣。
如果要產生動態庫,必須要借助libtool,libtool產生.a和.so文件,放在當前文件夾.lib/目錄中,這個被隱藏了,同時也產生.la文件,當其他模塊需要鏈接庫時,只需要鏈接.la文件,然后由.la文件來決定如何鏈接這個庫,是靜態鏈接還是動態鏈接,由configure參數決定,這樣的方式據說是用來解決夸平臺問題,但我似乎并沒有從中受益多少,不過產生動態庫的makefile也沒有其他辦法,不過好在.a和.so都產生了,怎么用就在于個人了。要用libtool就要在configure.in中添加宏AC_PROG_LIBTOOL,
然后可以寫Makefile.am, 如下
AUTOMAKE_OPTIONS=foreign
lib_LTLIBRARIES=libmylib.la
libmylib_la_SOURCES=mylib.c
libmylib_la_LIBFLAGS=......
libmylib_la_LIBADD=.....
如果要在應用程序里鏈接這個庫,那么就在mypro_LDADD +=libmylib.la,是動態還是靜態要在configure的參數中指定。