[cfe-commits] [libcxx] r133667 - /libcxx/trunk/test/utilities/utility/pairs/pair.piecewise/piecewise_construct.pass.cpp

Howard Hinnant hhinnant at apple.com
Wed Jun 22 16:51:19 PDT 2011


Author: hhinnant
Date: Wed Jun 22 18:51:19 2011
New Revision: 133667

URL: http://llvm.org/viewvc/llvm-project?rev=133667&view=rev
Log:
test for pair piecewise construction

Modified:
    libcxx/trunk/test/utilities/utility/pairs/pair.piecewise/piecewise_construct.pass.cpp

Modified: libcxx/trunk/test/utilities/utility/pairs/pair.piecewise/piecewise_construct.pass.cpp
URL: http://llvm.org/viewvc/llvm-project/libcxx/trunk/test/utilities/utility/pairs/pair.piecewise/piecewise_construct.pass.cpp?rev=133667&r1=133666&r2=133667&view=diff
==============================================================================
--- libcxx/trunk/test/utilities/utility/pairs/pair.piecewise/piecewise_construct.pass.cpp (original)
+++ libcxx/trunk/test/utilities/utility/pairs/pair.piecewise/piecewise_construct.pass.cpp Wed Jun 22 18:51:19 2011
@@ -15,8 +15,41 @@
 // constexpr piecewise_construct_t piecewise_construct = piecewise_construct_t();
 
 #include <utility>
+#include <tuple>
+#include <cassert>
+
+class A
+{
+    int i_;
+    char c_;
+public:
+    A(int i, char c) : i_(i), c_(c) {}
+    int get_i() const {return i_;}
+    char get_c() const {return c_;}
+};
+
+class B
+{
+    double d_;
+    unsigned u1_;
+    unsigned u2_;
+public:
+    B(double d, unsigned u1, unsigned u2) : d_(d), u1_(u1), u2_(u2) {}
+    double get_d() const {return d_;}
+    unsigned get_u1() const {return u1_;}
+    unsigned get_u2() const {return u2_;}
+};
 
 int main()
 {
-    std::piecewise_construct_t p = std::piecewise_construct;
+#ifndef _LIBCPP_HAS_NO_VARIADICS
+    std::pair<A, B> p(std::piecewise_construct,
+                      std::make_tuple(4, 'a'),
+                      std::make_tuple(3.5, 6u, 2u));
+    assert(p.first.get_i() == 4);
+    assert(p.first.get_c() == 'a');
+    assert(p.second.get_d() == 3.5);
+    assert(p.second.get_u1() == 6u);
+    assert(p.second.get_u2() == 2u);
+#endif
 }





More information about the cfe-commits mailing list