// Copyright 2017, 2021 Peter Dimov. // Distributed under the Boost Software License, Version 1.0. // https://www.boost.org/LICENSE_1_0.txt #include #include #include #include #include using namespace boost::system; struct X { static int instances; int v_; X(): v_() { ++instances; } explicit X( int v ): v_( v ) { ++instances; } X( int v1, int v2 ): v_( v1+v2 ) { ++instances; } X( int v1, int v2, int v3 ): v_( v1+v2+v3 ) { ++instances; } X( X const& r ): v_( r.v_ ) { ++instances; } X& operator=( X const& ) = delete; ~X() { --instances; } }; int X::instances = 0; int main() { { auto ec = make_error_code( errc::invalid_argument ); result r( ec ); BOOST_TEST( !r.has_value() ); BOOST_TEST( r.has_error() ); BOOST_TEST_EQ( r.error(), ec ); } { auto ec = make_error_code( errc::invalid_argument ); result r = ec; BOOST_TEST( !r.has_value() ); BOOST_TEST( r.has_error() ); BOOST_TEST_EQ( r.error(), ec ); } { result r( EINVAL, generic_category() ); BOOST_TEST( !r.has_value() ); BOOST_TEST( r.has_error() ); BOOST_TEST_EQ( r.error(), error_code( EINVAL, generic_category() ) ); } { auto ec = make_error_code( errc::invalid_argument ); result r( in_place_error, ec ); BOOST_TEST( !r.has_value() ); BOOST_TEST( r.has_error() ); BOOST_TEST_EQ( r.error(), ec ); } { result r( in_place_error, EINVAL, generic_category() ); BOOST_TEST( !r.has_value() ); BOOST_TEST( r.has_error() ); BOOST_TEST_EQ( r.error(), error_code( EINVAL, generic_category() ) ); } BOOST_TEST_EQ( X::instances, 0 ); { result r( 1 ); BOOST_TEST( !r.has_value() ); BOOST_TEST( r.has_error() ); BOOST_TEST_EQ( r.error().v_, 1 ); BOOST_TEST_EQ( X::instances, 1 ); } BOOST_TEST_EQ( X::instances, 0 ); { result r( 1, 2 ); BOOST_TEST( !r.has_value() ); BOOST_TEST( r.has_error() ); BOOST_TEST_EQ( r.error().v_, 1+2 ); BOOST_TEST_EQ( X::instances, 1 ); } BOOST_TEST_EQ( X::instances, 0 ); { result r( 1, 2, 3 ); BOOST_TEST( !r.has_value() ); BOOST_TEST( r.has_error() ); BOOST_TEST_EQ( r.error().v_, 1+2+3 ); BOOST_TEST_EQ( X::instances, 1 ); } BOOST_TEST_EQ( X::instances, 0 ); { result r( in_place_error, 1 ); BOOST_TEST( !r.has_value() ); BOOST_TEST( r.has_error() ); BOOST_TEST_EQ( r.error().v_, 1 ); BOOST_TEST_EQ( X::instances, 1 ); } BOOST_TEST_EQ( X::instances, 0 ); { BOOST_TEST_TRAIT_TRUE((std::is_constructible, error_code>)); BOOST_TEST_TRAIT_TRUE((std::is_convertible>)); BOOST_TEST_TRAIT_TRUE((std::is_constructible, int>)); BOOST_TEST_TRAIT_FALSE((std::is_convertible>)); BOOST_TEST_TRAIT_TRUE((std::is_constructible, int>)); BOOST_TEST_TRAIT_FALSE((std::is_convertible>)); // There's an ambiguity here between int& and X, but since is_convertible // is true, is_constructible can't be false. // BOOST_TEST_TRAIT_FALSE((std::is_constructible, int&>)); BOOST_TEST_TRAIT_TRUE((std::is_convertible>)); } return boost::report_errors(); }