diff options
| author | Lioncash <mathew1800@gmail.com> | 2018-08-07 13:31:57 -0400 | 
|---|---|---|
| committer | Lioncash <mathew1800@gmail.com> | 2018-08-07 19:34:47 -0400 | 
| commit | a7d6efc5201960b351fee4760663388dd946ab8e (patch) | |
| tree | aea37b49caa9b3b71a98a1266d7786ac39079e2f /src/common | |
| parent | 825e8cb9252cdffd3f150ef667ecb95655ab0696 (diff) | |
common: Convert type traits templates over to variable template versions where applicable
Uses the C++17 inline variable variants
Diffstat (limited to 'src/common')
| -rw-r--r-- | src/common/alignment.h | 4 | ||||
| -rw-r--r-- | src/common/bit_set.h | 2 | ||||
| -rw-r--r-- | src/common/file_util.h | 10 | ||||
| -rw-r--r-- | src/common/hash.h | 4 | ||||
| -rw-r--r-- | src/common/x64/xbyak_util.h | 2 | 
5 files changed, 11 insertions, 11 deletions
| diff --git a/src/common/alignment.h b/src/common/alignment.h index b77da4a92..b9dd38746 100644 --- a/src/common/alignment.h +++ b/src/common/alignment.h @@ -9,13 +9,13 @@ namespace Common {  template <typename T>  constexpr T AlignUp(T value, size_t size) { -    static_assert(std::is_unsigned<T>::value, "T must be an unsigned value."); +    static_assert(std::is_unsigned_v<T>, "T must be an unsigned value.");      return static_cast<T>(value + (size - value % size) % size);  }  template <typename T>  constexpr T AlignDown(T value, size_t size) { -    static_assert(std::is_unsigned<T>::value, "T must be an unsigned value."); +    static_assert(std::is_unsigned_v<T>, "T must be an unsigned value.");      return static_cast<T>(value - value % size);  } diff --git a/src/common/bit_set.h b/src/common/bit_set.h index 84e3cbe58..5a197d8c1 100644 --- a/src/common/bit_set.h +++ b/src/common/bit_set.h @@ -96,7 +96,7 @@ static inline int LeastSignificantSetBit(u64 val) {  template <typename IntTy>  class BitSet { -    static_assert(!std::is_signed<IntTy>::value, "BitSet should not be used with signed types"); +    static_assert(!std::is_signed_v<IntTy>, "BitSet should not be used with signed types");  public:      // A reference to a particular bit, returned from operator[]. diff --git a/src/common/file_util.h b/src/common/file_util.h index 28697d527..7f2a5cb63 100644 --- a/src/common/file_util.h +++ b/src/common/file_util.h @@ -207,7 +207,7 @@ public:      template <typename T>      size_t ReadArray(T* data, size_t length) const { -        static_assert(std::is_trivially_copyable<T>(), +        static_assert(std::is_trivially_copyable_v<T>,                        "Given array does not consist of trivially copyable objects");          if (!IsOpen()) @@ -218,7 +218,7 @@ public:      template <typename T>      size_t WriteArray(const T* data, size_t length) { -        static_assert(std::is_trivially_copyable<T>(), +        static_assert(std::is_trivially_copyable_v<T>,                        "Given array does not consist of trivially copyable objects");          if (!IsOpen())              return -1; @@ -227,19 +227,19 @@ public:      template <typename T>      size_t ReadBytes(T* data, size_t length) const { -        static_assert(std::is_trivially_copyable<T>(), "T must be trivially copyable"); +        static_assert(std::is_trivially_copyable_v<T>, "T must be trivially copyable");          return ReadArray(reinterpret_cast<char*>(data), length);      }      template <typename T>      size_t WriteBytes(const T* data, size_t length) { -        static_assert(std::is_trivially_copyable<T>(), "T must be trivially copyable"); +        static_assert(std::is_trivially_copyable_v<T>, "T must be trivially copyable");          return WriteArray(reinterpret_cast<const char*>(data), length);      }      template <typename T>      size_t WriteObject(const T& object) { -        static_assert(!std::is_pointer<T>::value, "Given object is a pointer"); +        static_assert(!std::is_pointer_v<T>, "WriteObject arguments must not be a pointer");          return WriteArray(&object, 1);      } diff --git a/src/common/hash.h b/src/common/hash.h index 73c326980..2c761e545 100644 --- a/src/common/hash.h +++ b/src/common/hash.h @@ -28,7 +28,7 @@ static inline u64 ComputeHash64(const void* data, size_t len) {   */  template <typename T>  static inline u64 ComputeStructHash64(const T& data) { -    static_assert(std::is_trivially_copyable<T>(), +    static_assert(std::is_trivially_copyable_v<T>,                    "Type passed to ComputeStructHash64 must be trivially copyable");      return ComputeHash64(&data, sizeof(data));  } @@ -38,7 +38,7 @@ template <typename T>  struct HashableStruct {      // In addition to being trivially copyable, T must also have a trivial default constructor,      // because any member initialization would be overridden by memset -    static_assert(std::is_trivial<T>(), "Type passed to HashableStruct must be trivial"); +    static_assert(std::is_trivial_v<T>, "Type passed to HashableStruct must be trivial");      /*       * We use a union because "implicitly-defined copy/move constructor for a union X copies the       * object representation of X." and "implicitly-defined copy assignment operator for a union X diff --git a/src/common/x64/xbyak_util.h b/src/common/x64/xbyak_util.h index 0f52f704b..ec76e0a47 100644 --- a/src/common/x64/xbyak_util.h +++ b/src/common/x64/xbyak_util.h @@ -34,7 +34,7 @@ inline bool IsWithin2G(const Xbyak::CodeGenerator& code, uintptr_t target) {  template <typename T>  inline void CallFarFunction(Xbyak::CodeGenerator& code, const T f) { -    static_assert(std::is_pointer<T>(), "Argument must be a (function) pointer."); +    static_assert(std::is_pointer_v<T>, "Argument must be a (function) pointer.");      size_t addr = reinterpret_cast<size_t>(f);      if (IsWithin2G(code, addr)) {          code.call(f); | 
