// 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_; explicit X( int v = 0 ): v_( v ) { ++instances; } X( X const& r ): v_( r.v_ ) { ++instances; } X& operator=( X const& ) = default; ~X() { --instances; } }; bool operator==( X const & x1, X const & x2 ) { return x1.v_ == x2.v_; } std::ostream& operator<<( std::ostream& os, X const & x ) { os << "X:" << x.v_; return os; } int X::instances = 0; struct Y { static int instances; int v_; explicit Y( int v = 0 ): v_( v ) { ++instances; } Y( Y const& r ) noexcept: v_( r.v_ ) { ++instances; } Y& operator=( Y const& ) = default; ~Y() { --instances; } }; bool operator==( Y const & y1, Y const & y2 ) { return y1.v_ == y2.v_; } std::ostream& operator<<( std::ostream& os, Y const & y ) { os << "Y:" << y.v_; return os; } int Y::instances = 0; int main() { // default-initialized lhs { result r; result r2; r2 = r; BOOST_TEST_EQ( r, r2 ); } { result r; result r2( 1 ); r2 = r; BOOST_TEST_EQ( r, r2 ); } { result r; result r2( ENOENT, generic_category() ); r2 = r; BOOST_TEST_EQ( r, r2 ); } { result const r; result r2; r2 = r; BOOST_TEST_EQ( r, r2 ); } { result const r; result r2( 1 ); r2 = r; BOOST_TEST_EQ( r, r2 ); } { result const r; result r2( ENOENT, generic_category() ); r2 = r; BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( X::instances, 0 ); { result r; result r2; BOOST_TEST_EQ( X::instances, 2 ); r2 = r; BOOST_TEST_EQ( X::instances, 2 ); BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( X::instances, 0 ); { result r; result r2( 1 ); BOOST_TEST_EQ( X::instances, 2 ); r2 = r; BOOST_TEST_EQ( X::instances, 2 ); BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( X::instances, 0 ); { result r; result r2( ENOENT, generic_category() ); BOOST_TEST_EQ( X::instances, 1 ); r2 = r; BOOST_TEST_EQ( X::instances, 2 ); BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( X::instances, 0 ); { result const r; result r2; BOOST_TEST_EQ( X::instances, 2 ); r2 = r; BOOST_TEST_EQ( X::instances, 2 ); BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( X::instances, 0 ); { result const r; result r2( 1 ); BOOST_TEST_EQ( X::instances, 2 ); r2 = r; BOOST_TEST_EQ( X::instances, 2 ); BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( X::instances, 0 ); { result const r; result r2( ENOENT, generic_category() ); BOOST_TEST_EQ( X::instances, 1 ); r2 = r; BOOST_TEST_EQ( X::instances, 2 ); BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( X::instances, 0 ); // value lhs { result r( 0 ); result r2; r2 = r; BOOST_TEST_EQ( r, r2 ); } { result r( 0 ); result r2( 1 ); r2 = r; BOOST_TEST_EQ( r, r2 ); } { result r( 0 ); result r2( ENOENT, generic_category() ); r2 = r; BOOST_TEST_EQ( r, r2 ); } { result const r( 0 ); result r2; r2 = r; BOOST_TEST_EQ( r, r2 ); } { result const r( 0 ); result r2( 1 ); r2 = r; BOOST_TEST_EQ( r, r2 ); } { result const r( 0 ); result r2( ENOENT, generic_category() ); r2 = r; BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( X::instances, 0 ); { result r( 1 ); result r2; BOOST_TEST_EQ( X::instances, 2 ); r2 = r; BOOST_TEST_EQ( X::instances, 2 ); BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( X::instances, 0 ); { result r( 1 ); result r2( 2 ); BOOST_TEST_EQ( X::instances, 2 ); r2 = r; BOOST_TEST_EQ( X::instances, 2 ); BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( X::instances, 0 ); { result r( 1 ); result r2( ENOENT, generic_category() ); BOOST_TEST_EQ( X::instances, 1 ); r2 = r; BOOST_TEST_EQ( X::instances, 2 ); BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( X::instances, 0 ); { result const r( 1 ); result r2; BOOST_TEST_EQ( X::instances, 2 ); r2 = r; BOOST_TEST_EQ( X::instances, 2 ); BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( X::instances, 0 ); { result const r( 1 ); result r2( 2 ); BOOST_TEST_EQ( X::instances, 2 ); r2 = r; BOOST_TEST_EQ( X::instances, 2 ); BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( X::instances, 0 ); { result const r( 1 ); result r2( ENOENT, generic_category() ); BOOST_TEST_EQ( X::instances, 1 ); r2 = r; BOOST_TEST_EQ( X::instances, 2 ); BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( X::instances, 0 ); // error lhs { auto ec = make_error_code( errc::invalid_argument ); result r( ec ); result r2; r2 = r; BOOST_TEST_EQ( r, r2 ); } { auto ec = make_error_code( errc::invalid_argument ); result r( ec ); result r2( 1 ); r2 = r; BOOST_TEST_EQ( r, r2 ); } { auto ec = make_error_code( errc::invalid_argument ); result r( ec ); result r2( ENOENT, generic_category() ); r2 = r; BOOST_TEST_EQ( r, r2 ); } { auto ec = make_error_code( errc::invalid_argument ); result const r( ec ); result r2; r2 = r; BOOST_TEST_EQ( r, r2 ); } { auto ec = make_error_code( errc::invalid_argument ); result const r( ec ); result r2( 1 ); r2 = r; BOOST_TEST_EQ( r, r2 ); } { auto ec = make_error_code( errc::invalid_argument ); result const r( ec ); result r2( ENOENT, generic_category() ); r2 = r; BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( X::instances, 0 ); { auto ec = make_error_code( errc::invalid_argument ); result r( ec ); result r2; BOOST_TEST_EQ( X::instances, 1 ); r2 = r; BOOST_TEST_EQ( X::instances, 0 ); BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( X::instances, 0 ); { auto ec = make_error_code( errc::invalid_argument ); result r( ec ); result r2( 1 ); BOOST_TEST_EQ( X::instances, 1 ); r2 = r; BOOST_TEST_EQ( X::instances, 0 ); BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( X::instances, 0 ); { auto ec = make_error_code( errc::invalid_argument ); result r( ec ); result r2( ENOENT, generic_category() ); BOOST_TEST_EQ( X::instances, 0 ); r2 = r; BOOST_TEST_EQ( X::instances, 0 ); BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( X::instances, 0 ); { auto ec = make_error_code( errc::invalid_argument ); result const r( ec ); result r2; BOOST_TEST_EQ( X::instances, 1 ); r2 = r; BOOST_TEST_EQ( X::instances, 0 ); BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( X::instances, 0 ); { auto ec = make_error_code( errc::invalid_argument ); result const r( ec ); result r2( 1 ); BOOST_TEST_EQ( X::instances, 1 ); r2 = r; BOOST_TEST_EQ( X::instances, 0 ); BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( X::instances, 0 ); { auto ec = make_error_code( errc::invalid_argument ); result const r( ec ); result r2( ENOENT, generic_category() ); BOOST_TEST_EQ( X::instances, 0 ); r2 = r; BOOST_TEST_EQ( X::instances, 0 ); BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( X::instances, 0 ); // BOOST_TEST_EQ( Y::instances, 0 ); { result r( 1 ); result r2( 2 ); BOOST_TEST_EQ( Y::instances, 2 ); r2 = r; BOOST_TEST_EQ( Y::instances, 2 ); BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( Y::instances, 0 ); { result r( 1 ); result r2( "str" ); BOOST_TEST_EQ( Y::instances, 1 ); r2 = r; BOOST_TEST_EQ( Y::instances, 2 ); BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( Y::instances, 0 ); { result const r( 1 ); result r2( 2 ); BOOST_TEST_EQ( Y::instances, 2 ); r2 = r; BOOST_TEST_EQ( Y::instances, 2 ); BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( Y::instances, 0 ); { result const r( 1 ); result r2( "str" ); BOOST_TEST_EQ( Y::instances, 1 ); r2 = r; BOOST_TEST_EQ( Y::instances, 2 ); BOOST_TEST_EQ( r, r2 ); } BOOST_TEST_EQ( Y::instances, 0 ); // void { result r; result r2; r2 = r; BOOST_TEST_EQ( r, r2 ); } { result r; result r2( ENOENT, generic_category() ); r2 = r; BOOST_TEST_EQ( r, r2 ); } { result const r; result r2; r2 = r; BOOST_TEST_EQ( r, r2 ); } { result const r; result r2( ENOENT, generic_category() ); r2 = r; BOOST_TEST_EQ( r, r2 ); } { auto ec = make_error_code( errc::invalid_argument ); result r( ec ); result r2; r2 = r; BOOST_TEST_EQ( r, r2 ); } { auto ec = make_error_code( errc::invalid_argument ); result r( ec ); result r2( ENOENT, generic_category() ); r2 = r; BOOST_TEST_EQ( r, r2 ); } { auto ec = make_error_code( errc::invalid_argument ); result const r( ec ); result r2; r2 = r; BOOST_TEST_EQ( r, r2 ); } { auto ec = make_error_code( errc::invalid_argument ); result const r( ec ); result r2( ENOENT, generic_category() ); r2 = r; BOOST_TEST_EQ( r, r2 ); } // reference { int x1 = 1; int x2 = 2; result r1( x1 ); result r2( x2 ); r2 = r1; BOOST_TEST_EQ( x1, 1 ); BOOST_TEST_EQ( x2, 2 ); BOOST_TEST_EQ( r1, r2 ); BOOST_TEST_EQ( &*r1, &*r2 ); } { int const x1 = 1; int const x2 = 2; result r1( x1 ); result r2( x2 ); r2 = r1; BOOST_TEST_EQ( x1, 1 ); BOOST_TEST_EQ( x2, 2 ); BOOST_TEST_EQ( r1, r2 ); BOOST_TEST_EQ( &*r1, &*r2 ); } { int x1 = 1; result r1( x1 ); result r2( ENOENT, generic_category() ); r2 = r1; BOOST_TEST_EQ( x1, 1 ); BOOST_TEST_EQ( r1, r2 ); BOOST_TEST_EQ( &*r1, &*r2 ); } { int x1 = 1; int x2 = 2; result const r1( x1 ); result r2( x2 ); r2 = r1; BOOST_TEST_EQ( x1, 1 ); BOOST_TEST_EQ( x2, 2 ); BOOST_TEST_EQ( r1, r2 ); BOOST_TEST_EQ( &*r1, &*r2 ); } { int const x1 = 1; int const x2 = 2; result const r1( x1 ); result r2( x2 ); r2 = r1; BOOST_TEST_EQ( x1, 1 ); BOOST_TEST_EQ( x2, 2 ); BOOST_TEST_EQ( r1, r2 ); BOOST_TEST_EQ( &*r1, &*r2 ); } { int x1 = 1; result const r1( x1 ); result r2( ENOENT, generic_category() ); r2 = r1; BOOST_TEST_EQ( x1, 1 ); BOOST_TEST_EQ( r1, r2 ); BOOST_TEST_EQ( &*r1, &*r2 ); } { int x2 = 2; auto ec = make_error_code( errc::invalid_argument ); result r1( ec ); result r2( x2 ); r2 = r1; BOOST_TEST_EQ( x2, 2 ); BOOST_TEST_EQ( r1, r2 ); } { auto ec = make_error_code( errc::invalid_argument ); result r1( ec ); result r2( ENOENT, generic_category() ); r2 = r1; BOOST_TEST_EQ( r1, r2 ); } { int x2 = 2; auto ec = make_error_code( errc::invalid_argument ); result const r1( ec ); result r2( x2 ); r2 = r1; BOOST_TEST_EQ( x2, 2 ); BOOST_TEST_EQ( r1, r2 ); } { auto ec = make_error_code( errc::invalid_argument ); result const r1( ec ); result r2( ENOENT, generic_category() ); r2 = r1; BOOST_TEST_EQ( r1, r2 ); } return boost::report_errors(); }