From a2a3c6531152fc5e8b7fabb51e932caa7b8e94f5 Mon Sep 17 00:00:00 2001 From: Shauren Date: Wed, 9 Jul 2025 20:14:21 +0200 Subject: Core/Database: Add Empty and CancelAll functions to AsyncCallbackProcessor and enable callback concept check (cherry picked from commit b4f7948dfbe991879dca39dc9b3d53056b8a9e81) --- src/common/Utilities/AsyncCallbackProcessor.h | 33 +++++++++++++++------------ 1 file changed, 19 insertions(+), 14 deletions(-) (limited to 'src/common/Utilities/AsyncCallbackProcessor.h') 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 . */ -#ifndef AsyncCallbackProcessor_h__ -#define AsyncCallbackProcessor_h__ +#ifndef TRINITYCORE_ASYNC_CALLBACK_PROCESSOR_H +#define TRINITYCORE_ASYNC_CALLBACK_PROCESSOR_H -#include "Define.h" -#include +#include "AsyncCallbackProcessorFwd.h" #include -//template -//concept AsyncCallback = requires(T t) { { t.InvokeIfReady() } -> std::convertible_to }; - -template // requires AsyncCallback +template 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 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 _callbacks; }; -#endif // AsyncCallbackProcessor_h__ +#endif // TRINITYCORE_ASYNC_CALLBACK_PROCESSOR_H -- cgit v1.2.3