mirror of
https://github.com/RPCSX/llvm.git
synced 2024-11-28 22:20:37 +00:00
[C++11] Replace LLVM_STATIC_ASSERT with static_assert, we now have
access to it on all host toolchains. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@202642 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
742e43f807
commit
fc6d7d6cf5
@ -333,19 +333,6 @@
|
||||
#define LLVM_EXPLICIT
|
||||
#endif
|
||||
|
||||
/// \macro LLVM_STATIC_ASSERT
|
||||
/// \brief Expands to C/C++'s static_assert on compilers which support it.
|
||||
#if __has_feature(cxx_static_assert) || \
|
||||
defined(__GXX_EXPERIMENTAL_CXX0X__) || LLVM_MSC_PREREQ(1600)
|
||||
# define LLVM_STATIC_ASSERT(expr, msg) static_assert(expr, msg)
|
||||
#elif __has_feature(c_static_assert)
|
||||
# define LLVM_STATIC_ASSERT(expr, msg) _Static_assert(expr, msg)
|
||||
#elif __has_extension(c_static_assert)
|
||||
# define LLVM_STATIC_ASSERT(expr, msg) LLVM_EXTENSION _Static_assert(expr, msg)
|
||||
#else
|
||||
# define LLVM_STATIC_ASSERT(expr, msg)
|
||||
#endif
|
||||
|
||||
/// \brief Does the compiler support generalized initializers (using braced
|
||||
/// lists and std::initializer_list). While clang may claim it supports general
|
||||
/// initializers, if we're using MSVC's headers, we might not have a usable
|
||||
|
@ -27,7 +27,7 @@ using namespace sys;
|
||||
ThreadLocalImpl::ThreadLocalImpl() : data() { }
|
||||
ThreadLocalImpl::~ThreadLocalImpl() { }
|
||||
void ThreadLocalImpl::setInstance(const void* d) {
|
||||
LLVM_STATIC_ASSERT(sizeof(d) <= sizeof(data), "size too big");
|
||||
static_assert(sizeof(d) <= sizeof(data), "size too big");
|
||||
void **pd = reinterpret_cast<void**>(&data);
|
||||
*pd = const_cast<void*>(d);
|
||||
}
|
||||
@ -51,7 +51,7 @@ namespace llvm {
|
||||
using namespace sys;
|
||||
|
||||
ThreadLocalImpl::ThreadLocalImpl() : data() {
|
||||
LLVM_STATIC_ASSERT(sizeof(pthread_key_t) <= sizeof(data), "size too big");
|
||||
static_assert(sizeof(pthread_key_t) <= sizeof(data), "size too big");
|
||||
pthread_key_t* key = reinterpret_cast<pthread_key_t*>(&data);
|
||||
int errorcode = pthread_key_create(key, NULL);
|
||||
assert(errorcode == 0);
|
||||
|
@ -117,8 +117,7 @@ TYPED_TEST(ValueMapTest, OperationsWork) {
|
||||
|
||||
template<typename ExpectedType, typename VarType>
|
||||
void CompileAssertHasType(VarType) {
|
||||
LLVM_STATIC_ASSERT((is_same<ExpectedType, VarType>::value),
|
||||
"Not the same type");
|
||||
static_assert((is_same<ExpectedType, VarType>::value), "Not the same type");
|
||||
}
|
||||
|
||||
TYPED_TEST(ValueMapTest, Iteration) {
|
||||
|
Loading…
Reference in New Issue
Block a user