summaryrefslogtreecommitdiff
path: root/src/common/bit_field.h
diff options
context:
space:
mode:
authorRodrigo Locatti <reinuseslisp@airmail.cc>2019-11-15 18:49:20 -0300
committerGitHub <noreply@github.com>2019-11-15 18:49:20 -0300
commit3026aec9bd2c5217ccaea5d00d4463493bb68286 (patch)
tree9eb76fec0c779ca53477c1b3bdf03a9909718ea2 /src/common/bit_field.h
parenta8295d2c533d1628887bd45d3bfd8adb66281834 (diff)
parent14581e4a59cfe983cae397850a091d866eee045c (diff)
Merge pull request #3106 from lioncash/bitfield
common/bit_field: Silence sign-conversion warnings
Diffstat (limited to 'src/common/bit_field.h')
-rw-r--r--src/common/bit_field.h5
1 files changed, 3 insertions, 2 deletions
diff --git a/src/common/bit_field.h b/src/common/bit_field.h
index fd2bbbd99..2dbe37839 100644
--- a/src/common/bit_field.h
+++ b/src/common/bit_field.h
@@ -135,7 +135,8 @@ public:
/// Constants to allow limited introspection of fields if needed
static constexpr std::size_t position = Position;
static constexpr std::size_t bits = Bits;
- static constexpr StorageType mask = (((StorageType)~0) >> (8 * sizeof(T) - bits)) << position;
+ static constexpr StorageType mask = StorageType(
+ (std::numeric_limits<StorageType>::max() >> (8 * sizeof(T) - bits)) << position);
/**
* Formats a value by masking and shifting it according to the field parameters. A value
@@ -143,7 +144,7 @@ public:
* the results together.
*/
static constexpr FORCE_INLINE StorageType FormatValue(const T& value) {
- return ((StorageType)value << position) & mask;
+ return (static_cast<StorageType>(value) << position) & mask;
}
/**