// 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_; }; struct Y { int v_; explicit Y( int v ): v_( v ) {} Y( X x ): v_( x.v_) {} Y( Y const& ) = delete; Y& operator=( Y const& ) = delete; Y( Y&& r ): v_( r.v_ ) { r.v_ = 0; } Y& operator=( Y&& r ) { if( &r != this ) { v_ = r.v_; r.v_ = 0; } return *this; } }; struct E { }; int f( int x ) { return x * 2 + 1; } X g( Y y ) { return X{ y.v_ * 2 + 1 }; } int& h( int& ) { static int x = 2; return x; } static int fv_called; void fv() { ++fv_called; } int main() { { result r( 1 ); r &= f; BOOST_TEST( r.has_value() ) && BOOST_TEST_EQ( *r, 3 ); } { result r( in_place_error ); r &= f; BOOST_TEST( r.has_error() ); } { result r( in_place_value, 1 ); r &= g; BOOST_TEST( r.has_value() ) && BOOST_TEST_EQ( r->v_, 3 ); } { result r( in_place_error ); r &= g; BOOST_TEST( r.has_error() ); } { int x1 = 1; result r( x1 ); r &= h; BOOST_TEST( r.has_value() ) && BOOST_TEST_EQ( &*r, &h( x1 ) ); } { result r( in_place_error ); r &= h; BOOST_TEST( r.has_error() ); } { result r; fv_called = 0; r &= fv; BOOST_TEST( r.has_value() ); BOOST_TEST_EQ( fv_called, 1 ); } { result r( in_place_error ); fv_called = 0; r &= fv; BOOST_TEST( r.has_error() ); BOOST_TEST_EQ( fv_called, 0 ); } return boost::report_errors(); }