// Copyright 2017 Peter Dimov. // // Distributed under the Boost Software License, Version 1.0. // // See accompanying file LICENSE_1_0.txt or copy at // http://www.boost.org/LICENSE_1_0.txt #include #include #include using namespace boost::variant2; struct X { constexpr X() = default; constexpr explicit X(int, int) {} template X( in_place_type_t ) = delete; }; #define STATIC_ASSERT(...) static_assert(__VA_ARGS__, #__VA_ARGS__) int main() { { constexpr variant v( in_place_type_t{} ); STATIC_ASSERT( v.index() == 0 ); STATIC_ASSERT( get<0>(v) == 0 ); STATIC_ASSERT( holds_alternative(v) ); } { constexpr variant v( in_place_type_t{} ); STATIC_ASSERT( v.index() == 0 ); STATIC_ASSERT( holds_alternative(v) ); } { constexpr variant v( in_place_type_t{}, 1 ); STATIC_ASSERT( v.index() == 0 ); STATIC_ASSERT( get<0>(v) == 1 ); STATIC_ASSERT( holds_alternative(v) ); } { constexpr variant v( in_place_type_t{} ); STATIC_ASSERT( v.index() == 0 ); STATIC_ASSERT( get<0>(v) == 0 ); STATIC_ASSERT( holds_alternative(v) ); } { constexpr variant v( in_place_type_t{}, 1 ); STATIC_ASSERT( v.index() == 0 ); STATIC_ASSERT( get<0>(v) == 1 ); STATIC_ASSERT( holds_alternative(v) ); } { constexpr variant v( in_place_type_t{} ); STATIC_ASSERT( v.index() == 1 ); STATIC_ASSERT( get<1>(v) == 0 ); STATIC_ASSERT( holds_alternative(v) ); } { constexpr variant v( in_place_type_t{}, 3.14f ); STATIC_ASSERT( v.index() == 1 ); STATIC_ASSERT( get<1>(v) == 3.14f ); STATIC_ASSERT( holds_alternative(v) ); } { constexpr variant v( in_place_type_t{}, 3.14f ); STATIC_ASSERT( v.index() == 2 ); STATIC_ASSERT( get<2>(v) == 3.14f ); STATIC_ASSERT( holds_alternative(v) ); } { constexpr variant v( in_place_type_t{} ); STATIC_ASSERT( v.index() == 4 ); STATIC_ASSERT( holds_alternative(v) ); } #if BOOST_WORKAROUND(BOOST_GCC, >= 100000 && BOOST_GCC < 100200) // no idea why this fails on g++ 10 #else { constexpr variant v( in_place_type_t{}, 0, 0 ); STATIC_ASSERT( v.index() == 4 ); STATIC_ASSERT( holds_alternative(v) ); } #endif }