fix(templates): fix FNoncopyable to satisfy the CMovable concept

This commit is contained in:
_Redstone_c_ 2023-02-17 23:31:24 +08:00
parent bae95fa438
commit f521c2b5d5
1 changed files with 13 additions and 9 deletions

View File

@ -9,17 +9,21 @@ NAMESPACE_MODULE_BEGIN(Utility)
/** A class indicates that a derived class cannot be copied. */
struct FNoncopyable
{
FNoncopyable() = default;
FNoncopyable(const FNoncopyable&) = delete;
FNoncopyable() = default;
FNoncopyable(const FNoncopyable&) = delete;
FNoncopyable(FNoncopyable&&) = default;
FNoncopyable& operator=(const FNoncopyable&) = delete;
FNoncopyable& operator=(FNoncopyable&&) = default;
};
/** A class indicates that a derived class cannot be moved. */
struct FNonmovable
{
FNonmovable() = default;
FNonmovable(FNonmovable&&) = delete;
FNonmovable& operator=(FNonmovable&&) = delete;
FNonmovable() = default;
FNonmovable(const FNonmovable&) = default;
FNonmovable(FNonmovable&&) = delete;
FNonmovable& operator=(const FNonmovable&) = default;
FNonmovable& operator=(FNonmovable&&) = delete;
};
/** A class indicates that a derived class cannot be copied or moved. */
@ -27,11 +31,11 @@ struct FSingleton // : FNoncopyable, FNonmovable
{
// NOTE: Multiple inheritance is no longer used here, as that would break the EBO in MSVC
FSingleton() = default;
FSingleton(const FSingleton&) = delete;
FSingleton(FSingleton&&) = delete;
FSingleton() = default;
FSingleton(const FSingleton&) = delete;
FSingleton(FSingleton&&) = delete;
FSingleton& operator=(const FSingleton&) = delete;
FSingleton& operator=(FSingleton&&) = delete;
FSingleton& operator=(FSingleton&&) = delete;
};
NAMESPACE_MODULE_END(Utility)