summaryrefslogtreecommitdiffstats
path: root/src/boost/libs/variant2/test/variant_special.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/boost/libs/variant2/test/variant_special.cpp')
-rw-r--r--src/boost/libs/variant2/test/variant_special.cpp103
1 files changed, 103 insertions, 0 deletions
diff --git a/src/boost/libs/variant2/test/variant_special.cpp b/src/boost/libs/variant2/test/variant_special.cpp
new file mode 100644
index 000000000..956d927b3
--- /dev/null
+++ b/src/boost/libs/variant2/test/variant_special.cpp
@@ -0,0 +1,103 @@
+// Copyright 2020 Peter Dimov.
+// Distributed under the Boost Software License, Version 1.0.
+// https://www.boost.org/LICENSE_1_0.txt
+
+#if defined(_MSC_VER) && _MSC_VER < 1910
+# pragma warning(disable: 4503) // decorated name length exceeded
+#endif
+
+#include <boost/variant2/variant.hpp>
+#include <boost/core/lightweight_test_trait.hpp>
+#include <boost/config.hpp>
+#include <boost/config/workaround.hpp>
+
+#include <boost/mp11.hpp>
+using namespace boost::mp11;
+
+//
+
+using namespace boost::variant2;
+
+struct D
+{
+ ~D() noexcept {}
+};
+
+struct CC1
+{
+ CC1( CC1 const& ) {}
+};
+
+struct CC2
+{
+ CC2( CC2 const& ) = delete;
+};
+
+struct MC1
+{
+ MC1( MC1 && ) {}
+};
+
+struct MC2
+{
+ MC2( MC2 && ) = delete;
+};
+
+struct CA1
+{
+ CA1& operator=( CA1 const& ) { return *this; }
+};
+
+struct CA2
+{
+ CA2& operator=( CA2 const& ) = delete;
+};
+
+struct MA1
+{
+ MA1& operator=( MA1 && ) { return *this; }
+};
+
+struct MA2
+{
+ MA2& operator=( MA2 && ) = delete;
+};
+
+struct test
+{
+ template<class... T> void operator()( mp_list<T...> ) const noexcept
+ {
+ using U = mp_inherit<T...>;
+
+#if !BOOST_WORKAROUND( __GNUC__, < 5 )
+
+ BOOST_TEST_EQ( std::is_copy_constructible<variant<U>>::value, std::is_copy_constructible<U>::value );
+ BOOST_TEST_EQ( std::is_nothrow_copy_constructible<variant<U>>::value, std::is_nothrow_copy_constructible<U>::value );
+
+#endif
+
+#if !BOOST_WORKAROUND(BOOST_MSVC, < 1910)
+
+ BOOST_TEST_EQ( std::is_move_constructible<variant<U>>::value, std::is_move_constructible<U>::value );
+
+#else
+
+ BOOST_TEST_GE( std::is_move_constructible<variant<U>>::value, std::is_move_constructible<U>::value );
+
+#endif
+
+ BOOST_TEST_EQ( std::is_nothrow_move_constructible<variant<U>>::value, std::is_nothrow_move_constructible<U>::value );
+
+ BOOST_TEST_EQ( std::is_copy_assignable<variant<U>>::value, std::is_copy_constructible<U>::value && std::is_copy_assignable<U>::value );
+ BOOST_TEST_EQ( std::is_nothrow_copy_assignable<variant<U>>::value, std::is_nothrow_copy_constructible<U>::value && std::is_copy_assignable<U>::value );
+
+ BOOST_TEST_EQ( std::is_move_assignable<variant<U>>::value, std::is_move_constructible<U>::value && std::is_move_assignable<U>::value );
+ BOOST_TEST_EQ( std::is_nothrow_move_assignable<variant<U>>::value, std::is_nothrow_move_constructible<U>::value && std::is_move_assignable<U>::value );
+ }
+};
+
+int main()
+{
+ mp_for_each< mp_power_set< mp_list<D, CC1, CC2, MC1, MC2, CA1, CA2, MA1, MA2> > >( test() );
+ return boost::report_errors();
+}