Work around bug in initialization of std::array base class with older clangs
authorEric Fiselier <eric@efcs.ca>
Wed, 14 Dec 2016 23:24:12 +0000 (23:24 +0000)
committerEric Fiselier <eric@efcs.ca>
Wed, 14 Dec 2016 23:24:12 +0000 (23:24 +0000)
llvm-svn: 289741

libcxx/test/std/utilities/tuple/tuple.tuple/tuple.assign/derived_from_tuple_like.pass.cpp
libcxx/test/std/utilities/tuple/tuple.tuple/tuple.cnstr/derived_from_tuple_like.pass.cpp

index 82bb898..c9496d0 100644 (file)
@@ -95,7 +95,9 @@ void do_derived_assign_test() {
   }
   reset();
   {
-    DerivedFromTup<std::array<int, 2>> d = {{{42, 101}}};
+    DerivedFromTup<std::array<int, 2>> d;
+    d[0] = 42;
+    d[1] = 101;
     t = ValueCategoryCast<VC>(d);
     assert(std::get<0>(t) == 42);
     assert(std::get<1>(t).checkAssign(101, VC));
index 233a308..53b1e30 100644 (file)
@@ -103,7 +103,9 @@ void do_derived_construct_test() {
     assert(std::get<1>(t).checkConstruct(101, VC));
   }
   {
-    DerivedFromTup<std::array<int, 2>> d = {{{42, 101}}};
+    DerivedFromTup<std::array<int, 2>> d;
+    d[0] = 42;
+    d[1] = 101;
     Tup1 t = ValueCategoryCast<VC>(d);
     assert(std::get<0>(t) == 42);
     assert(std::get<1>(t).checkConstruct(101, VC));
@@ -132,7 +134,9 @@ void do_derived_construct_test() {
     using D = DerivedFromTup<std::array<int, 2>>;
     static_assert(!std::is_convertible<ApplyValueCategoryT<VC, D>, Tup2>::value,
                   "");
-    D d = {{{42, 101}}};
+    D d;
+    d[0] = 42;
+    d[1] = 101;
     Tup2 t(ValueCategoryCast<VC>(d));
     assert(std::get<0>(t) == 42);
     assert(std::get<1>(t).checkConstruct(101, VC));