| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 {% for filename in cpp_files %} |
| 8 #include "{{header_filename}}" | |
| 9 | |
| 10 {% macro assign_and_return_if_hasinstance(member) %} | |
| 11 if (V8{{member.type_name}}::hasInstance(v8Value, isolate)) { | |
| 12 {{member.cpp_local_type}} cppValue = V8{{member.type_name}}::toImpl(v8::Loca
l<v8::Object>::Cast(v8Value)); | |
| 13 impl.set{{member.type_name}}(cppValue); | |
| 14 return; | |
| 15 } | |
| 16 {% endmacro %} | |
| 17 {% for filename in cpp_includes %} | |
| 18 #include "{{filename}}" | 8 #include "{{filename}}" |
| 19 {% endfor %} | 9 {% endfor %} |
| 20 | |
| 21 namespace blink { | |
| 22 | |
| 23 {% for container in containers %} | |
| 24 {{container.cpp_class}}::{{container.cpp_class}}() | |
| 25 : m_type(SpecificTypeNone) | |
| 26 { | |
| 27 } | |
| 28 | |
| 29 {% for member in container.members %} | |
| 30 {{member.rvalue_cpp_type}} {{container.cpp_class}}::getAs{{member.type_name}}()
const | |
| 31 { | |
| 32 ASSERT(is{{member.type_name}}()); | |
| 33 return m_{{member.cpp_name}}; | |
| 34 } | |
| 35 | |
| 36 void {{container.cpp_class}}::set{{member.type_name}}({{member.rvalue_cpp_type}}
value) | |
| 37 { | |
| 38 ASSERT(isNull()); | |
| 39 {% if member.enum_validation_expression %} | |
| 40 String string = value; | |
| 41 if (!({{member.enum_validation_expression}})) { | |
| 42 ASSERT_NOT_REACHED(); | |
| 43 return; | |
| 44 } | |
| 45 {% endif %} | |
| 46 m_{{member.cpp_name}} = value; | |
| 47 m_type = {{member.specific_type_enum}}; | |
| 48 } | |
| 49 | |
| 50 {{container.cpp_class}} {{container.cpp_class}}::from{{member.type_name}}({{memb
er.rvalue_cpp_type}} value) | |
| 51 { | |
| 52 {{container.cpp_class}} container; | |
| 53 container.set{{member.type_name}}(value); | |
| 54 return container; | |
| 55 } | |
| 56 | |
| 57 {% endfor %} | |
| 58 {% if container.needs_trace %} | |
| 59 DEFINE_TRACE({{container.cpp_class}}) | |
| 60 { | |
| 61 {% for member in container.members if member.is_traceable %} | |
| 62 visitor->trace(m_{{member.cpp_name}}); | |
| 63 {% endfor %} | |
| 64 } | |
| 65 | |
| 66 {% endif %} | |
| 67 void V8{{container.cpp_class}}::toImpl(v8::Isolate* isolate, v8::Local<v8::Value
> v8Value, {{container.cpp_class}}& impl, ExceptionState& exceptionState) | |
| 68 { | |
| 69 if (v8Value.IsEmpty()) | |
| 70 return; | |
| 71 | |
| 72 {# The numbers in the following comments refer to the steps described in | |
| 73 http://heycam.github.io/webidl/#es-union | |
| 74 NOTE: Step 1 (null or undefined) is handled in *OrNull::toImpl() | |
| 75 FIXME: Implement all necessary steps #} | |
| 76 {# 3. Platform objects (interfaces) #} | |
| 77 {% for interface in container.interface_types %} | |
| 78 {{assign_and_return_if_hasinstance(interface) | indent}} | |
| 79 | |
| 80 {% endfor %} | |
| 81 {# 8. ArrayBuffer #} | |
| 82 {% if container.array_buffer_type %} | |
| 83 {{assign_and_return_if_hasinstance(container.array_buffer_type) | indent}} | |
| 84 | |
| 85 {% endif %} | |
| 86 {# 9., 10. ArrayBufferView #} | |
| 87 {# FIXME: Individual typed arrays (e.g. Uint8Array) aren't supported yet. #} | |
| 88 {% if container.array_buffer_view_type %} | |
| 89 {{assign_and_return_if_hasinstance(container.array_buffer_view_type) | inden
t}} | |
| 90 | |
| 91 {% endif %} | |
| 92 {% if container.dictionary_type %} | |
| 93 {# 12. Dictionaries #} | |
| 94 {# FIXME: This should also check "object but not Date or RegExp". Add checks | |
| 95 when we implement conversions for Date and RegExp. #} | |
| 96 if (isUndefinedOrNull(v8Value) || v8Value->IsObject()) { | |
| 97 {% if container.dictionary_type.type_name != 'Dictionary' %} | |
| 98 {{container.dictionary_type.cpp_local_type}} cppValue; | |
| 99 {% endif %} | |
| 100 {{container.dictionary_type.v8_value_to_local_cpp_value}}; | |
| 101 impl.set{{container.dictionary_type.type_name}}(cppValue); | |
| 102 return; | |
| 103 } | |
| 104 | |
| 105 {% endif %} | |
| 106 {% if container.array_or_sequence_type %} | |
| 107 {# 13. Arrays/Sequences #} | |
| 108 {# FIXME: This should also check "object but not Date or RegExp". Add checks | |
| 109 when we implement conversions for Date and RegExp. #} | |
| 110 {# FIXME: Should check for sequences too, not just Array instances. #} | |
| 111 if (v8Value->IsArray()) { | |
| 112 {{container.array_or_sequence_type.v8_value_to_local_cpp_value}}; | |
| 113 impl.set{{container.array_or_sequence_type.type_name}}(cppValue); | |
| 114 return; | |
| 115 } | |
| 116 | |
| 117 {% endif %} | |
| 118 {# FIXME: In some cases, we can omit boolean and numeric type checks because | |
| 119 we have fallback conversions. (step 17 and 18) #} | |
| 120 {% if container.boolean_type %} | |
| 121 {# 14. Boolean #} | |
| 122 if (v8Value->IsBoolean()) { | |
| 123 impl.setBoolean(v8Value->ToBoolean()->Value()); | |
| 124 return; | |
| 125 } | |
| 126 | |
| 127 {% endif %} | |
| 128 {% if container.numeric_type %} | |
| 129 {# 15. Number #} | |
| 130 if (v8Value->IsNumber()) { | |
| 131 {{container.numeric_type.v8_value_to_local_cpp_value}}; | |
| 132 impl.set{{container.numeric_type.type_name}}(cppValue); | |
| 133 return; | |
| 134 } | |
| 135 | |
| 136 {% endif %} | |
| 137 {% if container.string_type %} | |
| 138 {# 16. String #} | |
| 139 { | |
| 140 {{container.string_type.v8_value_to_local_cpp_value}}; | |
| 141 {% if container.string_type.enum_validation_expression %} | |
| 142 String string = cppValue; | |
| 143 if (!({{container.string_type.enum_validation_expression}})) { | |
| 144 exceptionState.throwTypeError("'" + string + "' is not a valid enum
value."); | |
| 145 return; | |
| 146 } | |
| 147 {% endif %} | |
| 148 impl.set{{container.string_type.type_name}}(cppValue); | |
| 149 return; | |
| 150 } | |
| 151 | |
| 152 {# 17. Number (fallback) #} | |
| 153 {% elif container.numeric_type %} | |
| 154 { | |
| 155 {{container.numeric_type.v8_value_to_local_cpp_value}}; | |
| 156 impl.set{{container.numeric_type.type_name}}(cppValue); | |
| 157 return; | |
| 158 } | |
| 159 | |
| 160 {# 18. Boolean (fallback) #} | |
| 161 {% elif container.boolean_type %} | |
| 162 { | |
| 163 impl.setBoolean(v8Value->ToBoolean()->Value()); | |
| 164 return; | |
| 165 } | |
| 166 | |
| 167 {% else %} | |
| 168 {# 19. TypeError #} | |
| 169 exceptionState.throwTypeError("The provided value is not of type '{{containe
r.type_string}}'"); | |
| 170 {% endif %} | |
| 171 } | |
| 172 | |
| 173 v8::Local<v8::Value> toV8(const {{container.cpp_class}}& impl, v8::Local<v8::Obj
ect> creationContext, v8::Isolate* isolate) | |
| 174 { | |
| 175 switch (impl.m_type) { | |
| 176 case {{container.cpp_class}}::SpecificTypeNone: | |
| 177 {# FIXME: We might want to return undefined in some cases #} | |
| 178 return v8::Null(isolate); | |
| 179 {% for member in container.members %} | |
| 180 case {{container.cpp_class}}::{{member.specific_type_enum}}: | |
| 181 return {{member.cpp_value_to_v8_value}}; | |
| 182 {% endfor %} | |
| 183 default: | |
| 184 ASSERT_NOT_REACHED(); | |
| 185 } | |
| 186 return v8::Local<v8::Value>(); | |
| 187 } | |
| 188 | |
| 189 {{container.cpp_class}} NativeValueTraits<{{container.cpp_class}}>::nativeValue(
const v8::Local<v8::Value>& value, v8::Isolate* isolate, ExceptionState& excepti
onState) | |
| 190 { | |
| 191 {{container.cpp_class}} impl; | |
| 192 V8{{container.cpp_class}}::toImpl(isolate, value, impl, exceptionState); | |
| 193 return impl; | |
| 194 } | |
| 195 | |
| 196 {% endfor %} | |
| 197 } // namespace blink | |
| OLD | NEW |