• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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
3 // found in the LICENSE file.
4 
5 #ifndef PPAPI_CPP_COMPLETION_CALLBACK_H_
6 #define PPAPI_CPP_COMPLETION_CALLBACK_H_
7 
8 #include "ppapi/c/pp_completion_callback.h"
9 #include "ppapi/c/pp_errors.h"
10 #include "ppapi/cpp/extensions/ext_output_traits.h"
11 #include "ppapi/cpp/logging.h"
12 #include "ppapi/cpp/module.h"
13 #include "ppapi/cpp/output_traits.h"
14 
15 /// @file
16 /// This file defines the API to create and run a callback.
17 namespace pp {
18 
19 /// This API enables you to implement and receive callbacks when
20 /// Pepper operations complete asynchronously.
21 ///
22 /// You can create these objects yourself, but it is most common to use the
23 /// CompletionCallbackFactory to allow the callbacks to call class member
24 /// functions.
25 class CompletionCallback {
26  public:
27   /// The default constructor will create a blocking
28   /// <code>CompletionCallback</code> that can be passed to a method to
29   /// indicate that the calling thread should be blocked until the asynchronous
30   /// operation corresponding to the method completes.
31   ///
32   /// <strong>Note:</strong> Blocking completion callbacks are only allowed from
33   /// from background threads.
CompletionCallback()34   CompletionCallback() {
35     cc_ = PP_BlockUntilComplete();
36   }
37 
38   /// A constructor for creating a <code>CompletionCallback</code>.
39   ///
40   /// @param[in] func The function to be called on completion.
41   /// @param[in] user_data The user data to be passed to the callback function.
42   /// This is optional and is typically used to help track state in case of
43   /// multiple pending callbacks.
CompletionCallback(PP_CompletionCallback_Func func,void * user_data)44   CompletionCallback(PP_CompletionCallback_Func func, void* user_data) {
45     cc_ = PP_MakeCompletionCallback(func, user_data);
46   }
47 
48   /// A constructor for creating a <code>CompletionCallback</code> with
49   /// specified flags.
50   ///
51   /// @param[in] func The function to be called on completion.
52   /// @param[in] user_data The user data to be passed to the callback function.
53   /// This is optional and is typically used to help track state in case of
54   /// multiple pending callbacks.
55   /// @param[in] flags Bit field combination of
56   /// <code>PP_CompletionCallback_Flag</code> flags used to control how
57   /// non-NULL callbacks are scheduled by asynchronous methods.
CompletionCallback(PP_CompletionCallback_Func func,void * user_data,int32_t flags)58   CompletionCallback(PP_CompletionCallback_Func func, void* user_data,
59                      int32_t flags) {
60     cc_ = PP_MakeCompletionCallback(func, user_data);
61     cc_.flags = flags;
62   }
63 
64   /// The set_flags() function is used to set the flags used to control
65   /// how non-NULL callbacks are scheduled by asynchronous methods.
66   ///
67   /// @param[in] flags Bit field combination of
68   /// <code>PP_CompletionCallback_Flag</code> flags used to control how
69   /// non-NULL callbacks are scheduled by asynchronous methods.
set_flags(int32_t flags)70   void set_flags(int32_t flags) { cc_.flags = flags; }
71 
72   /// Run() is used to run the <code>CompletionCallback</code>.
73   /// Normally, the system runs a <code>CompletionCallback</code> after an
74   /// asynchronous operation completes, but programs may wish to run the
75   /// <code>CompletionCallback</code> manually in order to reuse the same code
76   /// paths.
77   ///
78   /// @param[in] result The result of the operation to be passed to the
79   /// callback function. Non-positive values correspond to the error codes
80   /// from <code>pp_errors.h</code> (excluding
81   /// <code>PP_OK_COMPLETIONPENDING</code>). Positive values indicate
82   /// additional information such as bytes read.
Run(int32_t result)83   void Run(int32_t result) {
84     PP_DCHECK(cc_.func);
85     PP_RunCompletionCallback(&cc_, result);
86   }
87 
88   /// RunAndClear() is used to run the <code>CompletionCallback</code> and
89   /// clear out the callback so that it cannot be run a second time.
90   ///
91   /// @param[in] result The result of the operation to be passed to the
92   /// callback function. Non-positive values correspond to the error codes
93   /// from <code>pp_errors.h</code> (excluding
94   /// <code>PP_OK_COMPLETIONPENDING</code>). Positive values indicate
95   /// additional information such as bytes read.
RunAndClear(int32_t result)96   void RunAndClear(int32_t result) {
97     PP_DCHECK(cc_.func);
98     PP_RunAndClearCompletionCallback(&cc_, result);
99   }
100 
101   /// IsOptional() is used to determine the setting of the
102   /// <code>PP_COMPLETIONCALLBACK_FLAG_OPTIONAL</code> flag. This flag allows
103   /// any method taking such callback to complete synchronously
104   /// and not call the callback if the operation would not block. This is useful
105   /// when performance is an issue, and the operation bandwidth should not be
106   /// limited to the processing speed of the message loop.
107   ///
108   /// On synchronous method completion, the completion result will be returned
109   /// by the method itself. Otherwise, the method will return
110   /// PP_OK_COMPLETIONPENDING, and the callback will be invoked asynchronously
111   /// on the same thread where the PPB method was invoked.
112   ///
113   /// @return true if this callback is optional, otherwise false.
IsOptional()114   bool IsOptional() const {
115     return (cc_.func == NULL ||
116             (cc_.flags & PP_COMPLETIONCALLBACK_FLAG_OPTIONAL) != 0);
117   }
118 
119   /// The pp_completion_callback() function returns the underlying
120   /// <code>PP_CompletionCallback</code>
121   ///
122   /// @return A <code>PP_CompletionCallback</code>.
pp_completion_callback()123   const PP_CompletionCallback& pp_completion_callback() const { return cc_; }
124 
125   /// The flags() function returns flags used to control how non-NULL callbacks
126   /// are scheduled by asynchronous methods.
127   ///
128   /// @return An int32_t containing a bit field combination of
129   /// <code>PP_CompletionCallback_Flag</code> flags.
flags()130   int32_t flags() const { return cc_.flags; }
131 
132   /// MayForce() is used when implementing functions taking callbacks.
133   /// If the callback is required and <code>result</code> indicates that it has
134   /// not been scheduled, it will be forced on the main thread.
135   ///
136   /// <strong>Example:</strong>
137   ///
138   /// @code
139   ///
140   /// int32_t OpenURL(pp::URLLoader* loader,
141   ///                 pp::URLRequestInfo* url_request_info,
142   ///                 const CompletionCallback& cc) {
143   ///   if (loader == NULL || url_request_info == NULL)
144   ///     return cc.MayForce(PP_ERROR_BADRESOURCE);
145   ///   return loader->Open(*loader, *url_request_info, cc);
146   /// }
147   ///
148   /// @endcode
149   ///
150   /// @param[in] result PP_OK_COMPLETIONPENDING or the result of the completed
151   /// operation to be passed to the callback function. PP_OK_COMPLETIONPENDING
152   /// indicates that the callback has already been scheduled. Other
153   /// non-positive values correspond to error codes from
154   /// <code>pp_errors.h</code>. Positive values indicate additional information
155   /// such as bytes read.
156   ///
157   /// @return <code>PP_OK_COMPLETIONPENDING</code> if the callback has been
158   /// forced, result parameter otherwise.
MayForce(int32_t result)159   int32_t MayForce(int32_t result) const {
160     if (result == PP_OK_COMPLETIONPENDING || IsOptional())
161       return result;
162     // FIXME(dmichael): Use pp::MessageLoop here once it's out of Dev.
163     Module::Get()->core()->CallOnMainThread(0, *this, result);
164     return PP_OK_COMPLETIONPENDING;
165   }
166 
167  protected:
168   PP_CompletionCallback cc_;
169 };
170 
171 namespace internal {
172 
173 /// The base class of [Ext]CompletionCallbackWithOutput.
174 ///
175 /// The template parameter Traits determines the storage type
176 /// (OutputStorageType), the output parameter type used by the browser
177 /// (APIArgType), and how to map OutputStorageType to APIArgType.
178 template <typename T, typename Traits>
179 class CompletionCallbackWithOutputBase : public CompletionCallback {
180  public:
181   typedef typename Traits::StorageType OutputStorageType;
182   typedef typename Traits::APIArgType APIArgType;
183   typedef Traits TraitsType;
184 
CompletionCallbackWithOutputBase(OutputStorageType * output)185   explicit CompletionCallbackWithOutputBase(OutputStorageType* output)
186       : CompletionCallback(),
187         output_(output) {
188   }
189 
CompletionCallbackWithOutputBase(PP_CompletionCallback_Func func,void * user_data,OutputStorageType * output)190   CompletionCallbackWithOutputBase(PP_CompletionCallback_Func func,
191                                    void* user_data,
192                                    OutputStorageType* output)
193       : CompletionCallback(func, user_data),
194         output_(output) {
195   }
196 
CompletionCallbackWithOutputBase(PP_CompletionCallback_Func func,void * user_data,int32_t flags,OutputStorageType * output)197   CompletionCallbackWithOutputBase(PP_CompletionCallback_Func func,
198                                    void* user_data,
199                                    int32_t flags,
200                                    OutputStorageType* output)
201       : CompletionCallback(func, user_data, flags),
202         output_(output) {
203   }
204 
output()205   APIArgType output() const {
206     return Traits::StorageToAPIArg(*output_);
207   }
208 
209  private:
210   OutputStorageType* output_;
211 };
212 
213 }  // namespace internal
214 
215 /// A CompletionCallbackWithOutput defines a completion callback that
216 /// additionally stores a pointer to some output data. Some C++ wrappers
217 /// take a CompletionCallbackWithOutput when the browser is returning a
218 /// bit of data as part of the function call. The "output" parameter
219 /// stored in the CompletionCallbackWithOutput will receive the data from
220 /// the browser.
221 ///
222 /// You can create this yourself, but it is most common to use with the
223 /// CompletionCallbackFactory's NewCallbackWithOutput, which manages the
224 /// storage for the output parameter for you and passes it as an argument
225 /// to your callback function.
226 ///
227 /// Note that this class doesn't actually do anything with the output data,
228 /// it just stores a pointer to it. C++ wrapper objects that accept a
229 /// CompletionCallbackWithOutput will retrieve this pointer and pass it to
230 /// the browser as the output parameter.
231 template <typename T>
232 class CompletionCallbackWithOutput
233     : public internal::CompletionCallbackWithOutputBase<
234         T, internal::CallbackOutputTraits<T> > {
235  public:
236   typedef internal::CompletionCallbackWithOutputBase<
237       T, internal::CallbackOutputTraits<T> > BaseType;
238 
239   /// The default constructor will create a blocking
240   /// <code>CompletionCallbackWithOutput</code> that references the given output
241   /// data.
242   ///
243   /// @param[in] output A pointer to the data associated with the callback. The
244   /// caller must ensure that this pointer outlives the completion callback.
245   /// In the common case, <code>OutputStorageType</code> will be equal to the
246   /// template parameter T (for example,
247   /// <code>CompletionCallbackWithOutput<int></code> would obviously take an
248   /// int*. However, resources are passed as PP_Resource, vars as PP_Var, and
249   /// arrays as our special ArrayOutputAdapter object.
250   /// <code>internal::CallbackOutputTraits</code> defines specializations for
251   /// all of these cases.
252   ///
253   /// <strong>Note:</strong> Blocking completion callbacks are only allowed from
254   /// background threads.
CompletionCallbackWithOutput(typename BaseType::OutputStorageType * output)255   explicit CompletionCallbackWithOutput(
256       typename BaseType::OutputStorageType* output)
257       : BaseType(output) {
258   }
259 
260   /// A constructor for creating a <code>CompletionCallbackWithOutput</code>
261   /// that references the given output data.
262   ///
263   /// @param[in] func The function to be called on completion.
264   /// @param[in] user_data The user data to be passed to the callback function.
265   /// This is optional and is typically used to help track state in case of
266   /// multiple pending callbacks.
267   /// @param[in] output A pointer to the data associated with the callback. The
268   /// caller must ensure that this pointer outlives the completion callback.
CompletionCallbackWithOutput(PP_CompletionCallback_Func func,void * user_data,typename BaseType::OutputStorageType * output)269   CompletionCallbackWithOutput(PP_CompletionCallback_Func func,
270                                void* user_data,
271                                typename BaseType::OutputStorageType* output)
272       : BaseType(func, user_data, output) {
273   }
274 
275   /// A constructor for creating a <code>CompletionCallbackWithOutput</code>
276   /// that references the given output data.
277   ///
278   /// @param[in] func The function to be called on completion.
279   ///
280   /// @param[in] user_data The user data to be passed to the callback function.
281   /// This is optional and is typically used to help track state in case of
282   /// multiple pending callbacks.
283   ///
284   /// @param[in] flags Bit field combination of
285   /// <code>PP_CompletionCallback_Flag</code> flags used to control how
286   /// non-NULL callbacks are scheduled by asynchronous methods.
287   ///
288   /// @param[in] output A pointer to the data associated with the callback. The
289   /// caller must ensure that this pointer outlives the completion callback.
CompletionCallbackWithOutput(PP_CompletionCallback_Func func,void * user_data,int32_t flags,typename BaseType::OutputStorageType * output)290   CompletionCallbackWithOutput(PP_CompletionCallback_Func func,
291                                void* user_data,
292                                int32_t flags,
293                                typename BaseType::OutputStorageType* output)
294       : BaseType(func, user_data, flags, output) {
295   }
296 };
297 
298 namespace ext {
299 
300 /// ExtCompletionCallbackWithOutput is similar to CompletionCallbackWithOutput,
301 /// but used by APIs within the pp::ext namespace. Usually it is used with the
302 /// CompletionCallbackFactory's NewExtCallbackWithOutput.
303 template <typename T>
304 class ExtCompletionCallbackWithOutput
305     : public ::pp::internal::CompletionCallbackWithOutputBase<
306         T, internal::ExtCallbackOutputTraits<T> > {
307  public:
308   typedef ::pp::internal::CompletionCallbackWithOutputBase<
309       T, internal::ExtCallbackOutputTraits<T> > BaseType;
310 
311   /// The default constructor will create a blocking
312   /// <code>ExtCompletionCallbackWithOutput</code> that references the given
313   /// output data.
314   ///
315   /// @param[in] output A pointer to the data associated with the callback. The
316   /// caller must ensure that this pointer outlives the completion callback.
317   /// <code>OutputStorageType</code> is either
318   /// <code>ext::internal::ArrayVarOutputAdapterWithStorage<U></code> (if the
319   /// template parameter T is of the form std::vector<U>) or
320   /// <code>ext::internal::VarOutputAdapterWithStorage<T></code> (otherwise).
321   ///
322   /// <strong>Note:</strong> Blocking completion callbacks are only allowed from
323   /// background threads.
ExtCompletionCallbackWithOutput(typename BaseType::OutputStorageType * output)324   explicit ExtCompletionCallbackWithOutput(
325       typename BaseType::OutputStorageType* output)
326       : BaseType(output) {
327   }
328 
329   /// A constructor for creating an <code>ExtCompletionCallbackWithOutput</code>
330   /// that references the given output data.
331   ///
332   /// @param[in] func The function to be called on completion.
333   /// @param[in] user_data The user data to be passed to the callback function.
334   /// This is optional and is typically used to help track state in case of
335   /// multiple pending callbacks.
336   /// @param[in] output A pointer to the data associated with the callback. The
337   /// caller must ensure that this pointer outlives the completion callback.
ExtCompletionCallbackWithOutput(PP_CompletionCallback_Func func,void * user_data,typename BaseType::OutputStorageType * output)338   ExtCompletionCallbackWithOutput(PP_CompletionCallback_Func func,
339                                   void* user_data,
340                                   typename BaseType::OutputStorageType* output)
341       : BaseType(func, user_data, output) {
342   }
343 
344   /// A constructor for creating an <code>ExtCompletionCallbackWithOutput</code>
345   /// that references the given output data.
346   ///
347   /// @param[in] func The function to be called on completion.
348   ///
349   /// @param[in] user_data The user data to be passed to the callback function.
350   /// This is optional and is typically used to help track state in case of
351   /// multiple pending callbacks.
352   ///
353   /// @param[in] flags Bit field combination of
354   /// <code>PP_CompletionCallback_Flag</code> flags used to control how
355   /// non-NULL callbacks are scheduled by asynchronous methods.
356   ///
357   /// @param[in] output A pointer to the data associated with the callback. The
358   /// caller must ensure that this pointer outlives the completion callback.
ExtCompletionCallbackWithOutput(PP_CompletionCallback_Func func,void * user_data,int32_t flags,typename BaseType::OutputStorageType * output)359   ExtCompletionCallbackWithOutput(PP_CompletionCallback_Func func,
360                                   void* user_data,
361                                   int32_t flags,
362                                   typename BaseType::OutputStorageType* output)
363       : BaseType(func, user_data, flags, output) {
364   }
365 };
366 
367 }  // namespace ext
368 
369 /// BlockUntilComplete() is used in place of an actual completion callback
370 /// to request blocking behavior. If specified, the calling thread will block
371 /// until the function completes. Blocking completion callbacks are only
372 /// allowed from background threads.
373 ///
374 /// @return A <code>CompletionCallback</code> corresponding to a NULL callback.
BlockUntilComplete()375 inline CompletionCallback BlockUntilComplete() {
376   // Note: Explicitly inlined to avoid link errors when included into
377   // ppapi_proxy and ppapi_cpp_objects.
378   return CompletionCallback();
379 }
380 
381 }  // namespace pp
382 
383 #endif  // PPAPI_CPP_COMPLETION_CALLBACK_H_
384