Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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_CPP_CORE_H_ | 5 #ifndef PPAPI_CPP_CORE_H_ |
| 6 #define PPAPI_CPP_CORE_H_ | 6 #define PPAPI_CPP_CORE_H_ |
| 7 | 7 |
| 8 #include "ppapi/c/ppb_core.h" | 8 #include "ppapi/c/ppb_core.h" |
| 9 | 9 |
| 10 /// @file | |
| 11 /// This file defines APIs related to memory management, time, and threads. | |
| 12 | |
| 10 namespace pp { | 13 namespace pp { |
| 11 | 14 |
| 12 class CompletionCallback; | 15 class CompletionCallback; |
| 13 class Module; | 16 class Module; |
| 14 | 17 |
| 15 // Simple wrapper around the PPB_Core interface. Some of these wrappers add | 18 /// APIs related to memory management, time, and threads. |
| 16 // nothing over the C interface, but some allow the use of C++ arguments. | |
| 17 class Core { | 19 class Core { |
| 18 public: | 20 public: |
| 19 // Note that we explicitly don't expose Resource& versions of this function | 21 // Note that we explicitly don't expose Resource& versions of this function |
| 20 // since Resource will normally manage the refcount properly. These should | 22 // since Resource will normally manage the refcount properly. These should |
| 21 // be called only when doing manual management on raw PP_Resource handles, | 23 // be called only when doing manual management on raw PP_Resource handles, |
| 22 // which should be fairly rare. | 24 // which should be fairly rare. |
| 25 | |
| 26 /// A function that adds a reference to a resource. | |
|
dmichael (off chromium)
2011/06/07 05:01:23
'Ref' is really short for ref count. I would say
jond
2011/06/07 16:41:00
Done.
| |
| 27 /// | |
| 28 /// @param[in] resource A PP_Resource containing the resource. | |
| 23 void AddRefResource(PP_Resource resource) { | 29 void AddRefResource(PP_Resource resource) { |
| 24 interface_->AddRefResource(resource); | 30 interface_->AddRefResource(resource); |
| 25 } | 31 } |
| 32 | |
| 33 /// A function that removes a reference from a resource. | |
|
dmichael (off chromium)
2011/06/07 05:01:23
ReleaseResource decrements the reference count for
jond
2011/06/07 16:41:00
Done.
| |
| 34 /// | |
| 35 /// @param[in] resource A PP_Resource containing the resource. | |
| 26 void ReleaseResource(PP_Resource resource) { | 36 void ReleaseResource(PP_Resource resource) { |
| 27 interface_->ReleaseResource(resource); | 37 interface_->ReleaseResource(resource); |
| 28 } | 38 } |
| 29 | 39 |
| 40 /// A function that allocates memory. | |
| 41 /// | |
| 42 /// @param[in] @param[in] num_bytes A number of bytes to allocate. | |
| 43 /// @return A pointer to the memory if successful, NULL If the | |
| 44 /// allocation fails. | |
| 30 void* MemAlloc(uint32_t num_bytes) { | 45 void* MemAlloc(uint32_t num_bytes) { |
| 31 return interface_->MemAlloc(num_bytes); | 46 return interface_->MemAlloc(num_bytes); |
| 32 } | 47 } |
| 48 | |
| 49 /// A function that deallocates memory. | |
| 50 /// | |
| 51 /// @param[in] ptr A pointer to the memory to deallocate. It is safe to | |
| 52 /// pass NULL to this function. | |
| 33 void MemFree(void* ptr) { | 53 void MemFree(void* ptr) { |
| 34 interface_->MemFree(ptr); | 54 interface_->MemFree(ptr); |
| 35 } | 55 } |
| 36 | 56 |
| 57 | |
| 58 /// A function that that returns the "wall clock time" according to the | |
| 59 /// browser. | |
| 60 /// | |
| 61 /// @return A PP_Time containing the "wall clock time" according to the | |
| 62 /// browser. | |
| 37 PP_Time GetTime() { | 63 PP_Time GetTime() { |
| 38 return interface_->GetTime(); | 64 return interface_->GetTime(); |
| 39 } | 65 } |
| 40 | 66 |
| 67 /// A function that that returns the "tick time" according to the browser. | |
| 68 /// This clock is used by the browser when passing some event times to the | |
| 69 /// plugin (e.g., via the PP_InputEvent::time_stamp_seconds field). It is | |
| 70 /// not correlated to any actual wall clock time (like GetTime()). Because | |
| 71 /// of this, it will not run change if the user changes their computer clock. | |
|
dmichael (off chromium)
2011/06/07 05:01:23
remove 'run'
jond
2011/06/07 16:41:00
Done.
jond
2011/06/07 16:41:00
Done.
| |
| 72 /// | |
| 73 /// @return A PP_TimeTicks containing the "tick time" according to the | |
| 74 /// browser. | |
| 41 PP_TimeTicks GetTimeTicks() { | 75 PP_TimeTicks GetTimeTicks() { |
| 42 return interface_->GetTimeTicks(); | 76 return interface_->GetTimeTicks(); |
| 43 } | 77 } |
| 44 | 78 |
| 79 | |
| 80 /// A function that schedules work to be executed on the main module thread | |
|
dmichael (off chromium)
2011/06/07 05:01:23
module thread->pepper thread? This should be cons
jond
2011/06/07 16:41:00
Done.
| |
| 81 /// after the specified delay. The delay may be 0 to specify a call back as | |
| 82 /// soon as possible. | |
| 83 /// | |
| 84 /// The |result| parameter will just be passed as the second argument to the | |
| 85 /// callback. Many applications won't need this, but it allows a plugin to | |
| 86 /// emulate calls of some callbacks which do use this value. | |
| 87 /// | |
| 88 /// NOTE: CallOnMainThread, even when used from the main thread with a delay | |
| 89 /// of 0 milliseconds, will never directly invoke the callback. Even in this | |
| 90 /// case, the callback will be scheduled asynchronously. | |
| 91 /// | |
| 92 /// NOTE: If the browser is shutting down or if the plugin has no instances, | |
| 93 /// then the callback function may not be called. | |
| 94 /// | |
| 95 /// @param[in] delay_in_milliseconds An int32_t delay in milliseconds. | |
| 96 /// @param[in] callback A CompletionCallback callback function that the | |
| 97 /// browser will call after the specified delay. | |
| 98 /// @param[in] result An int32_t that the browser will pass to the given | |
| 99 /// CompletionCallback. | |
| 45 void CallOnMainThread(int32_t delay_in_milliseconds, | 100 void CallOnMainThread(int32_t delay_in_milliseconds, |
| 46 const CompletionCallback& callback, | 101 const CompletionCallback& callback, |
| 47 int32_t result = 0); | 102 int32_t result = 0); |
| 48 | 103 |
| 104 | |
| 105 /// A function that returns true if thecurrent thread is the main pepper | |
|
dmichael (off chromium)
2011/06/07 05:01:23
thecurrent->the current
jond
2011/06/07 16:41:00
Done.
jond
2011/06/07 16:41:00
Done.
| |
| 106 /// thread. | |
| 107 /// | |
| 108 /// This function is useful for implementing sanity checks, and deciding if | |
| 109 /// dispatching using CallOnMainThread() is required. | |
| 110 /// | |
| 111 /// @return A PP_BOOL containing PP_TRUE if the current thread is the main | |
| 112 /// pepper thread, otherwise PP_FALSE. | |
| 49 bool IsMainThread(); | 113 bool IsMainThread(); |
| 50 | 114 |
| 51 private: | 115 private: |
| 52 // Allow Module to construct. | 116 // Allow Module to construct. |
| 53 friend class Module; | 117 friend class Module; |
| 54 | 118 |
| 55 // Only module should make this class so this constructor is private. | 119 // Only module should make this class so this constructor is private. |
| 56 Core(const PPB_Core* inter) : interface_(inter) {} | 120 Core(const PPB_Core* inter) : interface_(inter) {} |
| 57 | 121 |
| 58 // Copy and assignment are disallowed. | 122 // Copy and assignment are disallowed. |
| 59 Core(const Core& other); | 123 Core(const Core& other); |
| 60 Core& operator=(const Core& other); | 124 Core& operator=(const Core& other); |
| 61 | 125 |
| 62 const PPB_Core* interface_; | 126 const PPB_Core* interface_; |
| 63 }; | 127 }; |
| 64 | 128 |
| 65 } // namespace pp | 129 } // namespace pp |
| 66 | 130 |
| 67 #endif // PPAPI_CPP_CORE_H_ | 131 #endif // PPAPI_CPP_CORE_H_ |
| OLD | NEW |