1234567891011121314151617181920212223242526272829303132333435363738394041424344454647 |
- // Copyright (c) 2015 GitHub, Inc.
- // Use of this source code is governed by the MIT license that can be
- // found in the LICENSE file.
- #ifndef ATOM_BROWSER_BRIDGE_TASK_RUNNER_H_
- #define ATOM_BROWSER_BRIDGE_TASK_RUNNER_H_
- #include <tuple>
- #include <vector>
- #include "base/single_thread_task_runner.h"
- #include "base/tuple.h"
- namespace atom {
- // Post all tasks to the current message loop's task runner if available,
- // otherwise delay the work until message loop is ready.
- class BridgeTaskRunner : public base::SingleThreadTaskRunner {
- public:
- BridgeTaskRunner() {}
- ~BridgeTaskRunner() override {}
- // Called when message loop is ready.
- void MessageLoopIsReady();
- // base::SingleThreadTaskRunner:
- bool PostDelayedTask(const tracked_objects::Location& from_here,
- base::OnceClosure task,
- base::TimeDelta delay) override;
- bool RunsTasksInCurrentSequence() const override;
- bool PostNonNestableDelayedTask(
- const tracked_objects::Location& from_here,
- base::OnceClosure task,
- base::TimeDelta delay) override;
- private:
- using TaskPair = std::tuple<
- tracked_objects::Location, base::OnceClosure, base::TimeDelta>;
- std::vector<TaskPair> tasks_;
- std::vector<TaskPair> non_nestable_tasks_;
- DISALLOW_COPY_AND_ASSIGN(BridgeTaskRunner);
- };
- } // namespace atom
- #endif // ATOM_BROWSER_BRIDGE_TASK_RUNNER_H_
|