// 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 using namespace boost::system; struct X { int v_; explicit X( int v ): v_( v ) {} X( X const& ) = delete; X& operator=( X const& ) = delete; }; struct Y { }; struct E { }; BOOST_NORETURN void throw_exception_from_error( Y const & ) { throw E(); } int main() { { result r; BOOST_TEST( r.has_value() ); BOOST_TEST( !r.has_error() ); BOOST_TEST( r ); BOOST_TEST_NOT( !r ); BOOST_TEST_EQ( r.value(), 0 ); BOOST_TEST_EQ( *r, 0 ); BOOST_TEST_EQ( r.operator->(), &*r ); } { result const r; BOOST_TEST( r.has_value() ); BOOST_TEST( !r.has_error() ); BOOST_TEST( r ); BOOST_TEST_NOT( !r ); BOOST_TEST_EQ( r.value(), 0 ); BOOST_TEST_EQ( *r, 0 ); BOOST_TEST_EQ( r.operator->(), &*r ); } { BOOST_TEST( result().has_value() ); BOOST_TEST( !result().has_error() ); BOOST_TEST( result() ); BOOST_TEST_NOT( !result() ); BOOST_TEST_EQ( result().value(), 0 ); BOOST_TEST_EQ( *result(), 0 ); BOOST_TEST( result().operator->() != 0 ); } { result r( 1 ); BOOST_TEST( r.has_value() ); BOOST_TEST( !r.has_error() ); BOOST_TEST( r ); BOOST_TEST_NOT( !r ); BOOST_TEST_EQ( r.value(), 1 ); BOOST_TEST_EQ( *r, 1 ); BOOST_TEST_EQ( r.operator->(), &*r ); } { result const r( 1 ); BOOST_TEST( r.has_value() ); BOOST_TEST( !r.has_error() ); BOOST_TEST( r ); BOOST_TEST_NOT( !r ); BOOST_TEST_EQ( r.value(), 1 ); BOOST_TEST_EQ( *r, 1 ); BOOST_TEST_EQ( r.operator->(), &*r ); } { BOOST_TEST( result( 1 ).has_value() ); BOOST_TEST( !result( 1 ).has_error() ); BOOST_TEST( result( 1 ) ); BOOST_TEST_NOT( !result( 1 ) ); BOOST_TEST_EQ( result( 1 ).value(), 1 ); BOOST_TEST_EQ( *result( 1 ), 1 ); BOOST_TEST( result( 1 ).operator->() != 0 ); } { auto ec = make_error_code( errc::invalid_argument ); result r( ec ); BOOST_TEST( !r.has_value() ); BOOST_TEST( r.has_error() ); BOOST_TEST_NOT( r ); BOOST_TEST( !r ); BOOST_TEST_THROWS( r.value(), system_error ); BOOST_TEST_EQ( r.operator->(), static_cast(0) ); } { auto ec = make_error_code( errc::invalid_argument ); result const r( ec ); BOOST_TEST( !r.has_value() ); BOOST_TEST( r.has_error() ); BOOST_TEST_NOT( r ); BOOST_TEST( !r ); BOOST_TEST_THROWS( r.value(), system_error ); BOOST_TEST_EQ( r.operator->(), static_cast(0) ); } { auto ec = make_error_code( errc::invalid_argument ); BOOST_TEST( !result( ec ).has_value() ); BOOST_TEST( result( ec ).has_error() ); BOOST_TEST_NOT( result( ec ) ); BOOST_TEST( !result( ec ) ); BOOST_TEST_THROWS( result( ec ).value(), system_error ); BOOST_TEST_EQ( result( ec ).operator->(), static_cast(0) ); } { result r( 1 ); BOOST_TEST( r.has_value() ); BOOST_TEST( !r.has_error() ); BOOST_TEST( r ); BOOST_TEST_NOT( !r ); BOOST_TEST_EQ( r.value().v_, 1 ); BOOST_TEST_EQ( (*r).v_, 1 ); BOOST_TEST_EQ( r->v_, 1 ); BOOST_TEST_EQ( r.operator->(), &*r ); } { result const r( 1 ); BOOST_TEST( r.has_value() ); BOOST_TEST( !r.has_error() ); BOOST_TEST( r ); BOOST_TEST_NOT( !r ); BOOST_TEST_EQ( r.value().v_, 1 ); BOOST_TEST_EQ( (*r).v_, 1 ); BOOST_TEST_EQ( r->v_, 1 ); BOOST_TEST_EQ( r.operator->(), &*r ); } { BOOST_TEST( result( 1 ).has_value() ); BOOST_TEST( !result( 1 ).has_error() ); BOOST_TEST( result( 1 ) ); BOOST_TEST_NOT( !result( 1 ) ); BOOST_TEST_EQ( result( 1 ).value().v_, 1 ); BOOST_TEST_EQ( (*result( 1 )).v_, 1 ); BOOST_TEST_EQ( result( 1 )->v_, 1 ); } { auto ec = Y(); result r( ec ); BOOST_TEST( !r.has_value() ); BOOST_TEST( r.has_error() ); BOOST_TEST_NOT( r ); BOOST_TEST( !r ); BOOST_TEST_THROWS( r.value(), E ); BOOST_TEST_EQ( r.operator->(), static_cast(0) ); } { auto ec = Y(); result const r( ec ); BOOST_TEST( !r.has_value() ); BOOST_TEST( r.has_error() ); BOOST_TEST_NOT( r ); BOOST_TEST( !r ); BOOST_TEST_THROWS( r.value(), E ); BOOST_TEST_EQ( r.operator->(), static_cast(0) ); } { auto ec = Y(); BOOST_TEST(( !result( ec ).has_value() )); BOOST_TEST(( result( ec ).has_error() )); BOOST_TEST_NOT(( result( ec ) )); BOOST_TEST(( !result( ec ) )); BOOST_TEST_THROWS( (result( ec ).value()), E ); BOOST_TEST_EQ( (result( ec ).operator->()), static_cast(0) ); } { result r; BOOST_TEST( r.has_value() ); BOOST_TEST( !r.has_error() ); BOOST_TEST( r ); BOOST_TEST_NOT( !r ); BOOST_TEST_NO_THROW( r.value() ); BOOST_TEST( r.operator->() != 0 ); } { result const r; BOOST_TEST( r.has_value() ); BOOST_TEST( !r.has_error() ); BOOST_TEST( r ); BOOST_TEST_NOT( !r ); BOOST_TEST_NO_THROW( r.value() ); BOOST_TEST( r.operator->() != 0 ); } { BOOST_TEST( result().has_value() ); BOOST_TEST( !result().has_error() ); BOOST_TEST( result() ); BOOST_TEST_NOT( !result() ); BOOST_TEST_NO_THROW( result().value() ); BOOST_TEST( result().operator->() != 0 ); } { auto ec = make_error_code( errc::invalid_argument ); result r( ec ); BOOST_TEST( !r.has_value() ); BOOST_TEST( r.has_error() ); BOOST_TEST_NOT( r ); BOOST_TEST( !r ); BOOST_TEST_THROWS( r.value(), system_error ); BOOST_TEST_EQ( r.operator->(), static_cast(0) ); } { auto ec = make_error_code( errc::invalid_argument ); result const r( ec ); BOOST_TEST( !r.has_value() ); BOOST_TEST( r.has_error() ); BOOST_TEST_NOT( r ); BOOST_TEST( !r ); BOOST_TEST_THROWS( r.value(), system_error ); BOOST_TEST_EQ( r.operator->(), static_cast(0) ); } { auto ec = make_error_code( errc::invalid_argument ); BOOST_TEST( !result( ec ).has_value() ); BOOST_TEST( result( ec ).has_error() ); BOOST_TEST_NOT( result( ec ) ); BOOST_TEST( !result( ec ) ); BOOST_TEST_THROWS( result( ec ).value(), system_error ); BOOST_TEST_EQ( result( ec ).operator->(), static_cast(0) ); } return boost::report_errors(); }