From 5b7a90cd0b98636f2c0e426e0e1d8c171892e991 Mon Sep 17 00:00:00 2001 From: _Redstone_c_ Date: Fri, 17 Mar 2023 19:09:48 +0800 Subject: [PATCH] fix(containers): fix operator&= operator|= and operator^= of TBitset --- .../Source/Public/Containers/Bitset.h | 24 ++++++++----------- 1 file changed, 10 insertions(+), 14 deletions(-) diff --git a/Redcraft.Utility/Source/Public/Containers/Bitset.h b/Redcraft.Utility/Source/Public/Containers/Bitset.h index 27c762f..384e0d0 100644 --- a/Redcraft.Utility/Source/Public/Containers/Bitset.h +++ b/Redcraft.Utility/Source/Public/Containers/Bitset.h @@ -285,7 +285,9 @@ public: { if (&InValue == this) UNLIKELY return *this; - if (Num() == 0 || InValue.Num() == 0) return *this; + if (Num() == 0) return *this; + + if (InValue.Num() == 0) return Set(false); if (Num() <= InValue.Num()) { @@ -309,7 +311,7 @@ public: for (size_t Index = LastBlock + 1; Index != NumBlocks(); ++Index) { - Impl.Pointer[Index] &= 0; + Impl.Pointer[Index] = 0; } } @@ -321,7 +323,9 @@ public: { if (&InValue == this) UNLIKELY return *this; - if (Num() == 0 || InValue.Num() == 0) return *this; + if (Num() == 0) return *this; + + if (InValue.Num() == 0) return *this; if (Num() <= InValue.Num()) { @@ -342,11 +346,6 @@ public: const BlockType LastBlockBitmask = InValue.Num() % BlockWidth != 0 ? (1ull << InValue.Num() % BlockWidth) - 1 : -1; Impl.Pointer[LastBlock] |= InValue.Impl.Pointer[LastBlock] & LastBlockBitmask; - - for (size_t Index = LastBlock + 1; Index != NumBlocks(); ++Index) - { - Impl.Pointer[Index] |= 0; - } } return *this; @@ -357,7 +356,9 @@ public: { if (&InValue == this) UNLIKELY return *this; - if (Num() == 0 || InValue.Num() == 0) return *this; + if (Num() == 0) return *this; + + if (InValue.Num() == 0) return *this; if (Num() <= InValue.Num()) { @@ -378,11 +379,6 @@ public: const BlockType LastBlockBitmask = InValue.Num() % BlockWidth != 0 ? (1ull << InValue.Num() % BlockWidth) - 1 : -1; Impl.Pointer[LastBlock] ^= InValue.Impl.Pointer[LastBlock] & LastBlockBitmask; - - for (size_t Index = LastBlock + 1; Index != NumBlocks(); ++Index) - { - Impl.Pointer[Index] ^= 0; - } } return *this;