Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #ifndef CHROMECAST_PUBLIC_TASK_RUNNER_H_ | |
| 6 #define CHROMECAST_PUBLIC_TASK_RUNNER_H_ | |
| 7 | |
| 8 #include <stdint.h> | |
| 9 | |
| 10 namespace chromecast { | |
| 11 | |
| 12 // Provides a way for vendor libraries to run code on a specific thread. | |
| 13 // For example, cast_shell supplies an implementation of this interface through | |
| 14 // media APIs (see MediaPipelineDeviceParams) to allow media backends to | |
| 15 // schedule tasks to be run on the media thread. | |
| 16 class TaskRunner { | |
| 17 public: | |
| 18 // Subclass and implement 'Run' to supply code to be run by PostTask or | |
| 19 // PostDelayedTask. They both take ownership of the Task object passed in | |
| 20 // and will delete after running the Task. | |
| 21 class Task { | |
| 22 public: | |
| 23 virtual ~Task() {} | |
| 24 virtual void Run() = 0; | |
| 25 }; | |
| 26 | |
| 27 virtual ~TaskRunner() {} | |
| 28 | |
| 29 // Posts a task to the thread's task queue. Delay of 0 does not necessarily | |
| 30 // mean the task will run immediately, just as soon as it can be. | |
|
byungchul
2015/07/30 00:32:30
Comment that if it is called on same thread and de
halliwell
2015/07/30 03:08:10
Done.
| |
| 31 virtual bool PostTask(Task* task, uint64_t delay_milliseconds) = 0; | |
| 32 }; | |
| 33 | |
| 34 } // namespace chromecast | |
| 35 | |
| 36 #endif // CHROMECAST_PUBLIC_TASK_RUNNER_H_ | |
| OLD | NEW |