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

Unified Diff: Source/bindings/tests/results/core/UnionTypesCore.h

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/tests/results/core/UnionTypesCore.h
diff --git a/Source/bindings/tests/results/core/UnionTypesCore.h b/Source/bindings/tests/results/core/UnionTypesCore.h
index 59d2429fc17a4c01e825a79b8b12ba0dda17c87c..6c1d925bb341b715557348032ae5f8a4bed8952e 100644
--- a/Source/bindings/tests/results/core/UnionTypesCore.h
+++ b/Source/bindings/tests/results/core/UnionTypesCore.h
@@ -7,32 +7,260 @@
#ifndef UnionTypeCore_h
#define UnionTypeCore_h
+#include "bindings/core/v8/ExceptionState.h"
+#include "bindings/core/v8/V8Binding.h"
+#include "platform/heap/Handle.h"
+
namespace blink {
+class Node;
+class NodeList;
+class TestDictionary;
+class TestInterface;
+class TestInterfaceEmpty;
+class TestInterfaceGarbageCollected;
+class TestInterfaceWillBeGarbageCollected;
+
class LongSequenceOrStringArrayOrUnrestrictedDouble final {
- // FIXME: Implement
+ ALLOW_ONLY_INLINE_ALLOCATION();
+public:
+ LongSequenceOrStringArrayOrUnrestrictedDouble();
+ bool isNull() const { return m_type == SpecificTypeNone; }
+
+ bool isLongSequence() const { return m_type == SpecificTypeLongSequence; }
+ const Vector<int>& getAsLongSequence();
+ void setLongSequence(const Vector<int>&);
+
+ bool isStringArray() const { return m_type == SpecificTypeStringArray; }
+ const Vector<String>& getAsStringArray();
+ void setStringArray(const Vector<String>&);
+
+ bool isUnrestrictedDouble() const { return m_type == SpecificTypeUnrestrictedDouble; }
+ double getAsUnrestrictedDouble();
+ void setUnrestrictedDouble(double);
+
+private:
+ enum SpecificTypes {
+ SpecificTypeNone,
+ SpecificTypeLongSequence,
+ SpecificTypeStringArray,
+ SpecificTypeUnrestrictedDouble,
+ };
+ SpecificTypes m_type;
+
+ Vector<int> m_longSequence;
+ Vector<String> m_stringArray;
+ double m_unrestrictedDouble;
};
+class V8LongSequenceOrStringArrayOrUnrestrictedDouble final {
+public:
+ static void toImpl(v8::Isolate*, v8::Handle<v8::Value>, LongSequenceOrStringArrayOrUnrestrictedDouble&, ExceptionState&);
+};
+
+v8::Handle<v8::Value> toV8(LongSequenceOrStringArrayOrUnrestrictedDouble&, v8::Handle<v8::Object>, v8::Isolate*);
+
+template <class CallbackInfo>
+inline void v8SetReturnValue(const CallbackInfo& callbackInfo, LongSequenceOrStringArrayOrUnrestrictedDouble& impl)
+{
+ v8SetReturnValue(callbackInfo, toV8(impl, callbackInfo.Holder(), callbackInfo.GetIsolate()));
+}
+
class NodeOrNodeList final {
- // FIXME: Implement
+ ALLOW_ONLY_INLINE_ALLOCATION();
+public:
+ NodeOrNodeList();
+ bool isNull() const { return m_type == SpecificTypeNone; }
+
+ bool isNode() const { return m_type == SpecificTypeNode; }
+ PassRefPtrWillBeRawPtr<Node> getAsNode();
+ void setNode(PassRefPtrWillBeRawPtr<Node>);
+
+ bool isNodeList() const { return m_type == SpecificTypeNodeList; }
+ PassRefPtrWillBeRawPtr<NodeList> getAsNodeList();
+ void setNodeList(PassRefPtrWillBeRawPtr<NodeList>);
+
+private:
+ enum SpecificTypes {
+ SpecificTypeNone,
+ SpecificTypeNode,
+ SpecificTypeNodeList,
+ };
+ SpecificTypes m_type;
+
+ RefPtrWillBeMember<Node> m_node;
+ RefPtrWillBeMember<NodeList> m_nodeList;
+};
+
+class V8NodeOrNodeList final {
+public:
+ static void toImpl(v8::Isolate*, v8::Handle<v8::Value>, NodeOrNodeList&, ExceptionState&);
};
+v8::Handle<v8::Value> toV8(NodeOrNodeList&, v8::Handle<v8::Object>, v8::Isolate*);
+
+template <class CallbackInfo>
+inline void v8SetReturnValue(const CallbackInfo& callbackInfo, NodeOrNodeList& impl)
+{
+ v8SetReturnValue(callbackInfo, toV8(impl, callbackInfo.Holder(), callbackInfo.GetIsolate()));
+}
+
class StringOrDouble final {
- // FIXME: Implement
+ ALLOW_ONLY_INLINE_ALLOCATION();
+public:
+ StringOrDouble();
+ bool isNull() const { return m_type == SpecificTypeNone; }
+
+ bool isString() const { return m_type == SpecificTypeString; }
+ String getAsString();
+ void setString(String);
+
+ bool isDouble() const { return m_type == SpecificTypeDouble; }
+ double getAsDouble();
+ void setDouble(double);
+
+private:
+ enum SpecificTypes {
+ SpecificTypeNone,
+ SpecificTypeString,
+ SpecificTypeDouble,
+ };
+ SpecificTypes m_type;
+
+ String m_string;
+ double m_double;
};
+class V8StringOrDouble final {
+public:
+ static void toImpl(v8::Isolate*, v8::Handle<v8::Value>, StringOrDouble&, ExceptionState&);
+};
+
+v8::Handle<v8::Value> toV8(StringOrDouble&, v8::Handle<v8::Object>, v8::Isolate*);
+
+template <class CallbackInfo>
+inline void v8SetReturnValue(const CallbackInfo& callbackInfo, StringOrDouble& impl)
+{
+ v8SetReturnValue(callbackInfo, toV8(impl, callbackInfo.Holder(), callbackInfo.GetIsolate()));
+}
+
class TestInterfaceGarbageCollectedOrString final {
- // FIXME: Implement
+ ALLOW_ONLY_INLINE_ALLOCATION();
+public:
+ TestInterfaceGarbageCollectedOrString();
+ bool isNull() const { return m_type == SpecificTypeNone; }
+
+ bool isTestInterfaceGarbageCollected() const { return m_type == SpecificTypeTestInterfaceGarbageCollected; }
+ RawPtr<TestInterfaceGarbageCollected> getAsTestInterfaceGarbageCollected();
+ void setTestInterfaceGarbageCollected(RawPtr<TestInterfaceGarbageCollected>);
+
+ bool isString() const { return m_type == SpecificTypeString; }
+ String getAsString();
+ void setString(String);
+
+private:
+ enum SpecificTypes {
+ SpecificTypeNone,
+ SpecificTypeTestInterfaceGarbageCollected,
+ SpecificTypeString,
+ };
+ SpecificTypes m_type;
+
+ Member<TestInterfaceGarbageCollected> m_testInterfaceGarbageCollected;
+ String m_string;
+};
+
+class V8TestInterfaceGarbageCollectedOrString final {
+public:
+ static void toImpl(v8::Isolate*, v8::Handle<v8::Value>, TestInterfaceGarbageCollectedOrString&, ExceptionState&);
};
+v8::Handle<v8::Value> toV8(TestInterfaceGarbageCollectedOrString&, v8::Handle<v8::Object>, v8::Isolate*);
+
+template <class CallbackInfo>
+inline void v8SetReturnValue(const CallbackInfo& callbackInfo, TestInterfaceGarbageCollectedOrString& impl)
+{
+ v8SetReturnValue(callbackInfo, toV8(impl, callbackInfo.Holder(), callbackInfo.GetIsolate()));
+}
+
class TestInterfaceOrTestInterfaceEmpty final {
- // FIXME: Implement
+ ALLOW_ONLY_INLINE_ALLOCATION();
+public:
+ TestInterfaceOrTestInterfaceEmpty();
+ bool isNull() const { return m_type == SpecificTypeNone; }
+
+ bool isTestInterface() const { return m_type == SpecificTypeTestInterface; }
+ PassRefPtr<TestInterfaceImplementation> getAsTestInterface();
+ void setTestInterface(PassRefPtr<TestInterfaceImplementation>);
+
+ bool isTestInterfaceEmpty() const { return m_type == SpecificTypeTestInterfaceEmpty; }
+ PassRefPtr<TestInterfaceEmpty> getAsTestInterfaceEmpty();
+ void setTestInterfaceEmpty(PassRefPtr<TestInterfaceEmpty>);
+
+private:
+ enum SpecificTypes {
+ SpecificTypeNone,
+ SpecificTypeTestInterface,
+ SpecificTypeTestInterfaceEmpty,
+ };
+ SpecificTypes m_type;
+
+ RefPtr<TestInterfaceImplementation> m_testInterface;
+ RefPtr<TestInterfaceEmpty> m_testInterfaceEmpty;
};
+class V8TestInterfaceOrTestInterfaceEmpty final {
+public:
+ static void toImpl(v8::Isolate*, v8::Handle<v8::Value>, TestInterfaceOrTestInterfaceEmpty&, ExceptionState&);
+};
+
+v8::Handle<v8::Value> toV8(TestInterfaceOrTestInterfaceEmpty&, v8::Handle<v8::Object>, v8::Isolate*);
+
+template <class CallbackInfo>
+inline void v8SetReturnValue(const CallbackInfo& callbackInfo, TestInterfaceOrTestInterfaceEmpty& impl)
+{
+ v8SetReturnValue(callbackInfo, toV8(impl, callbackInfo.Holder(), callbackInfo.GetIsolate()));
+}
+
class TestInterfaceWillBeGarbageCollectedOrTestDictionary final {
- // FIXME: Implement
+ ALLOW_ONLY_INLINE_ALLOCATION();
+public:
+ TestInterfaceWillBeGarbageCollectedOrTestDictionary();
+ bool isNull() const { return m_type == SpecificTypeNone; }
+
+ bool isTestInterfaceWillBeGarbageCollected() const { return m_type == SpecificTypeTestInterfaceWillBeGarbageCollected; }
+ PassRefPtrWillBeRawPtr<TestInterfaceWillBeGarbageCollected> getAsTestInterfaceWillBeGarbageCollected();
+ void setTestInterfaceWillBeGarbageCollected(PassRefPtrWillBeRawPtr<TestInterfaceWillBeGarbageCollected>);
+
+ bool isTestDictionary() const { return m_type == SpecificTypeTestDictionary; }
+ TestDictionary getAsTestDictionary();
+ void setTestDictionary(TestDictionary);
+
+private:
+ enum SpecificTypes {
+ SpecificTypeNone,
+ SpecificTypeTestInterfaceWillBeGarbageCollected,
+ SpecificTypeTestDictionary,
+ };
+ SpecificTypes m_type;
+
+ RefPtrWillBeMember<TestInterfaceWillBeGarbageCollected> m_testInterfaceWillBeGarbageCollected;
+ TestDictionary m_testDictionary;
+};
+
+class V8TestInterfaceWillBeGarbageCollectedOrTestDictionary final {
+public:
+ static void toImpl(v8::Isolate*, v8::Handle<v8::Value>, TestInterfaceWillBeGarbageCollectedOrTestDictionary&, ExceptionState&);
};
+v8::Handle<v8::Value> toV8(TestInterfaceWillBeGarbageCollectedOrTestDictionary&, v8::Handle<v8::Object>, v8::Isolate*);
+
+template <class CallbackInfo>
+inline void v8SetReturnValue(const CallbackInfo& callbackInfo, TestInterfaceWillBeGarbageCollectedOrTestDictionary& impl)
+{
+ v8SetReturnValue(callbackInfo, toV8(impl, callbackInfo.Holder(), callbackInfo.GetIsolate()));
+}
+
} // namespace blink
#endif // UnionTypeCore_h

Powered by Google App Engine
This is Rietveld 408576698