xmake自動(dòng)構(gòu)建工具

一 前言

autotool簡化了Makefile的構(gòu)建難度,讓我們方便的生成復(fù)雜項(xiàng)目的Makefile;
CMake是一個(gè)跨平臺(tái)的安裝(編譯)工具,可以用簡單的語句來描述所有平臺(tái)的安裝(編譯過程)。他能夠輸出各種各樣的makefile或者project文件,能測試編譯器所支持的C++特性,類似UNIX下的automake,可以輸出不同IDE的工程文件如下:


image.png

說實(shí)話,autotool和CMake都比較復(fù)雜,autotool需要寫Make.am, CMake 要寫CMakeLists都有自己語法,還要仔細(xì)看說明,了解語法,基本上不常用,過幾天還要重新開。

xmake 是一個(gè)基于 Lua 的輕量級(jí)跨平臺(tái)構(gòu)建工具,使用 xmake.lua 維護(hù)項(xiàng)目構(gòu)建,相比 makefile/CMakeLists.txt,配置語法更加簡潔直觀,對(duì)新手非常友好,短時(shí)間內(nèi)就能快速入門,能夠讓用戶把更多的精力集中在實(shí)際的項(xiàng)目開發(fā)上,既能夠像 Make/Ninja 那樣可以直接編譯項(xiàng)目,也可以像 CMake/Meson 那樣生成工程文件,還有內(nèi)置的包管理系統(tǒng)來幫助用戶解決 C/C++依賴庫的集成使用問題,從功能上我覺得它比CMake的功能更強(qiáng)大。

二 安裝

非常簡單:

