OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright (C) 2009 Google Inc. All rights reserved. | 2 * Copyright (C) 2009 Google Inc. All rights reserved. |
3 * | 3 * |
4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
5 * modification, are permitted provided that the following conditions are | 5 * modification, are permitted provided that the following conditions are |
6 * met: | 6 * met: |
7 * | 7 * |
8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
10 * * Redistributions in binary form must reproduce the above | 10 * * Redistributions in binary form must reproduce the above |
(...skipping 12 matching lines...) Expand all Loading... | |
23 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | 23 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
24 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | 24 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | 25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 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. | 28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
29 */ | 29 */ |
30 | 30 |
31 #include "platform/v8_inspector/V8FunctionCall.h" | 31 #include "platform/v8_inspector/V8FunctionCall.h" |
32 | 32 |
33 #include "platform/v8_inspector/V8DebuggerImpl.h" | |
33 #include "platform/v8_inspector/V8StringUtil.h" | 34 #include "platform/v8_inspector/V8StringUtil.h" |
34 #include "platform/v8_inspector/public/V8DebuggerClient.h" | 35 #include "platform/v8_inspector/public/V8DebuggerClient.h" |
35 #include "wtf/PassOwnPtr.h" | 36 #include "wtf/PassOwnPtr.h" |
36 | 37 |
37 #include <v8.h> | 38 #include <v8.h> |
38 | 39 |
39 namespace blink { | 40 namespace blink { |
40 | 41 |
41 V8FunctionCall::V8FunctionCall(V8DebuggerClient* client, v8::Local<v8::Context> context, v8::Local<v8::Value> value, const String& name) | 42 V8FunctionCall::V8FunctionCall(V8DebuggerImpl* debugger, v8::Local<v8::Context> context, v8::Local<v8::Value> value, const String& name) |
42 : m_client(client) | 43 : m_debugger(debugger) |
43 , m_context(context) | 44 , m_context(context) |
44 , m_name(toV8String(context->GetIsolate(), name)) | 45 , m_name(toV8String(context->GetIsolate(), name)) |
45 , m_value(value) | 46 , m_value(value) |
46 { | 47 { |
47 } | 48 } |
48 | 49 |
49 void V8FunctionCall::appendArgument(v8::Local<v8::Value> value) | 50 void V8FunctionCall::appendArgument(v8::Local<v8::Value> value) |
50 { | 51 { |
51 m_arguments.append(value); | 52 m_arguments.append(value); |
52 } | 53 } |
(...skipping 29 matching lines...) Expand all Loading... | |
82 } | 83 } |
83 | 84 |
84 v8::Local<v8::Value> V8FunctionCall::call() | 85 v8::Local<v8::Value> V8FunctionCall::call() |
85 { | 86 { |
86 bool hadException = false; | 87 bool hadException = false; |
87 return call(hadException); | 88 return call(hadException); |
88 } | 89 } |
89 | 90 |
90 v8::Local<v8::Value> V8FunctionCall::callWithoutExceptionHandling() | 91 v8::Local<v8::Value> V8FunctionCall::callWithoutExceptionHandling() |
91 { | 92 { |
93 // TODO(dgozman): get rid of this check. | |
94 if (!m_debugger->client()->isExecutionAllowed()) | |
95 return v8::Local<v8::Value>(); | |
96 | |
92 v8::Local<v8::Object> thisObject = v8::Local<v8::Object>::Cast(m_value); | 97 v8::Local<v8::Object> thisObject = v8::Local<v8::Object>::Cast(m_value); |
93 v8::Local<v8::Value> value; | 98 v8::Local<v8::Value> value; |
94 if (!thisObject->Get(m_context, m_name).ToLocal(&value)) | 99 if (!thisObject->Get(m_context, m_name).ToLocal(&value)) |
95 return v8::Local<v8::Value>(); | 100 return v8::Local<v8::Value>(); |
96 | 101 |
97 ASSERT(value->IsFunction()); | 102 ASSERT(value->IsFunction()); |
98 | 103 |
99 v8::Local<v8::Function> function = v8::Local<v8::Function>::Cast(value); | 104 v8::Local<v8::Function> function = v8::Local<v8::Function>::Cast(value); |
100 OwnPtr<v8::Local<v8::Value>[]> info = adoptArrayPtr(new v8::Local<v8::Value> [m_arguments.size()]); | 105 OwnPtr<v8::Local<v8::Value>[]> info = adoptArrayPtr(new v8::Local<v8::Value> [m_arguments.size()]); |
101 for (size_t i = 0; i < m_arguments.size(); ++i) { | 106 for (size_t i = 0; i < m_arguments.size(); ++i) { |
102 info[i] = m_arguments[i]; | 107 info[i] = m_arguments[i]; |
103 ASSERT(!info[i].IsEmpty()); | 108 ASSERT(!info[i].IsEmpty()); |
104 } | 109 } |
105 | 110 |
111 v8::MicrotasksScope microtasksScope(m_context->GetIsolate(), v8::MicrotasksS cope::kRunMicrotasks); | |
112 int cookie = m_debugger->willExecuteScript(m_context, function->ScriptId()); | |
pfeldman
2016/03/08 01:44:21
m_debugger-callFunction.
dgozman
2016/03/08 02:23:00
Done.
| |
113 v8::MaybeLocal<v8::Value> maybeResult = function->Call(m_context, thisObject , m_arguments.size(), info.get()); | |
114 m_debugger->didExecuteScript(cookie); | |
115 | |
106 v8::Local<v8::Value> result; | 116 v8::Local<v8::Value> result; |
107 if (!m_client->callFunction(function, m_context, thisObject, m_arguments.siz e(), info.get()).ToLocal(&result)) | 117 if (!maybeResult.ToLocal(&result)) |
108 return v8::Local<v8::Value>(); | 118 return v8::Local<v8::Value>(); |
109 return result; | 119 return result; |
110 } | 120 } |
111 | 121 |
112 v8::Local<v8::Function> V8FunctionCall::function() | 122 v8::Local<v8::Function> V8FunctionCall::function() |
113 { | 123 { |
114 v8::TryCatch tryCatch(m_context->GetIsolate()); | 124 v8::TryCatch tryCatch(m_context->GetIsolate()); |
115 v8::Local<v8::Object> thisObject = v8::Local<v8::Object>::Cast(m_value); | 125 v8::Local<v8::Object> thisObject = v8::Local<v8::Object>::Cast(m_value); |
116 v8::Local<v8::Value> value; | 126 v8::Local<v8::Value> value; |
117 if (!thisObject->Get(m_context, m_name).ToLocal(&value)) | 127 if (!thisObject->Get(m_context, m_name).ToLocal(&value)) |
118 return v8::Local<v8::Function>(); | 128 return v8::Local<v8::Function>(); |
119 | 129 |
120 ASSERT(value->IsFunction()); | 130 ASSERT(value->IsFunction()); |
121 return v8::Local<v8::Function>::Cast(value); | 131 return v8::Local<v8::Function>::Cast(value); |
122 } | 132 } |
123 | 133 |
124 } // namespace blink | 134 } // namespace blink |
OLD | NEW |