mirror of
https://github.com/pybind/pybind11.git
synced 2024-11-11 08:03:55 +00:00
bd8985aa0f
* Step 1: Establish new `PYBIND11_SMART_HOLDER_ENABLED` macro, but only under include/pybind11/ At the stage `PYBIND11_HAS_INTERNALS_WITH_SMART_HOLDER_SUPPORT` and `PYBIND11_SMART_HOLDER_ENABLED` are still equivalent. * Systematically replace all `PYBIND11_HAS_INTERNALS_WITH_SMART_HOLDER_SUPPORT` with `PYBIND11_SMART_HOLDER_ENABLED` under tests/ and ubench/ As at the previous stage, `PYBIND11_HAS_INTERNALS_WITH_SMART_HOLDER_SUPPORT` and `PYBIND11_SMART_HOLDER_ENABLED` are still equivalent. * Introduce `PYBIND11_SMART_HOLDER_DISABLE` option. * `#ifdef` out entire `wrap()` function to avoid `unused-parameter` warning-as-error under macos-13 ``` /Users/runner/work/pybind11/pybind11/tests/test_class_sh_trampoline_basic.cpp:67:23: error: unused parameter 'm' [-Werror,-Wunused-parameter] void wrap(py::module_ m, const char *py_class_name) { ^ /Users/runner/work/pybind11/pybind11/tests/test_class_sh_trampoline_basic.cpp:67:38: error: unused parameter 'py_class_name' [-Werror,-Wunused-parameter] void wrap(py::module_ m, const char *py_class_name) { ^ 2 errors generated. ```
58 lines
1.7 KiB
C++
58 lines
1.7 KiB
C++
#include <pybind11/pybind11.h>
|
|
|
|
#include "number_bucket.h"
|
|
|
|
#include <cstddef>
|
|
#include <memory>
|
|
|
|
namespace hc { // holder comparison
|
|
|
|
using nb_up = pybind11_ubench::number_bucket<1>;
|
|
using nb_sp = pybind11_ubench::number_bucket<2>;
|
|
using nb_pu = pybind11_ubench::number_bucket<3>;
|
|
using nb_sh = pybind11_ubench::number_bucket<4>;
|
|
|
|
namespace py = pybind11;
|
|
|
|
template <typename WrappedType, typename HolderType>
|
|
void wrap_number_bucket(py::module m, const char *class_name) {
|
|
py::class_<WrappedType, HolderType>(m, class_name)
|
|
.def(py::init<std::size_t>(), py::arg("data_size") = 0)
|
|
.def("sum", &WrappedType::sum)
|
|
.def("add", &WrappedType::add, py::arg("other"));
|
|
}
|
|
|
|
#ifdef PYBIND11_SMART_HOLDER_ENABLED
|
|
|
|
template <typename T>
|
|
class padded_unique_ptr {
|
|
std::unique_ptr<T> ptr;
|
|
char padding[sizeof(py::smart_holder) - sizeof(std::unique_ptr<T>)];
|
|
|
|
public:
|
|
padded_unique_ptr(T *p) : ptr(p) {}
|
|
T *get() { return ptr.get(); }
|
|
};
|
|
|
|
static_assert(sizeof(padded_unique_ptr<nb_pu>) == sizeof(py::smart_holder),
|
|
"Unexpected sizeof mismatch.");
|
|
|
|
#endif
|
|
|
|
} // namespace hc
|
|
|
|
#ifdef PYBIND11_SMART_HOLDER_ENABLED
|
|
PYBIND11_DECLARE_HOLDER_TYPE(T, hc::padded_unique_ptr<T>);
|
|
#endif
|
|
|
|
PYBIND11_MODULE(pybind11_ubench_holder_comparison, m) {
|
|
using namespace hc;
|
|
wrap_number_bucket<nb_up, std::unique_ptr<nb_up>>(m, "number_bucket_up");
|
|
wrap_number_bucket<nb_sp, std::shared_ptr<nb_sp>>(m, "number_bucket_sp");
|
|
#ifdef PYBIND11_SMART_HOLDER_ENABLED
|
|
m.def("sizeof_smart_holder", []() { return sizeof(py::smart_holder); });
|
|
wrap_number_bucket<nb_pu, padded_unique_ptr<nb_pu>>(m, "number_bucket_pu");
|
|
wrap_number_bucket<nb_sh, py::smart_holder>(m, "number_bucket_sh");
|
|
#endif
|
|
}
|