У меня есть класс 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")
это дает ошибку типа. Я подозреваю, что это как-то связано с поддержкой 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. Может кто-нибудь помочь, пожалуйста, как я могу решить эту проблему?