WIP: remove convert_type() call from loaded_as_shared_ptr()

This commit is contained in:
Ralf W. Grosse-Kunstleve 2024-07-06 14:29:22 -07:00
parent b201eece19
commit eb15f1a384
2 changed files with 19 additions and 19 deletions

View File

@ -794,11 +794,11 @@ protected:
} }
} }
bool load_value(value_and_holder &&v_h) { void load_value(value_and_holder &&v_h) {
if (v_h.holder_constructed()) { if (v_h.holder_constructed()) {
value = v_h.value_ptr(); value = v_h.value_ptr();
holder = v_h.template holder<holder_type>(); holder = v_h.template holder<holder_type>();
return true; return;
} }
throw cast_error("Unable to cast from non-held to held instance (T& to Holder<T>) " throw cast_error("Unable to cast from non-held to held instance (T& to Holder<T>) "
#if !defined(PYBIND11_DETAILED_ERROR_MESSAGES) #if !defined(PYBIND11_DETAILED_ERROR_MESSAGES)
@ -848,6 +848,9 @@ public:
using base::value; using base::value;
bool load(handle src, bool convert) { bool load(handle src, bool convert) {
if (typeinfo->default_holder) {
return type_caster_generic::load(src, convert);
}
return base::template load_impl<copyable_holder_caster<type, std::shared_ptr<type>>>( return base::template load_impl<copyable_holder_caster<type, std::shared_ptr<type>>>(
src, convert); src, convert);
} }
@ -877,7 +880,7 @@ public:
explicit operator std::shared_ptr<type> &() { explicit operator std::shared_ptr<type> &() {
if (typeinfo->default_holder) { if (typeinfo->default_holder) {
shared_ptr_holder = sh_load_helper.loaded_as_shared_ptr(); shared_ptr_holder = sh_load_helper.loaded_as_shared_ptr(value);
} }
return shared_ptr_holder; return shared_ptr_holder;
} }
@ -900,11 +903,11 @@ protected:
friend class type_caster_generic; friend class type_caster_generic;
void check_holder_compat() {} void check_holder_compat() {}
bool load_value_shared_ptr(const value_and_holder &v_h) { void load_value_shared_ptr(const value_and_holder &v_h) {
if (v_h.holder_constructed()) { if (v_h.holder_constructed()) {
value = v_h.value_ptr(); value = v_h.value_ptr();
shared_ptr_holder = v_h.template holder<std::shared_ptr<type>>(); shared_ptr_holder = v_h.template holder<std::shared_ptr<type>>();
return true; return;
} }
throw cast_error("Unable to cast from non-held to held instance (T& to Holder<T>) " throw cast_error("Unable to cast from non-held to held instance (T& to Holder<T>) "
#if !defined(PYBIND11_DETAILED_ERROR_MESSAGES) #if !defined(PYBIND11_DETAILED_ERROR_MESSAGES)
@ -916,16 +919,13 @@ protected:
#endif #endif
} }
bool load_value_smart_holder(const value_and_holder &v_h) { void load_value(value_and_holder &&v_h) {
sh_load_helper.loaded_v_h = v_h;
return true;
}
bool load_value(value_and_holder &&v_h) {
if (typeinfo->default_holder) { if (typeinfo->default_holder) {
return load_value_smart_holder(v_h); sh_load_helper.loaded_v_h = v_h;
type_caster_generic::load_value(std::move(v_h));
return;
} }
return load_value_shared_ptr(v_h); load_value_shared_ptr(v_h);
} }
template <typename T = std::shared_ptr<type>, template <typename T = std::shared_ptr<type>,
@ -938,7 +938,7 @@ protected:
detail::enable_if_t<std::is_constructible<T, const T &, type *>::value, int> = 0> detail::enable_if_t<std::is_constructible<T, const T &, type *>::value, int> = 0>
bool try_implicit_casts(handle src, bool convert) { bool try_implicit_casts(handle src, bool convert) {
if (typeinfo->default_holder) { if (typeinfo->default_holder) {
throw std::runtime_error("BAKEIN_WIP: try_implicit_casts"); return type_caster_generic::try_implicit_casts(src, convert);
} }
for (auto &cast : typeinfo->implicit_casts) { for (auto &cast : typeinfo->implicit_casts) {
copyable_holder_caster sub_caster(*cast.first); copyable_holder_caster sub_caster(*cast.first);
@ -1029,11 +1029,11 @@ public:
move_only_holder_caster<type, std::unique_ptr<type, deleter>>>(src, convert); move_only_holder_caster<type, std::unique_ptr<type, deleter>>>(src, convert);
} }
bool load_value(value_and_holder &&v_h) { void load_value(value_and_holder &&v_h) {
if (typeinfo->default_holder) { if (typeinfo->default_holder) {
sh_load_helper.loaded_v_h = v_h; sh_load_helper.loaded_v_h = v_h;
sh_load_helper.loaded_v_h.type = get_type_info(typeid(type)); sh_load_helper.loaded_v_h.type = get_type_info(typeid(type));
return true; return;
} }
throw std::runtime_error("BAKEIN_WIP: What is the best behavior here?"); throw std::runtime_error("BAKEIN_WIP: What is the best behavior here?");
} }

View File

@ -833,7 +833,8 @@ struct load_helper : value_and_holder_helper {
shared_ptr_parent_life_support(parent.ptr())); shared_ptr_parent_life_support(parent.ptr()));
} }
std::shared_ptr<T> loaded_as_shared_ptr(handle responsible_parent = nullptr) const { std::shared_ptr<T> loaded_as_shared_ptr(void *void_raw_ptr,
handle responsible_parent = nullptr) const {
if (!have_holder()) { if (!have_holder()) {
return nullptr; return nullptr;
} }
@ -846,8 +847,7 @@ struct load_helper : value_and_holder_helper {
} }
throw std::runtime_error("Non-owning holder (loaded_as_shared_ptr)."); throw std::runtime_error("Non-owning holder (loaded_as_shared_ptr).");
} }
auto *void_raw_ptr = hld.template as_raw_ptr_unowned<void>(); auto *type_raw_ptr = static_cast<T *>(void_raw_ptr);
auto *type_raw_ptr = convert_type(void_raw_ptr);
if (hld.pointee_depends_on_holder_owner) { if (hld.pointee_depends_on_holder_owner) {
auto *vptr_gd_ptr = std::get_deleter<pybindit::memory::guarded_delete>(hld.vptr); auto *vptr_gd_ptr = std::get_deleter<pybindit::memory::guarded_delete>(hld.vptr);
if (vptr_gd_ptr != nullptr) { if (vptr_gd_ptr != nullptr) {