// Copyright 2017, 2021, 2022 Peter Dimov. // Distributed under the Boost Software License, Version 1.0. // https://www.boost.org/LICENSE_1_0.txt #include #include using namespace boost::system; struct X { int v_ = 0; mutable int g_called_ = 0; X( int v ): v_( v ) {} int f() const { return v_; } void g() const { ++g_called_; } int& h() { return v_; } int const& h2() const { return v_; } }; struct E { }; int main() { { result r( 1 ); result r2 = r & &X::f; BOOST_TEST( r2.has_value() ) && BOOST_TEST_EQ( *r2, 1 ); } { result const r( 1 ); result r2 = r & &X::f; BOOST_TEST( r2.has_value() ) && BOOST_TEST_EQ( *r2, 1 ); } { result r2 = result( 1 ) & &X::f; BOOST_TEST( r2.has_value() ) && BOOST_TEST_EQ( *r2, 1 ); } { result r( in_place_error ); result r2 = r & &X::f; BOOST_TEST( r2.has_error() ); } { result const r( in_place_error ); result r2 = r & &X::f; BOOST_TEST( r2.has_error() ); } { result r2 = result( in_place_error ) & &X::f; BOOST_TEST( r2.has_error() ); } { result r( 1 ); result r2 = r & &X::v_; BOOST_TEST( r2.has_value() ) && BOOST_TEST_EQ( &*r2, &r->v_ ); } { result const r( 1 ); result r2 = r & &X::v_; BOOST_TEST( r2.has_value() ) && BOOST_TEST_EQ( &*r2, &r->v_ ); } { result r2 = result( 1 ) & &X::v_; BOOST_TEST( r2.has_value() ) && BOOST_TEST_EQ( *r2, 1 ); } { result r( in_place_error ); result r2 = r & &X::v_; BOOST_TEST( r2.has_error() ); } { result const r( in_place_error ); result r2 = r & &X::v_; BOOST_TEST( r2.has_error() ); } { result r2 = result( in_place_error ) & &X::v_; BOOST_TEST( r2.has_error() ); } { X x( 1 ); result r( x ); result r2 = r & &X::v_; BOOST_TEST( r2.has_value() ) && BOOST_TEST_EQ( &*r2, &x.v_ ); } { X const x( 1 ); result r( x ); result r2 = r & &X::v_; BOOST_TEST( r2.has_value() ) && BOOST_TEST_EQ( &*r2, &x.v_ ); } { X x( 1 ); result r2 = result( x ) & &X::v_; BOOST_TEST( r2.has_value() ) && BOOST_TEST_EQ( &*r2, &x.v_ ); } { X const x( 1 ); result r2 = result( x ) & &X::v_; BOOST_TEST( r2.has_value() ) && BOOST_TEST_EQ( &*r2, &x.v_ ); } { result r( in_place_error ); result r2 = r & &X::v_; BOOST_TEST( r2.has_error() ); } { result const r( in_place_error ); result r2 = r & &X::v_; BOOST_TEST( r2.has_error() ); } { result r2 = result( in_place_error ) & &X::v_; BOOST_TEST( r2.has_error() ); } { result r2 = result( in_place_error ) & &X::v_; BOOST_TEST( r2.has_error() ); } { result r( 1 ); result r2 = r & &X::g; BOOST_TEST( r2.has_value() ); BOOST_TEST_EQ( r->g_called_, 1 ); } { result const r( 1 ); result r2 = r & &X::g; BOOST_TEST( r2.has_value() ); BOOST_TEST_EQ( r->g_called_, 1 ); } { result r2 = result( 1 ) & &X::g; BOOST_TEST( r2.has_value() ); } { result r( in_place_error ); result r2 = r & &X::g; BOOST_TEST( r2.has_error() ); } { result const r( in_place_error ); result r2 = r & &X::g; BOOST_TEST( r2.has_error() ); } { result r2 = result( in_place_error ) & &X::g; BOOST_TEST( r2.has_error() ); } { result r( 1 ); result r2 = r & &X::h; BOOST_TEST( r2.has_value() ) && BOOST_TEST_EQ( *r2, 1 ); } { result const r( 1 ); result r2 = r & &X::h2; BOOST_TEST( r2.has_value() ) && BOOST_TEST_EQ( *r2, 1 ); } { result r2 = result( 1 ) & &X::h2; BOOST_TEST( r2.has_value() ) && BOOST_TEST_EQ( *r2, 1 ); } { result r( in_place_error ); result r2 = r & &X::h; BOOST_TEST( r2.has_error() ); } { result const r( in_place_error ); result r2 = r & &X::h2; BOOST_TEST( r2.has_error() ); } { result r2 = result( in_place_error ) & &X::h2; BOOST_TEST( r2.has_error() ); } return boost::report_errors(); }