我目前有以下内容:
namespace py=boost::python;
//C++
void f() {
std::cout << "hello world\n";
}
//I am not precious about this, if it can be done without a module that would be great
BOOST_PYTHON_MODULE(test)
{
py::def("f", f);
}
int main() {
auto main_module =py::import("__main__");
auto main_namespace =main_module.attr("__dict__");
//???????
auto result=py::exec_file("t.py", main_namespace);
}
//t.py
f()
我正在尝试拨打f,但我不确定是否需要粘合剂才能使其工作。我可以做课程
int main() {
//...
py::obejct p_my_type=py::class_<my_type>("my_type").def("f", &my_type::f);
main_namespace["my_type"]=p_my_type;
//...
然而boost::python::def
似乎没有像boost::python::object
那样返回class_
我的问题是,我如何让第一个测试用例按预期工作? 其次是我在第二个代码片段“正确”中公开我的类型的方式?
答案 0 :(得分:0)
修复很简单,但在本页的文档中未提及:
http://www.boost.org/doc/libs/1_55_0/libs/python/doc/tutorial/doc/html/python/embedding.html
我需要这样做:
auto main_module =py::import("__main__");
auto main_namespace =main_module.attr("__dict__");
inittest();
auto result=py::exec_file("t.py", main_namespace);
from test import f
f()