summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLioncash <mathew1800@gmail.com>2020-08-24 10:39:26 +0200
committerLioncash <mathew1800@gmail.com>2020-08-24 10:42:43 +0200
commit504175e5b6889c5c07582561f762a1329d829fb0 (patch)
treece43f015e88720f563a5c38be6acd5dfeff19416
parentMerge pull request #4573 from lioncash/label (diff)
downloadyuzu-504175e5b6889c5c07582561f762a1329d829fb0.tar
yuzu-504175e5b6889c5c07582561f762a1329d829fb0.tar.gz
yuzu-504175e5b6889c5c07582561f762a1329d829fb0.tar.bz2
yuzu-504175e5b6889c5c07582561f762a1329d829fb0.tar.lz
yuzu-504175e5b6889c5c07582561f762a1329d829fb0.tar.xz
yuzu-504175e5b6889c5c07582561f762a1329d829fb0.tar.zst
yuzu-504175e5b6889c5c07582561f762a1329d829fb0.zip
-rw-r--r--src/common/common_funcs.h14
1 files changed, 10 insertions, 4 deletions
diff --git a/src/common/common_funcs.h b/src/common/common_funcs.h
index 98421bced..367b6bf6e 100644
--- a/src/common/common_funcs.h
+++ b/src/common/common_funcs.h
@@ -64,14 +64,20 @@ __declspec(dllimport) void __stdcall DebugBreak(void);
using T = std::underlying_type_t<type>; \
return static_cast<type>(static_cast<T>(a) & static_cast<T>(b)); \
} \
- constexpr type& operator|=(type& a, type b) noexcept { \
+ [[nodiscard]] constexpr type operator^(type a, type b) noexcept { \
using T = std::underlying_type_t<type>; \
- a = static_cast<type>(static_cast<T>(a) | static_cast<T>(b)); \
+ return static_cast<type>(static_cast<T>(a) ^ static_cast<T>(b)); \
+ } \
+ constexpr type& operator|=(type& a, type b) noexcept { \
+ a = a | b; \
return a; \
} \
constexpr type& operator&=(type& a, type b) noexcept { \
- using T = std::underlying_type_t<type>; \
- a = static_cast<type>(static_cast<T>(a) & static_cast<T>(b)); \
+ a = a & b; \
+ return a; \
+ } \
+ constexpr type& operator^=(type& a, type b) noexcept { \
+ a = a ^ b; \
return a; \
} \
[[nodiscard]] constexpr type operator~(type key) noexcept { \