2009-06-02 Albert J. Wong <ajwong@chromium.org>
[WebKit-https.git] / WebCore / bindings / v8 / ScriptFunctionCall.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 "ScriptFunctionCall.h"
33
34 #include "Document.h"
35 #include "Frame.h"
36 #include "ScriptScope.h"
37 #include "ScriptState.h"
38 #include "ScriptString.h"
39 #include "ScriptValue.h"
40
41 #include "V8Binding.h"
42 #include "V8Proxy.h"
43
44 #include <v8.h>
45 #include <wtf/OwnArrayPtr.h>
46
47 namespace WebCore {
48
49 static void reportException(ScriptState* scriptState, v8::TryCatch &exceptionCatcher)
50 {
51     v8::Local<v8::Message> message = exceptionCatcher.Message();
52     scriptState->frame()->document()->reportException(toWebCoreString(message->Get()), message->GetLineNumber(), toWebCoreString(message->GetScriptResourceName()));
53     exceptionCatcher.Reset();
54 }
55
56 ScriptFunctionCall::ScriptFunctionCall(ScriptState* scriptState, const ScriptObject& thisObject, const String& name)
57     : m_scriptState(scriptState)
58     , m_thisObject(thisObject)
59     , m_name(name)
60 {
61 }
62
63 void ScriptFunctionCall::appendArgument(const ScriptObject& argument)
64 {
65     m_arguments.append(argument);
66 }
67
68 void ScriptFunctionCall::appendArgument(const ScriptString& argument)
69 {
70     ScriptScope scope(m_scriptState);
71     m_arguments.append(v8String(argument));
72 }
73
74 void ScriptFunctionCall::appendArgument(const ScriptValue& argument)
75 {
76     m_arguments.append(argument);
77 }
78
79 void ScriptFunctionCall::appendArgument(const String& argument)
80 {
81     ScriptScope scope(m_scriptState);
82     m_arguments.append(v8String(argument));
83 }
84
85 void ScriptFunctionCall::appendArgument(long long argument)
86 {
87     ScriptScope scope(m_scriptState);
88     m_arguments.append(v8::Number::New(argument));
89 }
90
91 void ScriptFunctionCall::appendArgument(unsigned int argument)
92 {
93     ScriptScope scope(m_scriptState);
94     m_arguments.append(v8::Number::New(argument));
95 }
96
97 void ScriptFunctionCall::appendArgument(int argument)
98 {
99     ScriptScope scope(m_scriptState);
100     m_arguments.append(v8::Number::New(argument));
101 }
102
103 void ScriptFunctionCall::appendArgument(bool argument)
104 {
105     m_arguments.append(v8Boolean(argument));
106 }
107
108 ScriptValue ScriptFunctionCall::call(bool& hadException, bool reportExceptions)
109 {
110     ScriptScope scope(m_scriptState, reportExceptions);
111
112     v8::Local<v8::Object> thisObject = m_thisObject.v8Object();
113     v8::Local<v8::Value> value = thisObject->Get(v8String(m_name));
114     if (!scope.success()) {
115         hadException = true;
116         return ScriptValue();
117     }
118
119     ASSERT(value->IsFunction());
120
121     v8::Local<v8::Function> function(v8::Function::Cast(*value));
122     OwnArrayPtr<v8::Handle<v8::Value> > args(new v8::Handle<v8::Value>[m_arguments.size()]);
123     for (size_t i = 0; i < m_arguments.size(); ++i)
124         args[i] = m_arguments[i].v8Value();
125
126     v8::Local<v8::Value> result = function->Call(thisObject, m_arguments.size(), args.get());
127     if (!scope.success()) {
128         hadException = true;
129         return ScriptValue();
130     }
131
132     return ScriptValue(result);
133 }
134
135 ScriptValue ScriptFunctionCall::call()
136 {
137     bool hadException = false;
138     return call(hadException);
139 }
140
141 ScriptObject ScriptFunctionCall::construct(bool& hadException, bool reportExceptions)
142 {
143     ScriptScope scope(m_scriptState, reportExceptions);
144
145     v8::Local<v8::Object> thisObject = m_thisObject.v8Object();
146     v8::Local<v8::Value> value = thisObject->Get(v8String(m_name));
147     if (!scope.success()) {
148         hadException = true;
149         return ScriptObject();
150     }
151
152     ASSERT(value->IsFunction());
153
154     v8::Local<v8::Function> constructor(v8::Function::Cast(*value));
155     OwnArrayPtr<v8::Handle<v8::Value> > args(new v8::Handle<v8::Value>[m_arguments.size()]);
156     for (size_t i = 0; i < m_arguments.size(); ++i)
157         args[i] = m_arguments[i].v8Value();
158
159     v8::Local<v8::Object> result = SafeAllocation::newInstance(constructor, m_arguments.size(), args.get());
160     if (!scope.success()) {
161         hadException = true;
162         return ScriptObject();
163     }
164
165     return ScriptObject(result);
166 }
167
168 } // namespace WebCore