blob: d65c3e919b8a69f6cd27540d42199fff21f528a8 [file] [log] [blame]
// Copyright 2013 The Flutter Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef FLUTTER_FML_TASK_RUNNER_H_
#define FLUTTER_FML_TASK_RUNNER_H_
#include "flutter/fml/closure.h"
#include "flutter/fml/macros.h"
#include "flutter/fml/memory/ref_counted.h"
#include "flutter/fml/memory/ref_ptr.h"
#include "flutter/fml/message_loop_task_queues.h"
#include "flutter/fml/time/time_point.h"
namespace fml {
class MessageLoopImpl;
/// An interface over the ability to schedule tasks on a \p TaskRunner.
class BasicTaskRunner {
public:
/// Schedules \p task to be executed on the TaskRunner's associated event
/// loop.
virtual void PostTask(const fml::closure& task) = 0;
};
/// The object for scheduling tasks on a \p fml::MessageLoop.
///
/// Typically there is one \p TaskRunner associated with each thread. When one
/// wants to execute an operation on that thread they post a task to the
/// TaskRunner.
///
/// \see fml::MessageLoop
class TaskRunner : public fml::RefCountedThreadSafe<TaskRunner>,
public BasicTaskRunner {
public:
virtual ~TaskRunner();
virtual void PostTask(const fml::closure& task) override;
virtual void PostTaskForTime(const fml::closure& task,
fml::TimePoint target_time);
/// Schedules a task to be run on the MessageLoop after the time \p delay has
/// passed.
/// \note There is latency between when the task is schedule and actually
/// executed so that the actual execution time is: now + delay +
/// message_loop_latency, where message_loop_latency is undefined and could be
/// tens of milliseconds.
virtual void PostDelayedTask(const fml::closure& task, fml::TimeDelta delay);
/// Returns \p true when the current executing thread's TaskRunner matches
/// this instance.
virtual bool RunsTasksOnCurrentThread();
/// Returns the unique identifier associated with the TaskRunner.
/// \see fml::MessageLoopTaskQueues
virtual TaskQueueId GetTaskQueueId();
/// Executes the \p task directly if the TaskRunner \p runner is the
/// TaskRunner associated with the current executing thread.
static void RunNowOrPostTask(fml::RefPtr<fml::TaskRunner> runner,
const fml::closure& task);
protected:
TaskRunner(fml::RefPtr<MessageLoopImpl> loop);
private:
fml::RefPtr<MessageLoopImpl> loop_;
FML_FRIEND_MAKE_REF_COUNTED(TaskRunner);
FML_FRIEND_REF_COUNTED_THREAD_SAFE(TaskRunner);
FML_DISALLOW_COPY_AND_ASSIGN(TaskRunner);
};
} // namespace fml
#endif // FLUTTER_FML_TASK_RUNNER_H_