mirror of
https://github.com/pybind/pybind11.git
synced 2024-11-29 08:32:02 +00:00
Fix rtrn_shmp
, rtrn_shmp
by transferring smart_holder_from_shared_ptr()
functionality from smart_holder branch.
This commit is contained in:
parent
a332fe8cf4
commit
7a6d30ca58
@ -860,9 +860,9 @@ public:
|
|||||||
explicit operator std::shared_ptr<type> *() { return std::addressof(holder); }
|
explicit operator std::shared_ptr<type> *() { return std::addressof(holder); }
|
||||||
explicit operator std::shared_ptr<type> &() { return holder; }
|
explicit operator std::shared_ptr<type> &() { return holder; }
|
||||||
|
|
||||||
static handle cast(const std::shared_ptr<type> &src, return_value_policy, handle) {
|
static handle
|
||||||
const auto *ptr = holder_helper<std::shared_ptr<type>>::get(src);
|
cast(const std::shared_ptr<type> &src, return_value_policy policy, handle parent) {
|
||||||
return type_caster_base<type>::cast_holder(ptr, &src);
|
return smart_holder_type_caster_support::shared_ptr_to_python(src, policy, parent);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
@ -101,6 +101,71 @@ unique_ptr_to_python(std::unique_ptr<T, D> &&unq_ptr, return_value_policy policy
|
|||||||
nullptr,
|
nullptr,
|
||||||
std::addressof(unq_ptr));
|
std::addressof(unq_ptr));
|
||||||
}
|
}
|
||||||
|
template <typename T>
|
||||||
|
handle smart_holder_from_shared_ptr(const std::shared_ptr<T> &src,
|
||||||
|
return_value_policy policy,
|
||||||
|
handle parent,
|
||||||
|
const std::pair<const void *, const type_info *> &st) {
|
||||||
|
switch (policy) {
|
||||||
|
case return_value_policy::automatic:
|
||||||
|
case return_value_policy::automatic_reference:
|
||||||
|
break;
|
||||||
|
case return_value_policy::take_ownership:
|
||||||
|
throw cast_error("Invalid return_value_policy for shared_ptr (take_ownership).");
|
||||||
|
case return_value_policy::copy:
|
||||||
|
case return_value_policy::move:
|
||||||
|
break;
|
||||||
|
case return_value_policy::reference:
|
||||||
|
throw cast_error("Invalid return_value_policy for shared_ptr (reference).");
|
||||||
|
case return_value_policy::reference_internal:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (!src) {
|
||||||
|
return none().release();
|
||||||
|
}
|
||||||
|
|
||||||
|
auto src_raw_ptr = src.get();
|
||||||
|
assert(st.second != nullptr);
|
||||||
|
// BAKEIN_WIP: Better Const2Mutbl
|
||||||
|
void *src_raw_void_ptr = const_cast<void *>(static_cast<const void *>(src_raw_ptr));
|
||||||
|
const detail::type_info *tinfo = st.second;
|
||||||
|
if (handle existing_inst = find_registered_python_instance(src_raw_void_ptr, tinfo)) {
|
||||||
|
// SMART_HOLDER_WIP: MISSING: Enforcement of consistency with existing smart_holder.
|
||||||
|
// SMART_HOLDER_WIP: MISSING: keep_alive.
|
||||||
|
return existing_inst;
|
||||||
|
}
|
||||||
|
|
||||||
|
auto inst = reinterpret_steal<object>(make_new_instance(tinfo->type));
|
||||||
|
auto *inst_raw_ptr = reinterpret_cast<instance *>(inst.ptr());
|
||||||
|
inst_raw_ptr->owned = true;
|
||||||
|
void *&valueptr = values_and_holders(inst_raw_ptr).begin()->value_ptr();
|
||||||
|
valueptr = src_raw_void_ptr;
|
||||||
|
|
||||||
|
auto smhldr = pybindit::memory::smart_holder::from_shared_ptr(
|
||||||
|
std::shared_ptr<void>(src, const_cast<void *>(st.first)));
|
||||||
|
tinfo->init_instance(inst_raw_ptr, static_cast<const void *>(&smhldr));
|
||||||
|
|
||||||
|
if (policy == return_value_policy::reference_internal) {
|
||||||
|
keep_alive_impl(inst, parent);
|
||||||
|
}
|
||||||
|
|
||||||
|
return inst.release();
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
handle shared_ptr_to_python(const std::shared_ptr<T> &shd_ptr,
|
||||||
|
return_value_policy policy,
|
||||||
|
handle parent) {
|
||||||
|
const auto *ptr = shd_ptr.get();
|
||||||
|
auto st = type_caster_base<T>::src_and_type(ptr);
|
||||||
|
if (st.second == nullptr) {
|
||||||
|
return handle(); // no type info: error will be set already
|
||||||
|
}
|
||||||
|
if (st.second->default_holder) {
|
||||||
|
return smart_holder_from_shared_ptr(shd_ptr, policy, parent, st);
|
||||||
|
}
|
||||||
|
return type_caster_base<T>::cast_holder(ptr, &shd_ptr);
|
||||||
|
}
|
||||||
|
|
||||||
PYBIND11_NAMESPACE_END(smart_holder_type_caster_support)
|
PYBIND11_NAMESPACE_END(smart_holder_type_caster_support)
|
||||||
PYBIND11_NAMESPACE_END(detail)
|
PYBIND11_NAMESPACE_END(detail)
|
||||||
|
@ -26,8 +26,8 @@ def test_atyp_constructors():
|
|||||||
(m.rtrn_mref, "rtrn_mref(_MvCtor)*_CpCtor"),
|
(m.rtrn_mref, "rtrn_mref(_MvCtor)*_CpCtor"),
|
||||||
(m.rtrn_cptr, "rtrn_cptr"),
|
(m.rtrn_cptr, "rtrn_cptr"),
|
||||||
(m.rtrn_mptr, "rtrn_mptr"),
|
(m.rtrn_mptr, "rtrn_mptr"),
|
||||||
# BAKEIN_BREAK (m.rtrn_shmp, "rtrn_shmp"),
|
(m.rtrn_shmp, "rtrn_shmp"),
|
||||||
# BAKEIN_BREAK (m.rtrn_shcp, "rtrn_shcp"),
|
(m.rtrn_shcp, "rtrn_shcp"),
|
||||||
(m.rtrn_uqmp, "rtrn_uqmp"),
|
(m.rtrn_uqmp, "rtrn_uqmp"),
|
||||||
# BAKEIN_BREAK (m.rtrn_uqcp, "rtrn_uqcp"),
|
# BAKEIN_BREAK (m.rtrn_uqcp, "rtrn_uqcp"),
|
||||||
(m.rtrn_udmp, "rtrn_udmp"),
|
(m.rtrn_udmp, "rtrn_udmp"),
|
||||||
|
Loading…
Reference in New Issue
Block a user