# 使用curl 
bash <(curl -fsSL https://xmake.io/shget.text)

#或者使用wget
bash <(wget https://xmake.io/shget.text -O -)

# powershell
Invoke-Expression (Invoke-Webrequest 'https://xmake.io/psget.text' -UseBasicParsing).Content

三 編譯

編譯的時(shí)候,可以在源碼目錄直接運(yùn)行xmake,會(huì)自動(dòng)生成xmake.lua ,由于自動(dòng)生成的無法自動(dòng)設(shè)置依賴,所以需要添加下依賴的庫和包含的頭文件的路徑,設(shè)置些編譯選項(xiàng),簡單的如下,不用解釋看看就明白.

add_rules("mode.debug", "mode.release")

target("trunk")
    set_kind("static")
    add_includedirs("/usr/include/mysql","/usr/include")
    add_files("*.c")

target("flow_deal_main")
    set_kind("binary")
    add_files("flow_deal_main.c")
    add_includedirs("/usr/include/mysql","/usr/include")
    add_deps("trunk")
    add_cxflags("-Wall" ,"-O0",  "-m64 -pg  -g    -D_REENTRANT -D_THREAD_SAFE  -std=gnu99")
    add_ldflags("-L/usr/lib64/mysql", "-lmysqlclient", {force = true})
    add_ldflags("-L/usr/lib64","-lpthread",{force=true})

改好之后再次執(zhí)行xmake,然后就會(huì)在當(dāng)前目錄下生成build目錄,下面有編譯好的文件,如下:

[root@localhost trunk]# tree ./build
./build
└── linux
    └── x86_64
        └── release
            ├── flow_deal_main
            ├── libtrunk.a

如果要執(zhí)行程序,也簡單,通過以下命令直接調(diào)用flow_deal_main執(zhí)行。

# xmake run 

四 包管理功能

做過c、c++開發(fā)的朋友都會(huì)有找?guī)斓耐纯?,有時(shí)候要編譯一個(gè)庫,比如clickhouse,這個(gè)庫又依賴其他的庫,需要我們自己去搜索,下載,解壓,編譯安裝,不同的平臺(tái)編譯方法有差異,編譯好了又有可能發(fā)現(xiàn)需要的庫的版本和我們下的不一致,工作要重頭再來。 其他語言像java有maven對(duì)依賴的jar進(jìn)行管理,像js有npm來做包管理,rust有cargo,主要這些語言要么背靠一個(gè)大公司,要么是一個(gè)獨(dú)立的公司在運(yùn)作,所以包管理作的都比較不錯(cuò)。

c、或c++程序員就比較痛苦了,沒有統(tǒng)一的包管理,都沒有大規(guī)模流行起來,以至于很長時(shí)間我都不知道c、c++也有包管理器,后來發(fā)現(xiàn)c、c++ 也有些包管理器,比如微軟的Vpckg在visual studio下使用;conan 有可能成為事實(shí)標(biāo)準(zhǔn)的包管理器,配合cmake,應(yīng)用還是比較廣泛。


image.png

作為今天的主角xmake同樣具有包管理功能,具體如下:

PS F:\ccode\test> xrepo rm-repo conan
remove global repository(conan): ok!
PS F:\ccode\test> xrepo  install conan https://github.com/conan-io/conan-center-index
error: package(conan) not found!
error: execv(xmake require -j 12 --extra={system=false} conan https://github.com/conan-io/conan-center-index) failed(-1)
error: Cloning into 'C:\Users\Think\AppData\Local\.xmake\repositories\conan'...
fatal: unable to access 'https://hub.fastgit.xyz/conan-io/conan-center-index/': SSL certificate problem: certificate has expired

error: execv(xmake repo --add --global conan https://github.com/conan-io/conan-center-index) failed(-1)
PS F:\ccode\test> xrepo list-repo
global repositories:
    vcpkg https://github.com/microsoft/vcpkg
    conan https://github.com/conan-io/conan-center-index
    build-artifacts https://gitee.com/xmake-mirror/build-artifacts.git main
    xmake-repo https://gitee.com/tboox/xmake-repo.git master
    builtin-repo D:\Program Files\xmake\repository

5 repositories were found!
PS F:\ccode\test> xrepo rm-repo conan
remove global repository(conan): ok!
PS F:\ccode\test> xrepo search zlib
The package names:
    zlib:
      -> chromium_zlib-2022.02.22: zlib from chromium (in xmake-repo)
      -> zlib-v1.2.11: A Massively Spiffy Yet Delicately Unobtrusive Compression Library (in xmake-repo)
      -> zlib-ng-2.0.5: zlib replacement with optimizations for next generation systems. (in xmake-repo)
PS F:\ccode\test> xrepo install  zlib 
note: install or modify (m) these packages (pass -y to skip confirm)?
in xmake-repo:
  -> zlib v1.2.11 [vs_runtime:"MT"]
please input: y (y/n/m)
y
  => install zlib v1.2.11 .. ok       

在xmake.lua下寫就更簡單了,增加一句話就行:

add_requires("zlib 1.2.11")

在build的時(shí)候自動(dòng)編譯,非常方便。關(guān)鍵還可以用其他包管理器的包,比如:

add_requires("vcpkg::zlib 1.2.11")
target("test")
    add_files("src/*.c")
    add_packages("vcpkg::zlib")

但是我測試了報(bào)錯(cuò),因?yàn)槲业膙pckg沒裝好,安裝如下:

> git clone https://github.com/microsoft/vcpkg
> .\vcpkg\bootstrap-vcpkg.bat

集成下:

>vcpkg integrate install
或
> xmake f --vcpkg=d:\vcpkg

注意添加代理,這樣訪問github會(huì)快:

 xmake g --proxy_pac=github_mirror.lua  

至于加載conan的庫,需要下載exe文件,安裝后,配置path路徑,然后就可以使用了如下:

add_requires("conan::poco/1.9.4", {alias = "poco", debug = true})

build結(jié)果如下:

PS F:\ccode\test> xmake
checking for Microsoft Visual Studio (x64) version ... 2019
note: install or modify (m) these packages (pass -y to skip confirm)?
in conan:
  -> conan::poco/1.9.4 latest [debug:y, vs_runtime:"MT"]
please input: y (y/n/m)
y
  => install conan::poco/1.9.4 latest .. ok
[ 25%]: compiling.release src\main.c
[ 50%]: linking.release test.exe
[100%]: build ok!

五 windows下使用xmake

xmake也可以在windows下安裝運(yùn)行,配合vscode非常方便:

5.1 下載配套版本安裝

windows下配置path,增加xmake.exe所在路徑:

 [https://github.com/xmake-io/xmake/releases](https://github.com/xmake-io/xmake/releases)

5.2 vscode 安裝插件

安裝c、c++插件

c插件

安裝codelldb 插件
codelldb 方便調(diào)試c、c++程序,不過這個(gè)插件安裝經(jīng)常超時(shí)錯(cuò)誤,建議采用離線安裝方法。

安裝xmake插件

image.png

5.3 新建xmake的c工程項(xiàng)目過程

  1. 先建個(gè)測試目錄test,利用code 打開。
  2. 按ctrl+shit+p調(diào)出命令面板,輸入XMake中的XMake: NewFIles


    image.png
  3. 新建C工程。
  4. 點(diǎn)底部的build,編譯程序


    image.png
  5. 點(diǎn)擊右邊的三角即可以運(yùn)行
  6. 點(diǎn)擊設(shè)置中斷點(diǎn)后,點(diǎn)擊右邊的bug標(biāo)識(shí),進(jìn)行運(yùn)行代碼調(diào)試。

六 參考

[Conan教程(4)—— 使用包_jaronho的博客-CSDN博客_conan 使用](https://blog.csdn.net/hezhanran/article/details/112006992)
[C/C++ Open Source Package Manager (conan.io)](https://conan.io/downloads.html)
[microsoft/vcpkg: C++ Library Manager for Windows, Linux, and MacOS (github.com)](https://github.com/microsoft/vcpkg)
[Conan C++包管理教程 - 簡書 (jianshu.com)](http://m.itdecent.cn/p/a983966ffb16)
[https://docs.conan.io/en/latest/getting_started.html](https://docs.conan.io/en/latest/getting_started.html)
[http://blog.guorongfei.com/2018/04/23/conan-tutorial/](http://blog.guorongfei.com/2018/04/23/conan-tutorial/)
[http://m.itdecent.cn/p/eab110c93e4d](http://m.itdecent.cn/p/eab110c93e4d)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容