mirror of
https://github.com/boostorg/system.git
synced 2025-08-01 05:24:26 +02:00
Add in_place_value, in_place_error to result<>. Refs #93.
This commit is contained in:
@@ -100,6 +100,9 @@ public:
|
|||||||
using value_type = T;
|
using value_type = T;
|
||||||
using error_type = E;
|
using error_type = E;
|
||||||
|
|
||||||
|
static constexpr in_place_value_t in_place_value{};
|
||||||
|
static constexpr in_place_error_t in_place_error{};
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
// constructors
|
// constructors
|
||||||
@@ -454,6 +457,9 @@ public:
|
|||||||
using value_type = void;
|
using value_type = void;
|
||||||
using error_type = E;
|
using error_type = E;
|
||||||
|
|
||||||
|
static constexpr in_place_value_t in_place_value{};
|
||||||
|
static constexpr in_place_error_t in_place_error{};
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
// constructors
|
// constructors
|
||||||
|
@@ -150,3 +150,5 @@ boost_test(TYPE run SOURCES result_value_construct2.cpp)
|
|||||||
boost_test(TYPE run SOURCES result_error_construct2.cpp)
|
boost_test(TYPE run SOURCES result_error_construct2.cpp)
|
||||||
boost_test(TYPE run SOURCES result_convert_construct.cpp)
|
boost_test(TYPE run SOURCES result_convert_construct.cpp)
|
||||||
boost_test(TYPE run SOURCES result_typedefs.cpp)
|
boost_test(TYPE run SOURCES result_typedefs.cpp)
|
||||||
|
boost_test(TYPE run SOURCES result_value_construct3.cpp)
|
||||||
|
boost_test(TYPE run SOURCES result_error_construct3.cpp)
|
||||||
|
@@ -181,3 +181,5 @@ run result_error_construct2.cpp : : : $(CPP11) ;
|
|||||||
run result_errc_construct.cpp : : : $(CPP11) ;
|
run result_errc_construct.cpp : : : $(CPP11) ;
|
||||||
run result_convert_construct.cpp : : : $(CPP11) ;
|
run result_convert_construct.cpp : : : $(CPP11) ;
|
||||||
run result_typedefs.cpp : : : $(CPP11) ;
|
run result_typedefs.cpp : : : $(CPP11) ;
|
||||||
|
run result_value_construct3.cpp : : : $(CPP11) ;
|
||||||
|
run result_error_construct3.cpp : : : $(CPP11) ;
|
||||||
|
161
test/result_error_construct3.cpp
Normal file
161
test/result_error_construct3.cpp
Normal file
@@ -0,0 +1,161 @@
|
|||||||
|
// Copyright 2017, 2021, 2022 Peter Dimov.
|
||||||
|
// Distributed under the Boost Software License, Version 1.0.
|
||||||
|
// https://www.boost.org/LICENSE_1_0.txt
|
||||||
|
|
||||||
|
#include <boost/system/result.hpp>
|
||||||
|
#include <boost/core/lightweight_test.hpp>
|
||||||
|
#include <string>
|
||||||
|
#include <cerrno>
|
||||||
|
|
||||||
|
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 );
|
||||||
|
|
||||||
|
using R = result<int>;
|
||||||
|
R r( R::in_place_error, ec );
|
||||||
|
|
||||||
|
BOOST_TEST( !r.has_value() );
|
||||||
|
BOOST_TEST( r.has_error() );
|
||||||
|
|
||||||
|
BOOST_TEST_EQ( r.error(), ec );
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
using R = result<int>;
|
||||||
|
R r( 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() ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
auto ec = make_error_code( errc::invalid_argument );
|
||||||
|
|
||||||
|
using R = result<error_code>;
|
||||||
|
R r( R::in_place_error, ec );
|
||||||
|
|
||||||
|
BOOST_TEST( !r.has_value() );
|
||||||
|
BOOST_TEST( r.has_error() );
|
||||||
|
|
||||||
|
BOOST_TEST_EQ( r.error(), ec );
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
using R = result<error_code>;
|
||||||
|
R r( 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 );
|
||||||
|
|
||||||
|
{
|
||||||
|
using R = result<std::string, X>;
|
||||||
|
R r( 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 );
|
||||||
|
|
||||||
|
{
|
||||||
|
using R = result<int, X>;
|
||||||
|
R r( R::in_place_error, 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 );
|
||||||
|
|
||||||
|
{
|
||||||
|
using R = result<int, X>;
|
||||||
|
R r( R::in_place_error, 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 );
|
||||||
|
|
||||||
|
{
|
||||||
|
using R = result<X, X>;
|
||||||
|
R r( 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 );
|
||||||
|
|
||||||
|
{
|
||||||
|
auto ec = make_error_code( errc::invalid_argument );
|
||||||
|
|
||||||
|
using R = result<void>;
|
||||||
|
R r( R::in_place_error, ec );
|
||||||
|
|
||||||
|
BOOST_TEST( !r.has_value() );
|
||||||
|
BOOST_TEST( r.has_error() );
|
||||||
|
|
||||||
|
BOOST_TEST_EQ( r.error(), ec );
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
using R = result<void>;
|
||||||
|
R r( 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() ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
return boost::report_errors();
|
||||||
|
}
|
118
test/result_value_construct3.cpp
Normal file
118
test/result_value_construct3.cpp
Normal file
@@ -0,0 +1,118 @@
|
|||||||
|
// Copyright 2017, 2021, 2022 Peter Dimov.
|
||||||
|
// Distributed under the Boost Software License, Version 1.0.
|
||||||
|
// https://www.boost.org/LICENSE_1_0.txt
|
||||||
|
|
||||||
|
#include <boost/system/result.hpp>
|
||||||
|
#include <boost/core/lightweight_test.hpp>
|
||||||
|
|
||||||
|
using namespace boost::system;
|
||||||
|
|
||||||
|
struct X
|
||||||
|
{
|
||||||
|
static int instances;
|
||||||
|
|
||||||
|
int v_;
|
||||||
|
|
||||||
|
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& ) = delete;
|
||||||
|
X& operator=( X const& ) = delete;
|
||||||
|
|
||||||
|
~X() { --instances; }
|
||||||
|
};
|
||||||
|
|
||||||
|
int X::instances = 0;
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
{
|
||||||
|
using R = result<int>;
|
||||||
|
R r( R::in_place_value, 0 );
|
||||||
|
|
||||||
|
BOOST_TEST( r.has_value() );
|
||||||
|
BOOST_TEST( !r.has_error() );
|
||||||
|
|
||||||
|
BOOST_TEST_EQ( r.value(), 0 );
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
using R = result<int, int>;
|
||||||
|
R r( R::in_place_value, 1 );
|
||||||
|
|
||||||
|
BOOST_TEST( r.has_value() );
|
||||||
|
BOOST_TEST( !r.has_error() );
|
||||||
|
|
||||||
|
BOOST_TEST_EQ( *r, 1 );
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOST_TEST_EQ( X::instances, 0 );
|
||||||
|
|
||||||
|
{
|
||||||
|
using R = result<X>;
|
||||||
|
R r( R::in_place_value, 1 );
|
||||||
|
|
||||||
|
BOOST_TEST( r.has_value() );
|
||||||
|
BOOST_TEST( !r.has_error() );
|
||||||
|
|
||||||
|
BOOST_TEST_EQ( r.value().v_, 1 );
|
||||||
|
|
||||||
|
BOOST_TEST_EQ( X::instances, 1 );
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOST_TEST_EQ( X::instances, 0 );
|
||||||
|
|
||||||
|
{
|
||||||
|
using R = result<X>;
|
||||||
|
R r( R::in_place_value, 1, 2 );
|
||||||
|
|
||||||
|
BOOST_TEST( r.has_value() );
|
||||||
|
BOOST_TEST( !r.has_error() );
|
||||||
|
|
||||||
|
BOOST_TEST_EQ( r.value().v_, 1+2 );
|
||||||
|
|
||||||
|
BOOST_TEST_EQ( X::instances, 1 );
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOST_TEST_EQ( X::instances, 0 );
|
||||||
|
|
||||||
|
{
|
||||||
|
using R = result<X>;
|
||||||
|
R r( R::in_place_value, 1, 2, 3 );
|
||||||
|
|
||||||
|
BOOST_TEST( r.has_value() );
|
||||||
|
BOOST_TEST( !r.has_error() );
|
||||||
|
|
||||||
|
BOOST_TEST_EQ( r.value().v_, 1+2+3 );
|
||||||
|
|
||||||
|
BOOST_TEST_EQ( X::instances, 1 );
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOST_TEST_EQ( X::instances, 0 );
|
||||||
|
|
||||||
|
{
|
||||||
|
using R = result<X, X>;
|
||||||
|
R r( R::in_place_value, 1 );
|
||||||
|
|
||||||
|
BOOST_TEST( r.has_value() );
|
||||||
|
BOOST_TEST( !r.has_error() );
|
||||||
|
|
||||||
|
BOOST_TEST_EQ( r->v_, 1 );
|
||||||
|
|
||||||
|
BOOST_TEST_EQ( X::instances, 1 );
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOST_TEST_EQ( X::instances, 0 );
|
||||||
|
|
||||||
|
{
|
||||||
|
using R = result<void>;
|
||||||
|
R r( R::in_place_value );
|
||||||
|
|
||||||
|
BOOST_TEST( r.has_value() );
|
||||||
|
BOOST_TEST( !r.has_error() );
|
||||||
|
}
|
||||||
|
|
||||||
|
return boost::report_errors();
|
||||||
|
}
|
Reference in New Issue
Block a user