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

Side by Side Diff: third_party/WebKit/Source/bindings/templates/callback_function.cpp

Issue 2312093003: Generated bindings for IDL callback functions (Closed)
Patch Set: Addressed comments Created 4 years, 3 months 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 unified diff | Download patch
OLDNEW
(Empty)
1 {% from 'utilities.cpp' import v8_value_to_local_cpp_value %}
2 {% filter format_blink_cpp_source_code %}
3
4 {% include 'copyright_block.txt' %}
5 #include "{{v8_class}}.h"
6
7 {% for filename in cpp_includes %}
8 #include "{{filename}}"
9 {% endfor %}
10
11 namespace blink {
12
13 {{v8_class}}::{{v8_class}}(v8::Local<v8::Function> callback, ScriptState* scrip tState)
peria 2016/09/15 01:14:32 [style] redundant space after ','
lkawai 2016/09/16 05:05:50 Done.
14 : m_callback(scriptState->isolate(), callback)
15 {
16 m_callback.setPhantom();
17 }
18
19 DEFINE_TRACE({{v8_class}})
20 {
21 }
22
23 bool {{v8_class}}::call({{argument_declarations | join(', ')}})
24 {
25 {% set return_default = 'return false' %}
bashi 2016/09/13 00:35:06 Remove this and simply use 'return false' where {{
lkawai 2016/09/16 05:05:50 Done.
26 if (!scriptState->contextIsValid())
27 {{return_default}};
28
29 if (m_callback.isEmpty())
30 {{return_default}};
31
32 {% for argument in arguments %}
33 v8::Local<v8::Value> {{argument.handle}} = {{argument.cpp_value_to_v8_value} };
34 {% endfor %}
35 {% if arguments %}
36 v8::Local<v8::Value> argv[] = { {{arguments | join(', ', 'handle')}} };
37 {% else %}
38 {# Empty array initializers are illegal, and don\'t compile in MSVC. #}
39 v8::Local<v8::Value> *argv = 0;
peria 2016/09/15 01:14:32 [style] s/0/nullptr/
lkawai 2016/09/16 05:05:50 Done.
40 {% endif %}
41
42 v8::Local<v8::Value> currentValue;
43 v8::TryCatch exceptionCatcher(scriptState->isolate());
44 exceptionCatcher.SetVerbose(true);
45 if (V8ScriptRunner::callFunction(m_callback.newLocal(scriptState->isolate()) , scriptState->getExecutionContext(), scriptState->context()->Global(), {{argume nts | length}}, argv, scriptState->isolate()).ToLocal(&currentValue))
46 {
47 {% if rvalue_cpp_type != 'void' %}
bashi 2016/09/13 00:35:06 Did you try generating bindings for a callback of
lkawai 2016/09/16 05:05:50 Done.
48 {{v8_value_to_local_cpp_value(v8_value_to_local_cpp_value_dict)}}
49 {% endif %}
50 returnValue = cppValue;
51 return true;
52 }
53 else { return false; }
bashi 2016/09/13 00:35:06 Remove else clause and simply return false.
lkawai 2016/09/16 05:05:50 Done.
54 }
55
56 } // namespace blink
57
58 {% endfilter %}{# format_blink_cpp_source_code #}
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698