From ea4a3b2476db453b8627d58920d28a48cfd605d9 Mon Sep 17 00:00:00 2001 From: Nekotekina Date: Tue, 4 Sep 2018 13:31:18 +0300 Subject: [PATCH] bs_t<>: add missing operators --- Utilities/bit_set.h | 115 ++++++++++++++++++++++++++------------------ 1 file changed, 67 insertions(+), 48 deletions(-) diff --git a/Utilities/bit_set.h b/Utilities/bit_set.h index 3fa03067de..48b15a57a6 100644 --- a/Utilities/bit_set.h +++ b/Utilities/bit_set.h @@ -41,6 +41,12 @@ private: friend class atomic_bs_t; + // Value constructor + constexpr explicit bs_t(int, under data) + : m_data(data) + { + } + public: static constexpr std::size_t bitmax = sizeof(T) * 8; static constexpr std::size_t bitsize = static_cast(T::__bitset_enum_max); @@ -107,30 +113,22 @@ public: constexpr bs_t operator +(bs_t rhs) const { - bs_t r{}; - r.m_data = m_data | rhs.m_data; - return r; + return bs_t(0, m_data | rhs.m_data); } constexpr bs_t operator -(bs_t rhs) const { - bs_t r{}; - r.m_data = m_data & ~rhs.m_data; - return r; + return bs_t(0, m_data & ~rhs.m_data); } constexpr bs_t operator &(bs_t rhs) const { - bs_t r{}; - r.m_data = m_data & rhs.m_data; - return r; + return bs_t(0, m_data & rhs.m_data); } constexpr bs_t operator ^(bs_t rhs) const { - bs_t r{}; - r.m_data = m_data ^ rhs.m_data; - return r; + return bs_t(0, m_data ^ rhs.m_data); } constexpr bool operator ==(bs_t rhs) const @@ -248,18 +246,19 @@ public: return static_cast(base::load()); } + bs_t operator +() const + { + return base::load(); + } + bs_t fetch_add(const bs_t& rhs) { - bs_t r; - r.m_data = atomic_storage::fetch_or(m_data.m_data, rhs.m_data); - return r; + return bs_t(0, atomic_storage::fetch_or(m_data.m_data, rhs.m_data)); } bs_t add_fetch(const bs_t& rhs) { - bs_t r; - r.m_data = atomic_storage::or_fetch(m_data.m_data, rhs.m_data); - return r; + return bs_t(0, atomic_storage::or_fetch(m_data.m_data, rhs.m_data)); } bs_t operator +=(const bs_t& rhs) @@ -269,16 +268,12 @@ public: bs_t fetch_sub(const bs_t& rhs) { - bs_t r; - r.m_data = atomic_storage::fetch_and(m_data.m_data, ~rhs.m_data); - return r; + return bs_t(0, atomic_storage::fetch_and(m_data.m_data, ~rhs.m_data)); } bs_t sub_fetch(const bs_t& rhs) { - bs_t r; - r.m_data = atomic_storage::and_fetch(m_data.m_data, ~rhs.m_data); - return r; + return bs_t(0, atomic_storage::and_fetch(m_data.m_data, ~rhs.m_data)); } bs_t operator -=(const bs_t& rhs) @@ -288,16 +283,12 @@ public: bs_t fetch_and(const bs_t& rhs) { - bs_t r; - r.m_data = atomic_storage::fetch_and(m_data.m_data, rhs.m_data); - return r; + return bs_t(0, atomic_storage::fetch_and(m_data.m_data, rhs.m_data)); } bs_t and_fetch(const bs_t& rhs) { - bs_t r; - r.m_data = atomic_storage::and_fetch(m_data.m_data, rhs.m_data); - return r; + return bs_t(0, atomic_storage::and_fetch(m_data.m_data, rhs.m_data)); } bs_t operator &=(const bs_t& rhs) @@ -307,16 +298,12 @@ public: bs_t fetch_xor(const bs_t& rhs) { - bs_t r; - r.m_data = atomic_storage::fetch_xor(m_data.m_data, rhs.m_data); - return r; + return bs_t(0, atomic_storage::fetch_xor(m_data.m_data, rhs.m_data)); } bs_t xor_fetch(const bs_t& rhs) { - bs_t r; - r.m_data = atomic_storage::xor_fetch(m_data.m_data, rhs.m_data); - return r; + return bs_t(0, atomic_storage::xor_fetch(m_data.m_data, rhs.m_data)); } bs_t operator ^=(const bs_t& rhs) @@ -334,30 +321,62 @@ public: bs_t operator +(bs_t rhs) const { - bs_t r{}; - r.m_data = base::load().m_data | rhs.m_data; - return r; + return bs_t(0, base::load().m_data | rhs.m_data); } bs_t operator -(bs_t rhs) const { - bs_t r{}; - r.m_data = base::load().m_data & ~rhs.m_data; - return r; + return bs_t(0, base::load().m_data & ~rhs.m_data); } bs_t operator &(bs_t rhs) const { - bs_t r{}; - r.m_data = base::load().m_data & rhs.m_data; - return r; + return bs_t(0, base::load().m_data & rhs.m_data); } bs_t operator ^(bs_t rhs) const { - bs_t r{}; - r.m_data = base::load().m_data ^ rhs.m_data; - return r; + return bs_t(0, base::load().m_data ^ rhs.m_data); + } + + bs_t operator ==(bs_t rhs) const + { + return base::load().m_data == rhs.m_data; + } + + bs_t operator !=(bs_t rhs) const + { + return base::load().m_data != rhs.m_data; + } + + friend bs_t operator +(bs_t lhs, const atomic_bs_t& rhs) + { + return bs_t(0, lhs.m_data | rhs.load().m_data); + } + + friend bs_t operator -(bs_t lhs, const atomic_bs_t& rhs) + { + return bs_t(0, lhs.m_data & ~rhs.load().m_data); + } + + friend bs_t operator &(bs_t lhs, const atomic_bs_t& rhs) + { + return bs_t(0, lhs.m_data & rhs.load().m_data); + } + + friend bs_t operator ^(bs_t lhs, const atomic_bs_t& rhs) + { + return bs_t(0, lhs.m_data ^ rhs.load().m_data); + } + + friend bs_t operator ==(bs_t lhs, const atomic_bs_t& rhs) + { + return lhs.m_data == rhs.load().m_data; + } + + friend bs_t operator !=(bs_t lhs, const atomic_bs_t& rhs) + { + return lhs.m_data != rhs.load().m_data; } bool test(const bs_t& rhs)