// Copyright David Abrahams 2002. // Distributed under the Boost Software License, Version 1.0. (See // accompanying file LICENSE_1_0.txt or copy at // http://www.boost.org/LICENSE_1_0.txt) #include #include #include #include #include #include #include #include #include using namespace boost::python; struct Callback { Callback(PyObject* o) : mSelf(o) {} PyObject* mSelf; }; struct P { virtual ~P(){} virtual std::string f() = 0; std::string g() { return "P::g()"; } }; struct PCallback : P, Callback { PCallback (PyObject* self) : Callback(self) {} std::string f() { return call_method(mSelf, "f"); } }; struct Q : virtual P { std::string f() { return "Q::f()"; } }; struct A { virtual ~A(){} virtual std::string f() { return "A::f()"; } }; struct ACallback : A, Callback { ACallback (PyObject* self) : Callback(self) {} std::string f() { return call_method(mSelf, "f"); } std::string default_f() { return A::f(); } }; struct B : A { virtual std::string f() { return "B::f()"; } }; struct C : A { virtual std::string f() { return "C::f()"; } }; struct D : A { virtual std::string f() { return "D::f()"; } std::string g() { return "D::g()"; } }; struct DCallback : D, Callback { DCallback (PyObject* self) : Callback(self) {} std::string f() { return call_method(mSelf, "f"); } std::string default_f() { return A::f(); } }; A& getBCppObj () { static B b; return b; } std::string call_f(A& a) { return a.f(); } A* factory(unsigned choice) { switch (choice % 3) { case 0: return new A; break; case 1: return new B; break; default: return new C; break; } } C& getCCppObj () { static C c; return c; } A* pass_a(A* x) { return x; } BOOST_PYTHON_MODULE_INIT(polymorphism_ext) { class_("A") .def("f", &A::f, &ACallback::default_f) ; def("getBCppObj", getBCppObj, return_value_policy()); class_,boost::noncopyable>("C") .def("f", &C::f) ; class_,DCallback,boost::noncopyable>("D") .def("f", &D::f, &DCallback::default_f) .def("g", &D::g) ; def("pass_a", &pass_a, return_internal_reference<>()); def("getCCppObj", getCCppObj, return_value_policy()); def("factory", factory, return_value_policy()); def("call_f", call_f); class_("P") .def("f", pure_virtual(&P::f)) ; class_ >("Q") .def("g", &P::g) // make sure virtual inheritance doesn't interfere ; } //#include "module_tail.cpp"