#ifndef CC_RASTER_SINGLE_THREAD_TASK_GRAPH_RUNNER_H_
#define CC_RASTER_SINGLE_THREAD_TASK_GRAPH_RUNNER_H_
#include <memory>
#include <string>
#include "base/synchronization/condition_variable.h"
#include "base/thread_annotations.h"
#include "base/threading/simple_thread.h"
#include "cc/raster/task_graph_runner.h"
#include "cc/raster/task_graph_work_queue.h"
namespace base {
class SimpleThread;
}
namespace cc {
class CC_EXPORT SingleThreadTaskGraphRunner
: public TaskGraphRunner,
public base::DelegateSimpleThread::Delegate {
public:
SingleThreadTaskGraphRunner();
~SingleThreadTaskGraphRunner() override;
NamespaceToken GenerateNamespaceToken() override;
void ScheduleTasks(NamespaceToken token, TaskGraph* graph) override;
void ExternalDependencyCompletedForTask(NamespaceToken token,
scoped_refptr<Task> task) override;
void WaitForTasksToFinishRunning(NamespaceToken token) override;
void CollectCompletedTasks(NamespaceToken token,
Task::Vector* completed_tasks) override;
void RunTasksUntilIdleForTest() override;
void Run() override;
void Start(const std::string& thread_name,
const base::SimpleThread::Options& thread_options);
void Shutdown();
private:
bool RunTaskWithLockAcquired() EXCLUSIVE_LOCKS_REQUIRED(lock_);
std::unique_ptr<base::SimpleThread> thread_;
base::Lock lock_;
TaskGraphWorkQueue work_queue_ GUARDED_BY(lock_);
base::ConditionVariable has_ready_to_run_tasks_cv_;
base::ConditionVariable has_namespaces_with_finished_running_tasks_cv_;
base::ConditionVariable is_idle_cv_;
bool shutdown_ GUARDED_BY(lock_) = false;
};
}
#endif