diff options
author | Eric Fiselier <eric@efcs.ca> | 2016-08-11 07:04:14 +0000 |
---|---|---|
committer | Eric Fiselier <eric@efcs.ca> | 2016-08-11 07:04:14 +0000 |
commit | a3e11a5b1596d78ec69e88533ea9e1773cd57496 (patch) | |
tree | 01b9a4e73edad75845773eef8c8c243460972406 /libcxx/test/std/utilities/utility | |
parent | a78b768ed42c50d50386316cec7dd48c56087087 (diff) | |
download | bcm5719-llvm-a3e11a5b1596d78ec69e88533ea9e1773cd57496.tar.gz bcm5719-llvm-a3e11a5b1596d78ec69e88533ea9e1773cd57496.zip |
Refactor test archetypes implementation.
llvm-svn: 278319
Diffstat (limited to 'libcxx/test/std/utilities/utility')
6 files changed, 74 insertions, 68 deletions
diff --git a/libcxx/test/std/utilities/utility/pairs/pairs.pair/U_V.pass.cpp b/libcxx/test/std/utilities/utility/pairs/pairs.pair/U_V.pass.cpp index 0598c2da51d..1ef2d9402fc 100644 --- a/libcxx/test/std/utilities/utility/pairs/pairs.pair/U_V.pass.cpp +++ b/libcxx/test/std/utilities/utility/pairs/pairs.pair/U_V.pass.cpp @@ -22,6 +22,7 @@ #include "archetypes.hpp" #include "test_convertible.hpp" +using namespace ImplicitTypes; // Get implicitly archetypes template <class T1, class T1Arg, bool CanCopy = true, bool CanConvert = CanCopy> @@ -58,20 +59,20 @@ int main() // Test non-const lvalue and rvalue types test_sfinae<AllCtors, AllCtors&>(); test_sfinae<AllCtors, AllCtors&&>(); - test_sfinae<ExplicitAllCtors, ExplicitAllCtors&, true, false>(); - test_sfinae<ExplicitAllCtors, ExplicitAllCtors&&, true, false>(); + test_sfinae<ExplicitTypes::AllCtors, ExplicitTypes::AllCtors&, true, false>(); + test_sfinae<ExplicitTypes::AllCtors, ExplicitTypes::AllCtors&&, true, false>(); test_sfinae<CopyOnly, CopyOnly&>(); test_sfinae<CopyOnly, CopyOnly&&>(); - test_sfinae<ExplicitCopyOnly, ExplicitCopyOnly&, true, false>(); - test_sfinae<ExplicitCopyOnly, ExplicitCopyOnly&&, true, false>(); + test_sfinae<ExplicitTypes::CopyOnly, ExplicitTypes::CopyOnly&, true, false>(); + test_sfinae<ExplicitTypes::CopyOnly, ExplicitTypes::CopyOnly&&, true, false>(); test_sfinae<MoveOnly, MoveOnly&, false>(); test_sfinae<MoveOnly, MoveOnly&&>(); - test_sfinae<ExplicitMoveOnly, ExplicitMoveOnly&, false>(); - test_sfinae<ExplicitMoveOnly, ExplicitMoveOnly&&, true, false>(); + test_sfinae<ExplicitTypes::MoveOnly, ExplicitTypes::MoveOnly&, false>(); + test_sfinae<ExplicitTypes::MoveOnly, ExplicitTypes::MoveOnly&&, true, false>(); test_sfinae<NonCopyable, NonCopyable&, false>(); test_sfinae<NonCopyable, NonCopyable&&, false>(); - test_sfinae<ExplicitNonCopyable, ExplicitNonCopyable&, false>(); - test_sfinae<ExplicitNonCopyable, ExplicitNonCopyable&&, false>(); + test_sfinae<ExplicitTypes::NonCopyable, ExplicitTypes::NonCopyable&, false>(); + test_sfinae<ExplicitTypes::NonCopyable, ExplicitTypes::NonCopyable&&, false>(); } { // Test converting types @@ -79,10 +80,10 @@ int main() test_sfinae<ConvertingType, const int&>(); test_sfinae<ConvertingType, int&&>(); test_sfinae<ConvertingType, const int&&>(); - test_sfinae<ExplicitConvertingType, int&, true, false>(); - test_sfinae<ExplicitConvertingType, const int&, true, false>(); - test_sfinae<ExplicitConvertingType, int&&, true, false>(); - test_sfinae<ExplicitConvertingType, const int&&, true, false>(); + test_sfinae<ExplicitTypes::ConvertingType, int&, true, false>(); + test_sfinae<ExplicitTypes::ConvertingType, const int&, true, false>(); + test_sfinae<ExplicitTypes::ConvertingType, int&&, true, false>(); + test_sfinae<ExplicitTypes::ConvertingType, const int&&, true, false>(); } #if TEST_STD_VER > 11 { // explicit constexpr test diff --git a/libcxx/test/std/utilities/utility/pairs/pairs.pair/const_first_const_second.pass.cpp b/libcxx/test/std/utilities/utility/pairs/pairs.pair/const_first_const_second.pass.cpp index e3b780a0ec7..bf19d1abe4c 100644 --- a/libcxx/test/std/utilities/utility/pairs/pairs.pair/const_first_const_second.pass.cpp +++ b/libcxx/test/std/utilities/utility/pairs/pairs.pair/const_first_const_second.pass.cpp @@ -20,6 +20,7 @@ #include "archetypes.hpp" #include "test_convertible.hpp" +using namespace ImplicitTypes; // Get implicitly archetypes struct ExplicitT { constexpr explicit ExplicitT(int x) : value(x) {} @@ -62,13 +63,13 @@ int main() } { test_sfinae<AllCtors>(); - test_sfinae<ExplicitAllCtors, true, false>(); + test_sfinae<ExplicitTypes::AllCtors, true, false>(); test_sfinae<CopyOnly>(); - test_sfinae<ExplicitCopyOnly, true, false>(); + test_sfinae<ExplicitTypes::CopyOnly, true, false>(); test_sfinae<MoveOnly, false>(); - test_sfinae<ExplicitMoveOnly, false>(); + test_sfinae<ExplicitTypes::MoveOnly, false>(); test_sfinae<NonCopyable, false>(); - test_sfinae<ExplicitNonCopyable, false>(); + test_sfinae<ExplicitTypes::NonCopyable, false>(); } #if TEST_STD_VER > 11 { diff --git a/libcxx/test/std/utilities/utility/pairs/pairs.pair/const_pair_U_V.pass.cpp b/libcxx/test/std/utilities/utility/pairs/pairs.pair/const_pair_U_V.pass.cpp index ce9c2ccd413..ade8130d782 100644 --- a/libcxx/test/std/utilities/utility/pairs/pairs.pair/const_pair_U_V.pass.cpp +++ b/libcxx/test/std/utilities/utility/pairs/pairs.pair/const_pair_U_V.pass.cpp @@ -20,6 +20,7 @@ #include "archetypes.hpp" #include "test_convertible.hpp" +using namespace ImplicitTypes; // Get implicitly archetypes template <class T1, class U1, bool CanCopy = true, bool CanConvert = CanCopy> @@ -79,27 +80,27 @@ int main() test_pair_const<AllCtors, const AllCtors&>(); test_pair_const<AllCtors, const AllCtors&&>(); - test_pair_const<ExplicitAllCtors, ExplicitAllCtors>(); // copy construction - test_pair_const<ExplicitAllCtors, ExplicitAllCtors&, true, false>(); - test_pair_const<ExplicitAllCtors, ExplicitAllCtors&&, true, false>(); - test_pair_const<ExplicitAllCtors, const ExplicitAllCtors&, true, false>(); - test_pair_const<ExplicitAllCtors, const ExplicitAllCtors&&, true, false>(); + test_pair_const<ExplicitTypes::AllCtors, ExplicitTypes::AllCtors>(); // copy construction + test_pair_const<ExplicitTypes::AllCtors, ExplicitTypes::AllCtors&, true, false>(); + test_pair_const<ExplicitTypes::AllCtors, ExplicitTypes::AllCtors&&, true, false>(); + test_pair_const<ExplicitTypes::AllCtors, const ExplicitTypes::AllCtors&, true, false>(); + test_pair_const<ExplicitTypes::AllCtors, const ExplicitTypes::AllCtors&&, true, false>(); test_pair_const<MoveOnly, MoveOnly, false>(); // copy construction test_pair_const<MoveOnly, MoveOnly&, false>(); test_pair_const<MoveOnly, MoveOnly&&, false>(); - test_pair_const<ExplicitMoveOnly, ExplicitMoveOnly, false>(); // copy construction - test_pair_const<ExplicitMoveOnly, ExplicitMoveOnly&, false>(); - test_pair_const<ExplicitMoveOnly, ExplicitMoveOnly&&, false>(); + test_pair_const<ExplicitTypes::MoveOnly, ExplicitTypes::MoveOnly, false>(); // copy construction + test_pair_const<ExplicitTypes::MoveOnly, ExplicitTypes::MoveOnly&, false>(); + test_pair_const<ExplicitTypes::MoveOnly, ExplicitTypes::MoveOnly&&, false>(); test_pair_const<CopyOnly, CopyOnly>(); test_pair_const<CopyOnly, CopyOnly&>(); test_pair_const<CopyOnly, CopyOnly&&>(); - test_pair_const<ExplicitCopyOnly, ExplicitCopyOnly>(); - test_pair_const<ExplicitCopyOnly, ExplicitCopyOnly&, true, false>(); - test_pair_const<ExplicitCopyOnly, ExplicitCopyOnly&&, true, false>(); + test_pair_const<ExplicitTypes::CopyOnly, ExplicitTypes::CopyOnly>(); + test_pair_const<ExplicitTypes::CopyOnly, ExplicitTypes::CopyOnly&, true, false>(); + test_pair_const<ExplicitTypes::CopyOnly, ExplicitTypes::CopyOnly&&, true, false>(); test_pair_const<NonCopyable, NonCopyable, false>(); test_pair_const<NonCopyable, NonCopyable&, false>(); @@ -116,23 +117,23 @@ int main() test_pair_const<NonCopyable&&, NonCopyable&&, false>(); test_pair_const<ConvertingType&, int, false>(); - test_pair_const<ExplicitConvertingType&, int, false>(); + test_pair_const<ExplicitTypes::ConvertingType&, int, false>(); // Unfortunately the below conversions are allowed and create dangling // references. //test_pair_const<ConvertingType&&, int>(); //test_pair_const<ConvertingType const&, int>(); //test_pair_const<ConvertingType const&&, int>(); // But these are not because the converting constructor is explicit. - test_pair_const<ExplicitConvertingType&&, int, false>(); - test_pair_const<ExplicitConvertingType const&, int, false>(); - test_pair_const<ExplicitConvertingType const&&, int, false>(); + test_pair_const<ExplicitTypes::ConvertingType&&, int, false>(); + test_pair_const<ExplicitTypes::ConvertingType const&, int, false>(); + test_pair_const<ExplicitTypes::ConvertingType const&&, int, false>(); } { test_pair_const<AllCtors, int, false>(); - test_pair_const<ExplicitAllCtors, int, false>(); + test_pair_const<ExplicitTypes::AllCtors, int, false>(); test_pair_const<ConvertingType, int>(); - test_pair_const<ExplicitConvertingType, int, true, false>(); + test_pair_const<ExplicitTypes::ConvertingType, int, true, false>(); test_pair_const<ConvertingType, int>(); test_pair_const<ConvertingType, ConvertingType>(); @@ -140,16 +141,16 @@ int main() test_pair_const<ConvertingType, ConvertingType&>(); test_pair_const<ConvertingType, ConvertingType&&>(); - test_pair_const<ExplicitConvertingType, int, true, false>(); - test_pair_const<ExplicitConvertingType, int&, true, false>(); - test_pair_const<ExplicitConvertingType, const int&, true, false>(); - test_pair_const<ExplicitConvertingType, int&&, true, false>(); - test_pair_const<ExplicitConvertingType, const int&&, true, false>(); + test_pair_const<ExplicitTypes::ConvertingType, int, true, false>(); + test_pair_const<ExplicitTypes::ConvertingType, int&, true, false>(); + test_pair_const<ExplicitTypes::ConvertingType, const int&, true, false>(); + test_pair_const<ExplicitTypes::ConvertingType, int&&, true, false>(); + test_pair_const<ExplicitTypes::ConvertingType, const int&&, true, false>(); - test_pair_const<ExplicitConvertingType, ExplicitConvertingType>(); - test_pair_const<ExplicitConvertingType, ExplicitConvertingType const&, true, false>(); - test_pair_const<ExplicitConvertingType, ExplicitConvertingType&, true, false>(); - test_pair_const<ExplicitConvertingType, ExplicitConvertingType&&, true, false>(); + test_pair_const<ExplicitTypes::ConvertingType, ExplicitTypes::ConvertingType>(); + test_pair_const<ExplicitTypes::ConvertingType, ExplicitTypes::ConvertingType const&, true, false>(); + test_pair_const<ExplicitTypes::ConvertingType, ExplicitTypes::ConvertingType&, true, false>(); + test_pair_const<ExplicitTypes::ConvertingType, ExplicitTypes::ConvertingType&&, true, false>(); } #if TEST_STD_VER > 11 { diff --git a/libcxx/test/std/utilities/utility/pairs/pairs.pair/default.pass.cpp b/libcxx/test/std/utilities/utility/pairs/pairs.pair/default.pass.cpp index e6965412539..91af3756983 100644 --- a/libcxx/test/std/utilities/utility/pairs/pairs.pair/default.pass.cpp +++ b/libcxx/test/std/utilities/utility/pairs/pairs.pair/default.pass.cpp @@ -28,6 +28,7 @@ #include "test_macros.h" #include "archetypes.hpp" +using namespace ImplicitTypes; // Get implicitly archetypes int main() { diff --git a/libcxx/test/std/utilities/utility/pairs/pairs.pair/rv_pair_U_V.pass.cpp b/libcxx/test/std/utilities/utility/pairs/pairs.pair/rv_pair_U_V.pass.cpp index f10fae4f9ef..2856190841c 100644 --- a/libcxx/test/std/utilities/utility/pairs/pairs.pair/rv_pair_U_V.pass.cpp +++ b/libcxx/test/std/utilities/utility/pairs/pairs.pair/rv_pair_U_V.pass.cpp @@ -21,6 +21,7 @@ #include "archetypes.hpp" #include "test_convertible.hpp" +using namespace ImplicitTypes; // Get implicitly archetypes template <class T1, class U1, bool CanCopy = true, bool CanConvert = CanCopy> @@ -89,27 +90,27 @@ int main() test_pair_rv<AllCtors, const AllCtors&>(); test_pair_rv<AllCtors, const AllCtors&&>(); - test_pair_rv<ExplicitAllCtors, ExplicitAllCtors>(); - test_pair_rv<ExplicitAllCtors, ExplicitAllCtors&, true, false>(); - test_pair_rv<ExplicitAllCtors, ExplicitAllCtors&&, true, false>(); - test_pair_rv<ExplicitAllCtors, const ExplicitAllCtors&, true, false>(); - test_pair_rv<ExplicitAllCtors, const ExplicitAllCtors&&, true, false>(); + test_pair_rv<ExplicitTypes::AllCtors, ExplicitTypes::AllCtors>(); + test_pair_rv<ExplicitTypes::AllCtors, ExplicitTypes::AllCtors&, true, false>(); + test_pair_rv<ExplicitTypes::AllCtors, ExplicitTypes::AllCtors&&, true, false>(); + test_pair_rv<ExplicitTypes::AllCtors, const ExplicitTypes::AllCtors&, true, false>(); + test_pair_rv<ExplicitTypes::AllCtors, const ExplicitTypes::AllCtors&&, true, false>(); test_pair_rv<MoveOnly, MoveOnly>(); test_pair_rv<MoveOnly, MoveOnly&, false>(); test_pair_rv<MoveOnly, MoveOnly&&>(); - test_pair_rv<ExplicitMoveOnly, ExplicitMoveOnly>(); // copy construction - test_pair_rv<ExplicitMoveOnly, ExplicitMoveOnly&, false>(); - test_pair_rv<ExplicitMoveOnly, ExplicitMoveOnly&&, true, false>(); + test_pair_rv<ExplicitTypes::MoveOnly, ExplicitTypes::MoveOnly>(); // copy construction + test_pair_rv<ExplicitTypes::MoveOnly, ExplicitTypes::MoveOnly&, false>(); + test_pair_rv<ExplicitTypes::MoveOnly, ExplicitTypes::MoveOnly&&, true, false>(); test_pair_rv<CopyOnly, CopyOnly>(); test_pair_rv<CopyOnly, CopyOnly&>(); test_pair_rv<CopyOnly, CopyOnly&&>(); - test_pair_rv<ExplicitCopyOnly, ExplicitCopyOnly>(); - test_pair_rv<ExplicitCopyOnly, ExplicitCopyOnly&, true, false>(); - test_pair_rv<ExplicitCopyOnly, ExplicitCopyOnly&&, true, false>(); + test_pair_rv<ExplicitTypes::CopyOnly, ExplicitTypes::CopyOnly>(); + test_pair_rv<ExplicitTypes::CopyOnly, ExplicitTypes::CopyOnly&, true, false>(); + test_pair_rv<ExplicitTypes::CopyOnly, ExplicitTypes::CopyOnly&&, true, false>(); test_pair_rv<NonCopyable, NonCopyable, false>(); test_pair_rv<NonCopyable, NonCopyable&, false>(); @@ -125,22 +126,22 @@ int main() test_pair_rv<NonCopyable&&, NonCopyable&&>(); test_pair_rv<ConvertingType&, int, false>(); - test_pair_rv<ExplicitConvertingType&, int, false>(); + test_pair_rv<ExplicitTypes::ConvertingType&, int, false>(); // Unfortunately the below conversions are allowed and create dangling // references. //test_pair_rv<ConvertingType&&, int>(); //test_pair_rv<ConvertingType const&, int>(); //test_pair_rv<ConvertingType const&&, int>(); // But these are not because the converting constructor is explicit. - test_pair_rv<ExplicitConvertingType&&, int, false>(); - test_pair_rv<ExplicitConvertingType const&, int, false>(); - test_pair_rv<ExplicitConvertingType const&&, int, false>(); + test_pair_rv<ExplicitTypes::ConvertingType&&, int, false>(); + test_pair_rv<ExplicitTypes::ConvertingType const&, int, false>(); + test_pair_rv<ExplicitTypes::ConvertingType const&&, int, false>(); } { test_pair_rv<AllCtors, int, false>(); - test_pair_rv<ExplicitAllCtors, int, false>(); + test_pair_rv<ExplicitTypes::AllCtors, int, false>(); test_pair_rv<ConvertingType, int>(); - test_pair_rv<ExplicitConvertingType, int, true, false>(); + test_pair_rv<ExplicitTypes::ConvertingType, int, true, false>(); test_pair_rv<ConvertingType, int>(); test_pair_rv<ConvertingType, ConvertingType>(); @@ -148,16 +149,16 @@ int main() test_pair_rv<ConvertingType, ConvertingType&>(); test_pair_rv<ConvertingType, ConvertingType&&>(); - test_pair_rv<ExplicitConvertingType, int, true, false>(); - test_pair_rv<ExplicitConvertingType, int&, true, false>(); - test_pair_rv<ExplicitConvertingType, const int&, true, false>(); - test_pair_rv<ExplicitConvertingType, int&&, true, false>(); - test_pair_rv<ExplicitConvertingType, const int&&, true, false>(); + test_pair_rv<ExplicitTypes::ConvertingType, int, true, false>(); + test_pair_rv<ExplicitTypes::ConvertingType, int&, true, false>(); + test_pair_rv<ExplicitTypes::ConvertingType, const int&, true, false>(); + test_pair_rv<ExplicitTypes::ConvertingType, int&&, true, false>(); + test_pair_rv<ExplicitTypes::ConvertingType, const int&&, true, false>(); - test_pair_rv<ExplicitConvertingType, ExplicitConvertingType>(); - test_pair_rv<ExplicitConvertingType, ExplicitConvertingType const&, true, false>(); - test_pair_rv<ExplicitConvertingType, ExplicitConvertingType&, true, false>(); - test_pair_rv<ExplicitConvertingType, ExplicitConvertingType&&, true, false>(); + test_pair_rv<ExplicitTypes::ConvertingType, ExplicitTypes::ConvertingType>(); + test_pair_rv<ExplicitTypes::ConvertingType, ExplicitTypes::ConvertingType const&, true, false>(); + test_pair_rv<ExplicitTypes::ConvertingType, ExplicitTypes::ConvertingType&, true, false>(); + test_pair_rv<ExplicitTypes::ConvertingType, ExplicitTypes::ConvertingType&&, true, false>(); } #if TEST_STD_VER > 11 { // explicit constexpr test diff --git a/libcxx/test/std/utilities/utility/pairs/pairs.pair/special_member_generation_test.pass.cpp b/libcxx/test/std/utilities/utility/pairs/pairs.pair/special_member_generation_test.pass.cpp index c906f61f71c..1331a315364 100644 --- a/libcxx/test/std/utilities/utility/pairs/pairs.pair/special_member_generation_test.pass.cpp +++ b/libcxx/test/std/utilities/utility/pairs/pairs.pair/special_member_generation_test.pass.cpp @@ -26,6 +26,7 @@ #include <tuple> #include "archetypes.hpp" +using namespace ImplicitTypes; // Get implicitly archetypes namespace ConstructorTest { |