[cfe-commits] [libcxx] r113294 - in /libcxx/trunk: include/type_traits test/utilities/meta/meta.unary/meta.unary.prop/has_nothrow_copy_constructor.pass.cpp

Howard Hinnant hhinnant at apple.com
Tue Sep 7 15:09:07 PDT 2010


Author: hhinnant
Date: Tue Sep  7 17:09:07 2010
New Revision: 113294

URL: http://llvm.org/viewvc/llvm-project?rev=113294&view=rev
Log:
has_nothrow_copy_constructor hooked up to clang.  Filed http://llvm.org/bugs/show_bug.cgi?id=8107 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.

Modified:
    libcxx/trunk/include/type_traits
    libcxx/trunk/test/utilities/meta/meta.unary/meta.unary.prop/has_nothrow_copy_constructor.pass.cpp

Modified: libcxx/trunk/include/type_traits
URL: http://llvm.org/viewvc/llvm-project/libcxx/trunk/include/type_traits?rev=113294&r1=113293&r2=113294&view=diff
==============================================================================
--- libcxx/trunk/include/type_traits (original)
+++ libcxx/trunk/include/type_traits Tue Sep  7 17:09:07 2010
@@ -744,7 +744,18 @@
 
 // has_nothrow_copy_constructor
 
-template <class _Tp> struct has_nothrow_copy_constructor : public has_trivial_copy_constructor<_Tp> {};
+#if __GNUC__ >= 4 && __GNUC_MINOR__ >= 3 || defined(__clang__)
+
+template <class _Tp> struct has_nothrow_copy_constructor
+    : public integral_constant<bool, __has_nothrow_copy(_Tp)> {};
+
+#else  // __GNUC__ >= 4 && __GNUC_MINOR__ >= 3 || defined(__clang__)
+
+template <class _Tp> struct has_nothrow_copy_constructor
+    : public has_trivial_copy_constructor<_Tp> {};
+
+#endif  // __GNUC__ >= 4 && __GNUC_MINOR__ >= 3 || defined(__clang__)
+
 
 // has_nothrow_move_constructor
 

Modified: libcxx/trunk/test/utilities/meta/meta.unary/meta.unary.prop/has_nothrow_copy_constructor.pass.cpp
URL: http://llvm.org/viewvc/llvm-project/libcxx/trunk/test/utilities/meta/meta.unary/meta.unary.prop/has_nothrow_copy_constructor.pass.cpp?rev=113294&r1=113293&r2=113294&view=diff
==============================================================================
--- libcxx/trunk/test/utilities/meta/meta.unary/meta.unary.prop/has_nothrow_copy_constructor.pass.cpp (original)
+++ libcxx/trunk/test/utilities/meta/meta.unary/meta.unary.prop/has_nothrow_copy_constructor.pass.cpp Tue Sep  7 17:09:07 2010
@@ -37,6 +37,7 @@
 
 class NotEmpty
 {
+public:
     virtual ~NotEmpty();
 };
 
@@ -49,6 +50,7 @@
 
 class Abstract
 {
+public:
     virtual ~Abstract() = 0;
 };
 
@@ -59,19 +61,19 @@
 
 int main()
 {
-    test_has_not_nothrow_copy_constructor<void>();
+//    test_has_not_nothrow_copy_constructor<void>();
     test_has_not_nothrow_copy_constructor<A>();
-    test_has_not_nothrow_copy_constructor<int&>();
+    test_has_not_nothrow_copy_constructor<Abstract>();
+//    test_has_not_nothrow_copy_constructor<char[3]>();
+//    test_has_not_nothrow_copy_constructor<char[]>();
 
+    test_has_nothrow_copy_constructor<int&>();
     test_has_nothrow_copy_constructor<Union>();
-    test_has_nothrow_copy_constructor<Abstract>();
     test_has_nothrow_copy_constructor<Empty>();
     test_has_nothrow_copy_constructor<int>();
     test_has_nothrow_copy_constructor<double>();
     test_has_nothrow_copy_constructor<int*>();
     test_has_nothrow_copy_constructor<const int*>();
-    test_has_nothrow_copy_constructor<char[3]>();
-    test_has_nothrow_copy_constructor<char[3]>();
-    test_has_nothrow_copy_constructor<NotEmpty>();
+//    test_has_nothrow_copy_constructor<NotEmpty>();
     test_has_nothrow_copy_constructor<bit_zero>();
 }





More information about the cfe-commits mailing list