forked from TartanLlama/expected
Move the error value when throwing an exception in .value rval overloads (#62)
* Move the error value when throwing an exception in .value rval overloads Fixes #61 * Bump version
This commit is contained in:
@ -18,7 +18,7 @@
|
|||||||
|
|
||||||
#define TL_EXPECTED_VERSION_MAJOR 1
|
#define TL_EXPECTED_VERSION_MAJOR 1
|
||||||
#define TL_EXPECTED_VERSION_MINOR 0
|
#define TL_EXPECTED_VERSION_MINOR 0
|
||||||
#define TL_EXPECTED_VERSION_PATCH 0
|
#define TL_EXPECTED_VERSION_PATCH 1
|
||||||
|
|
||||||
#include <exception>
|
#include <exception>
|
||||||
#include <functional>
|
#include <functional>
|
||||||
@ -1907,14 +1907,14 @@ public:
|
|||||||
detail::enable_if_t<!std::is_void<U>::value> * = nullptr>
|
detail::enable_if_t<!std::is_void<U>::value> * = nullptr>
|
||||||
TL_EXPECTED_11_CONSTEXPR const U &&value() const && {
|
TL_EXPECTED_11_CONSTEXPR const U &&value() const && {
|
||||||
if (!has_value())
|
if (!has_value())
|
||||||
detail::throw_exception(bad_expected_access<E>(err().value()));
|
detail::throw_exception(bad_expected_access<E>(std::move(err()).value()));
|
||||||
return std::move(val());
|
return std::move(val());
|
||||||
}
|
}
|
||||||
template <class U = T,
|
template <class U = T,
|
||||||
detail::enable_if_t<!std::is_void<U>::value> * = nullptr>
|
detail::enable_if_t<!std::is_void<U>::value> * = nullptr>
|
||||||
TL_EXPECTED_11_CONSTEXPR U &&value() && {
|
TL_EXPECTED_11_CONSTEXPR U &&value() && {
|
||||||
if (!has_value())
|
if (!has_value())
|
||||||
detail::throw_exception(bad_expected_access<E>(err().value()));
|
detail::throw_exception(bad_expected_access<E>(std::move(err()).value()));
|
||||||
return std::move(val());
|
return std::move(val());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -126,4 +126,13 @@ TEST_CASE("Issue 49", "[issues.49]") {
|
|||||||
auto m = test(10)
|
auto m = test(10)
|
||||||
.and_then(test2);
|
.and_then(test2);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
tl::expected<int, std::unique_ptr<std::string>> func()
|
||||||
|
{
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("Issue 61", "[issues.61]") {
|
||||||
|
REQUIRE(func().value() == 1);
|
||||||
|
}
|
Reference in New Issue
Block a user