У меня есть класс Foo (), а у класса Foo () есть функция со следующим объявлением:
bool Foo::copyFile(const std::filesystem::path& src, const std::filesystem::path& dest)
Требование состоит в том, чтобы у класса Foo были привязки Python. Я использую pybind11 для создания привязок Python.
Для создания привязок Python я написал следующее:
#include <pybind11/pybind11.h>
#include <pybind11/stl.h>
#include "Foo.h"
namespace py = pybind11;
PYBIND11_MODULE(TestModule, m) {
py::class_ <Foo>(m, "Foo")
.def(py::init())
.def("copyFile",&Foo::copyFile);
};
Это нормально компилируется, и я могу создать файл pyd привязок Python. Когда я использую привязки Python для класса Foo, используя:
from TestModule import Foo
f = Foo()
ret = f.copyFile("C:\Users\csaikia\Downloads\testfile_src", "C:\Users\csaikia\Downloads\testfile_dest")
это дает TypeError. Я подозреваю, что это как-то связано с поддержкой pybind11 для std :: filesystem в C ++ 17, поскольку я не видел, чтобы это происходило с другими функциями класса, имеющего std::string
или std::vector
.
Я получаю следующую ошибку:
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: copyFile(): incompatible function arguments. The following argument types are supported:
1. (self: TestModule.Foo, arg0: std::filesystem::path, arg1: std::filesystem::path) -> bool
Invoked with: <TestModule.Foo object at 0x0000000002A33ED8>, 'C:\\Users\\csaikia\\Downloads\\testfile_src', 'C:\\Users\\csaikia\\Downloads\\testfile_dest'
Did you forget to `#include <pybind11/stl.h>`? Or <pybind11/complex.h>,
<pybind11/functional.h>, <pybind11/chrono.h>, etc. Some automatic
conversions are optional and require extra headers to be included
when compiling your pybind11 module.
Я новичок в pybind11. Может кто-нибудь помочь, как я могу это решить?