diff --git a/include/dpp/coro/awaitable.h b/include/dpp/coro/awaitable.h index 2fefb1fd4e..9a6836b863 100644 --- a/include/dpp/coro/awaitable.h +++ b/include/dpp/coro/awaitable.h @@ -534,19 +534,7 @@ class basic_promise : public detail::promise::promise_base { } /** - * @brief Construct the result by copy, and resume any awaiter. - * - * @tparam Notify Whether to resume any awaiter or not. - * @throws dpp::logic_exception if the promise is not empty. - */ - template - requires (std::convertible_to) - void set_value(const U& v) { - emplace_value(v); - } - - /** - * @brief Construct the result by move, and resume any awaiter. + * @brief Construct the result by forwarding reference, and resume any awaiter. * * @tparam Notify Whether to resume any awaiter or not. * @throws dpp::logic_exception if the promise is not empty. @@ -554,11 +542,11 @@ class basic_promise : public detail::promise::promise_base { template requires (std::convertible_to) void set_value(U&& v) { - emplace_value(std::move(v)); + emplace_value(std::forward(v)); } /** - * @brief Construct the result by move, and resume any awaiter. + * @brief Construct a void result, and resume any awaiter. * * @tparam Notify Whether to resume any awaiter or not. * @throws dpp::logic_exception if the promise is not empty. @@ -605,19 +593,11 @@ class moveable_promise { } /** - * @copydoc basic_promise::set_value(const T&) - */ - template - void set_value(const U& v) requires (std::convertible_to) { - shared_state->template set_value(v); - } - - /** - * @copydoc basic_promise::set_value(T&&) + * @copydoc basic_promise::set_value(U&&) */ template - void set_value(U&& v) requires (std::convertible_to) { - shared_state->template set_value(std::move(v)); + void set_value(U&& v) requires (std::convertible_to) { + shared_state->template set_value(std::forward(v)); } /**