#include #include "pybind11_tests.h" #include namespace pybind11_tests { namespace class_sh_disowning { template // Using int as a trick to easily generate a series of types. struct Atype { int val = 0; explicit Atype(int val_) : val{val_} {} int get() const { return val * 10 + SerNo; } }; int same_twice(std::unique_ptr> at1a, std::unique_ptr> at1b) { return at1a->get() * 100 + at1b->get() * 10; } int mixed(std::unique_ptr> at1, std::unique_ptr> at2) { return at1->get() * 200 + at2->get() * 20; } int overloaded(std::unique_ptr> at1, int i) { return at1->get() * 30 + i; } int overloaded(std::unique_ptr> at2, int i) { return at2->get() * 40 + i; } } // namespace class_sh_disowning } // namespace pybind11_tests PYBIND11_SMART_HOLDER_TYPE_CASTERS(pybind11_tests::class_sh_disowning::Atype<1>) PYBIND11_SMART_HOLDER_TYPE_CASTERS(pybind11_tests::class_sh_disowning::Atype<2>) TEST_SUBMODULE(class_sh_disowning, m) { m.attr("defined_PYBIND11_HAVE_INTERNALS_WITH_SMART_HOLDER_SUPPORT") = #ifndef PYBIND11_HAVE_INTERNALS_WITH_SMART_HOLDER_SUPPORT false; #else true; using namespace pybind11_tests::class_sh_disowning; py::classh>(m, "Atype1").def(py::init()).def("get", &Atype<1>::get); py::classh>(m, "Atype2").def(py::init()).def("get", &Atype<2>::get); m.def("same_twice", same_twice); m.def("mixed", mixed); m.def("overloaded", (int (*)(std::unique_ptr>, int)) & overloaded); m.def("overloaded", (int (*)(std::unique_ptr>, int)) & overloaded); #endif // PYBIND11_HAVE_INTERNALS_WITH_SMART_HOLDER_SUPPORT }