| Index: third_party/WebKit/Source/bindings/tests/results/core/TestEnumOrDouble.cpp
|
| diff --git a/third_party/WebKit/Source/bindings/tests/results/core/TestEnumOrDouble.cpp b/third_party/WebKit/Source/bindings/tests/results/core/TestEnumOrDouble.cpp
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..71948d7a10cc57fa0192b5e72e27cb23e051411f
|
| --- /dev/null
|
| +++ b/third_party/WebKit/Source/bindings/tests/results/core/TestEnumOrDouble.cpp
|
| @@ -0,0 +1,133 @@
|
| +// 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 "TestEnumOrDouble.h"
|
| +
|
| +#include "bindings/core/v8/ToV8.h"
|
| +
|
| +namespace blink {
|
| +
|
| +TestEnumOrDouble::TestEnumOrDouble()
|
| + : m_type(SpecificTypeNone)
|
| +{
|
| +}
|
| +
|
| +String TestEnumOrDouble::getAsTestEnum() const
|
| +{
|
| + ASSERT(isTestEnum());
|
| + return m_testEnum;
|
| +}
|
| +
|
| +void TestEnumOrDouble::setTestEnum(String value)
|
| +{
|
| + ASSERT(isNull());
|
| + NonThrowableExceptionState exceptionState;
|
| + const char* validValues[] = {
|
| + "",
|
| + "EnumValue1",
|
| + "EnumValue2",
|
| + "EnumValue3",
|
| + };
|
| + if (!isValidEnum(value, validValues, WTF_ARRAY_LENGTH(validValues), "TestEnum", exceptionState)) {
|
| + ASSERT_NOT_REACHED();
|
| + return;
|
| + }
|
| + m_testEnum = value;
|
| + m_type = SpecificTypeTestEnum;
|
| +}
|
| +
|
| +TestEnumOrDouble TestEnumOrDouble::fromTestEnum(String value)
|
| +{
|
| + TestEnumOrDouble container;
|
| + container.setTestEnum(value);
|
| + return container;
|
| +}
|
| +
|
| +double TestEnumOrDouble::getAsDouble() const
|
| +{
|
| + ASSERT(isDouble());
|
| + return m_double;
|
| +}
|
| +
|
| +void TestEnumOrDouble::setDouble(double value)
|
| +{
|
| + ASSERT(isNull());
|
| + m_double = value;
|
| + m_type = SpecificTypeDouble;
|
| +}
|
| +
|
| +TestEnumOrDouble TestEnumOrDouble::fromDouble(double value)
|
| +{
|
| + TestEnumOrDouble container;
|
| + container.setDouble(value);
|
| + return container;
|
| +}
|
| +
|
| +TestEnumOrDouble::TestEnumOrDouble(const TestEnumOrDouble&) = default;
|
| +TestEnumOrDouble::~TestEnumOrDouble() = default;
|
| +TestEnumOrDouble& TestEnumOrDouble::operator=(const TestEnumOrDouble&) = default;
|
| +
|
| +DEFINE_TRACE(TestEnumOrDouble)
|
| +{
|
| +}
|
| +
|
| +void V8TestEnumOrDouble::toImpl(v8::Isolate* isolate, v8::Local<v8::Value> v8Value, TestEnumOrDouble& impl, UnionTypeConversionMode conversionMode, ExceptionState& exceptionState)
|
| +{
|
| + if (v8Value.IsEmpty())
|
| + return;
|
| +
|
| + if (conversionMode == UnionTypeConversionMode::Nullable && isUndefinedOrNull(v8Value))
|
| + return;
|
| +
|
| + if (v8Value->IsNumber()) {
|
| + double cppValue = toRestrictedDouble(isolate, v8Value, exceptionState);
|
| + if (exceptionState.hadException())
|
| + return;
|
| + impl.setDouble(cppValue);
|
| + return;
|
| + }
|
| +
|
| + {
|
| + V8StringResource<> cppValue = v8Value;
|
| + if (!cppValue.prepare(exceptionState))
|
| + return;
|
| + const char* validValues[] = {
|
| + "",
|
| + "EnumValue1",
|
| + "EnumValue2",
|
| + "EnumValue3",
|
| + };
|
| + if (!isValidEnum(cppValue, validValues, WTF_ARRAY_LENGTH(validValues), "TestEnum", exceptionState))
|
| + return;
|
| + impl.setTestEnum(cppValue);
|
| + return;
|
| + }
|
| +
|
| +}
|
| +
|
| +v8::Local<v8::Value> toV8(const TestEnumOrDouble& impl, v8::Local<v8::Object> creationContext, v8::Isolate* isolate)
|
| +{
|
| + switch (impl.m_type) {
|
| + case TestEnumOrDouble::SpecificTypeNone:
|
| + return v8::Null(isolate);
|
| + case TestEnumOrDouble::SpecificTypeTestEnum:
|
| + return v8String(isolate, impl.getAsTestEnum());
|
| + case TestEnumOrDouble::SpecificTypeDouble:
|
| + return v8::Number::New(isolate, impl.getAsDouble());
|
| + default:
|
| + ASSERT_NOT_REACHED();
|
| + }
|
| + return v8::Local<v8::Value>();
|
| +}
|
| +
|
| +TestEnumOrDouble NativeValueTraits<TestEnumOrDouble>::nativeValue(v8::Isolate* isolate, v8::Local<v8::Value> value, ExceptionState& exceptionState)
|
| +{
|
| + TestEnumOrDouble impl;
|
| + V8TestEnumOrDouble::toImpl(isolate, value, impl, UnionTypeConversionMode::NotNullable, exceptionState);
|
| + return impl;
|
| +}
|
| +
|
| +} // namespace blink
|
|
|