Index: third_party/WebKit/Source/bindings/tests/results/core/TestEnumOrDouble.h |
diff --git a/third_party/WebKit/Source/bindings/tests/results/core/TestEnumOrDouble.h b/third_party/WebKit/Source/bindings/tests/results/core/TestEnumOrDouble.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..0f2133e9824967a5a62d9cc310d660384363590e |
--- /dev/null |
+++ b/third_party/WebKit/Source/bindings/tests/results/core/TestEnumOrDouble.h |
@@ -0,0 +1,80 @@ |
+// 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! |
+ |
+#ifndef TestEnumOrDouble_h |
+#define TestEnumOrDouble_h |
+ |
+#include "bindings/core/v8/Dictionary.h" |
+#include "bindings/core/v8/ExceptionState.h" |
+#include "bindings/core/v8/V8Binding.h" |
+#include "core/CoreExport.h" |
+#include "platform/heap/Handle.h" |
+ |
+namespace blink { |
+ |
+ |
+class CORE_EXPORT TestEnumOrDouble final { |
+ DISALLOW_NEW_EXCEPT_PLACEMENT_NEW(); |
+public: |
+ TestEnumOrDouble(); |
+ bool isNull() const { return m_type == SpecificTypeNone; } |
+ |
+ bool isTestEnum() const { return m_type == SpecificTypeTestEnum; } |
+ String getAsTestEnum() const; |
+ void setTestEnum(String); |
+ static TestEnumOrDouble fromTestEnum(String); |
+ |
+ bool isDouble() const { return m_type == SpecificTypeDouble; } |
+ double getAsDouble() const; |
+ void setDouble(double); |
+ static TestEnumOrDouble fromDouble(double); |
+ |
+ TestEnumOrDouble(const TestEnumOrDouble&); |
+ ~TestEnumOrDouble(); |
+ TestEnumOrDouble& operator=(const TestEnumOrDouble&); |
+ DECLARE_TRACE(); |
+ |
+private: |
+ enum SpecificTypes { |
+ SpecificTypeNone, |
+ SpecificTypeTestEnum, |
+ SpecificTypeDouble, |
+ }; |
+ SpecificTypes m_type; |
+ |
+ String m_testEnum; |
+ double m_double; |
+ |
+ friend CORE_EXPORT v8::Local<v8::Value> toV8(const TestEnumOrDouble&, v8::Local<v8::Object>, v8::Isolate*); |
+}; |
+ |
+class V8TestEnumOrDouble final { |
+public: |
+ CORE_EXPORT static void toImpl(v8::Isolate*, v8::Local<v8::Value>, TestEnumOrDouble&, UnionTypeConversionMode, ExceptionState&); |
+}; |
+ |
+CORE_EXPORT v8::Local<v8::Value> toV8(const TestEnumOrDouble&, v8::Local<v8::Object>, v8::Isolate*); |
+ |
+template <class CallbackInfo> |
+inline void v8SetReturnValue(const CallbackInfo& callbackInfo, TestEnumOrDouble& impl) |
+{ |
+ v8SetReturnValue(callbackInfo, toV8(impl, callbackInfo.Holder(), callbackInfo.GetIsolate())); |
+} |
+ |
+template <> |
+struct NativeValueTraits<TestEnumOrDouble> { |
+ CORE_EXPORT static TestEnumOrDouble nativeValue(v8::Isolate*, v8::Local<v8::Value>, ExceptionState&); |
+}; |
+ |
+} // namespace blink |
+ |
+// We need to set canInitializeWithMemset=true because HeapVector supports |
+// items that can initialize with memset or have a vtable. It is safe to |
+// set canInitializeWithMemset=true for a union type object in practice. |
+// See https://codereview.chromium.org/1118993002/#msg5 for more details. |
+WTF_ALLOW_MOVE_AND_INIT_WITH_MEM_FUNCTIONS(blink::TestEnumOrDouble); |
+ |
+#endif // TestEnumOrDouble_h |