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

Unified Diff: Source/bindings/templates/union.cpp

Issue 680193003: IDL: Generate union type containers (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Created 6 years, 2 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 side-by-side diff with in-line comments
Download patch
Index: Source/bindings/templates/union.cpp
diff --git a/Source/bindings/templates/union.cpp b/Source/bindings/templates/union.cpp
index d3523387f89a93d6f1a4de2575ba5b8a8293128b..a6ba469192dbf14e9b714cfbbe31ca28db1db917 100644
--- a/Source/bindings/templates/union.cpp
+++ b/Source/bindings/templates/union.cpp
@@ -2,4 +2,108 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
-// FIXME: Implement
+// This file has been auto-generated by {{code_generator}}. DO NOT MODIFY!
+
+#include "config.h"
+#include "{{header_filename}}"
+
+{% for filename in cpp_includes %}
+#include "{{filename}}"
+{% endfor %}
+
+namespace blink {
+
+{% for container in containers %}
+{{container.cpp_class}}::{{container.cpp_class}}()
+ : m_specificTypeFlag(0)
+{
+}
+
+{% for member in container.members %}
+{{member.rvalue_cpp_type}} {{container.cpp_class}}::getAs{{member.type_name}}()
+{
+ ASSERT(is{{member.type_name}}());
+ return m_{{member.cpp_name}};
+}
+
+void {{container.cpp_class}}::set{{member.type_name}}({{member.rvalue_cpp_type}} value)
+{
+ ASSERT(isNull());
+ m_{{member.cpp_name}} = value;
+ m_specificTypeFlag = {{member.index}};
+}
+
+{% endfor %}
+void V8{{container.cpp_class}}::toImpl(v8::Isolate* isolate, v8::Handle<v8::Value> v8Value, {{container.cpp_class}}& impl, ExceptionState& exceptionState)
+{
+ if (v8Value.IsEmpty() || isUndefinedOrNull(v8Value))
Jens Widell 2014/10/28 11:31:38 Null or undefined isn't treated this way in the sp
bashi 2014/10/29 01:34:33 Yes, this is tentative, and I should have added a
+ return;
+
+ {# The numbers in the following comments refer the steps described in
+ http://heycam.github.io/webidl/#es-union
+ FIXME: Implement all necessary steps #}
+ {# 3. Platform objects (interfaces) #}
+ {% for platform_object in container.platform_objects %}
+ if (V8{{platform_object.type_name}}::hasInstance(v8Value, isolate)) {
+ {{platform_object.cpp_type}} cppValue = V8{{platform_object.type_name}}::toImplWithTypeCheck(isolate, v8Value);
Jens Widell 2014/10/28 11:31:38 No need to use *WithTypeCheck() here; you just typ
bashi 2014/10/29 01:34:32 Done.
+ impl.set{{platform_object.type_name}}(cppValue);
+ return;
+ }
+
+ {% endfor %}
+ {% if container.dictionary_type %}
+ {# 12. Dictionaries #}
+ if (v8Value->IsObject()) {
Jens Widell 2014/10/28 11:31:38 Spec says "object but not Date or RegExp". If we d
bashi 2014/10/29 01:34:33 Added a FIXME comment.
+ {{container.dictionary_type.cpp_type}} cppValue = V8{{container.dictionary_type.type_name}}::toImpl(isolate, v8Value, exceptionState);
+ if (!exceptionState.hadException())
+ impl.set{{container.dictionary_type.type_name}}(cppValue);
+ return;
+ }
+
+ {% endif %}
+ {% if container.boolean_type %}
+ {# 14. Boolean #}
+ if (v8Value->IsBoolean()) {
+ impl.setBoolean(v8Value->ToBoolean()->Value());
+ return;
+ }
+
+ {% endif %}
+ {% if container.numeric_type %}
+ {# 15. Number #}
+ if (v8Value->IsNumber()) {
Jens Widell 2014/10/28 11:31:38 You never convert to number (or boolean). If there
bashi 2014/10/29 01:34:32 Good catch! Done.
+ {{container.numeric_type.v8_value_to_local_cpp_value}};
+ impl.set{{container.numeric_type.type_name}}(cppValue);
+ return;
+ }
+
+ {% endif %}
+ {% if container.string_type %}
+ {# 16. String #}
+ {
+ {{container.string_type.v8_value_to_local_cpp_value}};
+ impl.set{{container.string_type.type_name}}(cppValue);
+ return;
+ }
+
+ {% endif %}
+ {# 19. TypeError #}
+ exceptionState.throwTypeError("Not a valid union member.");
+}
+
+v8::Handle<v8::Value> toV8({{container.cpp_class}}& impl, v8::Handle<v8::Object> creationContext, v8::Isolate* isolate)
+{
+ if (impl.isNull())
+ return v8::Undefined(isolate);
+
+ {% for member in container.members %}
+ if (impl.is{{member.type_name}}())
+ return {{member.cpp_value_to_v8_value}};
+
+ {% endfor %}
+ ASSERT_NOT_REACHED();
+ return v8::Undefined(isolate);
+}
+
+{% endfor %}
+} // namespace blink

Powered by Google App Engine
This is Rietveld 408576698