Index: third_party/WebKit/Source/bindings/tests/results/core/ArrayBufferOrArrayBufferViewOrDictionary.cpp |
diff --git a/third_party/WebKit/Source/bindings/tests/results/core/ArrayBufferOrArrayBufferViewOrDictionary.cpp b/third_party/WebKit/Source/bindings/tests/results/core/ArrayBufferOrArrayBufferViewOrDictionary.cpp |
new file mode 100644 |
index 0000000000000000000000000000000000000000..3d246c464eb47a1bfb4f3eaa69f2fe81c6a74f8b |
--- /dev/null |
+++ b/third_party/WebKit/Source/bindings/tests/results/core/ArrayBufferOrArrayBufferViewOrDictionary.cpp |
@@ -0,0 +1,147 @@ |
+// Copyright 2014 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. |
+ |
+// This file has been auto-generated by code_generator_v8.py. DO NOT MODIFY! |
+ |
+#include "ArrayBufferOrArrayBufferViewOrDictionary.h" |
+ |
+#include "bindings/core/v8/Dictionary.h" |
+#include "bindings/core/v8/ToV8.h" |
+#include "bindings/core/v8/V8ArrayBuffer.h" |
+#include "bindings/core/v8/V8ArrayBufferView.h" |
+#include "core/dom/FlexibleArrayBufferView.h" |
+ |
+namespace blink { |
+ |
+ArrayBufferOrArrayBufferViewOrDictionary::ArrayBufferOrArrayBufferViewOrDictionary() |
+ : m_type(SpecificTypeNone) |
+{ |
+} |
+ |
+TestArrayBuffer* ArrayBufferOrArrayBufferViewOrDictionary::getAsArrayBuffer() const |
+{ |
+ ASSERT(isArrayBuffer()); |
+ return m_arrayBuffer; |
+} |
+ |
+void ArrayBufferOrArrayBufferViewOrDictionary::setArrayBuffer(TestArrayBuffer* value) |
+{ |
+ ASSERT(isNull()); |
+ m_arrayBuffer = value; |
+ m_type = SpecificTypeArrayBuffer; |
+} |
+ |
+ArrayBufferOrArrayBufferViewOrDictionary ArrayBufferOrArrayBufferViewOrDictionary::fromArrayBuffer(TestArrayBuffer* value) |
+{ |
+ ArrayBufferOrArrayBufferViewOrDictionary container; |
+ container.setArrayBuffer(value); |
+ return container; |
+} |
+ |
+TestArrayBufferView* ArrayBufferOrArrayBufferViewOrDictionary::getAsArrayBufferView() const |
+{ |
+ ASSERT(isArrayBufferView()); |
+ return m_arrayBufferView; |
+} |
+ |
+void ArrayBufferOrArrayBufferViewOrDictionary::setArrayBufferView(TestArrayBufferView* value) |
+{ |
+ ASSERT(isNull()); |
+ m_arrayBufferView = value; |
+ m_type = SpecificTypeArrayBufferView; |
+} |
+ |
+ArrayBufferOrArrayBufferViewOrDictionary ArrayBufferOrArrayBufferViewOrDictionary::fromArrayBufferView(TestArrayBufferView* value) |
+{ |
+ ArrayBufferOrArrayBufferViewOrDictionary container; |
+ container.setArrayBufferView(value); |
+ return container; |
+} |
+ |
+Dictionary ArrayBufferOrArrayBufferViewOrDictionary::getAsDictionary() const |
+{ |
+ ASSERT(isDictionary()); |
+ return m_dictionary; |
+} |
+ |
+void ArrayBufferOrArrayBufferViewOrDictionary::setDictionary(Dictionary value) |
+{ |
+ ASSERT(isNull()); |
+ m_dictionary = value; |
+ m_type = SpecificTypeDictionary; |
+} |
+ |
+ArrayBufferOrArrayBufferViewOrDictionary ArrayBufferOrArrayBufferViewOrDictionary::fromDictionary(Dictionary value) |
+{ |
+ ArrayBufferOrArrayBufferViewOrDictionary container; |
+ container.setDictionary(value); |
+ return container; |
+} |
+ |
+ArrayBufferOrArrayBufferViewOrDictionary::ArrayBufferOrArrayBufferViewOrDictionary(const ArrayBufferOrArrayBufferViewOrDictionary&) = default; |
+ArrayBufferOrArrayBufferViewOrDictionary::~ArrayBufferOrArrayBufferViewOrDictionary() = default; |
+ArrayBufferOrArrayBufferViewOrDictionary& ArrayBufferOrArrayBufferViewOrDictionary::operator=(const ArrayBufferOrArrayBufferViewOrDictionary&) = default; |
+ |
+DEFINE_TRACE(ArrayBufferOrArrayBufferViewOrDictionary) |
+{ |
+ visitor->trace(m_arrayBuffer); |
+ visitor->trace(m_arrayBufferView); |
+} |
+ |
+void V8ArrayBufferOrArrayBufferViewOrDictionary::toImpl(v8::Isolate* isolate, v8::Local<v8::Value> v8Value, ArrayBufferOrArrayBufferViewOrDictionary& impl, UnionTypeConversionMode conversionMode, ExceptionState& exceptionState) |
+{ |
+ if (v8Value.IsEmpty()) |
+ return; |
+ |
+ if (conversionMode == UnionTypeConversionMode::Nullable && isUndefinedOrNull(v8Value)) |
+ return; |
+ |
+ if (V8ArrayBuffer::hasInstance(v8Value, isolate)) { |
+ TestArrayBuffer* cppValue = V8ArrayBuffer::toImpl(v8::Local<v8::Object>::Cast(v8Value)); |
+ impl.setArrayBuffer(cppValue); |
+ return; |
+ } |
+ |
+ if (V8ArrayBufferView::hasInstance(v8Value, isolate)) { |
+ TestArrayBufferView* cppValue = V8ArrayBufferView::toImpl(v8::Local<v8::Object>::Cast(v8Value)); |
+ impl.setArrayBufferView(cppValue); |
+ return; |
+ } |
+ |
+ if (isUndefinedOrNull(v8Value) || v8Value->IsObject()) { |
+ Dictionary cppValue = Dictionary(v8Value, isolate, exceptionState); |
+ if (exceptionState.hadException()) |
+ return; |
+ impl.setDictionary(cppValue); |
+ return; |
+ } |
+ |
+ exceptionState.throwTypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView or Dictionary)'"); |
+} |
+ |
+v8::Local<v8::Value> toV8(const ArrayBufferOrArrayBufferViewOrDictionary& impl, v8::Local<v8::Object> creationContext, v8::Isolate* isolate) |
+{ |
+ switch (impl.m_type) { |
+ case ArrayBufferOrArrayBufferViewOrDictionary::SpecificTypeNone: |
+ return v8::Null(isolate); |
+ case ArrayBufferOrArrayBufferViewOrDictionary::SpecificTypeArrayBuffer: |
+ return toV8(impl.getAsArrayBuffer(), creationContext, isolate); |
+ case ArrayBufferOrArrayBufferViewOrDictionary::SpecificTypeArrayBufferView: |
+ return toV8(impl.getAsArrayBufferView(), creationContext, isolate); |
+ case ArrayBufferOrArrayBufferViewOrDictionary::SpecificTypeDictionary: |
+ return impl.getAsDictionary().v8Value(); |
+ default: |
+ ASSERT_NOT_REACHED(); |
+ } |
+ return v8::Local<v8::Value>(); |
+} |
+ |
+ArrayBufferOrArrayBufferViewOrDictionary NativeValueTraits<ArrayBufferOrArrayBufferViewOrDictionary>::nativeValue(v8::Isolate* isolate, v8::Local<v8::Value> value, ExceptionState& exceptionState) |
+{ |
+ ArrayBufferOrArrayBufferViewOrDictionary impl; |
+ V8ArrayBufferOrArrayBufferViewOrDictionary::toImpl(isolate, value, impl, UnionTypeConversionMode::NotNullable, exceptionState); |
+ return impl; |
+} |
+ |
+} // namespace blink |