Skip to content

Commit

Permalink
Merge pull request #66 from boostorg/feature/result_value_type
Browse files Browse the repository at this point in the history
Public result<T>::value_type
  • Loading branch information
zajo authored Nov 6, 2023
2 parents 4b37ca6 + 30a6e2a commit d8aae79
Show file tree
Hide file tree
Showing 3 changed files with 40 additions and 15 deletions.
17 changes: 17 additions & 0 deletions doc/leaf.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -2422,6 +2422,8 @@ namespace boost { namespace leaf {
{
public:
using value_type = T;
result() noexcept;
result( T && v ) noexcept;
result( T const & v );
Expand Down Expand Up @@ -2474,6 +2476,8 @@ namespace boost { namespace leaf {
{
public:
using value_type = void;
result() noexcept;
result( error_id err ) noexcept;
Expand Down Expand Up @@ -4408,6 +4412,8 @@ namespace boost { namespace leaf {
{
public:
using value_type = T;
result() noexcept;
result( T && v ) noexcept;
result( T const & v );
Expand Down Expand Up @@ -4457,6 +4463,8 @@ namespace boost { namespace leaf {
{
public:
using value_type = void;
result() noexcept;
result( error_id err ) noexcept;
Expand Down Expand Up @@ -4735,6 +4743,15 @@ namespace boost { namespace leaf {
} }
----

'''

[[result::value_type]]
==== `value_type`

A member type of `result<T>`, defined as a synonim for `T`.

'''

[[result::bad_result]]
Effects: :: If `*this` is in <<result,value state>>, returns a reference to the stored value, otherwise throws `bad_result`.

Expand Down
32 changes: 17 additions & 15 deletions include/boost/leaf/result.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -75,19 +75,19 @@ namespace leaf_detail
struct stored
{
using type = T;
using value_type = T;
using value_type_const = T const;
using value_no_ref = T;
using value_no_ref_const = T const;
using value_cref = T const &;
using value_ref = T &;
using value_rv_cref = T const &&;
using value_rv_ref = T &&;

static value_type_const * cptr( type const & v ) noexcept
static value_no_ref_const * cptr( type const & v ) noexcept
{
return &v;
}

static value_type * ptr( type & v ) noexcept
static value_no_ref * ptr( type & v ) noexcept
{
return &v;
}
Expand All @@ -97,19 +97,19 @@ namespace leaf_detail
struct stored<T &>
{
using type = std::reference_wrapper<T>;
using value_type_const = T;
using value_type = T;
using value_no_ref = T;
using value_no_ref_const = T;
using value_ref = T &;
using value_cref = T &;
using value_rv_ref = T &;
using value_rv_cref = T &;

static value_type_const * cptr( type const & v ) noexcept
static value_no_ref_const * cptr( type const & v ) noexcept
{
return &v.get();
}

static value_type * ptr( type const & v ) noexcept
static value_no_ref * ptr( type const & v ) noexcept
{
return &v.get();
}
Expand Down Expand Up @@ -226,8 +226,8 @@ class BOOST_LEAF_NODISCARD result
};

using stored_type = typename leaf_detail::stored<T>::type;
using value_type = typename leaf_detail::stored<T>::value_type;
using value_type_const = typename leaf_detail::stored<T>::value_type_const;
using value_no_ref = typename leaf_detail::stored<T>::value_no_ref;
using value_no_ref_const = typename leaf_detail::stored<T>::value_no_ref_const;
using value_ref = typename leaf_detail::stored<T>::value_ref;
using value_cref = typename leaf_detail::stored<T>::value_cref;
using value_rv_ref = typename leaf_detail::stored<T>::value_rv_ref;
Expand Down Expand Up @@ -330,6 +330,8 @@ class BOOST_LEAF_NODISCARD result

public:

using value_type = T;

result( result && x ) noexcept:
what_(move_from(std::move(x)))
{
Expand All @@ -347,13 +349,13 @@ class BOOST_LEAF_NODISCARD result
{
}

result( value_type && v ) noexcept:
stored_(std::forward<value_type>(v)),
result( value_no_ref && v ) noexcept:
stored_(std::forward<value_no_ref>(v)),
what_(result_discriminant::kind_val{})
{
}

result( value_type const & v ):
result( value_no_ref const & v ):
stored_(v),
what_(result_discriminant::kind_val{})
{
Expand Down Expand Up @@ -501,12 +503,12 @@ class BOOST_LEAF_NODISCARD result

#endif

value_type_const * operator->() const noexcept
value_no_ref_const * operator->() const noexcept
{
return has_value() ? leaf_detail::stored<T>::cptr(stored_) : nullptr;
}

value_type * operator->() noexcept
value_no_ref * operator->() noexcept
{
return has_value() ? leaf_detail::stored<T>::ptr(stored_) : nullptr;
}
Expand Down
6 changes: 6 additions & 0 deletions test/result_state_test.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,12 @@

namespace leaf = boost::leaf;

static_assert(std::is_same<void, leaf::result<void>::value_type>::value, "Bad value_type");
static_assert(std::is_same<int, leaf::result<int>::value_type>::value, "Bad value_type");
static_assert(std::is_same<int const, leaf::result<int const>::value_type>::value, "Bad value_type");
static_assert(std::is_same<int &, leaf::result<int &>::value_type>::value, "Bad value_type");
static_assert(std::is_same<int const &, leaf::result<int const &>::value_type>::value, "Bad value_type");

struct val
{
static int id_count;
Expand Down

0 comments on commit d8aae79

Please sign in to comment.