Boost Python Runtime error podczas przekazywania obiektu typu pochodnego z python do funkcji C ++ oczekując shared_ptr na typ bazowy
Mam funkcję, która pobiera std :: shared_ptr i chcę przekazać obiekt typu Derived do tej funkcji z Pythona. Oto moje definicje klas:
struct AbstractBase {
virtual void foo() = 0;
};
struct Derived : public AbstractBase {
virtual void foo(){
std::cout<<"Derived's foo!"<<std::endl;
}
};
struct Unrelated {
void bar(std::shared_ptr<AbstractBase> base_shared_ptr) {
base_shared_ptr->foo();
}
};
#endif /* CLASSES_H */
Prosty, czysty przykład C ++ robi to, co chcę:
int main()
{
std::shared_ptr<Derived> d(new Derived);
Unrelated u;
u.bar(d);
}
wydajność:Derived's foo!
Oto mój kod Boost.Python Wrapper:
#include <boost/python.hpp>
#include "classes.h"
BOOST_PYTHON_MODULE(shared_ptr_test) {
using namespace boost::python;
class_<AbstractBase,std::shared_ptr<AbstractBase>,boost::noncopyable>("AbstractBase",no_init);
class_<Derived,std::shared_ptr<Derived>,bases<AbstractBase>,boost::noncopyable>("Derived");
class_<Unrelated,std::shared_ptr<Unrelated>,boost::noncopyable>("Unrelated")
.def("bar",&Unrelated::bar);
}
A oto mój prosty test Pythona:
import shared_ptr_test
d=shared_ptr_test.Derived()
u=shared_ptr_test.Unrelated()
u.bar(d)
Ku mojemu przerażeniu to nie działa. Kompiluje się dobrze, ale po uruchomieniu skryptu Pythona pojawia się ten błąd:
Traceback (most recent call last):
File "test.py", line 5, in <module>
u.bar(d)
Boost.Python.ArgumentError: Python argument types in
Unrelated.bar(Unrelated, Derived)
did not match C++ signature:
bar(Unrelated {lvalue}, std::shared_ptr<AbstractBase>)
Wymiana pieniędzybar
wziąćshared_ptr<Derived>
naprawia to, więc wiem, że wewnętrznie Boost.Python zarządza obiektami za pomocąshared_ptr
s. Czy jest jeszcze coś, co muszę zrobić, aby uzyskać Boost.Python, aby zdać sobie sprawę, że przekazanie go jest w porządkushared_ptr<Derived>
do funkcji oczekującej ashared_ptr<Base>
?