aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/common/bit_field.h
diff options
context:
space:
mode:
authorGravatar Tony Wasserka <NeoBrainX@gmail.com>2014-07-16 09:07:57 +0200
committerGravatar Tony Wasserka <NeoBrainX@gmail.com>2014-07-16 09:08:19 +0200
commit15ab5382a553a47f21fe7283010ccdb342c0ead6 (patch)
tree3574ab838cf91b43a34642566b1d63e8368a1ac7 /src/common/bit_field.h
parent47a001722d7ada681e333e991373e19d159c380b (diff)
BitField: Delete copy assignment to prevent obscure bugs.
Diffstat (limited to 'src/common/bit_field.h')
-rw-r--r--src/common/bit_field.h16
1 files changed, 16 insertions, 0 deletions
diff --git a/src/common/bit_field.h b/src/common/bit_field.h
index a39bb988..c28e722c 100644
--- a/src/common/bit_field.h
+++ b/src/common/bit_field.h
@@ -124,6 +124,22 @@ public:
// so that we can use this within unions
BitField() = default;
+#ifndef _WIN32
+ // We explicitly delete the copy assigment operator here, because the
+ // default copy assignment would copy the full storage value, rather than
+ // just the bits relevant to this particular bit field.
+ // Ideally, we would just implement the copy assignment to copy only the
+ // relevant bits, but this requires compiler support for unrestricted
+ // unions.
+ // MSVC 2013 has no support for this, hence we disable this code on
+ // Windows (so that the default copy assignment operator will be used).
+ // For any C++11 conformant compiler we delete the operator to make sure
+ // we never use this inappropriate operator to begin with.
+ // TODO: Implement this operator properly once all target compilers
+ // support unrestricted unions.
+ BitField& operator=(const BitField&) = delete;
+#endif
+
__forceinline BitField& operator=(T val)
{
storage = (storage & ~GetMask()) | ((val << position) & GetMask());