OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 // This file has been auto-generated by {{code_generator}}. DO NOT MODIFY! | 5 // This file has been auto-generated by {{code_generator}}. DO NOT MODIFY! |
6 | 6 |
7 #include "config.h" | 7 #include "config.h" |
8 #include "{{v8_class}}.h" | 8 #include "{{v8_class}}.h" |
9 | 9 |
10 {% for filename in cpp_includes if filename != '%s.h' % v8_class %} | 10 {% for filename in cpp_includes if filename != '%s.h' % v8_class %} |
11 #include "{{filename}}" | 11 #include "{{filename}}" |
12 {% endfor %} | 12 {% endfor %} |
13 | 13 |
14 namespace blink { | 14 namespace blink { |
15 | 15 |
16 {{cpp_class}}* {{v8_class}}::toImpl(v8::Isolate* isolate, v8::Handle<v8::Value> v8Value) | 16 {{cpp_class}}* {{v8_class}}::toImpl(v8::Isolate* isolate, v8::Handle<v8::Value> v8Value, ExceptionState& exceptionState) |
Jens Widell
2014/09/10 06:20:15
This sort of conflicts with where I was going with
bashi
2014/09/10 07:21:04
Thank you for the heads up. That's a fantastic pla
Jens Widell
2014/09/10 08:31:11
Yes, absolutely.
| |
17 { | 17 { |
18 {{cpp_class}}* impl = {{cpp_class}}::create(); | 18 {{cpp_class}}* impl = {{cpp_class}}::create(); |
19 // FIXME: Do not use Dictionary and DictionaryHelper | 19 // FIXME: Do not use Dictionary and DictionaryHelper |
20 // https://crbug.com/321462 | 20 // https://crbug.com/321462 |
21 Dictionary dictionary(v8Value, isolate); | 21 Dictionary dictionary(v8Value, isolate); |
22 {% for member in members %} | 22 {% for member in members %} |
23 {{member.cpp_type}} {{member.name}}; | 23 {{member.cpp_type}} {{member.name}}; |
24 if (DictionaryHelper::getWithUndefinedOrNullCheck(dictionary, "{{member.name }}", {{member.name}})) | 24 if (DictionaryHelper::getWithUndefinedOrNullCheck(dictionary, "{{member.name }}", {{member.name}})) { |
25 {% if member.enum_validation_expression %} | |
26 String string = {{member.name}}; | |
27 if ({{member.enum_validation_expression}}) | |
Jens Widell
2014/09/10 06:20:15
Rephrase this as
if (!{{member.enum_validation_
bashi
2014/09/10 07:21:04
Great suggestion! Done.
| |
28 impl->{{member.setter_name}}({{member.name}}); | |
29 else | |
30 exceptionState.throwTypeError("member {{member.name}} ('" + string + "') is not a valid enum value."); | |
31 {% else %} | |
25 impl->{{member.setter_name}}({{member.name}}); | 32 impl->{{member.setter_name}}({{member.name}}); |
33 {% endif %} | |
34 } | |
26 {% endfor %} | 35 {% endfor %} |
27 return impl; | 36 return impl; |
28 } | 37 } |
29 | 38 |
30 v8::Handle<v8::Value> toV8({{cpp_class}}* impl, v8::Handle<v8::Object> creationC ontext, v8::Isolate* isolate) | 39 v8::Handle<v8::Value> toV8({{cpp_class}}* impl, v8::Handle<v8::Object> creationC ontext, v8::Isolate* isolate) |
31 { | 40 { |
32 v8::Handle<v8::Object> v8Object = v8::Object::New(isolate); | 41 v8::Handle<v8::Object> v8Object = v8::Object::New(isolate); |
33 {% for member in members %} | 42 {% for member in members %} |
34 if (impl->{{member.has_method_name}}()) | 43 if (impl->{{member.has_method_name}}()) |
35 v8Object->Set(v8String(isolate, "{{member.name}}"), {{member.cpp_value_t o_v8_value}}); | 44 v8Object->Set(v8String(isolate, "{{member.name}}"), {{member.cpp_value_t o_v8_value}}); |
36 {% if member.v8_default_value %} | 45 {% if member.v8_default_value %} |
37 else | 46 else |
38 v8Object->Set(v8String(isolate, "{{member.name}}"), {{member.v8_default_ value}}); | 47 v8Object->Set(v8String(isolate, "{{member.name}}"), {{member.v8_default_ value}}); |
39 {% endif %} | 48 {% endif %} |
40 {% endfor %} | 49 {% endfor %} |
41 return v8Object; | 50 return v8Object; |
42 } | 51 } |
43 | 52 |
44 } // namespace blink | 53 } // namespace blink |
OLD | NEW |