《Mysql入門用Autoconf檢測MySQL軟件包的教程》要點(diǎn):
本文介紹了Mysql入門用Autoconf檢測MySQL軟件包的教程,希望對(duì)您有用。如果有疑問,可以聯(lián)系我們。
在你的程序(或者工程)中,如果編譯階段必要檢測當(dāng)前環(huán)境中是否存在MySQL客戶端相關(guān)的庫文件時(shí),你可以使用Autoconf來幫你完成這個(gè)工作,輕盈、優(yōu)雅、無痛.閱讀本文必要了解簡單GNU Autoconf使用.
1. 本文的目標(biāo)MYSQL教程
目的:編譯時(shí),根據(jù)configure參數(shù)(如果有--with-mysql),選擇性編譯對(duì)應(yīng)的MySQL相關(guān)的功能.MYSQL教程
實(shí)現(xiàn):使用已經(jīng)寫好的m4腳本:ax_lib_mysql.m4
2. 如何利用Autoconf實(shí)現(xiàn)MYSQL教程
大部分你想到的事情都已經(jīng)有人做過嘗試了.這件事情也不例外,Autoconf中有很多腳本和指令幫你辦事情.這里,需要使用ax_lib_mysql.m4來幫助我們.先把該文件放到程序/工程目錄中,并在configure.ac中新增如下指令來檢測MySQL庫文件和版本:
MYSQL教程
說明:AX_LIB_MYSQL()設(shè)置了三個(gè)變量,可以在Makefile.am中直接使用,分別是MYSQL_CFLAGS、MYSQL_LDFLAGS、MYSQL_VERSION,另外還會(huì)在config.h中預(yù)定義宏HAVE_MYSQL;AM_CONDITIONAL(...)則會(huì)根據(jù)是否必要開啟MySQL支持,來設(shè)置變量BUILD_MYSQL_SUPPORT,這個(gè)變量可以在Makefile.am中使用.MYSQL教程
在程序源代碼中一般有兩種方式可以獲取HAVE_MYSQL宏的方式:一個(gè)是直接包含config.h;另一個(gè)是在你程序的CFLAGS中新增-DHAVE_MYSQL.(注意:有的變量是可以在Makefile.am中使用,有的則是可以在C源代碼中使用)
辦法一:直接include config.hMYSQL教程
Autoconf工具會(huì)將所有的預(yù)定義宏存放在config.h(默認(rèn)情況)中,并在編譯器選項(xiàng)中新增-DHAVE_CONFIG_H(通過@DEFS@).因?yàn)槲募x_lib_mysql.m4中,包括了如下代碼(如果加上--with-mysql并且找到了對(duì)應(yīng)mysql_config,那么如下代碼生效):
MYSQL教程
所以,config.h中會(huì)有對(duì)應(yīng)的宏定義:
MYSQL教程
在你的源代碼中(一般是頭文件),新增如下代碼:
MYSQL教程
這之后,就可以在你的源代碼中,使用#ifdef HAVE_MYSQL ... #endif這樣的寫法了
辦法二:編譯器選項(xiàng)新增-DHAVE_MYSQLMYSQL教程
因?yàn)槲募x_lib_mysql.m4包括了變量定義MYSQL_CFLAGS/MYSQL_LDFLAGS/MYSQL_VERSION,所以,簡單的可以在Makefile.am中,直接根據(jù)這些變量來新增gcc編譯參數(shù).類似如下寫法:
?MYSQL教程
這之后,也可以在你的源代碼中,使用#ifdef HAVE_MYSQL ... #endif這樣的寫法了MYSQL教程
小結(jié):上面兩種方法一個(gè)需要修改Makefile.am、一個(gè)需要修改頭文件,可以根據(jù)個(gè)人愛好來決定怎么做.
3. 更多關(guān)于ax_lib_mysql.m4的使用
常見的configure寫法MYSQL教程
有了上面的設(shè)置,法式就可以通過如下的方式來確定是否將MySQL客戶端的支持編譯到源代碼中:
?MYSQL教程
另外,如果你對(duì)MySQL版本有要求,例如,你希望只有檢測到5.5以上的MySQL客戶端,才編譯對(duì)MySQL的支持,則可以在configure.ac中這樣使用AX_LIB_MYSQL:
AX_LIB_MYSQL(5.5.18)
修改--with-mysql的默認(rèn)行為MYSQL教程
這里意思是說,如果在configure中沒有--with-mysql選項(xiàng)時(shí),則編譯時(shí)不加上對(duì)MySQL的支持(如果寫了),也便是說如下兩種寫法意思相同:
?MYSQL教程
ax_lib_mysql.m4的默認(rèn)行為并非如此,必要對(duì)其代碼做小小的修改:MYSQL教程
?MYSQL教程
這樣就如愿了.
4. 更一般的DEBUG選項(xiàng)MYSQL教程
其實(shí)使用Autoconf這種用法更一般的是開啟或者關(guān)閉DEBUG選項(xiàng).這個(gè)實(shí)現(xiàn)會(huì)比上面簡單很多.MYSQL教程
目標(biāo):編譯時(shí),根據(jù)configure參數(shù)(如果有--enable-debug),則執(zhí)行程序中#ifdef DEBUG ... #endif.(常??吹竭@樣的寫法吧)MYSQL教程
相比上面的--with-mysql這個(gè)就簡單多了(沒有版本信息、不必要找mysql_config等),所以實(shí)現(xiàn)也簡單多了,只需在你的configure.ac中新增如下代碼:MYSQL教程
?MYSQL教程
如果configure時(shí),帶有參數(shù)--enable-debug,則設(shè)置調(diào)用AM_CONDITIONAL設(shè)置遍歷DEBUG.這樣就可以在Makefile中根據(jù)遍歷DEBUG,來選擇性的新增編譯參數(shù)-DDEBUG,所以配套的還必要再M(fèi)akefile.am中新增:
?MYSQL教程
這時(shí),你的代碼中就可以寫#ifdef DEBUG ... #endif了.MYSQL教程
另一種包含config.h的辦法跟前面類似,只不過需要將AM_CONDITIONAL那里換成:
?MYSQL教程
那么法式代碼中include >config.h<就可以了.
MYSQL教程
維易PHP培訓(xùn)學(xué)院每天發(fā)布《Mysql入門用Autoconf檢測MySQL軟件包的教程》等實(shí)戰(zhàn)技能,PHP、MYSQL、LINUX、APP、JS,CSS全面培養(yǎng)人才。
轉(zhuǎn)載請(qǐng)注明本頁網(wǎng)址:
http://www.snjht.com/jiaocheng/11939.html