WinCairo build fails to link.
[WebKit-https.git] / Source / WebKit / chromium / src / WebBindings.cpp
1 /*
2  * Copyright (C) 2009 Google Inc. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions are
6  * met:
7  *
8  *     * Redistributions of source code must retain the above copyright
9  * notice, this list of conditions and the following disclaimer.
10  *     * Redistributions in binary form must reproduce the above
11  * copyright notice, this list of conditions and the following disclaimer
12  * in the documentation and/or other materials provided with the
13  * distribution.
14  *     * Neither the name of Google Inc. nor the names of its
15  * contributors may be used to endorse or promote products derived from
16  * this software without specific prior written permission.
17  *
18  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
19  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
20  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
21  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
22  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
24  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
28  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29  */
30
31 #include "config.h"
32 #include "WebBindings.h"
33
34 #include "npruntime_impl.h"
35 #include "npruntime_priv.h"
36
37 #if USE(V8)
38 #include "BindingState.h"
39 #include "DOMWindow.h"
40 #include "Frame.h"
41 #include "NPV8Object.h"  // for PrivateIdentifier
42 #include "Range.h"
43 #include "V8ArrayBuffer.h"
44 #include "V8ArrayBufferView.h"
45 #include "V8DOMWrapper.h"
46 #include "V8Element.h"
47 #include "V8NPUtils.h"
48 #include "V8Range.h"
49 #include <wtf/ArrayBufferView.h>
50 // FIXME: Remove the USE(JSC) ifdefs because we don't support USE(JSC) anymore.
51 #elif USE(JSC)
52 #include "bridge/c/c_utility.h"
53 #endif
54 #include "WebArrayBuffer.h"
55 #include "WebArrayBufferView.h"
56 #include "WebElement.h"
57 #include "WebRange.h"
58
59 using namespace WebCore;
60
61 namespace WebKit {
62
63 bool WebBindings::construct(NPP npp, NPObject* object, const NPVariant* args, uint32_t argCount, NPVariant* result)
64 {
65     return _NPN_Construct(npp, object, args, argCount, result);
66 }
67
68 NPObject* WebBindings::createObject(NPP npp, NPClass* npClass)
69 {
70     return _NPN_CreateObject(npp, npClass);
71 }
72
73 bool WebBindings::enumerate(NPP npp, NPObject* object, NPIdentifier** identifier, uint32_t* identifierCount)
74 {
75     return _NPN_Enumerate(npp, object, identifier, identifierCount);
76 }
77
78 bool WebBindings::evaluate(NPP npp, NPObject* object, NPString* script, NPVariant* result)
79 {
80     return _NPN_Evaluate(npp, object, script, result);
81 }
82
83 bool WebBindings::evaluateHelper(NPP npp, bool popupsAllowed, NPObject* object, NPString* script, NPVariant* result)
84 {
85     return _NPN_EvaluateHelper(npp, popupsAllowed, object, script, result);
86 }
87
88 NPIdentifier WebBindings::getIntIdentifier(int32_t number)
89 {
90     return _NPN_GetIntIdentifier(number);
91 }
92
93 bool WebBindings::getProperty(NPP npp, NPObject* object, NPIdentifier property, NPVariant* result)
94 {
95     return _NPN_GetProperty(npp, object, property, result);
96 }
97
98 NPIdentifier WebBindings::getStringIdentifier(const NPUTF8* string)
99 {
100     return _NPN_GetStringIdentifier(string);
101 }
102
103 void WebBindings::getStringIdentifiers(const NPUTF8** names, int32_t nameCount, NPIdentifier* identifiers)
104 {
105     _NPN_GetStringIdentifiers(names, nameCount, identifiers);
106 }
107
108 bool WebBindings::hasMethod(NPP npp, NPObject* object, NPIdentifier method)
109 {
110     return _NPN_HasMethod(npp, object, method);
111 }
112
113 bool WebBindings::hasProperty(NPP npp, NPObject* object, NPIdentifier property)
114 {
115     return _NPN_HasProperty(npp, object, property);
116 }
117
118 bool WebBindings::identifierIsString(NPIdentifier identifier)
119 {
120     return _NPN_IdentifierIsString(identifier);
121 }
122
123 int32_t WebBindings::intFromIdentifier(NPIdentifier identifier)
124 {
125     return _NPN_IntFromIdentifier(identifier);
126 }
127
128 void WebBindings::initializeVariantWithStringCopy(NPVariant* variant, const NPString* value)
129 {
130 #if USE(V8)
131     _NPN_InitializeVariantWithStringCopy(variant, value);
132 #else
133     NPN_InitializeVariantWithStringCopy(variant, value);
134 #endif
135 }
136
137 bool WebBindings::invoke(NPP npp, NPObject* object, NPIdentifier method, const NPVariant* args, uint32_t argCount, NPVariant* result)
138 {
139     return _NPN_Invoke(npp, object, method, args, argCount, result);
140 }
141
142 bool WebBindings::invokeDefault(NPP npp, NPObject* object, const NPVariant* args, uint32_t argCount, NPVariant* result)
143 {
144     return _NPN_InvokeDefault(npp, object, args, argCount, result);
145 }
146
147 void WebBindings::releaseObject(NPObject* object)
148 {
149     return _NPN_ReleaseObject(object);
150 }
151
152 void WebBindings::releaseVariantValue(NPVariant* variant)
153 {
154     _NPN_ReleaseVariantValue(variant);
155 }
156
157 bool WebBindings::removeProperty(NPP npp, NPObject* object, NPIdentifier identifier)
158 {
159     return _NPN_RemoveProperty(npp, object, identifier);
160 }
161
162 NPObject* WebBindings::retainObject(NPObject* object)
163 {
164     return _NPN_RetainObject(object);
165 }
166
167 void WebBindings::setException(NPObject* object, const NPUTF8* message)
168 {
169     _NPN_SetException(object, message);
170 }
171
172 bool WebBindings::setProperty(NPP npp, NPObject* object, NPIdentifier identifier, const NPVariant* value)
173 {
174     return _NPN_SetProperty(npp, object, identifier, value);
175 }
176
177 void WebBindings::unregisterObject(NPObject* object)
178 {
179 #if USE(V8)
180     _NPN_UnregisterObject(object);
181 #endif
182 }
183
184 NPUTF8* WebBindings::utf8FromIdentifier(NPIdentifier identifier)
185 {
186     return _NPN_UTF8FromIdentifier(identifier);
187 }
188
189 void WebBindings::extractIdentifierData(const NPIdentifier& identifier, const NPUTF8*& string, int32_t& number, bool& isString)
190 {
191     PrivateIdentifier* data = static_cast<PrivateIdentifier*>(identifier);
192     if (!data) {
193         isString = false;
194         number = 0;
195         return;
196     }
197
198     isString = data->isString;
199     if (isString)
200         string = data->value.string;
201     else
202         number = data->value.number;
203 }
204
205 #if USE(V8)
206
207 static bool getRangeImpl(NPObject* object, WebRange* webRange, v8::Isolate* isolate)
208 {
209     if (!object || (object->_class != npScriptObjectClass))
210         return false;
211
212     V8NPObject* v8NPObject = reinterpret_cast<V8NPObject*>(object);
213     v8::Handle<v8::Object> v8Object(v8NPObject->v8Object);
214     if (!V8Range::info.equals(toWrapperTypeInfo(v8Object)))
215         return false;
216
217     Range* native = V8Range::HasInstanceInAnyWorld(v8Object, isolate) ? V8Range::toNative(v8Object) : 0;
218     if (!native)
219         return false;
220
221     *webRange = WebRange(native);
222     return true;
223 }
224
225 static bool getNodeImpl(NPObject* object, WebNode* webNode, v8::Isolate* isolate)
226 {
227     if (!object || (object->_class != npScriptObjectClass))
228         return false;
229
230     V8NPObject* v8NPObject = reinterpret_cast<V8NPObject*>(object);
231     v8::Handle<v8::Object> v8Object(v8NPObject->v8Object);
232     Node* native = V8Node::HasInstanceInAnyWorld(v8Object, isolate) ? V8Node::toNative(v8Object) : 0;
233     if (!native)
234         return false;
235
236     *webNode = WebNode(native);
237     return true;
238 }
239
240 static bool getElementImpl(NPObject* object, WebElement* webElement, v8::Isolate* isolate)
241 {
242     if (!object || (object->_class != npScriptObjectClass))
243         return false;
244
245     V8NPObject* v8NPObject = reinterpret_cast<V8NPObject*>(object);
246     v8::Handle<v8::Object> v8Object(v8NPObject->v8Object);
247     Element* native = V8Element::HasInstanceInAnyWorld(v8Object, isolate) ? V8Element::toNative(v8Object) : 0;
248     if (!native)
249         return false;
250
251     *webElement = WebElement(native);
252     return true;
253 }
254
255 static bool getArrayBufferImpl(NPObject* object, WebArrayBuffer* arrayBuffer, v8::Isolate* isolate)
256 {
257     if (!object || (object->_class != npScriptObjectClass))
258         return false;
259
260     V8NPObject* v8NPObject = reinterpret_cast<V8NPObject*>(object);
261     v8::Handle<v8::Object> v8Object(v8NPObject->v8Object);
262     ArrayBuffer* native = V8ArrayBuffer::HasInstanceInAnyWorld(v8Object, isolate) ? V8ArrayBuffer::toNative(v8Object) : 0;
263     if (!native)
264         return false;
265
266     *arrayBuffer = WebArrayBuffer(native);
267     return true;
268 }
269
270 static bool getArrayBufferViewImpl(NPObject* object, WebArrayBufferView* arrayBufferView, v8::Isolate* isolate)
271 {
272     if (!object || (object->_class != npScriptObjectClass))
273         return false;
274
275     V8NPObject* v8NPObject = reinterpret_cast<V8NPObject*>(object);
276     v8::Handle<v8::Object> v8Object(v8NPObject->v8Object);
277     ArrayBufferView* native = V8ArrayBufferView::HasInstanceInAnyWorld(v8Object, isolate) ? V8ArrayBufferView::toNative(v8Object) : 0;
278     if (!native)
279         return false;
280
281     *arrayBufferView = WebArrayBufferView(native);
282     return true;
283 }
284
285 static NPObject* makeIntArrayImpl(const WebVector<int>& data)
286 {
287     v8::HandleScope handleScope;
288     v8::Handle<v8::Array> result = v8::Array::New(data.size());
289     for (size_t i = 0; i < data.size(); ++i)
290         result->Set(i, v8::Number::New(data[i]));
291
292     DOMWindow* window = toDOMWindow(v8::Context::GetCurrent());
293     return npCreateV8ScriptObject(0, result, window);
294 }
295
296 static NPObject* makeStringArrayImpl(const WebVector<WebString>& data)
297 {
298     v8::HandleScope handleScope;
299     v8::Handle<v8::Array> result = v8::Array::New(data.size());
300     for (size_t i = 0; i < data.size(); ++i)
301         result->Set(i, data[i].data() ? v8::String::New(reinterpret_cast<const uint16_t*>((data[i].data())), data[i].length()) : v8::String::New(""));
302
303     DOMWindow* window = toDOMWindow(v8::Context::GetCurrent());
304     return npCreateV8ScriptObject(0, result, window);
305 }
306
307 #endif
308
309 bool WebBindings::getRange(NPObject* range, WebRange* webRange)
310 {
311 #if USE(V8)
312     return getRangeImpl(range, webRange, v8::Isolate::GetCurrent());
313 #else
314     // Not supported on other ports (JSC, etc).
315     return false;
316 #endif
317 }
318
319 bool WebBindings::getArrayBuffer(NPObject* arrayBuffer, WebArrayBuffer* webArrayBuffer)
320 {
321 #if USE(V8)
322     return getArrayBufferImpl(arrayBuffer, webArrayBuffer, v8::Isolate::GetCurrent());
323 #else
324     // Not supported on other ports (JSC, etc).
325     return false;
326 #endif
327 }
328
329 bool WebBindings::getArrayBufferView(NPObject* arrayBufferView, WebArrayBufferView* webArrayBufferView)
330 {
331 #if USE(V8)
332     return getArrayBufferViewImpl(arrayBufferView, webArrayBufferView, v8::Isolate::GetCurrent());
333 #else
334     // Not supported on other ports (JSC, etc).
335     return false;
336 #endif
337 }
338
339 bool WebBindings::getNode(NPObject* node, WebNode* webNode)
340 {
341 #if USE(V8)
342     return getNodeImpl(node, webNode, v8::Isolate::GetCurrent());
343 #else
344     // Not supported on other ports (JSC, etc.).
345     return false;
346 #endif
347 }
348
349 bool WebBindings::getElement(NPObject* element, WebElement* webElement)
350 {
351 #if USE(V8)
352     return getElementImpl(element, webElement, v8::Isolate::GetCurrent());
353 #else
354     // Not supported on other ports (JSC, etc.).
355     return false;
356 #endif
357 }
358
359 NPObject* WebBindings::makeIntArray(const WebVector<int>& data)
360 {
361 #if USE(V8)
362     return makeIntArrayImpl(data);
363 #else
364     // Not supported on other ports (JSC, etc.).
365     return 0;
366 #endif
367 }
368
369 NPObject* WebBindings::makeStringArray(const WebVector<WebString>& data)
370 {
371 #if USE(V8)
372     return makeStringArrayImpl(data);
373 #else
374     // Not supported on other ports (JSC, etc.).
375     return 0;
376 #endif
377 }
378
379 void WebBindings::pushExceptionHandler(ExceptionHandler handler, void* data)
380 {
381     WebCore::pushExceptionHandler(handler, data);
382 }
383
384 void WebBindings::popExceptionHandler()
385 {
386     WebCore::popExceptionHandler();
387 }
388
389 void WebBindings::toNPVariant(v8::Local<v8::Value> object, NPObject* root, NPVariant* result)
390 {
391     WebCore::convertV8ObjectToNPVariant(object, root, result);
392 }
393
394 v8::Handle<v8::Value> WebBindings::toV8Value(const NPVariant* variant)
395 {
396     v8::Isolate* isolate = v8::Isolate::GetCurrent();
397     if (variant->type == NPVariantType_Object) {
398         NPObject* object = NPVARIANT_TO_OBJECT(*variant);
399         if (object->_class != npScriptObjectClass)
400             return v8::Undefined();
401         V8NPObject* v8Object = reinterpret_cast<V8NPObject*>(object);
402         return convertNPVariantToV8Object(variant, v8Object->rootObject->frame()->script()->windowScriptNPObject(), isolate);
403     }
404     // Safe to pass 0 since we have checked the script object class to make sure the
405     // argument is a primitive v8 type.
406     return convertNPVariantToV8Object(variant, 0, isolate);
407 }
408
409 } // namespace WebKit