mirror of
https://github.com/SerenityOS/serenity.git
synced 2025-01-22 09:21:57 -05:00
AK: Allow creating a MaybeOwned<Superclass> from a MaybeOwned<Subclass>
This commit is contained in:
parent
a72770cdf6
commit
07750774cf
1 changed files with 22 additions and 1 deletions
|
@ -32,6 +32,12 @@ public:
|
|||
MaybeOwned(MaybeOwned&&) = default;
|
||||
MaybeOwned& operator=(MaybeOwned&&) = default;
|
||||
|
||||
template<DerivedFrom<T> U>
|
||||
MaybeOwned(MaybeOwned<U>&& other)
|
||||
: m_handle(downcast<U, T>(move(other.m_handle)))
|
||||
{
|
||||
}
|
||||
|
||||
T* ptr()
|
||||
{
|
||||
if (m_handle.template has<T*>())
|
||||
|
@ -57,7 +63,22 @@ public:
|
|||
bool is_owned() const { return m_handle.template has<NonnullOwnPtr<T>>(); }
|
||||
|
||||
private:
|
||||
Variant<NonnullOwnPtr<T>, T*> m_handle;
|
||||
template<typename F>
|
||||
friend class MaybeOwned;
|
||||
|
||||
template<typename HT>
|
||||
using Handle = Variant<NonnullOwnPtr<HT>, HT*>;
|
||||
|
||||
template<typename U, typename D>
|
||||
Handle<D> downcast(Handle<U>&& variant)
|
||||
{
|
||||
if (variant.template has<U*>())
|
||||
return variant.template get<U*>();
|
||||
else
|
||||
return static_cast<NonnullOwnPtr<T>&&>(move(variant.template get<NonnullOwnPtr<U>>()));
|
||||
}
|
||||
|
||||
Handle<T> m_handle;
|
||||
};
|
||||
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue