xmake將依賴庫、依賴頭文件、依賴類型、依賴接口統一用 option 選項機制進行了封裝,更在上一層引入package包的機制,使得添加和檢測依賴更加的模塊化,簡單化。。。
下面通過一個具體實例,來看下xmake的包機制怎麼使用。。
假如你現在的工程已經有了兩個包:zlib.pkg,polarssl.pkg(如何構建包,後續會詳細說明,現在可以參考TBOX依賴包下已有包的例子),你的工程目錄結構如下:
demo
- xmake.lua
- src
main.c
- pkg
zlib.pkg
polarssl.pkg
那麼你可以修改xmake.lua來使用上述的兩個依賴包:
-- 添加依賴包目錄,之後添加需要的包,都會從這個目錄裏面查找
add_packagedirs("pkg")
-- 添加目標
target("demo")
-- 設置程序類型爲二進制可執行程序
set_kind("binary")
-- 添加源代碼文件
add_files("src/*.c")
-- 通過option機制添加polarssl、zlib包,如果檢測通過,會去自動鏈接它
add_options("polarssl", "zlib")
-- 設置自動生成的配置頭文件
set_config_h("$(buildir)/config.h")
-- 設置config.h宏開關的前綴: CONFIG_xxxx
set_config_h_prefix("CONFIG")
-- 添加頭文件搜索目錄,這裏爲了搜索到config.h
add_includedirs("$(buildir)")
接下來是代碼裏面怎麼去使用它:
#include <stdio.h>
// 包含自動生成的config.h頭文件
#include "config.h"
// 如果當前平臺存在zlib,那麼使用它
#ifdef CONFIG_PACKAGE_HAVE_ZLIB
# include "zlib/zlib.h"
#endif
// 如果當前平臺存在polarssl,那麼使用它
#ifdef CONFIG_PACKAGE_HAVE_POLARSSL
# include "polarssl/polarssl.h"
#endif
int main(int argc, char** argv)
{
printf("hello world!\n");
return 0;
}
上面就是一個包使用的最簡單的例子,下面我們來看下具體這個zlib.pkg是怎麼生成的:
如果這個包是你自己的項目xxx開發的,那麼你只需要執行xmake p進行打包,自動會在./build目錄下生成一個xxx.pkg的包,你直接在其他項目中使用就行了。。。
如果是第三方的庫,那麼你需要自己去構建它,但是也很方便,實在不行你可以參考已有的TBOX依賴包中一些包,做修改就行了。。。
一個pkg包的目錄結構:
zlib.pkg
- inc(頭文件目錄,可選)
- zlib/zlib.h
- lib(鏈接庫目錄,可選)
- linux/i386/libz.a
- windows/i386/zlib.lib
- xmake.lua(包描述文件)
其中 inc、lib是可選的,具體邏輯還是在xmake.lua進行描述,xmake默認生成的包邏輯,是會優先去檢測zlib.pkg目錄有沒有當前可用的庫和頭文件,如果檢測不通過,纔會去檢測系統平臺的。。。
當然你也可以自己修改檢測邏輯,不一定非得這麼來,你只需要根據自己的需求描述xxx.pkg/xmake.lua文件就行了。。。
下面看下我這裏提供的zlib.pkg/xmake.lua描述邏輯:
-- 添加一個zlib包自動配置選項
option("zlib")
-- 設置是否在xmake f -h配置菜單中顯示
set_showmenu(true)
-- 在xmake f -h中顯示相關描述信息
set_description("The mysql package")
-- 如果檢測通過,定義宏開關到config.h
add_defines_h_if_ok("$(prefix)_PACKAGE_HAVE_ZLIB")
-- 檢測鏈接
add_links("z")
-- 添加檢測的鏈接庫目錄,這裏設置優先檢測zlib.pkg/lib/下相關平臺是否存在鏈接庫,然後再去檢測系統的
add_linkdirs("lib/$(plat)/$(arch)")
-- 檢測 #include "zlib/zlib.h" 是否能編譯通過
add_cincludes("zlib/zlib.h")
-- 添加一些檢測的頭文件目錄,默認會在zlib.pkg/inc進行搜索
add_includedirs("inc/$(plat)", "inc")
只要描述好xxx.pkg/xmake.lua, 一個包就能被xmake使用,並進行自動檢測,其中利用的就是xmake的option機制,當然在包裏面不僅僅可以檢測依賴庫和頭文件,你也可以檢測是否存在某些需要的接口、類型定義等等。。
而且檢測機制完全採用lua語法,支持if條件邏輯,你可以針對一些特定的平臺,做一些特別處理,使得你的包更加的通用。
例如下面這個基礎包base.pkg的描述:
-- 基礎包base.pkg
option("base")
-- 如果當前爲windows平臺,檢測ws2_32鏈接庫依賴
if os("windows") then add_links("ws2_32")
else add_links("m", "dl", "pthread") end
如果你的包只是通過xmake.lua來描述,沒有其他文件目錄,那麼你也可以把你的包xmake.lua的描述內容,直接嵌入到工程描述文件xmake.lua中, 這兩者原本都是通用的,說白了 add_packagedirs("pkg")
的機制,就是調用工程描述api:add_subdirs("pkg/*")
進行添加子工程的過程。。而xxx.pkg說白了就是一個子工程描述文件而已。。。
如果你想在你的包檢測中增加對接口的檢測,那麼只需要用:
add_cfuncs
add_cxxfuncs
add_ctypes
add_cxxtypes
就行了
所以利用包的機制,可以讓你的不同項目最大化重用你的依賴環境。。是個非常有用的功能。。
本文分享自微信公衆號 - TBOOX開源工程(tboox-os)。
如有侵權,請聯繫 [email protected] 刪除。
本文參與“OSC源創計劃”,歡迎正在閱讀的你也加入,一起分享。