I have a module with two C++ classes exposed which both have a method foo():
struct MyClassA{
    void foo() { std::cout << "MyClassA::foo()" << std::endl; }
};
struct MyClassB{
    void foo() { std::cout << "MyClassB::foo()" << std::endl; }
};
BOOST_PYTHON_MODULE(my_module){
    class_<MyClassA>("MyClassA", init<>()).def("foo", &MyClassA::foo);
    class_<MyClassB>("MyClassB", init<>()).def("foo", &MyClassB::foo);
}
In Python, I create a class that is derived from both classes:
from my_module import MyClassA, MyClassB
class Derived(MyClassA, MyClassB):
    def foo(self):
        super().foo()  # should be unnessessary - doesn't work anyway
a = MyClassA()
a.foo()  # works
b = MyClassB()
b.foo()  # works
d = Derived()
d.foo()  # only prints 'MyClassA::foo()'
Now I'd love to have d.foo() call MyClassA.foo() as well as MyClassB.foo(). But while Derived.mro() looks good:
[<class '__main__.Derived'>, <class 'my_module.MyClassA'>, <class 'my_module.MyClassB'>, <class 'Boost.Python.instance'>, <class 'object'>]
.. only MyClassA.foo() gets called.
How do I make the C++ methods call their super() methods? And does that work for __init__() as well?
 
    