Implement [Supplemental] IDL and support it in run-bindings-tests
[WebKit-https.git] / Source / WebCore / bindings / scripts / test / JS / JSTestInterface.cpp
1 /*
2     This file is part of the WebKit open source project.
3     This file has been generated by generate-bindings.pl. DO NOT MODIFY!
4
5     This library is free software; you can redistribute it and/or
6     modify it under the terms of the GNU Library General Public
7     License as published by the Free Software Foundation; either
8     version 2 of the License, or (at your option) any later version.
9
10     This library is distributed in the hope that it will be useful,
11     but WITHOUT ANY WARRANTY; without even the implied warranty of
12     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13     Library General Public License for more details.
14
15     You should have received a copy of the GNU Library General Public License
16     along with this library; see the file COPYING.LIB.  If not, write to
17     the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
18     Boston, MA 02110-1301, USA.
19 */
20
21 #include "config.h"
22
23 #if ENABLE(Condition1) || ENABLE(Condition2)
24
25 #include "JSTestInterface.h"
26
27 #include "ExceptionCode.h"
28 #include "JSDOMBinding.h"
29 #include "JSTestSupplemental.h"
30 #include "TestInterface.h"
31 #include "TestSupplemental.h"
32 #include <runtime/Error.h>
33 #include <wtf/GetPtr.h>
34
35 #if ENABLE(Condition11) || ENABLE(Condition12)
36 #include "KURL.h"
37 #include <runtime/JSString.h>
38 #endif
39
40 using namespace JSC;
41
42 namespace WebCore {
43
44 ASSERT_CLASS_FITS_IN_CELL(JSTestInterface);
45
46 /* Hash table */
47 #if ENABLE(JIT)
48 #define THUNK_GENERATOR(generator) , generator
49 #else
50 #define THUNK_GENERATOR(generator)
51 #endif
52 #if ENABLE(DFG_JIT)
53 #define INTRINSIC(intrinsic) , intrinsic
54 #else
55 #define INTRINSIC(intrinsic)
56 #endif
57
58 static const HashTableValue JSTestInterfaceTableValues[] =
59 {
60 #if ENABLE(Condition11) || ENABLE(Condition12)
61     { "str1", DontDelete | ReadOnly, (intptr_t)static_cast<PropertySlot::GetValueFunc>(jsTestInterfaceStr1), (intptr_t)0 THUNK_GENERATOR(0) INTRINSIC(DFG::NoIntrinsic) },
62 #endif
63 #if ENABLE(Condition11) || ENABLE(Condition12)
64     { "str2", DontDelete, (intptr_t)static_cast<PropertySlot::GetValueFunc>(jsTestInterfaceStr2), (intptr_t)setJSTestInterfaceStr2 THUNK_GENERATOR(0) INTRINSIC(DFG::NoIntrinsic) },
65 #endif
66 #if ENABLE(Condition11) || ENABLE(Condition12)
67     { "str3", DontDelete, (intptr_t)static_cast<PropertySlot::GetValueFunc>(jsTestInterfaceStr3), (intptr_t)setJSTestInterfaceStr3 THUNK_GENERATOR(0) INTRINSIC(DFG::NoIntrinsic) },
68 #endif
69     { "constructor", DontEnum | ReadOnly, (intptr_t)static_cast<PropertySlot::GetValueFunc>(jsTestInterfaceConstructor), (intptr_t)0 THUNK_GENERATOR(0) INTRINSIC(DFG::NoIntrinsic) },
70     { 0, 0, 0, 0 THUNK_GENERATOR(0) INTRINSIC(DFG::NoIntrinsic) }
71 };
72
73 #undef THUNK_GENERATOR
74 static const HashTable JSTestInterfaceTable = { 8, 7, JSTestInterfaceTableValues, 0 };
75 /* Hash table for constructor */
76 #if ENABLE(JIT)
77 #define THUNK_GENERATOR(generator) , generator
78 #else
79 #define THUNK_GENERATOR(generator)
80 #endif
81 #if ENABLE(DFG_JIT)
82 #define INTRINSIC(intrinsic) , intrinsic
83 #else
84 #define INTRINSIC(intrinsic)
85 #endif
86
87 static const HashTableValue JSTestInterfaceConstructorTableValues[] =
88 {
89     { 0, 0, 0, 0 THUNK_GENERATOR(0) INTRINSIC(DFG::NoIntrinsic) }
90 };
91
92 #undef THUNK_GENERATOR
93 static const HashTable JSTestInterfaceConstructorTable = { 1, 0, JSTestInterfaceConstructorTableValues, 0 };
94 const ClassInfo JSTestInterfaceConstructor::s_info = { "TestInterfaceConstructor", &DOMConstructorObject::s_info, &JSTestInterfaceConstructorTable, 0, CREATE_METHOD_TABLE(JSTestInterfaceConstructor) };
95
96 JSTestInterfaceConstructor::JSTestInterfaceConstructor(Structure* structure, JSDOMGlobalObject* globalObject)
97     : DOMConstructorObject(structure, globalObject)
98 {
99 }
100
101 void JSTestInterfaceConstructor::finishCreation(ExecState* exec, JSDOMGlobalObject* globalObject)
102 {
103     Base::finishCreation(exec->globalData());
104     ASSERT(inherits(&s_info));
105     putDirect(exec->globalData(), exec->propertyNames().prototype, JSTestInterfacePrototype::self(exec, globalObject), DontDelete | ReadOnly);
106 }
107
108 bool JSTestInterfaceConstructor::getOwnPropertySlot(JSCell* cell, ExecState* exec, const Identifier& propertyName, PropertySlot& slot)
109 {
110     return getStaticValueSlot<JSTestInterfaceConstructor, JSDOMWrapper>(exec, &JSTestInterfaceConstructorTable, static_cast<JSTestInterfaceConstructor*>(cell), propertyName, slot);
111 }
112
113 bool JSTestInterfaceConstructor::getOwnPropertyDescriptor(JSObject* object, ExecState* exec, const Identifier& propertyName, PropertyDescriptor& descriptor)
114 {
115     return getStaticValueDescriptor<JSTestInterfaceConstructor, JSDOMWrapper>(exec, &JSTestInterfaceConstructorTable, static_cast<JSTestInterfaceConstructor*>(object), propertyName, descriptor);
116 }
117
118 EncodedJSValue JSC_HOST_CALL JSTestInterfaceConstructor::constructJSTestInterface(ExecState* exec)
119 {
120     JSTestInterfaceConstructor* jsConstructor = static_cast<JSTestInterfaceConstructor*>(exec->callee());
121     if (exec->argumentCount() < 1)
122         return throwVMError(exec, createTypeError(exec, "Not enough arguments"));
123     ExceptionCode ec = 0;
124     const String& str1(ustringToString(MAYBE_MISSING_PARAMETER(exec, 0, MissingIsUndefined).isEmpty() ? UString() : MAYBE_MISSING_PARAMETER(exec, 0, MissingIsUndefined).toString(exec)));
125     if (exec->hadException())
126         return JSValue::encode(jsUndefined());
127     const String& str2(ustringToString(MAYBE_MISSING_PARAMETER(exec, 1, MissingIsUndefined).isEmpty() ? UString() : MAYBE_MISSING_PARAMETER(exec, 1, MissingIsUndefined).toString(exec)));
128     if (exec->hadException())
129         return JSValue::encode(jsUndefined());
130     ScriptExecutionContext* context = jsConstructor->scriptExecutionContext();
131     if (!context)
132         return throwVMError(exec, createReferenceError(exec, "TestInterface constructor associated document is unavailable"));
133     RefPtr<TestInterface> object = TestInterface::create(context, str1, str2, ec);
134     if (ec) {
135         setDOMException(exec, ec);
136         return JSValue::encode(JSValue());
137     }
138     return JSValue::encode(asObject(toJS(exec, jsConstructor->globalObject(), object.get())));
139 }
140
141 ConstructType JSTestInterfaceConstructor::getConstructData(JSCell*, ConstructData& constructData)
142 {
143     constructData.native.function = constructJSTestInterface;
144     return ConstructTypeHost;
145 }
146
147 /* Hash table for prototype */
148 #if ENABLE(JIT)
149 #define THUNK_GENERATOR(generator) , generator
150 #else
151 #define THUNK_GENERATOR(generator)
152 #endif
153 #if ENABLE(DFG_JIT)
154 #define INTRINSIC(intrinsic) , intrinsic
155 #else
156 #define INTRINSIC(intrinsic)
157 #endif
158
159 static const HashTableValue JSTestInterfacePrototypeTableValues[] =
160 {
161     { 0, 0, 0, 0 THUNK_GENERATOR(0) INTRINSIC(DFG::NoIntrinsic) }
162 };
163
164 #undef THUNK_GENERATOR
165 static const HashTable JSTestInterfacePrototypeTable = { 1, 0, JSTestInterfacePrototypeTableValues, 0 };
166 const ClassInfo JSTestInterfacePrototype::s_info = { "TestInterfacePrototype", &JSC::JSNonFinalObject::s_info, &JSTestInterfacePrototypeTable, 0, CREATE_METHOD_TABLE(JSTestInterfacePrototype) };
167
168 JSObject* JSTestInterfacePrototype::self(ExecState* exec, JSGlobalObject* globalObject)
169 {
170     return getDOMPrototype<JSTestInterface>(exec, globalObject);
171 }
172
173 const ClassInfo JSTestInterface::s_info = { "TestInterface", &JSDOMWrapper::s_info, &JSTestInterfaceTable, 0 , CREATE_METHOD_TABLE(JSTestInterface) };
174
175 JSTestInterface::JSTestInterface(Structure* structure, JSDOMGlobalObject* globalObject, PassRefPtr<TestInterface> impl)
176     : JSDOMWrapper(structure, globalObject)
177     , m_impl(impl.leakRef())
178 {
179 }
180
181 void JSTestInterface::finishCreation(JSGlobalData& globalData)
182 {
183     Base::finishCreation(globalData);
184     ASSERT(inherits(&s_info));
185 }
186
187 JSObject* JSTestInterface::createPrototype(ExecState* exec, JSGlobalObject* globalObject)
188 {
189     return JSTestInterfacePrototype::create(exec->globalData(), globalObject, JSTestInterfacePrototype::createStructure(globalObject->globalData(), globalObject, globalObject->objectPrototype()));
190 }
191
192 bool JSTestInterface::getOwnPropertySlot(JSCell* cell, ExecState* exec, const Identifier& propertyName, PropertySlot& slot)
193 {
194     JSTestInterface* thisObject = jsCast<JSTestInterface*>(cell);
195     ASSERT_GC_OBJECT_INHERITS(thisObject, &s_info);
196     return getStaticValueSlot<JSTestInterface, Base>(exec, &JSTestInterfaceTable, thisObject, propertyName, slot);
197 }
198
199 bool JSTestInterface::getOwnPropertyDescriptor(JSObject* object, ExecState* exec, const Identifier& propertyName, PropertyDescriptor& descriptor)
200 {
201     JSTestInterface* thisObject = jsCast<JSTestInterface*>(object);
202     ASSERT_GC_OBJECT_INHERITS(thisObject, &s_info);
203     return getStaticValueDescriptor<JSTestInterface, Base>(exec, &JSTestInterfaceTable, thisObject, propertyName, descriptor);
204 }
205
206 #if ENABLE(Condition11) || ENABLE(Condition12)
207 JSValue jsTestInterfaceStr1(ExecState* exec, JSValue slotBase, const Identifier&)
208 {
209     JSTestInterface* castedThis = static_cast<JSTestInterface*>(asObject(slotBase));
210     UNUSED_PARAM(exec);
211     TestInterface* imp = static_cast<TestInterface*>(castedThis->impl());
212     JSValue result = jsString(exec, TestSupplemental::str1(imp));
213     return result;
214 }
215
216 #endif
217
218 #if ENABLE(Condition11) || ENABLE(Condition12)
219 JSValue jsTestInterfaceStr2(ExecState* exec, JSValue slotBase, const Identifier&)
220 {
221     JSTestInterface* castedThis = static_cast<JSTestInterface*>(asObject(slotBase));
222     UNUSED_PARAM(exec);
223     TestInterface* imp = static_cast<TestInterface*>(castedThis->impl());
224     JSValue result = jsString(exec, TestSupplemental::str2(imp));
225     return result;
226 }
227
228 #endif
229
230 #if ENABLE(Condition11) || ENABLE(Condition12)
231 JSValue jsTestInterfaceStr3(ExecState* exec, JSValue slotBase, const Identifier&)
232 {
233     JSTestInterface* castedThis = static_cast<JSTestInterface*>(asObject(slotBase));
234     return JSTestSupplemental::str3(castedThis, exec);
235 }
236
237 #endif
238
239 JSValue jsTestInterfaceConstructor(ExecState* exec, JSValue slotBase, const Identifier&)
240 {
241     JSTestInterface* domObject = static_cast<JSTestInterface*>(asObject(slotBase));
242     return JSTestInterface::getConstructor(exec, domObject->globalObject());
243 }
244
245 void JSTestInterface::put(JSCell* cell, ExecState* exec, const Identifier& propertyName, JSValue value, PutPropertySlot& slot)
246 {
247     JSTestInterface* thisObject = jsCast<JSTestInterface*>(cell);
248     ASSERT_GC_OBJECT_INHERITS(thisObject, &s_info);
249     lookupPut<JSTestInterface, Base>(exec, propertyName, value, &JSTestInterfaceTable, thisObject, slot);
250 }
251
252 #if ENABLE(Condition11) || ENABLE(Condition12)
253 void setJSTestInterfaceStr2(ExecState* exec, JSObject* thisObject, JSValue value)
254 {
255     JSTestInterface* castedThis = static_cast<JSTestInterface*>(thisObject);
256     TestInterface* imp = static_cast<TestInterface*>(castedThis->impl());
257     TestSupplemental::setStr2(imp, ustringToString(value.isEmpty() ? UString() : value.toString(exec)));
258 }
259
260 #endif
261
262 #if ENABLE(Condition11) || ENABLE(Condition12)
263 void setJSTestInterfaceStr3(ExecState* exec, JSObject* thisObject, JSValue value)
264 {
265     JSTestSupplemental::setStr3(static_cast<JSTestInterface*>(thisObject), exec, value);
266 }
267
268 #endif
269
270 JSValue JSTestInterface::getConstructor(ExecState* exec, JSGlobalObject* globalObject)
271 {
272     return getDOMConstructor<JSTestInterfaceConstructor>(exec, static_cast<JSDOMGlobalObject*>(globalObject));
273 }
274
275 static inline bool isObservable(JSTestInterface* jsTestInterface)
276 {
277     if (jsTestInterface->hasCustomProperties())
278         return true;
279     return false;
280 }
281
282 bool JSTestInterfaceOwner::isReachableFromOpaqueRoots(JSC::Handle<JSC::Unknown> handle, void*, SlotVisitor& visitor)
283 {
284     JSTestInterface* jsTestInterface = static_cast<JSTestInterface*>(handle.get().asCell());
285     if (jsTestInterface->impl()->hasPendingActivity())
286         return true;
287     if (!isObservable(jsTestInterface))
288         return false;
289     UNUSED_PARAM(visitor);
290     return false;
291 }
292
293 void JSTestInterfaceOwner::finalize(JSC::Handle<JSC::Unknown> handle, void* context)
294 {
295     JSTestInterface* jsTestInterface = static_cast<JSTestInterface*>(handle.get().asCell());
296     DOMWrapperWorld* world = static_cast<DOMWrapperWorld*>(context);
297     uncacheWrapper(world, jsTestInterface->impl(), jsTestInterface);
298     jsTestInterface->releaseImpl();
299 }
300
301 JSC::JSValue toJS(JSC::ExecState* exec, JSDOMGlobalObject* globalObject, TestInterface* impl)
302 {
303     return wrap<JSTestInterface>(exec, globalObject, impl);
304 }
305
306 TestInterface* toTestInterface(JSC::JSValue value)
307 {
308     return value.inherits(&JSTestInterface::s_info) ? static_cast<JSTestInterface*>(asObject(value))->impl() : 0;
309 }
310
311 }
312
313 #endif // ENABLE(Condition1) || ENABLE(Condition2)