用Autoconf檢測MySQL軟件包的教程
在你的程序(或者工程)中,如果編譯階段需要檢測當(dāng)前環(huán)境中是否存在MySQL客戶端相關(guān)的庫文件時,你可以使用Autoconf來幫你完成這個工作,輕盈、優(yōu)雅、無痛。閱讀本文需要了解簡單GNU Autoconf使用。
1. 本文的目標(biāo)
目的:編譯時,根據(jù)configure參數(shù)(如果有--with-mysql),選擇性編譯對應(yīng)的MySQL相關(guān)的功能。
實現(xiàn):使用已經(jīng)寫好的m4腳本:ax_lib_mysql.m4
2. 如何利用Autoconf實現(xiàn)
大部分你想到的事情都已經(jīng)有人做過嘗試了。這件事情也不例外,Autoconf中有很多腳本和指令幫你做事情。這里,需要使用ax_lib_mysql.m4來幫助我們。先把該文件放到程序/工程目錄中,并在configure.ac中新增如下指令來檢測MySQL庫文件和版本:
AX_LIB_MYSQL()
AM_CONDITIONAL(BUILD_MYSQL_SUPPORT, test x$MYSQL_VERSION != x)
說明:AX_LIB_MYSQL()設(shè)置了三個變量,可以在Makefile.am中直接使用,分別是MYSQL_CFLAGS、MYSQL_LDFLAGS、MYSQL_VERSION,另外還會在config.h中預(yù)定義宏HAVE_MYSQL;AM_CONDITIONAL(...)則會根據(jù)是否需要開啟MySQL支持,來設(shè)置變量BUILD_MYSQL_SUPPORT,這個變量可以在Makefile.am中使用。
在程序源代碼中一般有兩種方式可以獲取HAVE_MYSQL宏的方式:一個是直接包含config.h;另一個是在你程序的CFLAGS中新增-DHAVE_MYSQL。(注意:有的變量是可以在Makefile.am中使用,有的則是可以在C源代碼中使用)
方法一:直接include config.h
Autoconf工具會將所有的預(yù)定義宏存放在config.h(默認(rèn)情況)中,并在編譯器選項中新增-DHAVE_CONFIG_H(通過@DEFS@)。因為文件ax_lib_mysql.m4中,包含了如下代碼(如果加上--with-mysql并且找到了對應(yīng)mysql_config,那么如下代碼生效):
[Define to 1 if MySQL libraries are available])
所以,config.h中會有對應(yīng)的宏定義:
#define HAVE_MYSQL 1
在你的源代碼中(一般是頭文件),新增如下代碼:
#include >config.h<
#endif
這之后,就可以在你的源代碼中,使用#ifdef HAVE_MYSQL ... #endif這樣的寫法了
方法二:編譯器選項新增-DHAVE_MYSQL
因為文件ax_lib_mysql.m4包含了變量定義MYSQL_CFLAGS/MYSQL_LDFLAGS/MYSQL_VERSION,所以,簡單的可以在Makefile.am中,直接根據(jù)這些變量來新增gcc編譯參數(shù)。類似如下寫法:
XXX_CFLAGES= -DHAVE_MYSQL
endif
這之后,也可以在你的源代碼中,使用#ifdef HAVE_MYSQL ... #endif這樣的寫法了
小結(jié):上面兩種方法一個需要修改Makefile.am、一個需要修改頭文件,可以根據(jù)個人喜好來決定怎么做。
3. 更多關(guān)于ax_lib_mysql.m4的使用
常見的configure寫法
有了上面的設(shè)置,程序就可以通過如下的方式來確定是否將MySQL客戶端的支持編譯到源代碼中:
...
./configure --with-mysql[=no|yes]
...
./configure --with-mysql[=/YOUR_ENV_PATH/mysql_config] #如果mysql_config不在當(dāng)前的$PATH中,則需要顯示指定。
...
如果對最低版本有要求
另外,如果你對MySQL版本有要求,例如,你希望只有檢測到5.5以上的MySQL客戶端,才編譯對MySQL的支持,則可以在configure.ac中這樣使用AX_LIB_MYSQL:
AX_LIB_MYSQL(5.5.18)
修改--with-mysql的默認(rèn)行為
這里意思是說,如果在configure中沒有--with-mysql選項時,則編譯時不加上對MySQL的支持(如果寫了),也就是說如下兩種寫法意思相同:
./configure
ax_lib_mysql.m4的默認(rèn)行為并非如此,需要對其代碼做小小的修改:
MYSQL_CONFIG="$withval"
fi
],
- [want_mysql="yes"]
+ [want_mysql="no"]
)
AC_ARG_VAR([MYSQL_CONFIG], [Full path to mysql_config program])
這樣就如愿了。
4. 更一般的DEBUG選項
其實使用Autoconf這種用法更一般的是開啟或者關(guān)閉DEBUG選項。這個實現(xiàn)會比上面簡單很多。
目標(biāo):編譯時,根據(jù)configure參數(shù)(如果有--enable-debug),則執(zhí)行程序中#ifdef DEBUG ... #endif。(經(jīng)??吹竭@樣的寫法吧)
相比上面的--with-mysql這個就簡單多了(沒有版本信息、不需要找mysql_config等),所以實現(xiàn)也簡單多了,只需在你的configure.ac中新增如下代碼:
AS_HELP_STRING([--enable-debug],
[enable debugging, default: no]),
[case "${enableval}" in
yes) debug=true ;;
no) debug=false ;;
*) AC_MSG_ERROR([bad value ${enableval} for --enable-debug]) ;;
esac],
[debug=false])
AM_CONDITIONAL(DEBUG, test x"$debug" = x"true")
如果configure時,帶有參數(shù)--enable-debug,則設(shè)置調(diào)用AM_CONDITIONAL設(shè)置遍歷DEBUG。這樣就可以在Makefile中根據(jù)遍歷DEBUG,來選擇性的新增編譯參數(shù)-DDEBUG,所以配套的還需要再Makefile.am中新增:
XXX_CFALGS=... -DDEBUG
else
XXX_CFALGS=...
fi
這時,你的代碼中就可以寫#ifdef DEBUG ... #endif了。
另一種包含config.h的方法跟前面類似,只不過需要將AM_CONDITIONAL那里換成:
AC_DEFINE([HAVE_MYSQL], [1],
[Define to 1 if MySQL libraries are available])
fi
那么程序代碼中include >config.h<就可以了。
相關(guān)文章
解決MySQL 8.0以上版本設(shè)置大小寫不敏感的問題
MySQL 8.0以上版本默認(rèn)區(qū)分大小寫,但在低版本(如5.7)中,可以通過在my.cnf配置文件的[mysqld]節(jié)下添加lower_case_table_names=1來設(shè)置大小寫不敏感,本篇博客將介紹如何解決MySQL 8.0以上版本設(shè)置大小寫不敏感的問題,需要的朋友可以參考下2023-11-11mysql慢查詢操作實例分析【開啟、測試、確認(rèn)等】
這篇文章主要介紹了mysql慢查詢操作,結(jié)合實例形式分析了mysql慢查詢操作中的開啟、測試、確認(rèn)等實現(xiàn)方法及相關(guān)操作技巧,需要的朋友可以參考下2019-12-12淺談mysql中concat函數(shù),mysql在字段前/后增加字符串
下面小編就為大家?guī)硪黄獪\談mysql中concat函數(shù),mysql在字段前/后增加字符串。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02CentOS7.5 安裝 Mysql8.0.19的教程圖文詳解
這篇文章主要介紹了CentOS7.5 安裝 Mysql8.0.19的教程,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2020-01-01mysql4.0升級到mysql5(4.1),解決字符集問題
軟件升級部分就不說了,光說數(shù)據(jù)庫遷移。2009-09-09MYSQL開發(fā)性能研究之批量插入數(shù)據(jù)的優(yōu)化方法
在網(wǎng)上也看到過另外的幾種方法,比如說預(yù)處理SQL,比如說批量提交。那么這些方法的性能到底如何?本文就會對這些方法做一個比較2017-07-07Mysql刪除重復(fù)數(shù)據(jù)通用SQL的兩種方法
本文主要介紹了Mysql刪除重復(fù)數(shù)據(jù)通用SQL的兩種方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-08-08