Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(39)

Unified Diff: gin/function_template_util.h

Issue 76923003: First cut at gin::Bind() (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: k Created 7 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « gin/arguments.h ('k') | gin/function_template_util.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: gin/function_template_util.h
diff --git a/gin/function_template_util.h b/gin/function_template_util.h
new file mode 100644
index 0000000000000000000000000000000000000000..0052e8eca4f8d0d1988d083127f8a19e290a4d3c
--- /dev/null
+++ b/gin/function_template_util.h
@@ -0,0 +1,84 @@
+// Copyright 2013 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "base/callback_forward.h"
+#include "base/logging.h"
+#include "gin/arguments.h"
+#include "gin/converter.h"
+#include "gin/per_isolate_data.h"
+#include "gin/public/gin_embedders.h"
+#include "gin/public/wrapper_info.h"
+#include "gin/wrappable.h"
+
+#include "v8/include/v8.h"
+
+namespace gin {
+
+template<typename T>
+struct RemoveConstRef {
+ typedef T Type;
+};
+template<typename T>
+struct RemoveConstRef<const T&> {
+ typedef T Type;
+};
+
+class CallbackHolderBase : public Wrappable {
+ public:
+ static void Register(v8::Isolate* isolate);
+ virtual WrapperInfo* GetWrapperInfo() OVERRIDE;
+ static WrapperInfo kWrapperInfo;
+ protected:
+ virtual ~CallbackHolderBase() {}
+};
+
+template<>
+struct Converter<CallbackHolderBase*>
+ : public WrappableConverter<CallbackHolderBase> {};
+
+template<typename Sig>
+class CallbackHolder : public CallbackHolderBase {
+ public:
+ CallbackHolder() {}
+ base::Callback<Sig> callback;
+ private:
+ virtual ~CallbackHolder() {}
+};
+
+// TODO(aa): Generate the overloads below with pump.
+
+template<typename P1, typename P2>
+static void DispatchV8Call(const v8::FunctionCallbackInfo<v8::Value>& info) {
+ Arguments args(info);
+ CallbackHolderBase* holder_base = NULL;
+ CHECK(args.GetData(&holder_base));
+
+ typedef CallbackHolder<void(P1, P2)> HolderT;
+ HolderT* holder = static_cast<HolderT*>(holder_base);
+
+ typedef typename RemoveConstRef<P1>::Type P1Storage;
+ typedef typename RemoveConstRef<P2>::Type P2Storage;
+ P1Storage a1;
+ P2Storage a2;
+ if (!args.GetNext(&a1) ||
+ !args.GetNext(&a2)) {
+ return args.ThrowError();
jochen (gone - plz use gerrit) 2013/11/22 08:24:55 the function is void
+ }
+
+ holder->callback.Run(a1, a2);
+}
+
+template<typename P1, typename P2>
+v8::Local<v8::FunctionTemplate> CreateFunctionTempate(
+ v8::Isolate* isolate,
+ const base::Callback<void(P1, P2)>& callback) {
+ typedef CallbackHolder<void(P1, P2)> HolderT;
+ scoped_refptr<HolderT> holder(new HolderT());
+ holder->callback = callback;
jochen (gone - plz use gerrit) 2013/11/22 08:24:55 where is holder deleted again?
Aaron Boodman 2013/11/22 08:28:00 The Wrappable base class deletes it during GC. (Wr
jochen (gone - plz use gerrit) 2013/11/22 08:29:09 ah, makes sense
+ return v8::FunctionTemplate::New(
+ &DispatchV8Call<P1, P2>,
+ ConvertToV8<CallbackHolderBase*>(isolate, holder.get()));
+}
+
+} // namespace gin
« no previous file with comments | « gin/arguments.h ('k') | gin/function_template_util.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698