diff options
author | Shauren <shauren.trinity@gmail.com> | 2025-07-09 20:14:21 +0200 |
---|---|---|
committer | Shauren <shauren.trinity@gmail.com> | 2025-07-09 20:48:57 +0200 |
commit | a2a3c6531152fc5e8b7fabb51e932caa7b8e94f5 (patch) | |
tree | b5d7d66d89f5ab68597895ee645f11fb378a0d7a /src/common/Utilities/AsyncCallbackProcessor.h | |
parent | 2bdc0d6e9d0f663892608cbcf10be122b5db80a9 (diff) |
Core/Database: Add Empty and CancelAll functions to AsyncCallbackProcessor and enable callback concept check
(cherry picked from commit b4f7948dfbe991879dca39dc9b3d53056b8a9e81)
Diffstat (limited to 'src/common/Utilities/AsyncCallbackProcessor.h')
-rw-r--r-- | src/common/Utilities/AsyncCallbackProcessor.h | 33 |
1 files changed, 19 insertions, 14 deletions
diff --git a/src/common/Utilities/AsyncCallbackProcessor.h b/src/common/Utilities/AsyncCallbackProcessor.h index 76781f49425..5a45ab254a2 100644 --- a/src/common/Utilities/AsyncCallbackProcessor.h +++ b/src/common/Utilities/AsyncCallbackProcessor.h @@ -15,17 +15,13 @@ * with this program. If not, see <http://www.gnu.org/licenses/>. */ -#ifndef AsyncCallbackProcessor_h__ -#define AsyncCallbackProcessor_h__ +#ifndef TRINITYCORE_ASYNC_CALLBACK_PROCESSOR_H +#define TRINITYCORE_ASYNC_CALLBACK_PROCESSOR_H -#include "Define.h" -#include <algorithm> +#include "AsyncCallbackProcessorFwd.h" #include <vector> -//template <class T> -//concept AsyncCallback = requires(T t) { { t.InvokeIfReady() } -> std::convertible_to<bool> }; - -template<typename T> // requires AsyncCallback<T> +template<AsyncCallback T> class AsyncCallbackProcessor { public: @@ -34,8 +30,7 @@ public: T& AddCallback(T&& query) { - _callbacks.emplace_back(std::move(query)); - return _callbacks.back(); + return _callbacks.emplace_back(std::move(query)); } void ProcessReadyCallbacks() @@ -45,14 +40,24 @@ public: std::vector<T> updateCallbacks{ std::move(_callbacks) }; - updateCallbacks.erase(std::remove_if(updateCallbacks.begin(), updateCallbacks.end(), [](T& callback) + std::erase_if(updateCallbacks, [](T& callback) { - return callback.InvokeIfReady(); - }), updateCallbacks.end()); + return InvokeAsyncCallbackIfReady(callback); + }); _callbacks.insert(_callbacks.end(), std::make_move_iterator(updateCallbacks.begin()), std::make_move_iterator(updateCallbacks.end())); } + bool Empty() const + { + return _callbacks.empty(); + } + + void CancelAll() + { + _callbacks.clear(); + } + private: AsyncCallbackProcessor(AsyncCallbackProcessor const&) = delete; AsyncCallbackProcessor& operator=(AsyncCallbackProcessor const&) = delete; @@ -60,4 +65,4 @@ private: std::vector<T> _callbacks; }; -#endif // AsyncCallbackProcessor_h__ +#endif // TRINITYCORE_ASYNC_CALLBACK_PROCESSOR_H |