From 9c785814e7ce54652534cdad45c2bbecc6fa1a84 Mon Sep 17 00:00:00 2001 From: wwylele Date: Wed, 14 Mar 2018 15:37:47 +0200 Subject: [PATCH] Common/Hash: static_assert on the type passed to HashableStruct --- src/common/hash.h | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/src/common/hash.h b/src/common/hash.h index 042f4e5169..73c326980e 100644 --- a/src/common/hash.h +++ b/src/common/hash.h @@ -22,21 +22,23 @@ static inline u64 ComputeHash64(const void* data, size_t len) { } /** - * Computes a 64-bit hash of a struct. In addition to being POD (trivially copyable and having - * standard layout), it is also critical that either the struct includes no padding, or that any - * padding is initialized to a known value by memsetting the struct to 0 before filling it in. + * Computes a 64-bit hash of a struct. In addition to being trivially copyable, it is also critical + * that either the struct includes no padding, or that any padding is initialized to a known value + * by memsetting the struct to 0 before filling it in. */ template static inline u64 ComputeStructHash64(const T& data) { - static_assert( - std::is_trivially_copyable::value && std::is_standard_layout::value, - "Type passed to ComputeStructHash64 must be trivially copyable and standard layout"); + static_assert(std::is_trivially_copyable(), + "Type passed to ComputeStructHash64 must be trivially copyable"); return ComputeHash64(&data, sizeof(data)); } /// A helper template that ensures the padding in a struct is initialized by memsetting to 0. template 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(), "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