refactor(typetraits): replaces template class type traits with concepts for TypeTraits/SupportedOperations.h
This commit is contained in:
parent
c316b8f190
commit
413762a90a
@ -58,12 +58,6 @@ void TestConcepts()
|
|||||||
always_check(!(CSameAs<int32, int64>));
|
always_check(!(CSameAs<int32, int64>));
|
||||||
always_check((CSameAs<int32, int32>));
|
always_check((CSameAs<int32, int32>));
|
||||||
|
|
||||||
// Destructible.h
|
|
||||||
|
|
||||||
always_check(CDestructible<FTestStructS>);
|
|
||||||
always_check(CDestructible<FTestStructT>);
|
|
||||||
always_check(!CDestructible<FTestStructU>);
|
|
||||||
|
|
||||||
// Derived.h
|
// Derived.h
|
||||||
|
|
||||||
always_check(!(CDerivedFrom<FTestStructH, FTestStructD>));
|
always_check(!(CDerivedFrom<FTestStructH, FTestStructD>));
|
||||||
@ -78,27 +72,6 @@ void TestConcepts()
|
|||||||
always_check(!(CConvertibleTo<FTestStructE*, FTestStructH*>));
|
always_check(!(CConvertibleTo<FTestStructE*, FTestStructH*>));
|
||||||
always_check((CConvertibleTo<FTestStructW, FTestStructV>));
|
always_check((CConvertibleTo<FTestStructW, FTestStructV>));
|
||||||
|
|
||||||
// Constructible.h
|
|
||||||
|
|
||||||
always_check((CConstructibleFrom<FTestStructJ>));
|
|
||||||
always_check((CConstructibleFrom<FTestStructK>));
|
|
||||||
always_check(!(CConstructibleFrom<FTestStructI, int32>));
|
|
||||||
always_check((CConstructibleFrom<FTestStructI, FTestStructI&>));
|
|
||||||
always_check((CConstructibleFrom<FTestStructI, int32, double>));
|
|
||||||
|
|
||||||
always_check(!CDefaultInitializable<FTestStructI>);
|
|
||||||
always_check(CDefaultInitializable<FTestStructJ>);
|
|
||||||
always_check(CDefaultInitializable<FTestStructK>);
|
|
||||||
always_check(!CDefaultInitializable<FTestStructL>);
|
|
||||||
|
|
||||||
always_check(CMoveConstructible<FTestStructP>);
|
|
||||||
always_check(CMoveConstructible<FTestStructQ>);
|
|
||||||
always_check(!CMoveConstructible<FTestStructR>);
|
|
||||||
|
|
||||||
always_check(CCopyConstructible<FTestStructM>);
|
|
||||||
always_check(CCopyConstructible<FTestStructN>);
|
|
||||||
always_check(!CCopyConstructible<FTestStructO>);
|
|
||||||
|
|
||||||
// BooleanTestable.h
|
// BooleanTestable.h
|
||||||
|
|
||||||
always_check(CBooleanTestable<bool>);
|
always_check(CBooleanTestable<bool>);
|
||||||
@ -106,14 +79,6 @@ void TestConcepts()
|
|||||||
always_check(CBooleanTestable<float>);
|
always_check(CBooleanTestable<float>);
|
||||||
always_check(!CBooleanTestable<FTestStructA>);
|
always_check(!CBooleanTestable<FTestStructA>);
|
||||||
|
|
||||||
// Assignable.h
|
|
||||||
|
|
||||||
always_check((CAssignableFrom<int32&, int64>));
|
|
||||||
always_check((CAssignableFrom<int32&, int32>));
|
|
||||||
always_check((CAssignableFrom<int32&, int8>));
|
|
||||||
always_check(!(CAssignableFrom<FTestStructI&, int32>));
|
|
||||||
always_check(!(CAssignableFrom<FTestStructA&, void>));
|
|
||||||
|
|
||||||
// Common.h
|
// Common.h
|
||||||
|
|
||||||
always_check((CCommonWith<int32, int32>));
|
always_check((CCommonWith<int32, int32>));
|
||||||
|
@ -744,20 +744,20 @@ void TestTuple()
|
|||||||
Temp.Fifteenth = 0;
|
Temp.Fifteenth = 0;
|
||||||
Temp.Sixteenth = 0;
|
Temp.Sixteenth = 0;
|
||||||
|
|
||||||
always_check(TIsDefaultConstructible<Type>::Value);
|
always_check(CDefaultConstructible<Type>);
|
||||||
always_check(TIsTriviallyDefaultConstructible<Type>::Value);
|
always_check(CTriviallyDefaultConstructible<Type>);
|
||||||
always_check(TIsConstructible<Type>::Value);
|
always_check(CConstructible<Type>);
|
||||||
always_check(TIsTriviallyConstructible<Type>::Value);
|
always_check(CTriviallyConstructible<Type>);
|
||||||
always_check(TIsCopyConstructible<Type>::Value);
|
always_check(CCopyConstructible<Type>);
|
||||||
always_check(TIsTriviallyCopyConstructible<Type>::Value);
|
always_check(CTriviallyCopyConstructible<Type>);
|
||||||
always_check(TIsMoveConstructible<Type>::Value);
|
always_check(CMoveConstructible<Type>);
|
||||||
always_check(TIsTriviallyMoveConstructible<Type>::Value);
|
always_check(CTriviallyMoveConstructible<Type>);
|
||||||
always_check(TIsCopyAssignable<Type>::Value);
|
always_check(CCopyAssignable<Type>);
|
||||||
always_check(TIsTriviallyCopyAssignable<Type>::Value);
|
always_check(CTriviallyCopyAssignable<Type>);
|
||||||
always_check(TIsMoveAssignable<Type>::Value);
|
always_check(CMoveAssignable<Type>);
|
||||||
always_check(TIsTriviallyMoveAssignable<Type>::Value);
|
always_check(CTriviallyMoveAssignable<Type>);
|
||||||
always_check(TIsDestructible<Type>::Value);
|
always_check(CDestructible<Type>);
|
||||||
always_check(TIsTriviallyDestructible<Type>::Value);
|
always_check(CTriviallyDestructible<Type>);
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
|
@ -230,74 +230,74 @@ void TestTypeTraits()
|
|||||||
|
|
||||||
// SupportedOperations.h
|
// SupportedOperations.h
|
||||||
|
|
||||||
always_check(!TIsDefaultConstructible<FTestStructI>::Value);
|
always_check(!CDefaultConstructible<FTestStructI>);
|
||||||
always_check(TIsDefaultConstructible<FTestStructJ>::Value);
|
always_check(CDefaultConstructible<FTestStructJ>);
|
||||||
always_check(TIsDefaultConstructible<FTestStructK>::Value);
|
always_check(CDefaultConstructible<FTestStructK>);
|
||||||
always_check(!TIsDefaultConstructible<FTestStructL>::Value);
|
always_check(!CDefaultConstructible<FTestStructL>);
|
||||||
|
|
||||||
always_check(!TIsTriviallyDefaultConstructible<FTestStructI>::Value);
|
always_check(!CTriviallyDefaultConstructible<FTestStructI>);
|
||||||
always_check(!TIsTriviallyDefaultConstructible<FTestStructJ>::Value);
|
always_check(!CTriviallyDefaultConstructible<FTestStructJ>);
|
||||||
always_check(TIsTriviallyDefaultConstructible<FTestStructK>::Value);
|
always_check(CTriviallyDefaultConstructible<FTestStructK>);
|
||||||
always_check(!TIsTriviallyDefaultConstructible<FTestStructL>::Value);
|
always_check(!CTriviallyDefaultConstructible<FTestStructL>);
|
||||||
|
|
||||||
always_check(!(TIsConstructible<FTestStructI, int32>::Value));
|
always_check(!(CConstructible<FTestStructI, int32>));
|
||||||
always_check((TIsConstructible<FTestStructI, FTestStructI&>::Value));
|
always_check((CConstructible<FTestStructI, FTestStructI&>));
|
||||||
always_check((TIsConstructible<FTestStructI, int32, double>::Value));
|
always_check((CConstructible<FTestStructI, int32, double>));
|
||||||
|
|
||||||
always_check(!(TIsTriviallyConstructible<FTestStructI, int32>::Value));
|
always_check(!(CTriviallyConstructible<FTestStructI, int32>));
|
||||||
always_check((TIsTriviallyConstructible<FTestStructI, FTestStructI&>::Value));
|
always_check((CTriviallyConstructible<FTestStructI, FTestStructI&>));
|
||||||
always_check(!(TIsTriviallyConstructible<FTestStructI, int32, double>::Value));
|
always_check(!(CTriviallyConstructible<FTestStructI, int32, double>));
|
||||||
|
|
||||||
always_check(TIsCopyConstructible<FTestStructM>::Value);
|
always_check(CCopyConstructible<FTestStructM>);
|
||||||
always_check(TIsCopyConstructible<FTestStructN>::Value);
|
always_check(CCopyConstructible<FTestStructN>);
|
||||||
always_check(!TIsCopyConstructible<FTestStructO>::Value);
|
always_check(!CCopyConstructible<FTestStructO>);
|
||||||
|
|
||||||
always_check(!TIsTriviallyCopyConstructible<FTestStructM>::Value);
|
always_check(!CTriviallyCopyConstructible<FTestStructM>);
|
||||||
always_check(TIsTriviallyCopyConstructible<FTestStructN>::Value);
|
always_check(CTriviallyCopyConstructible<FTestStructN>);
|
||||||
always_check(!TIsTriviallyCopyConstructible<FTestStructO>::Value);
|
always_check(!CTriviallyCopyConstructible<FTestStructO>);
|
||||||
|
|
||||||
always_check(TIsMoveConstructible<FTestStructP>::Value);
|
always_check(CMoveConstructible<FTestStructP>);
|
||||||
always_check(TIsMoveConstructible<FTestStructQ>::Value);
|
always_check(CMoveConstructible<FTestStructQ>);
|
||||||
always_check(!TIsMoveConstructible<FTestStructR>::Value);
|
always_check(!CMoveConstructible<FTestStructR>);
|
||||||
|
|
||||||
always_check(!TIsTriviallyMoveConstructible<FTestStructP>::Value);
|
always_check(!CTriviallyMoveConstructible<FTestStructP>);
|
||||||
always_check(TIsTriviallyMoveConstructible<FTestStructQ>::Value);
|
always_check(CTriviallyMoveConstructible<FTestStructQ>);
|
||||||
always_check(!TIsTriviallyMoveConstructible<FTestStructR>::Value);
|
always_check(!CTriviallyMoveConstructible<FTestStructR>);
|
||||||
|
|
||||||
always_check(!(TIsAssignable<FTestStructI, FTestStructH>::Value));
|
always_check(!(CAssignable<FTestStructI, FTestStructH>));
|
||||||
always_check((TIsAssignable<FTestStructI, FTestStructI&>::Value));
|
always_check((CAssignable<FTestStructI, FTestStructI&>));
|
||||||
always_check((TIsAssignable<FTestStructI, int32>::Value));
|
always_check((CAssignable<FTestStructI, int32>));
|
||||||
|
|
||||||
always_check(!(TIsTriviallyAssignable<FTestStructI, FTestStructH>::Value));
|
always_check(!(CTriviallyAssignable<FTestStructI, FTestStructH>));
|
||||||
always_check((TIsTriviallyAssignable<FTestStructI, FTestStructI&>::Value));
|
always_check((CTriviallyAssignable<FTestStructI, FTestStructI&>));
|
||||||
always_check(!(TIsTriviallyAssignable<FTestStructI, int32>::Value));
|
always_check(!(CTriviallyAssignable<FTestStructI, int32>));
|
||||||
|
|
||||||
always_check(TIsCopyAssignable<FTestStructM>::Value);
|
always_check(CCopyAssignable<FTestStructM>);
|
||||||
always_check(TIsCopyAssignable<FTestStructN>::Value);
|
always_check(CCopyAssignable<FTestStructN>);
|
||||||
always_check(!TIsCopyAssignable<FTestStructO>::Value);
|
always_check(!CCopyAssignable<FTestStructO>);
|
||||||
|
|
||||||
always_check(!TIsTriviallyCopyAssignable<FTestStructM>::Value);
|
always_check(!CTriviallyCopyAssignable<FTestStructM>);
|
||||||
always_check(TIsTriviallyCopyAssignable<FTestStructN>::Value);
|
always_check(CTriviallyCopyAssignable<FTestStructN>);
|
||||||
always_check(!TIsTriviallyCopyAssignable<FTestStructO>::Value);
|
always_check(!CTriviallyCopyAssignable<FTestStructO>);
|
||||||
|
|
||||||
always_check(TIsMoveAssignable<FTestStructP>::Value);
|
always_check(CMoveAssignable<FTestStructP>);
|
||||||
always_check(TIsMoveAssignable<FTestStructQ>::Value);
|
always_check(CMoveAssignable<FTestStructQ>);
|
||||||
always_check(!TIsMoveAssignable<FTestStructR>::Value);
|
always_check(!CMoveAssignable<FTestStructR>);
|
||||||
|
|
||||||
always_check(!TIsTriviallyMoveAssignable<FTestStructP>::Value);
|
always_check(!CTriviallyMoveAssignable<FTestStructP>);
|
||||||
always_check(TIsTriviallyMoveAssignable<FTestStructQ>::Value);
|
always_check(CTriviallyMoveAssignable<FTestStructQ>);
|
||||||
always_check(!TIsTriviallyMoveAssignable<FTestStructR>::Value);
|
always_check(!CTriviallyMoveAssignable<FTestStructR>);
|
||||||
|
|
||||||
always_check(TIsDestructible<FTestStructS>::Value);
|
always_check(CDestructible<FTestStructS>);
|
||||||
always_check(TIsDestructible<FTestStructT>::Value);
|
always_check(CDestructible<FTestStructT>);
|
||||||
always_check(!TIsDestructible<FTestStructU>::Value);
|
always_check(!CDestructible<FTestStructU>);
|
||||||
|
|
||||||
always_check(!TIsTriviallyDestructible<FTestStructS>::Value);
|
always_check(!CTriviallyDestructible<FTestStructS>);
|
||||||
always_check(TIsTriviallyDestructible<FTestStructT>::Value);
|
always_check(CTriviallyDestructible<FTestStructT>);
|
||||||
always_check(!TIsTriviallyDestructible<FTestStructU>::Value);
|
always_check(!CTriviallyDestructible<FTestStructU>);
|
||||||
|
|
||||||
always_check(!THasVirtualDestructor<FTestStructT>::Value);
|
always_check(!CVirtualDestructible<FTestStructT>);
|
||||||
always_check(THasVirtualDestructor<FTestStructV>::Value);
|
always_check(CVirtualDestructible<FTestStructV>);
|
||||||
|
|
||||||
// Miscellaneous.h
|
// Miscellaneous.h
|
||||||
|
|
||||||
|
@ -12,20 +12,11 @@ NAMESPACE_MODULE_BEGIN(Redcraft)
|
|||||||
NAMESPACE_MODULE_BEGIN(Utility)
|
NAMESPACE_MODULE_BEGIN(Utility)
|
||||||
|
|
||||||
template <typename T, typename... Args>
|
template <typename T, typename... Args>
|
||||||
concept CConstructibleFrom = CDestructible<T> && TIsConstructible<T, Args...>::Value;
|
concept CConstructibleFrom = CDestructible<T> && CConstructible<T, Args...>;
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
concept CDefaultInitializable = CConstructibleFrom<T> && requires { T{}; ::new(static_cast<void*>(nullptr)) T; };
|
concept CDefaultInitializable = CConstructibleFrom<T> && requires { T{}; ::new(static_cast<void*>(nullptr)) T; };
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
concept CMoveConstructible = CConstructibleFrom<T, T> && CConvertibleTo<T, T>;
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
concept CCopyConstructible = CMoveConstructible<T> &&
|
|
||||||
CConstructibleFrom<T, T&> && CConvertibleTo<T&, T> &&
|
|
||||||
CConstructibleFrom<T, const T&> && CConvertibleTo<const T&, T> &&
|
|
||||||
CConstructibleFrom<T, const T> && CConvertibleTo<const T, T>;
|
|
||||||
|
|
||||||
NAMESPACE_MODULE_END(Utility)
|
NAMESPACE_MODULE_END(Utility)
|
||||||
NAMESPACE_MODULE_END(Redcraft)
|
NAMESPACE_MODULE_END(Redcraft)
|
||||||
NAMESPACE_REDCRAFT_END
|
NAMESPACE_REDCRAFT_END
|
||||||
|
@ -7,9 +7,6 @@ NAMESPACE_REDCRAFT_BEGIN
|
|||||||
NAMESPACE_MODULE_BEGIN(Redcraft)
|
NAMESPACE_MODULE_BEGIN(Redcraft)
|
||||||
NAMESPACE_MODULE_BEGIN(Utility)
|
NAMESPACE_MODULE_BEGIN(Utility)
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
concept CDestructible = TIsDestructible<T>::Value;
|
|
||||||
|
|
||||||
NAMESPACE_MODULE_END(Utility)
|
NAMESPACE_MODULE_END(Utility)
|
||||||
NAMESPACE_MODULE_END(Redcraft)
|
NAMESPACE_MODULE_END(Redcraft)
|
||||||
NAMESPACE_REDCRAFT_END
|
NAMESPACE_REDCRAFT_END
|
||||||
|
@ -13,7 +13,7 @@ NAMESPACE_MODULE_BEGIN(Utility)
|
|||||||
NAMESPACE_BEGIN(Memory)
|
NAMESPACE_BEGIN(Memory)
|
||||||
|
|
||||||
template <typename ElementType>
|
template <typename ElementType>
|
||||||
requires TIsDefaultConstructible<ElementType>::Value
|
requires CDefaultConstructible<ElementType>
|
||||||
FORCEINLINE void DefaultConstruct(ElementType* Address, size_t Count = 1)
|
FORCEINLINE void DefaultConstruct(ElementType* Address, size_t Count = 1)
|
||||||
{
|
{
|
||||||
if constexpr (TIsZeroConstructible<ElementType>::Value)
|
if constexpr (TIsZeroConstructible<ElementType>::Value)
|
||||||
@ -33,7 +33,7 @@ FORCEINLINE void DefaultConstruct(ElementType* Address, size_t Count = 1)
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename DestinationElementType, typename SourceElementType>
|
template <typename DestinationElementType, typename SourceElementType>
|
||||||
requires TIsConstructible<DestinationElementType, const SourceElementType&>::Value
|
requires CConstructible<DestinationElementType, const SourceElementType&>
|
||||||
FORCEINLINE void Construct(DestinationElementType* Destination, const SourceElementType* Source, size_t Count = 1)
|
FORCEINLINE void Construct(DestinationElementType* Destination, const SourceElementType* Source, size_t Count = 1)
|
||||||
{
|
{
|
||||||
if constexpr (TIsBitwiseConstructible<DestinationElementType, const SourceElementType>::Value)
|
if constexpr (TIsBitwiseConstructible<DestinationElementType, const SourceElementType>::Value)
|
||||||
@ -53,10 +53,10 @@ FORCEINLINE void Construct(DestinationElementType* Destination, const SourceElem
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename ElementType>
|
template <typename ElementType>
|
||||||
requires TIsCopyConstructible<ElementType>::Value
|
requires CCopyConstructible<ElementType>
|
||||||
FORCEINLINE void CopyConstruct(ElementType* Destination, const ElementType* Source, size_t Count = 1)
|
FORCEINLINE void CopyConstruct(ElementType* Destination, const ElementType* Source, size_t Count = 1)
|
||||||
{
|
{
|
||||||
if constexpr (TIsTriviallyCopyConstructible<ElementType>::Value)
|
if constexpr (CTriviallyCopyConstructible<ElementType>)
|
||||||
{
|
{
|
||||||
Memory::Memcpy(Destination, Source, sizeof(ElementType) * Count);
|
Memory::Memcpy(Destination, Source, sizeof(ElementType) * Count);
|
||||||
}
|
}
|
||||||
@ -73,10 +73,10 @@ FORCEINLINE void CopyConstruct(ElementType* Destination, const ElementType* Sour
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename ElementType>
|
template <typename ElementType>
|
||||||
requires TIsMoveConstructible<ElementType>::Value
|
requires CMoveConstructible<ElementType>
|
||||||
FORCEINLINE void MoveConstruct(ElementType* Destination, ElementType* Source, size_t Count = 1)
|
FORCEINLINE void MoveConstruct(ElementType* Destination, ElementType* Source, size_t Count = 1)
|
||||||
{
|
{
|
||||||
if constexpr (TIsTriviallyMoveConstructible<ElementType>::Value)
|
if constexpr (CTriviallyMoveConstructible<ElementType>)
|
||||||
{
|
{
|
||||||
Memory::Memmove(Destination, Source, sizeof(ElementType) * Count);
|
Memory::Memmove(Destination, Source, sizeof(ElementType) * Count);
|
||||||
}
|
}
|
||||||
@ -93,7 +93,7 @@ FORCEINLINE void MoveConstruct(ElementType* Destination, ElementType* Source, si
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename DestinationElementType, typename SourceElementType>
|
template <typename DestinationElementType, typename SourceElementType>
|
||||||
requires TIsConstructible<DestinationElementType, SourceElementType&&>::Value && TIsDestructible<SourceElementType>::Value
|
requires CConstructible<DestinationElementType, SourceElementType&&> && CDestructible<SourceElementType>
|
||||||
FORCEINLINE void RelocateConstruct(DestinationElementType* Destination, SourceElementType* Source, size_t Count = 1)
|
FORCEINLINE void RelocateConstruct(DestinationElementType* Destination, SourceElementType* Source, size_t Count = 1)
|
||||||
{
|
{
|
||||||
if constexpr (TIsBitwiseRelocatable<DestinationElementType, SourceElementType>::Value)
|
if constexpr (TIsBitwiseRelocatable<DestinationElementType, SourceElementType>::Value)
|
||||||
@ -115,10 +115,10 @@ FORCEINLINE void RelocateConstruct(DestinationElementType* Destination, SourceEl
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename ElementType>
|
template <typename ElementType>
|
||||||
requires TIsDestructible<ElementType>::Value
|
requires CDestructible<ElementType>
|
||||||
FORCEINLINE void Destruct(ElementType* Element, size_t Count = 1)
|
FORCEINLINE void Destruct(ElementType* Element, size_t Count = 1)
|
||||||
{
|
{
|
||||||
if constexpr (!TIsTriviallyDestructible<ElementType>::Value)
|
if constexpr (!CTriviallyDestructible<ElementType>)
|
||||||
{
|
{
|
||||||
while (Count)
|
while (Count)
|
||||||
{
|
{
|
||||||
@ -130,10 +130,10 @@ FORCEINLINE void Destruct(ElementType* Element, size_t Count = 1)
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename ElementType>
|
template <typename ElementType>
|
||||||
requires TIsCopyAssignable<ElementType>::Value
|
requires CCopyAssignable<ElementType>
|
||||||
FORCEINLINE void CopyAssign(ElementType* Destination, const ElementType* Source, size_t Count = 1)
|
FORCEINLINE void CopyAssign(ElementType* Destination, const ElementType* Source, size_t Count = 1)
|
||||||
{
|
{
|
||||||
if constexpr (TIsTriviallyCopyAssignable<ElementType>::Value)
|
if constexpr (CTriviallyCopyAssignable<ElementType>)
|
||||||
{
|
{
|
||||||
Memory::Memcpy(Destination, Source, sizeof(ElementType) * Count);
|
Memory::Memcpy(Destination, Source, sizeof(ElementType) * Count);
|
||||||
}
|
}
|
||||||
@ -150,10 +150,10 @@ FORCEINLINE void CopyAssign(ElementType* Destination, const ElementType* Source,
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename ElementType>
|
template <typename ElementType>
|
||||||
requires TIsMoveAssignable<ElementType>::Value
|
requires CMoveAssignable<ElementType>
|
||||||
FORCEINLINE void MoveAssign(ElementType* Destination, ElementType* Source, size_t Count = 1)
|
FORCEINLINE void MoveAssign(ElementType* Destination, ElementType* Source, size_t Count = 1)
|
||||||
{
|
{
|
||||||
if constexpr (TIsTriviallyCopyConstructible<ElementType>::Value)
|
if constexpr (CTriviallyCopyConstructible<ElementType>)
|
||||||
{
|
{
|
||||||
Memory::Memmove(Destination, Source, sizeof(ElementType) * Count);
|
Memory::Memmove(Destination, Source, sizeof(ElementType) * Count);
|
||||||
}
|
}
|
||||||
|
@ -68,8 +68,8 @@ struct alignas(InlineAlignment) TAny
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T, typename... Types> requires TIsDestructible<typename TDecay<T>::Type>::Value
|
template <typename T, typename... Types> requires CDestructible<typename TDecay<T>::Type>
|
||||||
&& TIsConstructible<typename TDecay<T>::Type, Types...>::Value
|
&& CConstructible<typename TDecay<T>::Type, Types...>
|
||||||
FORCEINLINE explicit TAny(TInPlaceType<T>, Types&&... Args)
|
FORCEINLINE explicit TAny(TInPlaceType<T>, Types&&... Args)
|
||||||
{
|
{
|
||||||
using SelectedType = typename TDecay<T>::Type;
|
using SelectedType = typename TDecay<T>::Type;
|
||||||
@ -77,7 +77,7 @@ struct alignas(InlineAlignment) TAny
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> requires (!TIsSame<typename TDecay<T>::Type, TAny>::Value) && (!TIsTInPlaceType<typename TDecay<T>::Type>::Value)
|
template <typename T> requires (!TIsSame<typename TDecay<T>::Type, TAny>::Value) && (!TIsTInPlaceType<typename TDecay<T>::Type>::Value)
|
||||||
&& TIsDestructible<typename TDecay<T>::Type>::Value && TIsConstructible<typename TDecay<T>::Type, T&&>::Value
|
&& CDestructible<typename TDecay<T>::Type> && CConstructible<typename TDecay<T>::Type, T&&>
|
||||||
FORCEINLINE TAny(T&& InValue) : TAny(InPlaceType<typename TDecay<T>::Type>, Forward<T>(InValue))
|
FORCEINLINE TAny(T&& InValue) : TAny(InPlaceType<typename TDecay<T>::Type>, Forward<T>(InValue))
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
@ -185,7 +185,7 @@ struct alignas(InlineAlignment) TAny
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> requires (!TIsSame<typename TDecay<T>::Type, TAny>::Value) && (!TIsTInPlaceType<typename TDecay<T>::Type>::Value)
|
template <typename T> requires (!TIsSame<typename TDecay<T>::Type, TAny>::Value) && (!TIsTInPlaceType<typename TDecay<T>::Type>::Value)
|
||||||
&& TIsDestructible<typename TDecay<T>::Type>::Value && TIsConstructible<typename TDecay<T>::Type, T&&>::Value
|
&& CDestructible<typename TDecay<T>::Type> && CConstructible<typename TDecay<T>::Type, T&&>
|
||||||
FORCEINLINE TAny& operator=(T&& InValue)
|
FORCEINLINE TAny& operator=(T&& InValue)
|
||||||
{
|
{
|
||||||
using SelectedType = typename TDecay<T>::Type;
|
using SelectedType = typename TDecay<T>::Type;
|
||||||
@ -203,8 +203,8 @@ struct alignas(InlineAlignment) TAny
|
|||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T, typename... Types> requires TIsDestructible<typename TDecay<T>::Type>::Value
|
template <typename T, typename... Types> requires CDestructible<typename TDecay<T>::Type>
|
||||||
&& TIsConstructible<typename TDecay<T>::Type, T&&>::Value
|
&& CConstructible<typename TDecay<T>::Type, T&&>
|
||||||
FORCEINLINE typename TDecay<T>::Type& Emplace(Types&&... Args)
|
FORCEINLINE typename TDecay<T>::Type& Emplace(Types&&... Args)
|
||||||
{
|
{
|
||||||
ResetImpl();
|
ResetImpl();
|
||||||
@ -221,22 +221,22 @@ struct alignas(InlineAlignment) TAny
|
|||||||
|
|
||||||
template <typename T> constexpr bool HoldsAlternative() const { return IsValid() ? GetTypeInfo() == typeid(T) : false; }
|
template <typename T> constexpr bool HoldsAlternative() const { return IsValid() ? GetTypeInfo() == typeid(T) : false; }
|
||||||
|
|
||||||
template <typename T> requires TIsDestructible<typename TDecay<T>::Type>::Value
|
template <typename T> requires CDestructible<typename TDecay<T>::Type>
|
||||||
constexpr T& GetValue() & { checkf(HoldsAlternative<T>(), TEXT("It is an error to call GetValue() on an wrong TAny. Please either check HoldsAlternative() or use Get(DefaultValue) instead.")); return *reinterpret_cast< T*>(GetAllocation()); }
|
constexpr T& GetValue() & { checkf(HoldsAlternative<T>(), TEXT("It is an error to call GetValue() on an wrong TAny. Please either check HoldsAlternative() or use Get(DefaultValue) instead.")); return *reinterpret_cast< T*>(GetAllocation()); }
|
||||||
|
|
||||||
template <typename T> requires TIsDestructible<typename TDecay<T>::Type>::Value
|
template <typename T> requires CDestructible<typename TDecay<T>::Type>
|
||||||
constexpr T&& GetValue() && { checkf(HoldsAlternative<T>(), TEXT("It is an error to call GetValue() on an wrong TAny. Please either check HoldsAlternative() or use Get(DefaultValue) instead.")); return MoveTemp(*reinterpret_cast< T*>(GetAllocation())); }
|
constexpr T&& GetValue() && { checkf(HoldsAlternative<T>(), TEXT("It is an error to call GetValue() on an wrong TAny. Please either check HoldsAlternative() or use Get(DefaultValue) instead.")); return MoveTemp(*reinterpret_cast< T*>(GetAllocation())); }
|
||||||
|
|
||||||
template <typename T> requires TIsDestructible<typename TDecay<T>::Type>::Value
|
template <typename T> requires CDestructible<typename TDecay<T>::Type>
|
||||||
constexpr const T& GetValue() const& { checkf(HoldsAlternative<T>(), TEXT("It is an error to call GetValue() on an wrong TAny. Please either check HoldsAlternative() or use Get(DefaultValue) instead.")); return *reinterpret_cast<const T*>(GetAllocation()); }
|
constexpr const T& GetValue() const& { checkf(HoldsAlternative<T>(), TEXT("It is an error to call GetValue() on an wrong TAny. Please either check HoldsAlternative() or use Get(DefaultValue) instead.")); return *reinterpret_cast<const T*>(GetAllocation()); }
|
||||||
|
|
||||||
template <typename T> requires TIsDestructible<typename TDecay<T>::Type>::Value
|
template <typename T> requires CDestructible<typename TDecay<T>::Type>
|
||||||
constexpr const T&& GetValue() const&& { checkf(HoldsAlternative<T>(), TEXT("It is an error to call GetValue() on an wrong TAny. Please either check HoldsAlternative() or use Get(DefaultValue) instead.")); return MoveTemp(*reinterpret_cast<const T*>(GetAllocation())); }
|
constexpr const T&& GetValue() const&& { checkf(HoldsAlternative<T>(), TEXT("It is an error to call GetValue() on an wrong TAny. Please either check HoldsAlternative() or use Get(DefaultValue) instead.")); return MoveTemp(*reinterpret_cast<const T*>(GetAllocation())); }
|
||||||
|
|
||||||
template <typename T> requires TIsSame<T, typename TDecay<T>::Type>::Value&& TIsDestructible<typename TDecay<T>::Type>::Value
|
template <typename T> requires TIsSame<T, typename TDecay<T>::Type>::Value&& CDestructible<typename TDecay<T>::Type>
|
||||||
constexpr T& Get( T& DefaultValue) & { return HoldsAlternative<T>() ? GetValue<T>() : DefaultValue; }
|
constexpr T& Get( T& DefaultValue) & { return HoldsAlternative<T>() ? GetValue<T>() : DefaultValue; }
|
||||||
|
|
||||||
template <typename T> requires TIsSame<T, typename TDecay<T>::Type>::Value&& TIsDestructible<typename TDecay<T>::Type>::Value
|
template <typename T> requires TIsSame<T, typename TDecay<T>::Type>::Value&& CDestructible<typename TDecay<T>::Type>
|
||||||
constexpr const T& Get(const T& DefaultValue) const& { return HoldsAlternative<T>() ? GetValue<T>() : DefaultValue; }
|
constexpr const T& Get(const T& DefaultValue) const& { return HoldsAlternative<T>() ? GetValue<T>() : DefaultValue; }
|
||||||
|
|
||||||
FORCEINLINE void Reset()
|
FORCEINLINE void Reset()
|
||||||
|
@ -52,8 +52,8 @@ NAMESPACE_PRIVATE_END
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
template <typename T, bool bIsRef = false> requires CTriviallyCopyable<T>
|
template <typename T, bool bIsRef = false> requires CTriviallyCopyable<T>
|
||||||
&& TIsCopyConstructible<T>::Value && TIsMoveConstructible<T>::Value
|
&& CCopyConstructible<T> && CMoveConstructible<T>
|
||||||
&& TIsCopyAssignable<T>::Value && TIsMoveAssignable<T>::Value
|
&& CCopyAssignable<T> && CMoveAssignable<T>
|
||||||
struct TAtomic : public FSingleton
|
struct TAtomic : public FSingleton
|
||||||
{
|
{
|
||||||
protected:
|
protected:
|
||||||
|
@ -107,10 +107,10 @@ public:
|
|||||||
|
|
||||||
FORCEINLINE const type_info& TargetType() const requires (!bIsRef) { return IsValid() ? Storage.GetTypeInfo() : typeid(void); };
|
FORCEINLINE const type_info& TargetType() const requires (!bIsRef) { return IsValid() ? Storage.GetTypeInfo() : typeid(void); };
|
||||||
|
|
||||||
template <typename T> FORCEINLINE T& Target() & requires (!bIsRef) && TIsDestructible<typename TDecay<T>::Type>::Value { return static_cast< StorageType& >(Storage).template GetValue<T>(); }
|
template <typename T> FORCEINLINE T& Target() & requires (!bIsRef) && CDestructible<typename TDecay<T>::Type> { return static_cast< StorageType& >(Storage).template GetValue<T>(); }
|
||||||
template <typename T> FORCEINLINE T&& Target() && requires (!bIsRef) && TIsDestructible<typename TDecay<T>::Type>::Value { return static_cast< StorageType&&>(Storage).template GetValue<T>(); }
|
template <typename T> FORCEINLINE T&& Target() && requires (!bIsRef) && CDestructible<typename TDecay<T>::Type> { return static_cast< StorageType&&>(Storage).template GetValue<T>(); }
|
||||||
template <typename T> FORCEINLINE const T& Target() const& requires (!bIsRef) && TIsDestructible<typename TDecay<T>::Type>::Value { return static_cast<const StorageType& >(Storage).template GetValue<T>(); }
|
template <typename T> FORCEINLINE const T& Target() const& requires (!bIsRef) && CDestructible<typename TDecay<T>::Type> { return static_cast<const StorageType& >(Storage).template GetValue<T>(); }
|
||||||
template <typename T> FORCEINLINE const T&& Target() const&& requires (!bIsRef) && TIsDestructible<typename TDecay<T>::Type>::Value { return static_cast<const StorageType&&>(Storage).template GetValue<T>(); }
|
template <typename T> FORCEINLINE const T&& Target() const&& requires (!bIsRef) && CDestructible<typename TDecay<T>::Type> { return static_cast<const StorageType&&>(Storage).template GetValue<T>(); }
|
||||||
|
|
||||||
constexpr void Swap(TFunctionImpl& InValue) requires (!bIsRef)
|
constexpr void Swap(TFunctionImpl& InValue) requires (!bIsRef)
|
||||||
{
|
{
|
||||||
@ -296,7 +296,7 @@ public:
|
|||||||
|
|
||||||
template <typename T> requires (!TIsTInPlaceType<typename TDecay<T>::Type>::Value)
|
template <typename T> requires (!TIsTInPlaceType<typename TDecay<T>::Type>::Value)
|
||||||
&& (!TIsTFunctionRef<typename TDecay<T>::Type>::Value) && (!TIsTFunction<typename TDecay<T>::Type>::Value) && (!TIsTUniqueFunction<typename TDecay<T>::Type>::Value)
|
&& (!TIsTFunctionRef<typename TDecay<T>::Type>::Value) && (!TIsTFunction<typename TDecay<T>::Type>::Value) && (!TIsTUniqueFunction<typename TDecay<T>::Type>::Value)
|
||||||
&& TIsConstructible<typename TDecay<T>::Type, T&&>::Value && TIsCopyConstructible<typename TDecay<T>::Type>::Value
|
&& CConstructible<typename TDecay<T>::Type, T&&> && CCopyConstructible<typename TDecay<T>::Type>
|
||||||
&& NAMESPACE_PRIVATE::TIsInvocableSignature<F, typename TDecay<T>::Type>::Value
|
&& NAMESPACE_PRIVATE::TIsInvocableSignature<F, typename TDecay<T>::Type>::Value
|
||||||
FORCEINLINE TFunction(T&& InValue)
|
FORCEINLINE TFunction(T&& InValue)
|
||||||
{
|
{
|
||||||
@ -306,7 +306,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename T, typename... ArgTypes> requires NAMESPACE_PRIVATE::TIsInvocableSignature<F, typename TDecay<T>::Type>::Value
|
template <typename T, typename... ArgTypes> requires NAMESPACE_PRIVATE::TIsInvocableSignature<F, typename TDecay<T>::Type>::Value
|
||||||
&& TIsConstructible<typename TDecay<T>::Type, ArgTypes...>::Value && TIsCopyConstructible<typename TDecay<T>::Type>::Value
|
&& CConstructible<typename TDecay<T>::Type, ArgTypes...> && CCopyConstructible<typename TDecay<T>::Type>
|
||||||
FORCEINLINE TFunction(TInPlaceType<T>, ArgTypes&&... Args)
|
FORCEINLINE TFunction(TInPlaceType<T>, ArgTypes&&... Args)
|
||||||
{
|
{
|
||||||
using DecayedType = typename TDecay<T>::Type;
|
using DecayedType = typename TDecay<T>::Type;
|
||||||
@ -317,7 +317,7 @@ public:
|
|||||||
|
|
||||||
template <typename T> requires NAMESPACE_PRIVATE::TIsInvocableSignature<F, typename TDecay<T>::Type>::Value
|
template <typename T> requires NAMESPACE_PRIVATE::TIsInvocableSignature<F, typename TDecay<T>::Type>::Value
|
||||||
&& (!TIsTFunctionRef<typename TDecay<T>::Type>::Value) && (!TIsTFunction<typename TDecay<T>::Type>::Value) && (!TIsTUniqueFunction<typename TDecay<T>::Type>::Value)
|
&& (!TIsTFunctionRef<typename TDecay<T>::Type>::Value) && (!TIsTFunction<typename TDecay<T>::Type>::Value) && (!TIsTUniqueFunction<typename TDecay<T>::Type>::Value)
|
||||||
&& TIsConstructible<typename TDecay<T>::Type, T&&>::Value && TIsCopyConstructible<typename TDecay<T>::Type>::Value
|
&& CConstructible<typename TDecay<T>::Type, T&&> && CCopyConstructible<typename TDecay<T>::Type>
|
||||||
FORCEINLINE TFunction& operator=(T&& InValue)
|
FORCEINLINE TFunction& operator=(T&& InValue)
|
||||||
{
|
{
|
||||||
using DecayedType = typename TDecay<T>::Type;
|
using DecayedType = typename TDecay<T>::Type;
|
||||||
@ -329,7 +329,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename T, typename... ArgTypes> requires NAMESPACE_PRIVATE::TIsInvocableSignature<F, typename TDecay<T>::Type>::Value
|
template <typename T, typename... ArgTypes> requires NAMESPACE_PRIVATE::TIsInvocableSignature<F, typename TDecay<T>::Type>::Value
|
||||||
&& TIsConstructible<typename TDecay<T>::Type, ArgTypes...>::Value&& TIsCopyConstructible<typename TDecay<T>::Type>::Value
|
&& CConstructible<typename TDecay<T>::Type, ArgTypes...>&& CCopyConstructible<typename TDecay<T>::Type>
|
||||||
FORCEINLINE typename TDecay<T>::Type& Emplace(ArgTypes&&... Args)
|
FORCEINLINE typename TDecay<T>::Type& Emplace(ArgTypes&&... Args)
|
||||||
{
|
{
|
||||||
using DecayedType = typename TDecay<T>::Type;
|
using DecayedType = typename TDecay<T>::Type;
|
||||||
@ -399,7 +399,7 @@ public:
|
|||||||
|
|
||||||
template <typename T> requires (!TIsTInPlaceType<typename TDecay<T>::Type>::Value)
|
template <typename T> requires (!TIsTInPlaceType<typename TDecay<T>::Type>::Value)
|
||||||
&& (!TIsTFunctionRef<typename TDecay<T>::Type>::Value) && (!TIsTFunction<typename TDecay<T>::Type>::Value) && (!TIsTUniqueFunction<typename TDecay<T>::Type>::Value)
|
&& (!TIsTFunctionRef<typename TDecay<T>::Type>::Value) && (!TIsTFunction<typename TDecay<T>::Type>::Value) && (!TIsTUniqueFunction<typename TDecay<T>::Type>::Value)
|
||||||
&& TIsConstructible<typename TDecay<T>::Type, T&&>::Value && TIsMoveConstructible<typename TDecay<T>::Type>::Value
|
&& CConstructible<typename TDecay<T>::Type, T&&> && CMoveConstructible<typename TDecay<T>::Type>
|
||||||
&& NAMESPACE_PRIVATE::TIsInvocableSignature<F, typename TDecay<T>::Type>::Value
|
&& NAMESPACE_PRIVATE::TIsInvocableSignature<F, typename TDecay<T>::Type>::Value
|
||||||
FORCEINLINE TUniqueFunction(T&& InValue)
|
FORCEINLINE TUniqueFunction(T&& InValue)
|
||||||
{
|
{
|
||||||
@ -409,7 +409,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename T, typename... ArgTypes> requires NAMESPACE_PRIVATE::TIsInvocableSignature<F, typename TDecay<T>::Type>::Value
|
template <typename T, typename... ArgTypes> requires NAMESPACE_PRIVATE::TIsInvocableSignature<F, typename TDecay<T>::Type>::Value
|
||||||
&& TIsConstructible<typename TDecay<T>::Type, ArgTypes...>::Value && TIsMoveConstructible<typename TDecay<T>::Type>::Value
|
&& CConstructible<typename TDecay<T>::Type, ArgTypes...> && CMoveConstructible<typename TDecay<T>::Type>
|
||||||
FORCEINLINE TUniqueFunction(TInPlaceType<T>, ArgTypes&&... Args)
|
FORCEINLINE TUniqueFunction(TInPlaceType<T>, ArgTypes&&... Args)
|
||||||
{
|
{
|
||||||
using DecayedType = typename TDecay<T>::Type;
|
using DecayedType = typename TDecay<T>::Type;
|
||||||
@ -420,7 +420,7 @@ public:
|
|||||||
|
|
||||||
template <typename T> requires NAMESPACE_PRIVATE::TIsInvocableSignature<F, typename TDecay<T>::Type>::Value
|
template <typename T> requires NAMESPACE_PRIVATE::TIsInvocableSignature<F, typename TDecay<T>::Type>::Value
|
||||||
&& (!TIsTFunctionRef<typename TDecay<T>::Type>::Value) && (!TIsTFunction<typename TDecay<T>::Type>::Value) && (!TIsTUniqueFunction<typename TDecay<T>::Type>::Value)
|
&& (!TIsTFunctionRef<typename TDecay<T>::Type>::Value) && (!TIsTFunction<typename TDecay<T>::Type>::Value) && (!TIsTUniqueFunction<typename TDecay<T>::Type>::Value)
|
||||||
&& TIsConstructible<typename TDecay<T>::Type, T&&>::Value&& TIsMoveConstructible<typename TDecay<T>::Type>::Value
|
&& CConstructible<typename TDecay<T>::Type, T&&>&& CMoveConstructible<typename TDecay<T>::Type>
|
||||||
FORCEINLINE TUniqueFunction& operator=(T&& InValue)
|
FORCEINLINE TUniqueFunction& operator=(T&& InValue)
|
||||||
{
|
{
|
||||||
using DecayedType = typename TDecay<T>::Type;
|
using DecayedType = typename TDecay<T>::Type;
|
||||||
@ -432,7 +432,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename T, typename... ArgTypes> requires NAMESPACE_PRIVATE::TIsInvocableSignature<F, typename TDecay<T>::Type>::Value
|
template <typename T, typename... ArgTypes> requires NAMESPACE_PRIVATE::TIsInvocableSignature<F, typename TDecay<T>::Type>::Value
|
||||||
&& TIsConstructible<typename TDecay<T>::Type, ArgTypes...>::Value&& TIsMoveConstructible<typename TDecay<T>::Type>::Value
|
&& CConstructible<typename TDecay<T>::Type, ArgTypes...>&& CMoveConstructible<typename TDecay<T>::Type>
|
||||||
FORCEINLINE typename TDecay<T>::Type& Emplace(ArgTypes&&... Args)
|
FORCEINLINE typename TDecay<T>::Type& Emplace(ArgTypes&&... Args)
|
||||||
{
|
{
|
||||||
using DecayedType = typename TDecay<T>::Type;
|
using DecayedType = typename TDecay<T>::Type;
|
||||||
|
@ -12,25 +12,25 @@ NAMESPACE_REDCRAFT_BEGIN
|
|||||||
NAMESPACE_MODULE_BEGIN(Redcraft)
|
NAMESPACE_MODULE_BEGIN(Redcraft)
|
||||||
NAMESPACE_MODULE_BEGIN(Utility)
|
NAMESPACE_MODULE_BEGIN(Utility)
|
||||||
|
|
||||||
template <typename OptionalType> requires TIsDestructible<OptionalType>::Value
|
template <typename OptionalType> requires CDestructible<OptionalType>
|
||||||
struct TOptional
|
struct TOptional
|
||||||
{
|
{
|
||||||
private:
|
private:
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct TAllowUnwrapping : TBoolConstant<!(
|
struct TAllowUnwrapping : TBoolConstant<!(
|
||||||
TIsConstructible<OptionalType, TOptional<T>& >::Value
|
CConstructible<OptionalType, TOptional<T>& >
|
||||||
|| TIsConstructible<OptionalType, const TOptional<T>& >::Value
|
|| CConstructible<OptionalType, const TOptional<T>& >
|
||||||
|| TIsConstructible<OptionalType, TOptional<T>&&>::Value
|
|| CConstructible<OptionalType, TOptional<T>&&>
|
||||||
|| TIsConstructible<OptionalType, const TOptional<T>&&>::Value
|
|| CConstructible<OptionalType, const TOptional<T>&&>
|
||||||
|| TIsConvertible< TOptional<T>&, OptionalType>::Value
|
|| TIsConvertible< TOptional<T>&, OptionalType>::Value
|
||||||
|| TIsConvertible<const TOptional<T>&, OptionalType>::Value
|
|| TIsConvertible<const TOptional<T>&, OptionalType>::Value
|
||||||
|| TIsConvertible< TOptional<T>&&, OptionalType>::Value
|
|| TIsConvertible< TOptional<T>&&, OptionalType>::Value
|
||||||
|| TIsConvertible<const TOptional<T>&&, OptionalType>::Value
|
|| TIsConvertible<const TOptional<T>&&, OptionalType>::Value
|
||||||
|| TIsAssignable<OptionalType&, TOptional<T>& >::Value
|
|| CAssignable<OptionalType&, TOptional<T>& >
|
||||||
|| TIsAssignable<OptionalType&, const TOptional<T>& >::Value
|
|| CAssignable<OptionalType&, const TOptional<T>& >
|
||||||
|| TIsAssignable<OptionalType&, TOptional<T>&&>::Value
|
|| CAssignable<OptionalType&, TOptional<T>&&>
|
||||||
|| TIsAssignable<OptionalType&, const TOptional<T>&&>::Value
|
|| CAssignable<OptionalType&, const TOptional<T>&&>
|
||||||
)> { };
|
)> { };
|
||||||
|
|
||||||
public:
|
public:
|
||||||
@ -41,39 +41,39 @@ public:
|
|||||||
|
|
||||||
constexpr TOptional(FInvalid) : TOptional() { }
|
constexpr TOptional(FInvalid) : TOptional() { }
|
||||||
|
|
||||||
template <typename... Types> requires TIsConstructible<OptionalType, Types...>::Value
|
template <typename... Types> requires CConstructible<OptionalType, Types...>
|
||||||
constexpr explicit TOptional(FInPlace, Types&&... Args)
|
constexpr explicit TOptional(FInPlace, Types&&... Args)
|
||||||
: bIsValid(true)
|
: bIsValid(true)
|
||||||
{
|
{
|
||||||
new(&Value) OptionalType(Forward<Types>(Args)...);
|
new(&Value) OptionalType(Forward<Types>(Args)...);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T = OptionalType> requires TIsConstructible<OptionalType, T&&>::Value
|
template <typename T = OptionalType> requires CConstructible<OptionalType, T&&>
|
||||||
&& (!TIsSame<typename TRemoveCVRef<T>::Type, FInPlace>::Value) && (!TIsSame<typename TRemoveCVRef<T>::Type, TOptional>::Value)
|
&& (!TIsSame<typename TRemoveCVRef<T>::Type, FInPlace>::Value) && (!TIsSame<typename TRemoveCVRef<T>::Type, TOptional>::Value)
|
||||||
constexpr explicit (!TIsConvertible<T&&, OptionalType>::Value) TOptional(T&& InValue)
|
constexpr explicit (!TIsConvertible<T&&, OptionalType>::Value) TOptional(T&& InValue)
|
||||||
: TOptional(InPlace, Forward<T>(InValue))
|
: TOptional(InPlace, Forward<T>(InValue))
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
constexpr TOptional(const TOptional& InValue) requires TIsCopyConstructible<OptionalType>::Value
|
constexpr TOptional(const TOptional& InValue) requires CCopyConstructible<OptionalType>
|
||||||
: bIsValid(InValue.IsValid())
|
: bIsValid(InValue.IsValid())
|
||||||
{
|
{
|
||||||
if (InValue.IsValid()) new(&Value) OptionalType(InValue.GetValue());
|
if (InValue.IsValid()) new(&Value) OptionalType(InValue.GetValue());
|
||||||
}
|
}
|
||||||
|
|
||||||
constexpr TOptional(TOptional&& InValue) requires TIsMoveConstructible<OptionalType>::Value
|
constexpr TOptional(TOptional&& InValue) requires CMoveConstructible<OptionalType>
|
||||||
: bIsValid(InValue.IsValid())
|
: bIsValid(InValue.IsValid())
|
||||||
{
|
{
|
||||||
if (InValue.IsValid()) new(&Value) OptionalType(MoveTemp(InValue.GetValue()));
|
if (InValue.IsValid()) new(&Value) OptionalType(MoveTemp(InValue.GetValue()));
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T = OptionalType> requires TIsConstructible<OptionalType, const T&>::Value && TAllowUnwrapping<T>::Value
|
template <typename T = OptionalType> requires CConstructible<OptionalType, const T&> && TAllowUnwrapping<T>::Value
|
||||||
constexpr explicit (!TIsConvertible<const T&, OptionalType>::Value) TOptional(const TOptional<T>& InValue)
|
constexpr explicit (!TIsConvertible<const T&, OptionalType>::Value) TOptional(const TOptional<T>& InValue)
|
||||||
: bIsValid(InValue.IsValid())
|
: bIsValid(InValue.IsValid())
|
||||||
{
|
{
|
||||||
if (InValue.IsValid()) new(&Value) OptionalType(InValue.GetValue());
|
if (InValue.IsValid()) new(&Value) OptionalType(InValue.GetValue());
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T = OptionalType> requires TIsConstructible<OptionalType, T&&>::Value && TAllowUnwrapping<T>::Value
|
template <typename T = OptionalType> requires CConstructible<OptionalType, T&&> && TAllowUnwrapping<T>::Value
|
||||||
constexpr explicit (!TIsConvertible<T&&, OptionalType>::Value) TOptional(TOptional<T>&& InValue)
|
constexpr explicit (!TIsConvertible<T&&, OptionalType>::Value) TOptional(TOptional<T>&& InValue)
|
||||||
: bIsValid(InValue.IsValid())
|
: bIsValid(InValue.IsValid())
|
||||||
{
|
{
|
||||||
@ -82,10 +82,10 @@ public:
|
|||||||
|
|
||||||
constexpr ~TOptional()
|
constexpr ~TOptional()
|
||||||
{
|
{
|
||||||
if constexpr (!TIsTriviallyDestructible<OptionalType>::Value) Reset();
|
if constexpr (!CTriviallyDestructible<OptionalType>) Reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
constexpr TOptional& operator=(const TOptional& InValue) requires TIsCopyConstructible<OptionalType>::Value && TIsCopyAssignable<OptionalType>::Value
|
constexpr TOptional& operator=(const TOptional& InValue) requires CCopyConstructible<OptionalType> && CCopyAssignable<OptionalType>
|
||||||
{
|
{
|
||||||
if (&InValue == this) return *this;
|
if (&InValue == this) return *this;
|
||||||
|
|
||||||
@ -105,7 +105,7 @@ public:
|
|||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
constexpr TOptional& operator=(TOptional&& InValue) requires TIsMoveConstructible<OptionalType>::Value && TIsMoveAssignable<OptionalType>::Value
|
constexpr TOptional& operator=(TOptional&& InValue) requires CMoveConstructible<OptionalType> && CMoveAssignable<OptionalType>
|
||||||
{
|
{
|
||||||
if (&InValue == this) return *this;
|
if (&InValue == this) return *this;
|
||||||
|
|
||||||
@ -125,7 +125,7 @@ public:
|
|||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T = OptionalType> requires TIsConstructible<OptionalType, const T&>::Value && TIsAssignable<OptionalType&, const T&>::Value && TAllowUnwrapping<T>::Value
|
template <typename T = OptionalType> requires CConstructible<OptionalType, const T&> && CAssignable<OptionalType&, const T&> && TAllowUnwrapping<T>::Value
|
||||||
constexpr TOptional& operator=(const TOptional<T>& InValue)
|
constexpr TOptional& operator=(const TOptional<T>& InValue)
|
||||||
{
|
{
|
||||||
if (!InValue.IsValid())
|
if (!InValue.IsValid())
|
||||||
@ -144,7 +144,7 @@ public:
|
|||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T = OptionalType> requires TIsConstructible<OptionalType, T&&>::Value && TIsAssignable<OptionalType&, T&&>::Value && TAllowUnwrapping<T>::Value
|
template <typename T = OptionalType> requires CConstructible<OptionalType, T&&> && CAssignable<OptionalType&, T&&> && TAllowUnwrapping<T>::Value
|
||||||
constexpr TOptional& operator=(TOptional<T>&& InValue)
|
constexpr TOptional& operator=(TOptional<T>&& InValue)
|
||||||
{
|
{
|
||||||
if (!InValue.IsValid())
|
if (!InValue.IsValid())
|
||||||
@ -163,7 +163,7 @@ public:
|
|||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T = OptionalType> requires TIsConstructible<OptionalType, T&&>::Value && TIsAssignable<OptionalType&, T&&>::Value
|
template <typename T = OptionalType> requires CConstructible<OptionalType, T&&> && CAssignable<OptionalType&, T&&>
|
||||||
constexpr TOptional& operator=(T&& InValue)
|
constexpr TOptional& operator=(T&& InValue)
|
||||||
{
|
{
|
||||||
if (IsValid()) GetValue() = Forward<T>(InValue);
|
if (IsValid()) GetValue() = Forward<T>(InValue);
|
||||||
@ -176,7 +176,7 @@ public:
|
|||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename... ArgTypes> requires TIsConstructible<OptionalType, ArgTypes...>::Value
|
template <typename... ArgTypes> requires CConstructible<OptionalType, ArgTypes...>
|
||||||
constexpr OptionalType& Emplace(ArgTypes&&... Args)
|
constexpr OptionalType& Emplace(ArgTypes&&... Args)
|
||||||
{
|
{
|
||||||
Reset();
|
Reset();
|
||||||
@ -223,7 +223,7 @@ public:
|
|||||||
return NAMESPACE_REDCRAFT::GetTypeHash(GetValue());
|
return NAMESPACE_REDCRAFT::GetTypeHash(GetValue());
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> requires TIsMoveConstructible<OptionalType>::Value && TIsSwappable<OptionalType>::Value
|
template <typename T> requires CMoveConstructible<OptionalType> && TIsSwappable<OptionalType>::Value
|
||||||
constexpr void Swap(TOptional& InValue)
|
constexpr void Swap(TOptional& InValue)
|
||||||
{
|
{
|
||||||
if (!IsValid() && !InValue.IsValid()) return;
|
if (!IsValid() && !InValue.IsValid()) return;
|
||||||
@ -283,19 +283,19 @@ constexpr bool operator==(const TOptional<T>& LHS, FInvalid)
|
|||||||
return !LHS.IsValid();
|
return !LHS.IsValid();
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> requires TIsDestructible<T>::Value
|
template <typename T> requires CDestructible<T>
|
||||||
constexpr TOptional<typename TDecay<T>::Type> MakeOptional(FInvalid)
|
constexpr TOptional<typename TDecay<T>::Type> MakeOptional(FInvalid)
|
||||||
{
|
{
|
||||||
return TOptional<typename TDecay<T>::Type>(Invalid);
|
return TOptional<typename TDecay<T>::Type>(Invalid);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> requires TIsDestructible<T>::Value && TIsConstructible<T, T&&>::Value
|
template <typename T> requires CDestructible<T> && CConstructible<T, T&&>
|
||||||
constexpr TOptional<T> MakeOptional(T&& InValue)
|
constexpr TOptional<T> MakeOptional(T&& InValue)
|
||||||
{
|
{
|
||||||
return TOptional<T>(Forward<T>(InValue));
|
return TOptional<T>(Forward<T>(InValue));
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T, typename... Types> requires TIsDestructible<T>::Value && TIsConstructible<T, Types...>::Value
|
template <typename T, typename... Types> requires CDestructible<T> && CConstructible<T, Types...>
|
||||||
constexpr TOptional<T> MakeOptional(Types&&... Args)
|
constexpr TOptional<T> MakeOptional(Types&&... Args)
|
||||||
{
|
{
|
||||||
return TOptional<T>(InPlace, Forward<T>(Args)...);
|
return TOptional<T>(InPlace, Forward<T>(Args)...);
|
||||||
|
@ -65,7 +65,7 @@ private:
|
|||||||
|
|
||||||
// Optimize TOptional with these hacking
|
// Optimize TOptional with these hacking
|
||||||
constexpr TReferenceWrapper(FInvalid) : Pointer(nullptr) { };
|
constexpr TReferenceWrapper(FInvalid) : Pointer(nullptr) { };
|
||||||
template <typename T> requires TIsDestructible<T>::Value friend struct TOptional;
|
template <typename T> requires CDestructible<T> friend struct TOptional;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -116,18 +116,18 @@ private:
|
|||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct TAllowUnwrapping : TBoolConstant<!(
|
struct TAllowUnwrapping : TBoolConstant<!(
|
||||||
TIsConstructible<OptionalType, TOptional<T>& >::Value
|
CConstructible<OptionalType, TOptional<T>& >
|
||||||
|| TIsConstructible<OptionalType, const TOptional<T>& >::Value
|
|| CConstructible<OptionalType, const TOptional<T>& >
|
||||||
|| TIsConstructible<OptionalType, TOptional<T>&&>::Value
|
|| CConstructible<OptionalType, TOptional<T>&&>
|
||||||
|| TIsConstructible<OptionalType, const TOptional<T>&&>::Value
|
|| CConstructible<OptionalType, const TOptional<T>&&>
|
||||||
|| TIsConvertible< TOptional<T>&, OptionalType>::Value
|
|| TIsConvertible< TOptional<T>&, OptionalType>::Value
|
||||||
|| TIsConvertible<const TOptional<T>&, OptionalType>::Value
|
|| TIsConvertible<const TOptional<T>&, OptionalType>::Value
|
||||||
|| TIsConvertible< TOptional<T>&&, OptionalType>::Value
|
|| TIsConvertible< TOptional<T>&&, OptionalType>::Value
|
||||||
|| TIsConvertible<const TOptional<T>&&, OptionalType>::Value
|
|| TIsConvertible<const TOptional<T>&&, OptionalType>::Value
|
||||||
|| TIsAssignable<OptionalType&, TOptional<T>& >::Value
|
|| CAssignable<OptionalType&, TOptional<T>& >
|
||||||
|| TIsAssignable<OptionalType&, const TOptional<T>& >::Value
|
|| CAssignable<OptionalType&, const TOptional<T>& >
|
||||||
|| TIsAssignable<OptionalType&, TOptional<T>&&>::Value
|
|| CAssignable<OptionalType&, TOptional<T>&&>
|
||||||
|| TIsAssignable<OptionalType&, const TOptional<T>&&>::Value
|
|| CAssignable<OptionalType&, const TOptional<T>&&>
|
||||||
)> { };
|
)> { };
|
||||||
|
|
||||||
public:
|
public:
|
||||||
@ -138,12 +138,12 @@ public:
|
|||||||
|
|
||||||
constexpr TOptional(FInvalid) : TOptional() { }
|
constexpr TOptional(FInvalid) : TOptional() { }
|
||||||
|
|
||||||
template <typename... Types> requires TIsConstructible<OptionalType, Types...>::Value
|
template <typename... Types> requires CConstructible<OptionalType, Types...>
|
||||||
constexpr explicit TOptional(FInPlace, Types&&... Args)
|
constexpr explicit TOptional(FInPlace, Types&&... Args)
|
||||||
: Reference(Forward<Types>(Args)...)
|
: Reference(Forward<Types>(Args)...)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
template <typename T = OptionalType> requires TIsConstructible<OptionalType, T&&>::Value
|
template <typename T = OptionalType> requires CConstructible<OptionalType, T&&>
|
||||||
&& (!TIsSame<typename TRemoveCVRef<T>::Type, FInPlace>::Value) && (!TIsSame<typename TRemoveCVRef<T>::Type, TOptional>::Value)
|
&& (!TIsSame<typename TRemoveCVRef<T>::Type, FInPlace>::Value) && (!TIsSame<typename TRemoveCVRef<T>::Type, TOptional>::Value)
|
||||||
constexpr explicit (!TIsConvertible<T&&, OptionalType>::Value) TOptional(T&& InValue)
|
constexpr explicit (!TIsConvertible<T&&, OptionalType>::Value) TOptional(T&& InValue)
|
||||||
: TOptional(InPlace, Forward<T>(InValue))
|
: TOptional(InPlace, Forward<T>(InValue))
|
||||||
@ -152,7 +152,7 @@ public:
|
|||||||
TOptional(const TOptional& InValue) = default;
|
TOptional(const TOptional& InValue) = default;
|
||||||
TOptional(TOptional&& InValue) = default;
|
TOptional(TOptional&& InValue) = default;
|
||||||
|
|
||||||
template <typename T = OptionalType> requires TIsConstructible<OptionalType, const T&>::Value && TAllowUnwrapping<T>::Value
|
template <typename T = OptionalType> requires CConstructible<OptionalType, const T&> && TAllowUnwrapping<T>::Value
|
||||||
constexpr explicit (!TIsConvertible<const T&, OptionalType>::Value) TOptional(const TOptional<T>& InValue)
|
constexpr explicit (!TIsConvertible<const T&, OptionalType>::Value) TOptional(const TOptional<T>& InValue)
|
||||||
: Reference(InValue.Reference)
|
: Reference(InValue.Reference)
|
||||||
{ }
|
{ }
|
||||||
@ -162,21 +162,21 @@ public:
|
|||||||
TOptional& operator=(const TOptional& InValue) = default;
|
TOptional& operator=(const TOptional& InValue) = default;
|
||||||
TOptional& operator=(TOptional&& InValue) = default;
|
TOptional& operator=(TOptional&& InValue) = default;
|
||||||
|
|
||||||
template <typename T = OptionalType> requires TIsConstructible<OptionalType, const T&>::Value && TIsAssignable<OptionalType&, const T&>::Value && TAllowUnwrapping<T>::Value
|
template <typename T = OptionalType> requires CConstructible<OptionalType, const T&> && CAssignable<OptionalType&, const T&> && TAllowUnwrapping<T>::Value
|
||||||
constexpr TOptional& operator=(const TOptional<T>& InValue)
|
constexpr TOptional& operator=(const TOptional<T>& InValue)
|
||||||
{
|
{
|
||||||
Reference = InValue.Reference;
|
Reference = InValue.Reference;
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T = OptionalType> requires TIsConstructible<OptionalType, T&&>::Value && TIsAssignable<OptionalType&, T&&>::Value
|
template <typename T = OptionalType> requires CConstructible<OptionalType, T&&> && CAssignable<OptionalType&, T&&>
|
||||||
constexpr TOptional& operator=(T&& InValue)
|
constexpr TOptional& operator=(T&& InValue)
|
||||||
{
|
{
|
||||||
Reference = InValue;
|
Reference = InValue;
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename... ArgTypes> requires TIsConstructible<OptionalType, ArgTypes...>::Value
|
template <typename... ArgTypes> requires CConstructible<OptionalType, ArgTypes...>
|
||||||
constexpr OptionalType& Emplace(ArgTypes&&... Args)
|
constexpr OptionalType& Emplace(ArgTypes&&... Args)
|
||||||
{
|
{
|
||||||
Reference = TReferenceWrapper<ReferencedType>(Forward<ArgTypes>(Args)...);
|
Reference = TReferenceWrapper<ReferencedType>(Forward<ArgTypes>(Args)...);
|
||||||
@ -221,7 +221,7 @@ public:
|
|||||||
private:
|
private:
|
||||||
|
|
||||||
TReferenceWrapper<ReferencedType> Reference;
|
TReferenceWrapper<ReferencedType> Reference;
|
||||||
template <typename T> requires TIsDestructible<T>::Value friend struct TOptional;
|
template <typename T> requires CDestructible<T> friend struct TOptional;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -236,23 +236,23 @@ public:
|
|||||||
TTuple() = default;
|
TTuple() = default;
|
||||||
|
|
||||||
template <typename... ArgTypes> requires (ElementSize > 0) && (sizeof...(ArgTypes) == ElementSize)
|
template <typename... ArgTypes> requires (ElementSize > 0) && (sizeof...(ArgTypes) == ElementSize)
|
||||||
&& (true && ... && TIsConstructible<Types, ArgTypes&&>::Value)
|
&& (true && ... && CConstructible<Types, ArgTypes&&>)
|
||||||
&& (true && ... && TIsConvertible<ArgTypes&&, Types>::Value)
|
&& (true && ... && TIsConvertible<ArgTypes&&, Types>::Value)
|
||||||
constexpr TTuple(ArgTypes&&... Args)
|
constexpr TTuple(ArgTypes&&... Args)
|
||||||
: Super(NAMESPACE_PRIVATE::ForwardingConstructor, Forward<ArgTypes>(Args)...)
|
: Super(NAMESPACE_PRIVATE::ForwardingConstructor, Forward<ArgTypes>(Args)...)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
template <typename... ArgTypes> requires (ElementSize > 0) && (sizeof...(ArgTypes) == ElementSize)
|
template <typename... ArgTypes> requires (ElementSize > 0) && (sizeof...(ArgTypes) == ElementSize)
|
||||||
&& (true && ... && TIsConstructible<Types, ArgTypes&&>::Value)
|
&& (true && ... && CConstructible<Types, ArgTypes&&>)
|
||||||
&& (!(true && ... && TIsConvertible<ArgTypes&&, Types>::Value))
|
&& (!(true && ... && TIsConvertible<ArgTypes&&, Types>::Value))
|
||||||
constexpr explicit TTuple(ArgTypes&&... Args)
|
constexpr explicit TTuple(ArgTypes&&... Args)
|
||||||
: Super(NAMESPACE_PRIVATE::ForwardingConstructor, Forward<ArgTypes>(Args)...)
|
: Super(NAMESPACE_PRIVATE::ForwardingConstructor, Forward<ArgTypes>(Args)...)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
template <typename... OtherTypes> requires (sizeof...(OtherTypes) == ElementSize)
|
template <typename... OtherTypes> requires (sizeof...(OtherTypes) == ElementSize)
|
||||||
&& (true && ... && TIsConstructible<Types, const OtherTypes&>::Value)
|
&& (true && ... && CConstructible<Types, const OtherTypes&>)
|
||||||
&& ((ElementSize != 1) || !(TIsConvertible<const TTuple<OtherTypes...>&, typename TElementType<0>::Type>::Value
|
&& ((ElementSize != 1) || !(TIsConvertible<const TTuple<OtherTypes...>&, typename TElementType<0>::Type>::Value
|
||||||
|| TIsConstructible<typename TElementType<0>::Type, const TTuple<OtherTypes...>&>::Value
|
|| CConstructible<typename TElementType<0>::Type, const TTuple<OtherTypes...>&>
|
||||||
|| TIsSame<typename TElementType<0>::Type, typename TTuple<OtherTypes...>::template TElementType<0>::Type>::Value))
|
|| TIsSame<typename TElementType<0>::Type, typename TTuple<OtherTypes...>::template TElementType<0>::Type>::Value))
|
||||||
&& (true && ... && TIsConvertible<OtherTypes&&, Types>::Value)
|
&& (true && ... && TIsConvertible<OtherTypes&&, Types>::Value)
|
||||||
constexpr TTuple(const TTuple<OtherTypes...>& InValue)
|
constexpr TTuple(const TTuple<OtherTypes...>& InValue)
|
||||||
@ -260,9 +260,9 @@ public:
|
|||||||
{ }
|
{ }
|
||||||
|
|
||||||
template <typename... OtherTypes> requires (sizeof...(OtherTypes) == ElementSize)
|
template <typename... OtherTypes> requires (sizeof...(OtherTypes) == ElementSize)
|
||||||
&& (true && ... && TIsConstructible<Types, const OtherTypes&>::Value)
|
&& (true && ... && CConstructible<Types, const OtherTypes&>)
|
||||||
&& ((ElementSize != 1) || !(TIsConvertible<const TTuple<OtherTypes...>&, typename TElementType<0>::Type>::Value
|
&& ((ElementSize != 1) || !(TIsConvertible<const TTuple<OtherTypes...>&, typename TElementType<0>::Type>::Value
|
||||||
|| TIsConstructible<typename TElementType<0>::Type, const TTuple<OtherTypes...>&>::Value
|
|| CConstructible<typename TElementType<0>::Type, const TTuple<OtherTypes...>&>
|
||||||
|| TIsSame<typename TElementType<0>::Type, typename TTuple<OtherTypes...>::template TElementType<0>::Type>::Value))
|
|| TIsSame<typename TElementType<0>::Type, typename TTuple<OtherTypes...>::template TElementType<0>::Type>::Value))
|
||||||
&& (!(true && ... && TIsConvertible<OtherTypes&&, Types>::Value))
|
&& (!(true && ... && TIsConvertible<OtherTypes&&, Types>::Value))
|
||||||
constexpr explicit TTuple(const TTuple<OtherTypes...>& InValue)
|
constexpr explicit TTuple(const TTuple<OtherTypes...>& InValue)
|
||||||
@ -270,9 +270,9 @@ public:
|
|||||||
{ }
|
{ }
|
||||||
|
|
||||||
template <typename... OtherTypes> requires (sizeof...(OtherTypes) == ElementSize)
|
template <typename... OtherTypes> requires (sizeof...(OtherTypes) == ElementSize)
|
||||||
&& (true && ... && TIsConstructible<Types, OtherTypes&&>::Value)
|
&& (true && ... && CConstructible<Types, OtherTypes&&>)
|
||||||
&& ((ElementSize != 1) || !(TIsConvertible<TTuple<OtherTypes...>&&, typename TElementType<0>::Type>::Value
|
&& ((ElementSize != 1) || !(TIsConvertible<TTuple<OtherTypes...>&&, typename TElementType<0>::Type>::Value
|
||||||
|| TIsConstructible<typename TElementType<0>::Type, TTuple<OtherTypes...>&&>::Value
|
|| CConstructible<typename TElementType<0>::Type, TTuple<OtherTypes...>&&>
|
||||||
|| TIsSame<typename TElementType<0>::Type, typename TTuple<OtherTypes...>::template TElementType<0>::Type>::Value))
|
|| TIsSame<typename TElementType<0>::Type, typename TTuple<OtherTypes...>::template TElementType<0>::Type>::Value))
|
||||||
&& (true && ... && TIsConvertible<OtherTypes&&, Types>::Value)
|
&& (true && ... && TIsConvertible<OtherTypes&&, Types>::Value)
|
||||||
constexpr TTuple(TTuple<OtherTypes...>&& InValue)
|
constexpr TTuple(TTuple<OtherTypes...>&& InValue)
|
||||||
@ -280,9 +280,9 @@ public:
|
|||||||
{ }
|
{ }
|
||||||
|
|
||||||
template <typename... OtherTypes> requires (sizeof...(OtherTypes) == ElementSize)
|
template <typename... OtherTypes> requires (sizeof...(OtherTypes) == ElementSize)
|
||||||
&& (true && ... && TIsConstructible<Types, OtherTypes&&>::Value)
|
&& (true && ... && CConstructible<Types, OtherTypes&&>)
|
||||||
&& ((ElementSize != 1) || !(TIsConvertible<TTuple<OtherTypes...>&&, typename TElementType<0>::Type>::Value
|
&& ((ElementSize != 1) || !(TIsConvertible<TTuple<OtherTypes...>&&, typename TElementType<0>::Type>::Value
|
||||||
|| TIsConstructible<typename TElementType<0>::Type, TTuple<OtherTypes...>&&>::Value
|
|| CConstructible<typename TElementType<0>::Type, TTuple<OtherTypes...>&&>
|
||||||
|| TIsSame<typename TElementType<0>::Type, typename TTuple<OtherTypes...>::template TElementType<0>::Type>::Value))
|
|| TIsSame<typename TElementType<0>::Type, typename TTuple<OtherTypes...>::template TElementType<0>::Type>::Value))
|
||||||
&& (!(true && ... && TIsConvertible<OtherTypes&&, Types>::Value))
|
&& (!(true && ... && TIsConvertible<OtherTypes&&, Types>::Value))
|
||||||
constexpr explicit TTuple(TTuple<OtherTypes...>&& InValue)
|
constexpr explicit TTuple(TTuple<OtherTypes...>&& InValue)
|
||||||
@ -293,7 +293,7 @@ public:
|
|||||||
TTuple(TTuple&&) = default;
|
TTuple(TTuple&&) = default;
|
||||||
|
|
||||||
template <typename... OtherTypes> requires (sizeof...(OtherTypes) == ElementSize)
|
template <typename... OtherTypes> requires (sizeof...(OtherTypes) == ElementSize)
|
||||||
&& (true && ... && TIsAssignable<Types&, const OtherTypes&>::Value)
|
&& (true && ... && CAssignable<Types&, const OtherTypes&>)
|
||||||
constexpr TTuple& operator=(const TTuple<OtherTypes...>& InValue)
|
constexpr TTuple& operator=(const TTuple<OtherTypes...>& InValue)
|
||||||
{
|
{
|
||||||
Helper::Assign(*this, InValue);
|
Helper::Assign(*this, InValue);
|
||||||
@ -301,7 +301,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename... OtherTypes> requires (sizeof...(OtherTypes) == ElementSize)
|
template <typename... OtherTypes> requires (sizeof...(OtherTypes) == ElementSize)
|
||||||
&& (true && ... && TIsAssignable<Types&, OtherTypes&&>::Value)
|
&& (true && ... && CAssignable<Types&, OtherTypes&&>)
|
||||||
constexpr TTuple& operator=(TTuple<OtherTypes...>&& InValue)
|
constexpr TTuple& operator=(TTuple<OtherTypes...>&& InValue)
|
||||||
{
|
{
|
||||||
Helper::Assign(*this, MoveTemp(InValue));
|
Helper::Assign(*this, MoveTemp(InValue));
|
||||||
@ -365,21 +365,21 @@ public:
|
|||||||
template <typename F> requires (true && ... && (TIsInvocable<F, Types>::Value && !TIsSame<void, typename TInvokeResult<F, Types>::Type>::Value)) constexpr auto Transform(F&& Func) volatile&& { return Helper::Transform(Forward<F>(Func), static_cast< volatile TTuple&&>(*this)); }
|
template <typename F> requires (true && ... && (TIsInvocable<F, Types>::Value && !TIsSame<void, typename TInvokeResult<F, Types>::Type>::Value)) constexpr auto Transform(F&& Func) volatile&& { return Helper::Transform(Forward<F>(Func), static_cast< volatile TTuple&&>(*this)); }
|
||||||
template <typename F> requires (true && ... && (TIsInvocable<F, Types>::Value && !TIsSame<void, typename TInvokeResult<F, Types>::Type>::Value)) constexpr auto Transform(F&& Func) const volatile&& { return Helper::Transform(Forward<F>(Func), static_cast<const volatile TTuple&&>(*this)); }
|
template <typename F> requires (true && ... && (TIsInvocable<F, Types>::Value && !TIsSame<void, typename TInvokeResult<F, Types>::Type>::Value)) constexpr auto Transform(F&& Func) const volatile&& { return Helper::Transform(Forward<F>(Func), static_cast<const volatile TTuple&&>(*this)); }
|
||||||
|
|
||||||
template <typename T> requires TIsConstructible<T, Types...>::Value constexpr T Construct() & { return Helper::template Construct<T>(static_cast< TTuple& >(*this)); }
|
template <typename T> requires CConstructible<T, Types...> constexpr T Construct() & { return Helper::template Construct<T>(static_cast< TTuple& >(*this)); }
|
||||||
template <typename T> requires TIsConstructible<T, Types...>::Value constexpr T Construct() const & { return Helper::template Construct<T>(static_cast<const TTuple& >(*this)); }
|
template <typename T> requires CConstructible<T, Types...> constexpr T Construct() const & { return Helper::template Construct<T>(static_cast<const TTuple& >(*this)); }
|
||||||
template <typename T> requires TIsConstructible<T, Types...>::Value constexpr T Construct() volatile& { return Helper::template Construct<T>(static_cast< volatile TTuple& >(*this)); }
|
template <typename T> requires CConstructible<T, Types...> constexpr T Construct() volatile& { return Helper::template Construct<T>(static_cast< volatile TTuple& >(*this)); }
|
||||||
template <typename T> requires TIsConstructible<T, Types...>::Value constexpr T Construct() const volatile& { return Helper::template Construct<T>(static_cast<const volatile TTuple& >(*this)); }
|
template <typename T> requires CConstructible<T, Types...> constexpr T Construct() const volatile& { return Helper::template Construct<T>(static_cast<const volatile TTuple& >(*this)); }
|
||||||
template <typename T> requires TIsConstructible<T, Types...>::Value constexpr T Construct() && { return Helper::template Construct<T>(static_cast< TTuple&&>(*this)); }
|
template <typename T> requires CConstructible<T, Types...> constexpr T Construct() && { return Helper::template Construct<T>(static_cast< TTuple&&>(*this)); }
|
||||||
template <typename T> requires TIsConstructible<T, Types...>::Value constexpr T Construct() const && { return Helper::template Construct<T>(static_cast<const TTuple&&>(*this)); }
|
template <typename T> requires CConstructible<T, Types...> constexpr T Construct() const && { return Helper::template Construct<T>(static_cast<const TTuple&&>(*this)); }
|
||||||
template <typename T> requires TIsConstructible<T, Types...>::Value constexpr T Construct() volatile&& { return Helper::template Construct<T>(static_cast< volatile TTuple&&>(*this)); }
|
template <typename T> requires CConstructible<T, Types...> constexpr T Construct() volatile&& { return Helper::template Construct<T>(static_cast< volatile TTuple&&>(*this)); }
|
||||||
template <typename T> requires TIsConstructible<T, Types...>::Value constexpr T Construct() const volatile&& { return Helper::template Construct<T>(static_cast<const volatile TTuple&&>(*this)); }
|
template <typename T> requires CConstructible<T, Types...> constexpr T Construct() const volatile&& { return Helper::template Construct<T>(static_cast<const volatile TTuple&&>(*this)); }
|
||||||
|
|
||||||
constexpr size_t GetTypeHash() const requires (true && ... && CHashable<Types>)
|
constexpr size_t GetTypeHash() const requires (true && ... && CHashable<Types>)
|
||||||
{
|
{
|
||||||
return [this]<size_t... Indices>(TIndexSequence<Indices...>) -> size_t { return HashCombine(NAMESPACE_REDCRAFT::GetTypeHash(GetValue<Indices>())...); } (TMakeIndexSequence<ElementSize>());
|
return [this]<size_t... Indices>(TIndexSequence<Indices...>) -> size_t { return HashCombine(NAMESPACE_REDCRAFT::GetTypeHash(GetValue<Indices>())...); } (TMakeIndexSequence<ElementSize>());
|
||||||
}
|
}
|
||||||
|
|
||||||
constexpr void Swap(TTuple& InValue) requires (true && ... && (TIsMoveConstructible<Types>::Value&& TIsSwappable<Types>::Value))
|
constexpr void Swap(TTuple& InValue) requires (true && ... && (CMoveConstructible<Types>&& TIsSwappable<Types>::Value))
|
||||||
{
|
{
|
||||||
[&A = *this, &B = InValue]<size_t... Indices>(TIndexSequence<Indices...>) { ((NAMESPACE_REDCRAFT::Swap(A.template GetValue<Indices>(), B.template GetValue<Indices>())), ...); } (TMakeIndexSequence<ElementSize>());
|
[&A = *this, &B = InValue]<size_t... Indices>(TIndexSequence<Indices...>) { ((NAMESPACE_REDCRAFT::Swap(A.template GetValue<Indices>(), B.template GetValue<Indices>())), ...); } (TMakeIndexSequence<ElementSize>());
|
||||||
}
|
}
|
||||||
|
@ -62,7 +62,7 @@ constexpr T&& Forward(typename TRemoveReference<T>::Type&& Obj)
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> requires requires(T& A, T& B) { A.Swap(B); }
|
template <typename T> requires requires(T& A, T& B) { A.Swap(B); }
|
||||||
|| (TIsMoveConstructible<T>::Value && TIsMoveAssignable<T>::Value)
|
|| (CMoveConstructible<T> && CMoveAssignable<T>)
|
||||||
constexpr void Swap(T& A, T& B)
|
constexpr void Swap(T& A, T& B)
|
||||||
{
|
{
|
||||||
if constexpr (requires(T& A, T& B) { A.Swap(B); })
|
if constexpr (requires(T& A, T& B) { A.Swap(B); })
|
||||||
@ -77,7 +77,7 @@ constexpr void Swap(T& A, T& B)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T, typename U = T> requires TIsMoveConstructible<T>::Value && TIsAssignable<T&, U>::Value
|
template <typename T, typename U = T> requires CMoveConstructible<T> && CAssignable<T&, U>
|
||||||
constexpr T Exchange(T& A, U&& B)
|
constexpr T Exchange(T& A, U&& B)
|
||||||
{
|
{
|
||||||
T Temp = MoveTemp(A);
|
T Temp = MoveTemp(A);
|
||||||
|
@ -49,7 +49,7 @@ struct TVariantSelectedType;
|
|||||||
template <typename T, typename U, typename... Types>
|
template <typename T, typename U, typename... Types>
|
||||||
struct TVariantSelectedType<T, U, Types...>
|
struct TVariantSelectedType<T, U, Types...>
|
||||||
{
|
{
|
||||||
using TypeAlternativeA = typename TConditional<TIsConstructible<U, T&&>::Value, U, void>::Type;
|
using TypeAlternativeA = typename TConditional<CConstructible<U, T&&>, U, void>::Type;
|
||||||
using TypeAlternativeB = typename TVariantSelectedType<T, Types...>::Type;
|
using TypeAlternativeB = typename TVariantSelectedType<T, Types...>::Type;
|
||||||
|
|
||||||
using Type = typename TConditional<TIsSame<typename TRemoveCVRef<TypeAlternativeA>::Type, void>::Value, TypeAlternativeB,
|
using Type = typename TConditional<TIsSame<typename TRemoveCVRef<TypeAlternativeA>::Type, void>::Value, TypeAlternativeB,
|
||||||
@ -78,7 +78,7 @@ struct TVariantSelectedType<T>
|
|||||||
|
|
||||||
NAMESPACE_PRIVATE_END
|
NAMESPACE_PRIVATE_END
|
||||||
|
|
||||||
template <typename... Types> requires (true && ... && TIsDestructible<Types>::Value) && (sizeof...(Types) < 0xFF)
|
template <typename... Types> requires (true && ... && CDestructible<Types>) && (sizeof...(Types) < 0xFF)
|
||||||
struct TVariant
|
struct TVariant
|
||||||
{
|
{
|
||||||
static constexpr size_t AlternativeSize = sizeof...(Types);
|
static constexpr size_t AlternativeSize = sizeof...(Types);
|
||||||
@ -90,20 +90,20 @@ struct TVariant
|
|||||||
|
|
||||||
constexpr TVariant(FInvalid) : TVariant() { };
|
constexpr TVariant(FInvalid) : TVariant() { };
|
||||||
|
|
||||||
constexpr TVariant(const TVariant& InValue) requires (true && ... && TIsCopyConstructible<Types>::Value)
|
constexpr TVariant(const TVariant& InValue) requires (true && ... && CCopyConstructible<Types>)
|
||||||
: TypeIndex(static_cast<uint8>(InValue.GetIndex()))
|
: TypeIndex(static_cast<uint8>(InValue.GetIndex()))
|
||||||
{
|
{
|
||||||
if (IsValid()) CopyConstructImpl[InValue.GetIndex()](&Value, &InValue.Value);
|
if (IsValid()) CopyConstructImpl[InValue.GetIndex()](&Value, &InValue.Value);
|
||||||
}
|
}
|
||||||
|
|
||||||
constexpr TVariant(TVariant&& InValue) requires (true && ... && TIsMoveConstructible<Types>::Value)
|
constexpr TVariant(TVariant&& InValue) requires (true && ... && CMoveConstructible<Types>)
|
||||||
: TypeIndex(static_cast<uint8>(InValue.GetIndex()))
|
: TypeIndex(static_cast<uint8>(InValue.GetIndex()))
|
||||||
{
|
{
|
||||||
if (IsValid()) MoveConstructImpl[InValue.GetIndex()](&Value, &InValue.Value);
|
if (IsValid()) MoveConstructImpl[InValue.GetIndex()](&Value, &InValue.Value);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <size_t I, typename... ArgTypes> requires (I < AlternativeSize)
|
template <size_t I, typename... ArgTypes> requires (I < AlternativeSize)
|
||||||
&& TIsConstructible<typename TAlternativeType<I>::Type, ArgTypes...>::Value
|
&& CConstructible<typename TAlternativeType<I>::Type, ArgTypes...>
|
||||||
constexpr explicit TVariant(TInPlaceIndex<I>, ArgTypes&&... Args)
|
constexpr explicit TVariant(TInPlaceIndex<I>, ArgTypes&&... Args)
|
||||||
: TypeIndex(I)
|
: TypeIndex(I)
|
||||||
{
|
{
|
||||||
@ -112,7 +112,7 @@ struct TVariant
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename T, typename... ArgTypes> requires (TAlternativeIndex<T>::Value != INDEX_NONE)
|
template <typename T, typename... ArgTypes> requires (TAlternativeIndex<T>::Value != INDEX_NONE)
|
||||||
&& TIsConstructible<typename TAlternativeType<TAlternativeIndex<T>::Value>::Type, ArgTypes...>::Value
|
&& CConstructible<typename TAlternativeType<TAlternativeIndex<T>::Value>::Type, ArgTypes...>
|
||||||
constexpr explicit TVariant(TInPlaceType<T>, ArgTypes&&... Args)
|
constexpr explicit TVariant(TInPlaceType<T>, ArgTypes&&... Args)
|
||||||
: TVariant(InPlaceIndex<TAlternativeIndex<T>::Value>, Forward<ArgTypes>(Args)...)
|
: TVariant(InPlaceIndex<TAlternativeIndex<T>::Value>, Forward<ArgTypes>(Args)...)
|
||||||
{ }
|
{ }
|
||||||
@ -125,10 +125,10 @@ struct TVariant
|
|||||||
|
|
||||||
constexpr ~TVariant()
|
constexpr ~TVariant()
|
||||||
{
|
{
|
||||||
if constexpr (!(true && ... && TIsTriviallyDestructible<Types>::Value)) Reset();
|
if constexpr (!(true && ... && CTriviallyDestructible<Types>)) Reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
constexpr TVariant& operator=(const TVariant& InValue) requires (true && ... && (TIsCopyConstructible<Types>::Value && TIsCopyAssignable<Types>::Value))
|
constexpr TVariant& operator=(const TVariant& InValue) requires (true && ... && (CCopyConstructible<Types> && CCopyAssignable<Types>))
|
||||||
{
|
{
|
||||||
if (&InValue == this) return *this;
|
if (&InValue == this) return *this;
|
||||||
|
|
||||||
@ -149,7 +149,7 @@ struct TVariant
|
|||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
constexpr TVariant& operator=(TVariant&& InValue) requires (true && ... && (TIsMoveConstructible<Types>::Value && TIsMoveAssignable<Types>::Value))
|
constexpr TVariant& operator=(TVariant&& InValue) requires (true && ... && (CMoveConstructible<Types> && CMoveAssignable<Types>))
|
||||||
{
|
{
|
||||||
if (&InValue == this) return *this;
|
if (&InValue == this) return *this;
|
||||||
|
|
||||||
@ -187,7 +187,7 @@ struct TVariant
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <size_t I, typename... ArgTypes> requires (I < AlternativeSize)
|
template <size_t I, typename... ArgTypes> requires (I < AlternativeSize)
|
||||||
&& TIsConstructible<typename TAlternativeType<I>::Type, ArgTypes...>::Value
|
&& CConstructible<typename TAlternativeType<I>::Type, ArgTypes...>
|
||||||
constexpr typename TAlternativeType<I>::Type& Emplace(ArgTypes&&... Args)
|
constexpr typename TAlternativeType<I>::Type& Emplace(ArgTypes&&... Args)
|
||||||
{
|
{
|
||||||
Reset();
|
Reset();
|
||||||
@ -200,7 +200,7 @@ struct TVariant
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename T, typename... ArgTypes> requires (TAlternativeIndex<T>::Value != INDEX_NONE)
|
template <typename T, typename... ArgTypes> requires (TAlternativeIndex<T>::Value != INDEX_NONE)
|
||||||
&& TIsConstructible<typename TAlternativeType<TAlternativeIndex<T>::Value>::Type, ArgTypes...>::Value
|
&& CConstructible<typename TAlternativeType<TAlternativeIndex<T>::Value>::Type, ArgTypes...>
|
||||||
constexpr T& Emplace(ArgTypes&&... Args)
|
constexpr T& Emplace(ArgTypes&&... Args)
|
||||||
{
|
{
|
||||||
return Emplace<TAlternativeIndex<T>::Value>(Forward<ArgTypes>(Args)...);
|
return Emplace<TAlternativeIndex<T>::Value>(Forward<ArgTypes>(Args)...);
|
||||||
@ -299,7 +299,7 @@ struct TVariant
|
|||||||
{
|
{
|
||||||
if (GetIndex() == INDEX_NONE) return;
|
if (GetIndex() == INDEX_NONE) return;
|
||||||
|
|
||||||
if constexpr (!(true && ... && TIsTriviallyDestructible<Types>::Value))
|
if constexpr (!(true && ... && CTriviallyDestructible<Types>))
|
||||||
{
|
{
|
||||||
DestroyImpl[GetIndex()](&Value);
|
DestroyImpl[GetIndex()](&Value);
|
||||||
}
|
}
|
||||||
@ -319,7 +319,7 @@ struct TVariant
|
|||||||
return HashCombine(GetTypeHash(GetIndex()), HashImpl[GetIndex()](&Value));
|
return HashCombine(GetTypeHash(GetIndex()), HashImpl[GetIndex()](&Value));
|
||||||
}
|
}
|
||||||
|
|
||||||
constexpr void Swap(TVariant& InValue) requires (true && ... && (TIsMoveConstructible<Types>::Value && TIsSwappable<Types>::Value))
|
constexpr void Swap(TVariant& InValue) requires (true && ... && (CMoveConstructible<Types> && TIsSwappable<Types>::Value))
|
||||||
{
|
{
|
||||||
if (!IsValid() && !InValue.IsValid()) return;
|
if (!IsValid() && !InValue.IsValid()) return;
|
||||||
|
|
||||||
|
@ -14,7 +14,7 @@ NAMESPACE_MODULE_BEGIN(Utility)
|
|||||||
// Assume that all operands of bitwise operations have the same size
|
// Assume that all operands of bitwise operations have the same size
|
||||||
|
|
||||||
// This type traits is allowed to be specialised.
|
// This type traits is allowed to be specialised.
|
||||||
template <typename T> struct TIsZeroConstructible : TBoolConstant<TIsDefaultConstructible<T>::Value && (CEnum<T> || CArithmetic<T> || CPointer<T>)> { };
|
template <typename T> struct TIsZeroConstructible : TBoolConstant<CDefaultConstructible<T> && (CEnum<T> || CArithmetic<T> || CPointer<T>)> { };
|
||||||
|
|
||||||
// This type traits is allowed to be specialised.
|
// This type traits is allowed to be specialised.
|
||||||
template <typename T, typename U> struct TIsBitwiseConstructible;
|
template <typename T, typename U> struct TIsBitwiseConstructible;
|
||||||
@ -37,7 +37,7 @@ template <typename T, typename U> struct TIsBitwiseConstructible<const volatile
|
|||||||
|
|
||||||
template <typename T, typename U> struct TIsBitwiseConstructible<T*, U*> : TIsConvertible<U*, T*> { };
|
template <typename T, typename U> struct TIsBitwiseConstructible<T*, U*> : TIsConvertible<U*, T*> { };
|
||||||
|
|
||||||
template <typename T, typename U> struct TIsBitwiseConstructible : TBoolConstant<TIsSame<T, U>::Value ? TIsTriviallyCopyConstructible<T>::Value : false> { };
|
template <typename T, typename U> struct TIsBitwiseConstructible : TBoolConstant<TIsSame<T, U>::Value ? CTriviallyCopyConstructible<T> : false> { };
|
||||||
|
|
||||||
template <> struct TIsBitwiseConstructible<uint8, int8> : FTrue { };
|
template <> struct TIsBitwiseConstructible<uint8, int8> : FTrue { };
|
||||||
template <> struct TIsBitwiseConstructible< int8, uint8> : FTrue { };
|
template <> struct TIsBitwiseConstructible< int8, uint8> : FTrue { };
|
||||||
@ -69,7 +69,7 @@ template <typename T, typename U> struct TIsBitwiseRelocatable<const volatile T,
|
|||||||
|
|
||||||
template <typename T> struct TIsBitwiseRelocatable<T, T> : TBoolConstant<CObject<T>> { };
|
template <typename T> struct TIsBitwiseRelocatable<T, T> : TBoolConstant<CObject<T>> { };
|
||||||
|
|
||||||
template <typename T, typename U> struct TIsBitwiseRelocatable : TBoolConstant<TIsBitwiseConstructible<T, U>::Value && TIsTriviallyDestructible<U>::Value> { };
|
template <typename T, typename U> struct TIsBitwiseRelocatable : TBoolConstant<TIsBitwiseConstructible<T, U>::Value && CTriviallyDestructible<U>> { };
|
||||||
|
|
||||||
// This type traits is allowed to be specialised.
|
// This type traits is allowed to be specialised.
|
||||||
template <typename T> struct TIsBitwiseComparable : TBoolConstant<CEnum<T> || CArithmetic<T> || CPointer<T>> { };
|
template <typename T> struct TIsBitwiseComparable : TBoolConstant<CEnum<T> || CArithmetic<T> || CPointer<T>> { };
|
||||||
|
@ -12,44 +12,43 @@ NAMESPACE_MODULE_BEGIN(Utility)
|
|||||||
NAMESPACE_PRIVATE_BEGIN
|
NAMESPACE_PRIVATE_BEGIN
|
||||||
|
|
||||||
// Cpp17Destructible requirements
|
// Cpp17Destructible requirements
|
||||||
template <typename T>
|
template <typename T> concept CCpp17Destructible = NAMESPACE_STD::is_object_v<T> && !NAMESPACE_STD::is_array_v<T> && NAMESPACE_STD::is_destructible_v<T>;
|
||||||
struct TIsCpp17Destructible : TBoolConstant<NAMESPACE_STD::is_object_v<T> && !NAMESPACE_STD::is_array_v<T> && NAMESPACE_STD::is_destructible_v<T>> { };
|
|
||||||
|
|
||||||
NAMESPACE_PRIVATE_END
|
NAMESPACE_PRIVATE_END
|
||||||
|
|
||||||
template <typename T> struct TIsDefaultConstructible : TBoolConstant<NAMESPACE_STD::is_default_constructible_v<T>> { };
|
template <typename T> concept CDefaultConstructible = NAMESPACE_STD::is_default_constructible_v<T>;
|
||||||
template <typename T> struct TIsCopyConstructible : TBoolConstant<NAMESPACE_STD::is_copy_constructible_v<T>> { };
|
template <typename T> concept CCopyConstructible = NAMESPACE_STD::is_copy_constructible_v<T>;
|
||||||
template <typename T> struct TIsMoveConstructible : TBoolConstant<NAMESPACE_STD::is_move_constructible_v<T>> { };
|
template <typename T> concept CMoveConstructible = NAMESPACE_STD::is_move_constructible_v<T>;
|
||||||
template <typename T> struct TIsCopyAssignable : TBoolConstant<NAMESPACE_STD::is_copy_assignable_v<T>> { };
|
template <typename T> concept CCopyAssignable = NAMESPACE_STD::is_copy_assignable_v<T>;
|
||||||
template <typename T> struct TIsMoveAssignable : TBoolConstant<NAMESPACE_STD::is_move_assignable_v<T>> { };
|
template <typename T> concept CMoveAssignable = NAMESPACE_STD::is_move_assignable_v<T>;
|
||||||
template <typename T> struct TIsDestructible : NAMESPACE_PRIVATE::TIsCpp17Destructible<T> { }; // Use Cpp17Destructible requirements instead of std::is_destructible
|
template <typename T> concept CDestructible = NAMESPACE_PRIVATE::CCpp17Destructible<T>; // Use Cpp17Destructible requirements instead of std::is_destructible
|
||||||
|
|
||||||
template <typename T> struct TIsTriviallyDefaultConstructible : TBoolConstant<TIsDefaultConstructible<T>::Value && NAMESPACE_STD::is_trivially_default_constructible_v<T>> { };
|
template <typename T> concept CTriviallyDefaultConstructible = CDefaultConstructible<T> && NAMESPACE_STD::is_trivially_default_constructible_v<T>;
|
||||||
template <typename T> struct TIsTriviallyCopyConstructible : TBoolConstant<TIsCopyConstructible<T>::Value && NAMESPACE_STD::is_trivially_copy_constructible_v<T>> { };
|
template <typename T> concept CTriviallyCopyConstructible = CCopyConstructible<T> && NAMESPACE_STD::is_trivially_copy_constructible_v<T>;
|
||||||
template <typename T> struct TIsTriviallyMoveConstructible : TBoolConstant<TIsMoveConstructible<T>::Value && NAMESPACE_STD::is_trivially_move_constructible_v<T>> { };
|
template <typename T> concept CTriviallyMoveConstructible = CMoveConstructible<T> && NAMESPACE_STD::is_trivially_move_constructible_v<T>;
|
||||||
template <typename T> struct TIsTriviallyCopyAssignable : TBoolConstant<TIsCopyAssignable<T>::Value && NAMESPACE_STD::is_trivially_copy_assignable_v<T>> { };
|
template <typename T> concept CTriviallyCopyAssignable = CCopyAssignable<T> && NAMESPACE_STD::is_trivially_copy_assignable_v<T>;
|
||||||
template <typename T> struct TIsTriviallyMoveAssignable : TBoolConstant<TIsMoveAssignable<T>::Value && NAMESPACE_STD::is_trivially_move_assignable_v<T>> { };
|
template <typename T> concept CTriviallyMoveAssignable = CMoveAssignable<T> && NAMESPACE_STD::is_trivially_move_assignable_v<T>;
|
||||||
template <typename T> struct TIsTriviallyDestructible : TBoolConstant<TIsDestructible<T>::Value && NAMESPACE_STD::is_trivially_destructible_v<T>> { };
|
template <typename T> concept CTriviallyDestructible = CDestructible<T> && NAMESPACE_STD::is_trivially_destructible_v<T>;
|
||||||
template <typename T> struct THasVirtualDestructor : TBoolConstant<TIsDestructible<T>::Value && NAMESPACE_STD::has_virtual_destructor_v<T>> { };
|
template <typename T> concept CVirtualDestructible = CDestructible<T> && NAMESPACE_STD::has_virtual_destructor_v<T>;
|
||||||
|
|
||||||
//template <typename T> struct TIsNothrowDefaultConstructible;
|
//template <typename T> concept CNothrowDefaultConstructible;
|
||||||
//template <typename T> struct TIsNothrowCopyConstructible;
|
//template <typename T> concept CNothrowCopyConstructible;
|
||||||
//template <typename T> struct TIsNothrowMoveConstructible;
|
//template <typename T> concept CNothrowMoveConstructible;
|
||||||
//template <typename T> struct TIsNothrowCopyAssignable;
|
//template <typename T> concept CNothrowCopyAssignable;
|
||||||
//template <typename T> struct TIsNothrowMoveAssignable;
|
//template <typename T> concept CNothrowMoveAssignable;
|
||||||
//template <typename T> struct TIsNothrowDestructible;
|
//template <typename T> concept CNothrowDestructible;
|
||||||
|
|
||||||
template <typename T, typename U> struct TIsAssignable : TBoolConstant<NAMESPACE_STD::is_assignable_v<T, U>> { };
|
template <typename T, typename U> concept CAssignable = NAMESPACE_STD::is_assignable_v<T, U>;
|
||||||
|
|
||||||
template <typename T, typename U> struct TIsTriviallyAssignable : TBoolConstant<TIsAssignable<T, U>::Value && NAMESPACE_STD::is_trivially_assignable_v<T, U>> { };
|
template <typename T, typename U> concept CTriviallyAssignable = CAssignable<T, U> && NAMESPACE_STD::is_trivially_assignable_v<T, U>;
|
||||||
|
|
||||||
//template <typename T, typename U> struct TIsNothrowAssignable;
|
//template <typename T, typename U> concept CNothrowAssignable;
|
||||||
|
|
||||||
template <typename T, typename... Args> struct TIsConstructible : TBoolConstant<NAMESPACE_STD::is_constructible_v<T, Args...>> { };
|
template <typename T, typename... Args> concept CConstructible = NAMESPACE_STD::is_constructible_v<T, Args...>;
|
||||||
|
|
||||||
template <typename T, typename... Args> struct TIsTriviallyConstructible : TBoolConstant<TIsConstructible<T, Args...>::Value && NAMESPACE_STD::is_trivially_constructible_v<T, Args...>> { };
|
template <typename T, typename... Args> concept CTriviallyConstructible = CConstructible<T, Args...> && NAMESPACE_STD::is_trivially_constructible_v<T, Args...>;
|
||||||
|
|
||||||
//template <typename T, typename... Args> struct TIsNothrowConstructible;
|
//template <typename T, typename... Args> concept CNothrowConstructible;
|
||||||
|
|
||||||
NAMESPACE_MODULE_END(Utility)
|
NAMESPACE_MODULE_END(Utility)
|
||||||
NAMESPACE_MODULE_END(Redcraft)
|
NAMESPACE_MODULE_END(Redcraft)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user