diff --git a/luna/include/luna/SharedPtr.h b/luna/include/luna/SharedPtr.h index cdf02fb5..5eb9f918 100644 --- a/luna/include/luna/SharedPtr.h +++ b/luna/include/luna/SharedPtr.h @@ -117,12 +117,17 @@ template Result> make_shared(Args... ar return SharedPtr { ptr, ref_count }; } +// NOTE: ptr is deleted if any of the adopt_shared* functions fail to construct a SharedPtr. template Result> adopt_shared(T* ptr) { using RefCount = __detail::RefCount; + auto guard = make_scope_guard([ptr] { delete ptr; }); + RefCount* const ref_count = TRY(make()); + guard.deactivate(); + return SharedPtr { ptr, ref_count }; } @@ -138,13 +143,7 @@ template Result> adopt_shared_from_owned(OwnedPtr&& T* ptr = other.m_ptr; other.m_ptr = nullptr; - // FIXME: Should the pointee magically vanish on failure? Or go back into the OwnedPtr, even though it's been - // moved... - auto guard = make_scope_guard([&] { delete ptr; }); - const SharedPtr shared_ptr = TRY(adopt_shared(ptr)); - guard.deactivate(); - return shared_ptr; }