From 99ad7652614642881e7aa344ff0d9cd13a87196d Mon Sep 17 00:00:00 2001 From: Howard Hinnant Date: Tue, 7 Sep 2010 23:38:59 +0000 Subject: [PATCH] has_trivial_copy_assign hooked up to clang (without workarounds). Filed http://llvm.org/bugs/show_bug.cgi?id=8109 to take care of several types which don't work yet. If there is some reason we don't want to handle these types in the compiler, I can handle most of them in the library. git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@113312 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/type_traits | 12 ++--- .../has_trivial_copy_assign.pass.cpp | 45 +++++++------------ 2 files changed, 20 insertions(+), 37 deletions(-) diff --git a/include/type_traits b/include/type_traits index 0f45f489..2aedd604 100644 --- a/include/type_traits +++ b/include/type_traits @@ -769,20 +769,14 @@ template struct has_copy_assign; #if defined(__clang__) || (__GNUC__ >= 4 && __GNUC_MINOR__ >= 3) -template ::value> -struct __has_trivial_copy_assign - : public integral_constant {}; - -template struct __has_trivial_copy_assign<_Tp, true> - : public false_type {}; - template struct has_trivial_copy_assign - : __has_trivial_copy_assign<_Tp> {}; + : public integral_constant {}; #else template struct has_trivial_copy_assign - : public integral_constant::value && !is_const<_Tp>::value> {}; + : public integral_constant::value && + !is_const<_Tp>::value> {}; #endif // defined(__clang__) || (__GNUC__ >= 4 && __GNUC_MINOR__ >= 3) diff --git a/test/utilities/meta/meta.unary/meta.unary.prop/has_trivial_copy_assign.pass.cpp b/test/utilities/meta/meta.unary/meta.unary.prop/has_trivial_copy_assign.pass.cpp index 9993cbdc..061277a1 100644 --- a/test/utilities/meta/meta.unary/meta.unary.prop/has_trivial_copy_assign.pass.cpp +++ b/test/utilities/meta/meta.unary/meta.unary.prop/has_trivial_copy_assign.pass.cpp @@ -13,22 +13,10 @@ #include -template +template void test_has_trivial_assign() { - static_assert( std::has_trivial_copy_assign::value, ""); - static_assert(!std::has_trivial_copy_assign::value, ""); - static_assert( std::has_trivial_copy_assign::value, ""); - static_assert(!std::has_trivial_copy_assign::value, ""); -} - -template -void test_has_not_trivial_assign() -{ - static_assert(!std::has_trivial_copy_assign::value, ""); - static_assert(!std::has_trivial_copy_assign::value, ""); - static_assert(!std::has_trivial_copy_assign::value, ""); - static_assert(!std::has_trivial_copy_assign::value, ""); + static_assert(std::has_trivial_copy_assign::value == Result, ""); } class Empty @@ -59,19 +47,20 @@ struct A int main() { - test_has_not_trivial_assign(); - test_has_not_trivial_assign(); - test_has_not_trivial_assign(); - test_has_not_trivial_assign(); - test_has_not_trivial_assign(); + test_has_trivial_assign(); + test_has_trivial_assign(); + test_has_trivial_assign(); + test_has_trivial_assign(); + test_has_trivial_assign(); + test_has_trivial_assign(); + test_has_trivial_assign(); + test_has_trivial_assign(); - test_has_trivial_assign(); - test_has_trivial_assign(); - test_has_trivial_assign(); - test_has_trivial_assign(); - test_has_trivial_assign(); - test_has_trivial_assign(); - test_has_trivial_assign(); - test_has_trivial_assign(); - test_has_trivial_assign(); + test_has_trivial_assign(); + test_has_trivial_assign(); + test_has_trivial_assign(); + test_has_trivial_assign(); + test_has_trivial_assign(); + test_has_trivial_assign(); + test_has_trivial_assign(); }