Adding in vptr_deleter_guard_flag.

This commit is contained in:
Ralf W. Grosse-Kunstleve 2021-01-06 19:23:00 -08:00
parent 80fe0d0d2f
commit 4144651c2c

View File

@ -33,18 +33,21 @@ struct smart_holder {
const std::type_info* rtti_uqp_del; const std::type_info* rtti_uqp_del;
std::shared_ptr<void> vptr; std::shared_ptr<void> vptr;
bool vptr_deleter_guard_flag; bool vptr_deleter_guard_flag;
bool vptr_is_using_builtin_delete;
void clear() { void clear() {
vptr.reset();
vptr_deleter_guard_flag = false;
rtti_held = nullptr; rtti_held = nullptr;
rtti_uqp_del = nullptr; rtti_uqp_del = nullptr;
vptr.reset();
vptr_deleter_guard_flag = false;
vptr_is_using_builtin_delete = false;
} }
smart_holder() smart_holder()
: rtti_held{nullptr}, : rtti_held{nullptr},
rtti_uqp_del{nullptr}, rtti_uqp_del{nullptr},
vptr_deleter_guard_flag{false} {} vptr_deleter_guard_flag{false},
vptr_is_using_builtin_delete{false} {}
bool has_pointee() const { return vptr.get() != nullptr; } bool has_pointee() const { return vptr.get() != nullptr; }
@ -52,7 +55,7 @@ struct smart_holder {
void ensure_compatible_rtti_held(const char* context) const { void ensure_compatible_rtti_held(const char* context) const {
const std::type_info* rtti_requested = &typeid(T); const std::type_info* rtti_requested = &typeid(T);
if (!(*rtti_requested == *rtti_held)) { if (!(*rtti_requested == *rtti_held)) {
throw std::runtime_error(std::string("Incompatible RTTI (") + context + throw std::runtime_error(std::string("Incompatible type (") + context +
")."); ").");
} }
} }
@ -73,9 +76,9 @@ struct smart_holder {
} }
} }
void ensure_vptr_deleter_guard_flag_true(const char* context) const { void ensure_vptr_is_using_builtin_delete(const char* context) const {
if (rtti_uqp_del != nullptr) { if (!vptr_is_using_builtin_delete) {
throw std::runtime_error(std::string("Cannot disown this shared_ptr (") + throw std::runtime_error(std::string("Cannot disown custom deleter (") +
context + ")."); context + ").");
} }
} }
@ -100,6 +103,7 @@ struct smart_holder {
clear(); clear();
rtti_held = &typeid(T); rtti_held = &typeid(T);
vptr_deleter_guard_flag = true; vptr_deleter_guard_flag = true;
vptr_is_using_builtin_delete = true;
vptr.reset(raw_ptr, guarded_builtin_delete<T>(&vptr_deleter_guard_flag)); vptr.reset(raw_ptr, guarded_builtin_delete<T>(&vptr_deleter_guard_flag));
} }
@ -107,7 +111,6 @@ struct smart_holder {
void from_raw_ptr_unowned(T* raw_ptr) { void from_raw_ptr_unowned(T* raw_ptr) {
clear(); clear();
rtti_held = &typeid(T); rtti_held = &typeid(T);
vptr_deleter_guard_flag = false;
vptr.reset(raw_ptr, guarded_builtin_delete<T>(&vptr_deleter_guard_flag)); vptr.reset(raw_ptr, guarded_builtin_delete<T>(&vptr_deleter_guard_flag));
} }
@ -115,7 +118,7 @@ struct smart_holder {
T* as_raw_ptr_release_ownership( T* as_raw_ptr_release_ownership(
const char* context = "as_raw_ptr_release_ownership") { const char* context = "as_raw_ptr_release_ownership") {
ensure_compatible_rtti_held<T>(context); ensure_compatible_rtti_held<T>(context);
ensure_vptr_deleter_guard_flag_true(context); ensure_vptr_is_using_builtin_delete(context);
ensure_use_count_1(context); ensure_use_count_1(context);
T* raw_ptr = static_cast<T*>(vptr.get()); T* raw_ptr = static_cast<T*>(vptr.get());
vptr_deleter_guard_flag = false; vptr_deleter_guard_flag = false;
@ -135,6 +138,7 @@ struct smart_holder {
clear(); clear();
rtti_held = &typeid(T); rtti_held = &typeid(T);
vptr_deleter_guard_flag = true; vptr_deleter_guard_flag = true;
vptr_is_using_builtin_delete = true;
vptr.reset(unq_ptr.get(), vptr.reset(unq_ptr.get(),
guarded_builtin_delete<T>(&vptr_deleter_guard_flag)); guarded_builtin_delete<T>(&vptr_deleter_guard_flag));
unq_ptr.release(); unq_ptr.release();