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 |