diff options
| author | Eric Fiselier <eric@efcs.ca> | 2016-12-03 00:13:33 +0000 |
|---|---|---|
| committer | Eric Fiselier <eric@efcs.ca> | 2016-12-03 00:13:33 +0000 |
| commit | d7a50d1d6b097d5fbf64d7aaa4d76adede1a5106 (patch) | |
| tree | d51c0eb9db0985d8b8d6a93f61369a8877cd33b4 /libcxx/test/std/utilities/variant/variant.variant | |
| parent | 5877920183809117560cded151e054f720fcee18 (diff) | |
| download | bcm5719-llvm-d7a50d1d6b097d5fbf64d7aaa4d76adede1a5106.tar.gz bcm5719-llvm-d7a50d1d6b097d5fbf64d7aaa4d76adede1a5106.zip | |
Work around Clang 3.8 bugs
llvm-svn: 288556
Diffstat (limited to 'libcxx/test/std/utilities/variant/variant.variant')
4 files changed, 6 insertions, 47 deletions
diff --git a/libcxx/test/std/utilities/variant/variant.variant/variant.assign/copy.pass.cpp b/libcxx/test/std/utilities/variant/variant.variant/variant.assign/copy.pass.cpp index 0e1a0cd2a38..d92f16fd641 100644 --- a/libcxx/test/std/utilities/variant/variant.variant/variant.assign/copy.pass.cpp +++ b/libcxx/test/std/utilities/variant/variant.variant/variant.assign/copy.pass.cpp @@ -385,28 +385,6 @@ void test_copy_assignment_different_index() { #endif } -template <size_t NewIdx, class ValueType> -constexpr bool test_constexpr_assign_extension_imp( - std::variant<long, void*, int>&& v, ValueType&& new_value) -{ - const std::variant<long, void*, int> cp( - std::forward<ValueType>(new_value)); - v = cp; - return v.index() == NewIdx && - std::get<NewIdx>(v) == std::get<NewIdx>(cp); -} - -void test_constexpr_copy_assignment_extension() { -#ifdef _LIBCPP_VERSION - using V = std::variant<long, void*, int>; - static_assert(std::is_trivially_copyable<V>::value, ""); - static_assert(std::is_trivially_copy_assignable<V>::value, ""); - static_assert(test_constexpr_assign_extension_imp<0>(V(42l), 101l), ""); - static_assert(test_constexpr_assign_extension_imp<0>(V(nullptr), 101l), ""); - static_assert(test_constexpr_assign_extension_imp<1>(V(42l), nullptr), ""); - static_assert(test_constexpr_assign_extension_imp<2>(V(42l), 101), ""); -#endif -} int main() { test_copy_assignment_empty_empty(); @@ -416,5 +394,4 @@ int main() { test_copy_assignment_different_index(); test_copy_assignment_sfinae(); test_copy_assignment_not_noexcept(); - test_constexpr_copy_assignment_extension(); } diff --git a/libcxx/test/std/utilities/variant/variant.variant/variant.assign/move.pass.cpp b/libcxx/test/std/utilities/variant/variant.variant/variant.assign/move.pass.cpp index f3dc8155b6b..232d77c882e 100644 --- a/libcxx/test/std/utilities/variant/variant.variant/variant.assign/move.pass.cpp +++ b/libcxx/test/std/utilities/variant/variant.variant/variant.assign/move.pass.cpp @@ -308,29 +308,6 @@ void test_move_assignment_different_index() { #endif } -template <size_t NewIdx, class ValueType> -constexpr bool test_constexpr_assign_extension_imp( - std::variant<long, void*, int>&& v, ValueType&& new_value) -{ - std::variant<long, void*, int> v2( - std::forward<ValueType>(new_value)); - const auto cp = v2; - v = std::move(v2); - return v.index() == NewIdx && - std::get<NewIdx>(v) == std::get<NewIdx>(cp); -} - -void test_constexpr_move_assignment_extension() { -#ifdef _LIBCPP_VERSION - using V = std::variant<long, void*, int>; - static_assert(std::is_trivially_copyable<V>::value, ""); - static_assert(std::is_trivially_move_assignable<V>::value, ""); - static_assert(test_constexpr_assign_extension_imp<0>(V(42l), 101l), ""); - static_assert(test_constexpr_assign_extension_imp<0>(V(nullptr), 101l), ""); - static_assert(test_constexpr_assign_extension_imp<1>(V(42l), nullptr), ""); - static_assert(test_constexpr_assign_extension_imp<2>(V(42l), 101), ""); -#endif -} int main() { test_move_assignment_empty_empty(); test_move_assignment_non_empty_empty(); @@ -339,5 +316,4 @@ int main() { test_move_assignment_different_index(); test_move_assignment_sfinae(); test_move_assignment_noexcept(); - test_constexpr_move_assignment_extension(); } diff --git a/libcxx/test/std/utilities/variant/variant.variant/variant.status/index.pass.cpp b/libcxx/test/std/utilities/variant/variant.variant/variant.status/index.pass.cpp index fab1850056e..de9dde74e3c 100644 --- a/libcxx/test/std/utilities/variant/variant.variant/variant.status/index.pass.cpp +++ b/libcxx/test/std/utilities/variant/variant.variant/variant.status/index.pass.cpp @@ -10,6 +10,9 @@ // UNSUPPORTED: c++98, c++03, c++11, c++14 +// Clang 3.8 doesn't allow constexpr variables of non-literal type +// XFAIL: clang-3.8 + // <variant> // template <class ...Types> class variant; diff --git a/libcxx/test/std/utilities/variant/variant.variant/variant.status/valueless_by_exception.pass.cpp b/libcxx/test/std/utilities/variant/variant.variant/variant.status/valueless_by_exception.pass.cpp index c0e7030fb11..88b128b9cb8 100644 --- a/libcxx/test/std/utilities/variant/variant.variant/variant.status/valueless_by_exception.pass.cpp +++ b/libcxx/test/std/utilities/variant/variant.variant/variant.status/valueless_by_exception.pass.cpp @@ -10,6 +10,9 @@ // UNSUPPORTED: c++98, c++03, c++11, c++14 +// Clang 3.8 doesn't allow constexpr variables of non-literal type +// XFAIL: clang-3.8 + // <variant> // template <class ...Types> class variant; |

