OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef PPAPI_THUNK_PPB_MESSAGE_LOOP_API_H_ | 5 #ifndef PPAPI_THUNK_PPB_MESSAGE_LOOP_API_H_ |
6 #define PPAPI_THUNK_PPB_MESSAGE_LOOP_API_H_ | 6 #define PPAPI_THUNK_PPB_MESSAGE_LOOP_API_H_ |
7 | 7 |
| 8 #include "ppapi/c/pp_bool.h" |
| 9 #include "ppapi/c/pp_completion_callback.h" |
| 10 #include "ppapi/c/pp_stdint.h" |
| 11 |
8 namespace ppapi { | 12 namespace ppapi { |
9 namespace thunk { | 13 namespace thunk { |
10 | 14 |
11 class PPB_MessageLoop_API { | 15 class PPB_MessageLoop_API { |
12 public: | 16 public: |
13 virtual ~PPB_MessageLoop_API() {} | 17 virtual ~PPB_MessageLoop_API() {} |
14 | 18 |
15 virtual int32_t AttachToCurrentThread() = 0; | 19 virtual int32_t AttachToCurrentThread() = 0; |
16 virtual int32_t Run() = 0; | 20 virtual int32_t Run() = 0; |
| 21 // Note: Most interfaces should use ApiCallbackType, in order to track |
| 22 // callbacks and support things like blocking or optional callbacks. In this |
| 23 // case, the callback is really just a way to pass a function pointer, and |
| 24 // those options don't make sense. |
17 virtual int32_t PostWork(PP_CompletionCallback callback, | 25 virtual int32_t PostWork(PP_CompletionCallback callback, |
18 int64_t delay_ms) = 0; | 26 int64_t delay_ms) = 0; |
19 virtual int32_t PostQuit(PP_Bool should_destroy) = 0; | 27 virtual int32_t PostQuit(PP_Bool should_destroy) = 0; |
20 }; | 28 }; |
21 | 29 |
22 } // namespace thunk | 30 } // namespace thunk |
23 } // namespace ppapi | 31 } // namespace ppapi |
24 | 32 |
25 #endif // PPAPI_THUNK_PPB_MESSAGE_LOOP_API_H_ | 33 #endif // PPAPI_THUNK_PPB_MESSAGE_LOOP_API_H_ |
OLD | NEW |