xmake
国产编程语言编译系统,简单易用,网址:https://xmake.io/#/
pybind11
简单易用的C++和Python的双向绑定项目,借鉴boost.python,网址为:http://pybind11.readthedocs.io/en/stable/basics.html
xmake编译pybind11项目
pybind11官网教程有gcc和cmake的示例,这里补充xmake的。
- 创建xmake工程
xmake create -l c++ pybind_demo
通过上述脚本创建pybind_demo工程。
- 目录结构概览
新建的工程里面有:
src文件夹,里面存放生成的main.cpp文件;
xmake.lua文件,xmake的工程配置文件。 - 添加pybind11官网的exaple.cpp示例代码
将pybind11官网的example.cpp代码放到src目录里面,
example.cpp代码如下所示:
#include <pybind11/pybind11.h>
namespace py = pybind11;
int add(int i, int j) {
return i + j;
}
PYBIND11_MODULE(example, m) {
m.doc() = "pybind11 example plugin"; // optional module docstring
m.def("add", &add, "A function which adds two numbers");
}
- 修改xmale.lua文件
pybind11官网给的编译shell为:
c++ -O3 -Wall -shared -std=c++11 -fPIC `python -m pybind11 --includes` example.cpp -o example`python-config --extension-suffix`
我们将它翻译为xmale.lua文件:
-- add modes: debug and release
add_rules("mode.debug", "mode.release")
set_languages("cxx11")
set_optimize("fastest")
target("main")
set_kind("binary")
add_files("src/main.cpp")
target("example")
set_kind("shared")
add_files("src/example.cpp")
add_cxflags("$(shell python -m pybind11 --includes)")
after_build(
function(target)
local targetfile = target:targetfile()
os.cp(targetfile, path.join("./", path.filename(targetfile):sub(4)))
end
)
其中xmake自动生成的target(“main”)可删掉,如果不删掉,则要将add_files中的通配符去掉。
after_build是xmake编译后的处理过程,这里是将xmake编译的so文件搬运到当前目录,根据情况使用。
- 编译
回到xmake.lua所在的目录,编译工程:
xmake build
即可在当前目录得到example.so动态链接库。 - 测试
在example.so所在的目录输入:
python
进入python交互环境:
import example
example.add(4,5)
输出应该为:9
最后
xmake简单易用,而且作者ruki人勤奋、nice,后面如果有机会一定考虑使用。