refactor(templates): add final specifier for template class

This commit is contained in:
_Redstone_c_ 2022-12-30 19:11:01 +08:00
parent 9368a49806
commit e4d59b9832
8 changed files with 13 additions and 13 deletions

View File

@ -32,7 +32,7 @@ NAMESPACE_PRIVATE_END
* An object of class any stores an instance of any type that satisfies the constructor requirements or is empty, * An object of class any stores an instance of any type that satisfies the constructor requirements or is empty,
* and this is referred to as the state of the class any object. The stored instance is called the contained object. * and this is referred to as the state of the class any object. The stored instance is called the contained object.
*/ */
class alignas(16) FAny class alignas(16) FAny final
{ {
public: public:

View File

@ -287,10 +287,10 @@ NAMESPACE_PRIVATE_END
template <typename T> requires (CTriviallyCopyable<T> template <typename T> requires (CTriviallyCopyable<T>
&& CCopyConstructible<T> && CMoveConstructible<T> && CCopyConstructible<T> && CMoveConstructible<T>
&& CCopyAssignable<T> && CMoveAssignable<T>) && CCopyAssignable<T> && CMoveAssignable<T>)
struct TAtomic : STRONG_INHERIT(NAMESPACE_PRIVATE::TAtomicImpl<T, false>); struct TAtomic final : STRONG_INHERIT(NAMESPACE_PRIVATE::TAtomicImpl<T, false>);
template <typename T> requires (CTriviallyCopyable<T>) template <typename T> requires (CTriviallyCopyable<T>)
struct TAtomicRef : STRONG_INHERIT(NAMESPACE_PRIVATE::TAtomicImpl<T, true>); struct TAtomicRef final : STRONG_INHERIT(NAMESPACE_PRIVATE::TAtomicImpl<T, true>);
template <typename T> template <typename T>
TAtomic(T) -> TAtomic<T>; TAtomic(T) -> TAtomic<T>;
@ -304,7 +304,7 @@ static_assert(sizeof(TAtomic<int32>) == sizeof(int32), "The byte size of TAtomic
* FAtomicFlag is an atomic boolean type. Unlike all specializations of TAtomic, it is guaranteed to be lock-free. * FAtomicFlag is an atomic boolean type. Unlike all specializations of TAtomic, it is guaranteed to be lock-free.
* Unlike TAtomic<bool>, FAtomicFlag does not provide load or store operations. * Unlike TAtomic<bool>, FAtomicFlag does not provide load or store operations.
*/ */
struct FAtomicFlag : FSingleton struct FAtomicFlag final : FSingleton
{ {
public: public:

View File

@ -549,7 +549,7 @@ NAMESPACE_PRIVATE_END
* without making it a template. * without making it a template.
*/ */
template <CFunction F> template <CFunction F>
class TFunctionRef class TFunctionRef final
: public NAMESPACE_PRIVATE::TFunctionImpl< : public NAMESPACE_PRIVATE::TFunctionImpl<
typename NAMESPACE_PRIVATE::TFunctionInfo<F>::Fn, typename NAMESPACE_PRIVATE::TFunctionInfo<F>::Fn,
typename NAMESPACE_PRIVATE::TFunctionInfo<F>::CVRef, typename NAMESPACE_PRIVATE::TFunctionInfo<F>::CVRef,
@ -599,7 +599,7 @@ public:
* objects without caring about the lifetime of the original object being bound. * objects without caring about the lifetime of the original object being bound.
*/ */
template <CFunction F> template <CFunction F>
class TFunction class TFunction final
: public NAMESPACE_PRIVATE::TFunctionImpl< : public NAMESPACE_PRIVATE::TFunctionImpl<
typename NAMESPACE_PRIVATE::TFunctionInfo<F>::Fn, typename NAMESPACE_PRIVATE::TFunctionInfo<F>::Fn,
typename NAMESPACE_PRIVATE::TFunctionInfo<F>::CVRef, typename NAMESPACE_PRIVATE::TFunctionInfo<F>::CVRef,
@ -698,7 +698,7 @@ public:
* objects without caring about the lifetime of the original object being bound. * objects without caring about the lifetime of the original object being bound.
*/ */
template <CFunction F> template <CFunction F>
class TUniqueFunction class TUniqueFunction final
: public NAMESPACE_PRIVATE::TFunctionImpl< : public NAMESPACE_PRIVATE::TFunctionImpl<
typename NAMESPACE_PRIVATE::TFunctionInfo<F>::Fn, typename NAMESPACE_PRIVATE::TFunctionInfo<F>::Fn,
typename NAMESPACE_PRIVATE::TFunctionInfo<F>::CVRef, typename NAMESPACE_PRIVATE::TFunctionInfo<F>::CVRef,

View File

@ -40,7 +40,7 @@ template <typename T> concept CTOptional = NAMESPACE_PRIVATE::TIsTOptional<TRemo
/** The class template manages an optional contained value, i.e. a value that may or may not be present. */ /** The class template manages an optional contained value, i.e. a value that may or may not be present. */
template <typename OptionalType> requires (CDestructible<OptionalType>) template <typename OptionalType> requires (CDestructible<OptionalType>)
class TOptional class TOptional final
{ {
public: public:

View File

@ -16,7 +16,7 @@ NAMESPACE_MODULE_BEGIN(Utility)
* containers which cannot normally hold references. * containers which cannot normally hold references.
*/ */
template <typename ReferencedType> requires (CObject<ReferencedType> || CFunction<ReferencedType>) template <typename ReferencedType> requires (CObject<ReferencedType> || CFunction<ReferencedType>)
class TReferenceWrapper class TReferenceWrapper final
{ {
public: public:

View File

@ -292,7 +292,7 @@ template <size_t I, CTTuple U>
using TTupleElement = TCopyCV<U, typename NAMESPACE_PRIVATE::TTupleElementImpl<I, TRemoveCV<U>>::Type>; using TTupleElement = TCopyCV<U, typename NAMESPACE_PRIVATE::TTupleElementImpl<I, TRemoveCV<U>>::Type>;
template <typename... Ts> template <typename... Ts>
class TTuple : public NAMESPACE_PRIVATE::TTupleImpl<TIndexSequenceFor<Ts...>, Ts...> class TTuple final : public NAMESPACE_PRIVATE::TTupleImpl<TIndexSequenceFor<Ts...>, Ts...>
{ {
private: private:

View File

@ -107,7 +107,7 @@ FORCEINLINE constexpr T* AddressOf(T& Object)
template <typename T> template <typename T>
const T* AddressOf(const T&&) = delete; const T* AddressOf(const T&&) = delete;
struct FIgnore struct FIgnore final
{ {
template <typename T> template <typename T>
FORCEINLINE constexpr void operator=(T&&) const { } FORCEINLINE constexpr void operator=(T&&) const { }
@ -145,7 +145,7 @@ inline constexpr FIgnore Ignore;
* }, Target); * }, Target);
*/ */
template <typename... Ts> template <typename... Ts>
struct TOverloaded : Ts... struct TOverloaded final : Ts...
{ {
using Ts::operator()...; using Ts::operator()...;
}; };

View File

@ -84,7 +84,7 @@ using TVariantAlternative = TCopyCV<U, typename NAMESPACE_PRIVATE::TVariantAlter
* holds a value of one of its alternative types, or in the case of invalid - no value. * holds a value of one of its alternative types, or in the case of invalid - no value.
*/ */
template <typename... Ts> requires (sizeof...(Ts) > 0 && (true && ... && CDestructible<Ts>)) template <typename... Ts> requires (sizeof...(Ts) > 0 && (true && ... && CDestructible<Ts>))
class TVariant class TVariant final
{ {
public: public: