Используйте boost::python::make_function
и предоставьте подпись, потому что подпись по умолчанию не обрабатывает std::function
.
Например, мы хотим обернуть возвращаемый тип:
std::function<std::string(int, int)> get_string_function(const std::string& name)
{
return [=](int x, int y)
{
return name + "(x=" + std::to_string(x) + ", y=" + std::to_string(y) + ")";
};
}
Мы можем определить оболочку и def
, используя ее:
boost::python::object get_string_function_pywrapper(const std::string& name)
{
auto func = get_string_function(name);
auto call_policies = boost::python::default_call_policies();
typedef boost::mpl::vector<std::string, int, int> func_sig;
return boost::python::make_function(func, call_policies, func_sig());
}
BOOST_PYTHON_MODULE(s)
{
boost::python::def("get_string_function", get_string_function_pywrapper);
}
Теперь сторона Python может использовать результат так, как мы хотим:
>>> import s
>>> s.get_string_function("Coord")
<Boost.Python.function object at 0x1cca450>
>>> _(1, 4)
'Coord(x=1, y=4)'