Reduce memory use for static property maps
[WebKit-https.git] / Source / WebCore / bindings / scripts / test / JS / JSTestGenerateIsReachable.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 #include "JSTestGenerateIsReachable.h"
23
24 #include "TestGenerateIsReachable.h"
25 #include <wtf/GetPtr.h>
26
27 using namespace JSC;
28
29 namespace WebCore {
30
31 #if COMPILER(MSVC)
32 #pragma warning(push)
33 #pragma warning(disable: 2466) // Disable 'cannot allocate an array of constant size 0' warning
34 #endif
35 /* Hash table for constructor */
36
37 static const struct CompactHashIndex JSTestGenerateIsReachableConstructorTableIndex[1] = {
38     { -1, -1 },
39 };
40
41
42 static const HashTableValue JSTestGenerateIsReachableConstructorTableValues[0] =
43 {
44 };
45
46 static const HashTable JSTestGenerateIsReachableConstructorTable = { 0, 0, false, JSTestGenerateIsReachableConstructorTableValues, 0, JSTestGenerateIsReachableConstructorTableIndex };
47 #if COMPILER(MSVC)
48 #pragma warning(pop)
49 #endif
50 const ClassInfo JSTestGenerateIsReachableConstructor::s_info = { "TestGenerateIsReachableConstructor", &Base::s_info, &JSTestGenerateIsReachableConstructorTable, 0, CREATE_METHOD_TABLE(JSTestGenerateIsReachableConstructor) };
51
52 JSTestGenerateIsReachableConstructor::JSTestGenerateIsReachableConstructor(Structure* structure, JSDOMGlobalObject* globalObject)
53     : DOMConstructorObject(structure, globalObject)
54 {
55 }
56
57 void JSTestGenerateIsReachableConstructor::finishCreation(VM& vm, JSDOMGlobalObject* globalObject)
58 {
59     Base::finishCreation(vm);
60     ASSERT(inherits(info()));
61     putDirect(vm, vm.propertyNames->prototype, JSTestGenerateIsReachablePrototype::self(vm, globalObject), DontDelete | ReadOnly);
62     putDirect(vm, vm.propertyNames->length, jsNumber(0), ReadOnly | DontDelete | DontEnum);
63 }
64
65 bool JSTestGenerateIsReachableConstructor::getOwnPropertySlot(JSObject* object, ExecState* exec, PropertyName propertyName, PropertySlot& slot)
66 {
67     return getStaticValueSlot<JSTestGenerateIsReachableConstructor, JSDOMWrapper>(exec, JSTestGenerateIsReachableConstructorTable, jsCast<JSTestGenerateIsReachableConstructor*>(object), propertyName, slot);
68 }
69
70 #if COMPILER(MSVC)
71 #pragma warning(push)
72 #pragma warning(disable: 2466) // Disable 'cannot allocate an array of constant size 0' warning
73 #endif
74 /* Hash table for prototype */
75
76 static const struct CompactHashIndex JSTestGenerateIsReachablePrototypeTableIndex[2] = {
77     { -1, -1 },
78     { 0, -1 },
79 };
80
81
82 static const HashTableValue JSTestGenerateIsReachablePrototypeTableValues[1] =
83 {
84     { "constructor", DontEnum | ReadOnly, NoIntrinsic, (intptr_t)static_cast<PropertySlot::GetValueFunc>(jsTestGenerateIsReachableConstructor), (intptr_t) static_cast<PutPropertySlot::PutValueFunc>(0) },
85 };
86
87 static const HashTable JSTestGenerateIsReachablePrototypeTable = { 1, 1, true, JSTestGenerateIsReachablePrototypeTableValues, 0, JSTestGenerateIsReachablePrototypeTableIndex };
88 #if COMPILER(MSVC)
89 #pragma warning(pop)
90 #endif
91 const ClassInfo JSTestGenerateIsReachablePrototype::s_info = { "TestGenerateIsReachablePrototype", &Base::s_info, &JSTestGenerateIsReachablePrototypeTable, 0, CREATE_METHOD_TABLE(JSTestGenerateIsReachablePrototype) };
92
93 JSObject* JSTestGenerateIsReachablePrototype::self(VM& vm, JSGlobalObject* globalObject)
94 {
95     return getDOMPrototype<JSTestGenerateIsReachable>(vm, globalObject);
96 }
97
98 bool JSTestGenerateIsReachablePrototype::getOwnPropertySlot(JSObject* object, ExecState* exec, PropertyName propertyName, PropertySlot& slot)
99 {
100     JSTestGenerateIsReachablePrototype* thisObject = jsCast<JSTestGenerateIsReachablePrototype*>(object);
101     return getStaticPropertySlot<JSTestGenerateIsReachablePrototype, JSObject>(exec, JSTestGenerateIsReachablePrototypeTable, thisObject, propertyName, slot);
102 }
103
104 const ClassInfo JSTestGenerateIsReachable::s_info = { "TestGenerateIsReachable", &Base::s_info, 0, 0 , CREATE_METHOD_TABLE(JSTestGenerateIsReachable) };
105
106 JSTestGenerateIsReachable::JSTestGenerateIsReachable(Structure* structure, JSDOMGlobalObject* globalObject, PassRefPtr<TestGenerateIsReachable> impl)
107     : JSDOMWrapper(structure, globalObject)
108     , m_impl(impl.leakRef())
109 {
110 }
111
112 void JSTestGenerateIsReachable::finishCreation(VM& vm)
113 {
114     Base::finishCreation(vm);
115     ASSERT(inherits(info()));
116 }
117
118 JSObject* JSTestGenerateIsReachable::createPrototype(VM& vm, JSGlobalObject* globalObject)
119 {
120     return JSTestGenerateIsReachablePrototype::create(vm, globalObject, JSTestGenerateIsReachablePrototype::createStructure(vm, globalObject, globalObject->objectPrototype()));
121 }
122
123 void JSTestGenerateIsReachable::destroy(JSC::JSCell* cell)
124 {
125     JSTestGenerateIsReachable* thisObject = static_cast<JSTestGenerateIsReachable*>(cell);
126     thisObject->JSTestGenerateIsReachable::~JSTestGenerateIsReachable();
127 }
128
129 JSTestGenerateIsReachable::~JSTestGenerateIsReachable()
130 {
131     releaseImplIfNotNull();
132 }
133
134 bool JSTestGenerateIsReachable::getOwnPropertySlot(JSObject* object, ExecState* exec, PropertyName propertyName, PropertySlot& slot)
135 {
136     JSTestGenerateIsReachable* thisObject = jsCast<JSTestGenerateIsReachable*>(object);
137     ASSERT_GC_OBJECT_INHERITS(thisObject, info());
138     return Base::getOwnPropertySlot(thisObject, exec, propertyName, slot);
139 }
140
141 EncodedJSValue jsTestGenerateIsReachableConstructor(ExecState* exec, JSObject* baseValue, EncodedJSValue thisValue, PropertyName)
142 {
143     UNUSED_PARAM(baseValue);
144     UNUSED_PARAM(thisValue);
145     JSTestGenerateIsReachablePrototype* domObject = jsDynamicCast<JSTestGenerateIsReachablePrototype*>(baseValue);
146     if (!domObject)
147         return throwVMTypeError(exec);
148     return JSValue::encode(JSTestGenerateIsReachable::getConstructor(exec->vm(), domObject->globalObject()));
149 }
150
151 JSValue JSTestGenerateIsReachable::getConstructor(VM& vm, JSGlobalObject* globalObject)
152 {
153     return getDOMConstructor<JSTestGenerateIsReachableConstructor>(vm, jsCast<JSDOMGlobalObject*>(globalObject));
154 }
155
156 static inline bool isObservable(JSTestGenerateIsReachable* jsTestGenerateIsReachable)
157 {
158     if (jsTestGenerateIsReachable->hasCustomProperties())
159         return true;
160     return false;
161 }
162
163 bool JSTestGenerateIsReachableOwner::isReachableFromOpaqueRoots(JSC::Handle<JSC::Unknown> handle, void*, SlotVisitor& visitor)
164 {
165     JSTestGenerateIsReachable* jsTestGenerateIsReachable = jsCast<JSTestGenerateIsReachable*>(handle.get().asCell());
166     if (!isObservable(jsTestGenerateIsReachable))
167         return false;
168     TestGenerateIsReachable* root = &jsTestGenerateIsReachable->impl();
169     return visitor.containsOpaqueRoot(root);
170 }
171
172 void JSTestGenerateIsReachableOwner::finalize(JSC::Handle<JSC::Unknown> handle, void* context)
173 {
174     JSTestGenerateIsReachable* jsTestGenerateIsReachable = jsCast<JSTestGenerateIsReachable*>(handle.get().asCell());
175     DOMWrapperWorld& world = *static_cast<DOMWrapperWorld*>(context);
176     uncacheWrapper(world, &jsTestGenerateIsReachable->impl(), jsTestGenerateIsReachable);
177     jsTestGenerateIsReachable->releaseImpl();
178 }
179
180 #if ENABLE(BINDING_INTEGRITY)
181 #if PLATFORM(WIN)
182 #pragma warning(disable: 4483)
183 extern "C" { extern void (*const __identifier("??_7TestGenerateIsReachable@WebCore@@6B@")[])(); }
184 #else
185 extern "C" { extern void* _ZTVN7WebCore23TestGenerateIsReachableE[]; }
186 #endif
187 #endif
188 JSC::JSValue toJS(JSC::ExecState* exec, JSDOMGlobalObject* globalObject, TestGenerateIsReachable* impl)
189 {
190     if (!impl)
191         return jsNull();
192     if (JSValue result = getExistingWrapper<JSTestGenerateIsReachable>(exec, impl))
193         return result;
194
195 #if ENABLE(BINDING_INTEGRITY)
196     void* actualVTablePointer = *(reinterpret_cast<void**>(impl));
197 #if PLATFORM(WIN)
198     void* expectedVTablePointer = reinterpret_cast<void*>(__identifier("??_7TestGenerateIsReachable@WebCore@@6B@"));
199 #else
200     void* expectedVTablePointer = &_ZTVN7WebCore23TestGenerateIsReachableE[2];
201 #if COMPILER(CLANG)
202     // If this fails TestGenerateIsReachable does not have a vtable, so you need to add the
203     // ImplementationLacksVTable attribute to the interface definition
204     COMPILE_ASSERT(__is_polymorphic(TestGenerateIsReachable), TestGenerateIsReachable_is_not_polymorphic);
205 #endif
206 #endif
207     // If you hit this assertion you either have a use after free bug, or
208     // TestGenerateIsReachable has subclasses. If TestGenerateIsReachable has subclasses that get passed
209     // to toJS() we currently require TestGenerateIsReachable you to opt out of binding hardening
210     // by adding the SkipVTableValidation attribute to the interface IDL definition
211     RELEASE_ASSERT(actualVTablePointer == expectedVTablePointer);
212 #endif
213     return createNewWrapper<JSTestGenerateIsReachable>(exec, globalObject, impl);
214 }
215
216 TestGenerateIsReachable* toTestGenerateIsReachable(JSC::JSValue value)
217 {
218     return value.inherits(JSTestGenerateIsReachable::info()) ? &jsCast<JSTestGenerateIsReachable*>(value)->impl() : 0;
219 }
220
221 }