2021-12-29 18:25:47 +00:00
|
|
|
#ifndef ZYLANN_ASYNC_DEPENDENCY_TRACKER_H
|
|
|
|
#define ZYLANN_ASYNC_DEPENDENCY_TRACKER_H
|
2021-10-13 20:28:20 +01:00
|
|
|
|
2021-12-29 19:08:23 +00:00
|
|
|
#include "../span.h"
|
2021-10-13 20:28:20 +01:00
|
|
|
#include <atomic>
|
|
|
|
#include <vector>
|
|
|
|
|
2021-12-29 18:25:47 +00:00
|
|
|
namespace zylann {
|
|
|
|
|
|
|
|
class IThreadedTask;
|
2021-10-13 20:28:20 +01:00
|
|
|
|
|
|
|
// Tracks the status of one or more tasks.
|
2021-12-29 18:25:47 +00:00
|
|
|
class AsyncDependencyTracker {
|
2021-10-13 20:28:20 +01:00
|
|
|
public:
|
|
|
|
// Creates a tracker which will track `initial_count` tasks.
|
|
|
|
// The tracker may be passed by shared pointer to each of these tasks so they can notify completion.
|
2021-12-29 18:25:47 +00:00
|
|
|
AsyncDependencyTracker(int initial_count);
|
2021-10-13 20:28:20 +01:00
|
|
|
|
2021-12-29 18:54:45 +00:00
|
|
|
typedef void (*ScheduleNextTasksCallback)(Span<IThreadedTask *> tasks);
|
|
|
|
|
2021-10-13 20:28:20 +01:00
|
|
|
// Alternate constructor where a collection of tasks will be scheduled on completion.
|
|
|
|
// All the next tasks will be run in parallel.
|
|
|
|
// If a dependency is aborted, these tasks will be destroyed instead.
|
2021-12-29 18:54:45 +00:00
|
|
|
AsyncDependencyTracker(int initial_count, Span<IThreadedTask *> next_tasks, ScheduleNextTasksCallback scheduler_cb);
|
2021-10-13 20:28:20 +01:00
|
|
|
|
2021-12-29 18:25:47 +00:00
|
|
|
~AsyncDependencyTracker();
|
2021-10-13 20:28:20 +01:00
|
|
|
|
|
|
|
// Call this when one of the tracked dependencies is complete
|
|
|
|
void post_complete();
|
|
|
|
|
|
|
|
// Call this when one of the tracked dependencies is aborted
|
|
|
|
void abort() {
|
|
|
|
_aborted = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Returns `true` if any of the tracked tasks was aborted.
|
|
|
|
// It usually means tasks depending on this tracker may be aborted as well.
|
|
|
|
bool is_aborted() const {
|
|
|
|
return _aborted;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Returns `true` when all the tracked tasks have completed
|
|
|
|
bool is_complete() const {
|
|
|
|
return _count == 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int get_remaining_count() const {
|
|
|
|
return _count;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool has_next_tasks() const {
|
|
|
|
return _next_tasks.size() > 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
std::atomic_int _count;
|
|
|
|
std::atomic_bool _aborted;
|
2021-12-29 18:25:47 +00:00
|
|
|
std::vector<IThreadedTask *> _next_tasks;
|
2021-12-29 18:54:45 +00:00
|
|
|
ScheduleNextTasksCallback _next_tasks_schedule_callback = nullptr;
|
2021-10-13 20:28:20 +01:00
|
|
|
};
|
|
|
|
|
2021-12-29 18:25:47 +00:00
|
|
|
} // namespace zylann
|
|
|
|
|
|
|
|
#endif // ZYLANN_ASYNC_DEPENDENCY_TRACKER_H
|