Próbuję wykonać proste wywołanie przez odwołanie z Pythona do metody klasy C++.Przywoływanie wywołania metody python z argumentami odwołującymi się
Moje C++ kod wygląda następująco:
class Foo {
protected:
int _internalVal;
public:
Foo() : _internalVal(5){}
void getVal(int& val_io) {val_io = _internalVal;}
void getValDoesNothing(int val_io) {val_io = _internalVal;}
}
Moje doładowania kodem otoki który kompiluje grzywny:
BOOST_PYTHON_MODULE(libBar) {
boost::python::class_<Foo>("Foo")
.def("getVal", &Foo::getVal)
.def("getValDoesNothing", &Foo::getValDoesNothing);
}
Jednak kiedy dokonać następujących połączeń Pythonie
In [1]: import libBar
In [2]: f = libBar.Foo()
In [3]: f
Out[3]: <libBar.Foo at 0x2b483c0>
In [4]: val = int()
In [5]: #next command is just to check function signature type
In [6]: f.getValDoesNothing(val)
In [7]: f.getVal(val)
---------------------------------------------------------------------------
ArgumentError Traceback (most recent call last)
<ipython-input-5-531e4cea97c2> in <module>()
----> 1 f.getVal(val)
ArgumentError: Python argument types in
Foo.getVal(Foo, int)
did not match C++ signature:
getVal(Foo {lvalue}, int {lvalue})
I pracuję z biblioteką, której nie kontroluję, więc zmiana getVal w celu zwrócenia wartości nie jest opcją.
Czy istnieje sposób na wykonanie ostatniego polecenia Pythona?
Nawet poprawkę, która nie zmienia zmiennej Python, ale nadal pozwala na wywołanie funkcji.
Wiem, że przechodzę w referencji. Moje pytanie brzmi: jak to zrobić? –