6#include <system/object_ext.h>
7#include <system/action.h>
8#include <system/threading/tasks/result_task.h>
9#include <system/threading/tasks/task_status.h>
10#include <system/details/dereference.h>
12namespace System {
namespace Details {
17struct ASPOSECPP_SHARED_CLASS AsyncContextBase
20 AsyncContextBase() : stage(0), m_executing(false) {}
22 AsyncContextBase(
const AsyncContextBase& other) : AsyncContextBase() {}
25 ASPOSECPP_SHARED_API
void Continue();
34 bool Await(
const T& awaitee, int32_t step)
36 return AwaitImpl(awaitee, step, [](
const auto& awaiter) { awaiter.GetResult(); });
47 template <
typename T,
typename V>
48 bool Await(
const T& awaitee, V& value, int32_t step)
50 return AwaitImpl(awaitee, step, [&value](
const auto& awaiter) { value = ExplicitCast<V>(awaiter.GetResult()); });
54 ASPOSECPP_SHARED_API
void operator()();
61 using Continuer = std::function<void()>;
64 virtual Threading::Tasks::Task* get_Task()
const = 0;
75 template <
typename AwaiteeT,
typename ContinuerT>
76 bool AwaitImpl(
const AwaiteeT& awaitee, int32_t stage,
const ContinuerT& continuer)
79 auto awaiter = Dereference(awaitee).GetAwaiter();
82 if (awaiter.get_IsCompleted())
89 Suspend([awaiter, continuer]() { continuer(awaiter); }, stage);
92 auto continuationContext = GetResumeScheduler(awaiter.continueOnCapturedContext);
95 awaiter.OnCompleted(Action<>([
this, continuationContext] {
Resume(continuationContext); }));
100 ASPOSECPP_SHARED_API
void Suspend(Continuer&& continuer, int32_t stage);
102 ASPOSECPP_SHARED_API SharedPtr<Threading::Tasks::TaskScheduler> GetResumeScheduler(
bool continueOnCapturedContext)
const;
104 ASPOSECPP_SHARED_API
void Resume(
const SharedPtr<Threading::Tasks::TaskScheduler>& context);
107 Continuer m_continuer;
111 SharedPtr<Threading::Tasks::TaskScheduler> m_activator;
113 std::mutex m_state_mutex;
118using AsyncFunction = std::function<void(
struct AsyncContext&)>;
122struct AsyncContext : AsyncContextBase
126 AsyncContext(Threading::Tasks::Task* task,
const AsyncFunction& fnc) : m_task(task), m_function(fnc)
130 ASPOSECPP_SHARED_API
void Return();
134 Threading::Tasks::Task* get_Task()
const override {
return m_task;}
136 void Execute()
override {m_function(*
this);}
139 Threading::Tasks::Task* m_task;
141 AsyncFunction m_function;
145struct ResultAsyncContext;
152using ResultAsyncFunction = std::function<void(ResultAsyncContext<T>&)>;
158struct ResultAsyncContext : AsyncContextBase
162 ResultAsyncContext(Threading::Tasks::ResultTask<T>* task,
const ResultAsyncFunction<T>& fnc) : m_result_task(task), m_function(fnc)
169 void Return(
const T& result)
171 m_result_task->set_Result(result);
177 Threading::Tasks::Task* get_Task()
const override {
return m_result_task;}
179 void Execute()
override {m_function(*
this);}
182 Threading::Tasks::ResultTask<T>* m_result_task;
184 ResultAsyncFunction<T> m_function;
194 auto result = System::MakeObject<Threading::Tasks::ResultTask<T>>();
195 result->
set_Function(Details::ResultAsyncContext<T>(result.GetPointer(), fnc));
196 result->RunSynchronously();
void set_Function(const FunctionT &fnc)
Sets the internal function to execute.
Definition: task.h:131
@ Suspend
Suspension of a logical operation.
@ Resume
Resumption of a logical operation.
@ Continue
The 'Continue' status code that equals to HTTP status 100.
Definition: db_command.h:9
TaskPtr MakeAsync(const Details::AsyncFunction &fnc)