| OLD | NEW |
| 1 // This file was GENERATED by command: | 1 // This file was GENERATED by command: |
| 2 // pump.py function_template.h.pump | 2 // pump.py function_template.h.pump |
| 3 // DO NOT EDIT BY HAND!!! | 3 // DO NOT EDIT BY HAND!!! |
| 4 | 4 |
| 5 | 5 |
| 6 | 6 |
| 7 #ifndef GIN_FUNCTION_TEMPLATE_H_ | 7 #ifndef GIN_FUNCTION_TEMPLATE_H_ |
| 8 #define GIN_FUNCTION_TEMPLATE_H_ | 8 #define GIN_FUNCTION_TEMPLATE_H_ |
| 9 | 9 |
| 10 // Copyright 2013 The Chromium Authors. All rights reserved. | 10 // Copyright 2013 The Chromium Authors. All rights reserved. |
| (...skipping 14 matching lines...) Expand all Loading... |
| 25 namespace gin { | 25 namespace gin { |
| 26 | 26 |
| 27 class PerIsolateData; | 27 class PerIsolateData; |
| 28 | 28 |
| 29 enum CreateFunctionTemplateFlags { | 29 enum CreateFunctionTemplateFlags { |
| 30 HolderIsFirstArgument = 1 << 0, | 30 HolderIsFirstArgument = 1 << 0, |
| 31 }; | 31 }; |
| 32 | 32 |
| 33 namespace internal { | 33 namespace internal { |
| 34 | 34 |
| 35 // TODO(aa): Move this to base/template_util.h as remove_const. | |
| 36 template<typename T> | 35 template<typename T> |
| 37 struct CallbackParamTraits { | 36 struct CallbackParamTraits { |
| 38 typedef T LocalType; | 37 typedef T LocalType; |
| 39 }; | 38 }; |
| 40 template<typename T> | 39 template<typename T> |
| 41 struct CallbackParamTraits<const T&> { | 40 struct CallbackParamTraits<const T&> { |
| 42 typedef T LocalType; | 41 typedef T LocalType; |
| 43 }; | 42 }; |
| 44 template<typename T> | 43 template<typename T> |
| 45 struct CallbackParamTraits<const T*> { | 44 struct CallbackParamTraits<const T*> { |
| 46 typedef T* LocalType; | 45 typedef T* LocalType; |
| 47 }; | 46 }; |
| 48 | 47 |
| 49 | 48 |
| 50 // CallbackHolder and CallbackHolderBase are used to pass a base::Callback from | 49 // CallbackHolder and CallbackHolderBase are used to pass a base::Callback from |
| 51 // CreateFunctionTemplate through v8 (via v8::FunctionTemplate) to | 50 // CreateFunctionTemplate through v8 (via v8::FunctionTemplate) to |
| 52 // DispatchToCallback, where it is invoked. | 51 // DispatchToCallback, where it is invoked. |
| 53 // | 52 // |
| 54 // v8::FunctionTemplate only supports passing void* as data so how do we know | 53 // v8::FunctionTemplate only supports passing void* as data so how do we know |
| 55 // when to delete the base::Callback? That's where CallbackHolderBase comes in. | 54 // when to delete the base::Callback? That's where CallbackHolderBase comes in. |
| 56 // It inherits from Wrappable, which delete itself when both (a) the refcount | 55 // It inherits from Wrappable, which delete itself when both (a) the refcount |
| 57 // via base::RefCounted has dropped to zero, and (b) there are no more | 56 // via base::RefCounted has dropped to zero, and (b) there are no more |
| 58 // JavaScript references in V8. | 57 // JavaScript references in V8. |
| 59 class CallbackHolderBase : public Wrappable { | 58 |
| 60 public: | 59 // This simple base class is used so that we can share a single object template |
| 61 virtual WrapperInfo* GetWrapperInfo() OVERRIDE; | 60 // among every CallbackHolder instance. |
| 62 static WrapperInfo kWrapperInfo; | 61 class CallbackHolderBase : public Wrappable<CallbackHolderBase> { |
| 63 protected: | 62 protected: |
| 64 virtual ~CallbackHolderBase() {} | 63 ~CallbackHolderBase() {} |
| 65 }; | 64 }; |
| 66 | 65 |
| 67 template<typename Sig> | 66 template<typename Sig> |
| 68 class CallbackHolder : public CallbackHolderBase { | 67 class CallbackHolder : public CallbackHolderBase { |
| 69 public: | 68 public: |
| 70 CallbackHolder(const base::Callback<Sig>& callback, int flags) | 69 CallbackHolder(const base::Callback<Sig>& callback, int flags) |
| 71 : callback(callback), flags(flags) {} | 70 : callback(callback), flags(flags) {} |
| 72 base::Callback<Sig> callback; | 71 base::Callback<Sig> callback; |
| 73 int flags; | 72 int flags; |
| 74 private: | 73 private: |
| 75 virtual ~CallbackHolder() {} | 74 ~CallbackHolder() {} |
| 76 }; | 75 }; |
| 77 | 76 |
| 78 | 77 |
| 79 // This set of templates invokes a base::Callback, converts the return type to a | 78 // This set of templates invokes a base::Callback, converts the return type to a |
| 80 // JavaScript value, and returns that value to script via the provided | 79 // JavaScript value, and returns that value to script via the provided |
| 81 // gin::Arguments object. | 80 // gin::Arguments object. |
| 82 // | 81 // |
| 83 // In C++, you can declare the function foo(void), but you can't pass a void | 82 // In C++, you can declare the function foo(void), but you can't pass a void |
| 84 // expression to foo. As a result, we must specialize the case of Callbacks that | 83 // expression to foo. As a result, we must specialize the case of Callbacks that |
| 85 // have the void return type. | 84 // have the void return type. |
| (...skipping 260 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 346 gin::Handle<HolderT> holder = CreateHandle( | 345 gin::Handle<HolderT> holder = CreateHandle( |
| 347 isolate, new HolderT(callback, callback_flags)); | 346 isolate, new HolderT(callback, callback_flags)); |
| 348 return v8::FunctionTemplate::New( | 347 return v8::FunctionTemplate::New( |
| 349 &internal::Dispatcher<Sig>::DispatchToCallback, | 348 &internal::Dispatcher<Sig>::DispatchToCallback, |
| 350 ConvertToV8<internal::CallbackHolderBase*>(isolate, holder.get())); | 349 ConvertToV8<internal::CallbackHolderBase*>(isolate, holder.get())); |
| 351 } | 350 } |
| 352 | 351 |
| 353 } // namespace gin | 352 } // namespace gin |
| 354 | 353 |
| 355 #endif // GIN_FUNCTION_TEMPLATE_H_ | 354 #endif // GIN_FUNCTION_TEMPLATE_H_ |
| OLD | NEW |