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_MINOR 0
|
||||
#define TL_EXPECTED_VERSION_PATCH 0
|
||||
#define TL_EXPECTED_VERSION_PATCH 1
|
||||
|
||||
#include <exception>
|
||||
#include <functional>
|
||||
@ -1907,14 +1907,14 @@ public:
|
||||
detail::enable_if_t<!std::is_void<U>::value> * = nullptr>
|
||||
TL_EXPECTED_11_CONSTEXPR const U &&value() const && {
|
||||
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());
|
||||
}
|
||||
template <class U = T,
|
||||
detail::enable_if_t<!std::is_void<U>::value> * = nullptr>
|
||||
TL_EXPECTED_11_CONSTEXPR U &&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());
|
||||
}
|
||||
|
||||
|
@ -126,4 +126,13 @@ TEST_CASE("Issue 49", "[issues.49]") {
|
||||
auto m = test(10)
|
||||
.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