Commit 56a90a20 authored by Nico Weber's avatar Nico Weber

Let GOOGLE_COMPILE_ASSERT use static_assert if available.

The motivation is that gcc 4.8+ and clang trunk warn on unused local
typedefs, which COMPILE_ASSERT adds. After this change, the warning
will be happy at least in C++11 builds. static_assert also produces a
slighly nicer diagnostic than the typedef method.

https://github.com/google/re2/commit/eb93e8bc43ac8d05322fb3e9fc885898ad924f8a
did the same change in re2.
parent 798ed10e
...@@ -113,12 +113,13 @@ struct CompileAssert { ...@@ -113,12 +113,13 @@ struct CompileAssert {
} // namespace internal } // namespace internal
#undef GOOGLE_COMPILE_ASSERT #undef GOOGLE_COMPILE_ASSERT
#if __cplusplus >= 201103L
#define GOOGLE_COMPILE_ASSERT(expr, msg) static_assert(expr, #msg)
#else
#define GOOGLE_COMPILE_ASSERT(expr, msg) \ #define GOOGLE_COMPILE_ASSERT(expr, msg) \
::google::protobuf::internal::CompileAssert<(bool(expr))> \ ::google::protobuf::internal::CompileAssert<(bool(expr))> \
msg[bool(expr) ? 1 : -1]; \ msg[bool(expr) ? 1 : -1]; \
(void)msg (void)msg
// Implementation details of COMPILE_ASSERT: // Implementation details of COMPILE_ASSERT:
// //
// - COMPILE_ASSERT works by defining an array type that has -1 // - COMPILE_ASSERT works by defining an array type that has -1
...@@ -159,6 +160,7 @@ struct CompileAssert { ...@@ -159,6 +160,7 @@ struct CompileAssert {
// //
// This is to avoid running into a bug in MS VC 7.1, which // This is to avoid running into a bug in MS VC 7.1, which
// causes ((0.0) ? 1 : -1) to incorrectly evaluate to 1. // causes ((0.0) ? 1 : -1) to incorrectly evaluate to 1.
#endif // __cplusplus >= 201103L
} // namespace protobuf } // namespace protobuf
} // namespace google } // namespace google
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment