Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (C) 2012 Google Inc. All rights reserved. | 2 * Copyright (C) 2012 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 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 44 using blink::TypeBuilder::Debugger::CallFrame; | 44 using blink::TypeBuilder::Debugger::CallFrame; |
| 45 using blink::TypeBuilder::Debugger::CollectionEntry; | 45 using blink::TypeBuilder::Debugger::CollectionEntry; |
| 46 using blink::TypeBuilder::Debugger::FunctionDetails; | 46 using blink::TypeBuilder::Debugger::FunctionDetails; |
| 47 using blink::TypeBuilder::Debugger::GeneratorObjectDetails; | 47 using blink::TypeBuilder::Debugger::GeneratorObjectDetails; |
| 48 using blink::TypeBuilder::Runtime::PropertyDescriptor; | 48 using blink::TypeBuilder::Runtime::PropertyDescriptor; |
| 49 using blink::TypeBuilder::Runtime::InternalPropertyDescriptor; | 49 using blink::TypeBuilder::Runtime::InternalPropertyDescriptor; |
| 50 using blink::TypeBuilder::Runtime::RemoteObject; | 50 using blink::TypeBuilder::Runtime::RemoteObject; |
| 51 | 51 |
| 52 namespace blink { | 52 namespace blink { |
| 53 | 53 |
| 54 PassRefPtr<JSONValue> toJSONValue(const ScriptValue& value) | |
| 55 { | |
| 56 ScriptState* scriptState = value.scriptState(); | |
| 57 ASSERT(scriptState->contextIsValid()); | |
| 58 ScriptState::Scope scope(scriptState); | |
| 59 return toJSONValue(scriptState->isolate(), value.v8Value()); | |
| 60 } | |
| 61 | |
| 62 static PassRefPtr<TypeBuilder::Debugger::ExceptionDetails> toExceptionDetails(Pa ssRefPtr<JSONObject> object) | 54 static PassRefPtr<TypeBuilder::Debugger::ExceptionDetails> toExceptionDetails(Pa ssRefPtr<JSONObject> object) |
| 63 { | 55 { |
| 64 String text; | 56 String text; |
| 65 if (!object->getString("text", &text)) | 57 if (!object->getString("text", &text)) |
| 66 return nullptr; | 58 return nullptr; |
| 67 | 59 |
| 68 RefPtr<TypeBuilder::Debugger::ExceptionDetails> exceptionDetails = TypeBuild er::Debugger::ExceptionDetails::create().setText(text); | 60 RefPtr<TypeBuilder::Debugger::ExceptionDetails> exceptionDetails = TypeBuild er::Debugger::ExceptionDetails::create().setText(text); |
| 69 String url; | 61 String url; |
| 70 if (object->getString("url", &url)) | 62 if (object->getString("url", &url)) |
| 71 exceptionDetails->setUrl(url); | 63 exceptionDetails->setUrl(url); |
| (...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 106 | 98 |
| 107 frames->addItem(callFrame.release()); | 99 frames->addItem(callFrame.release()); |
| 108 } | 100 } |
| 109 exceptionDetails->setStackTrace(frames.release()); | 101 exceptionDetails->setStackTrace(frames.release()); |
| 110 } | 102 } |
| 111 if (originScriptId) | 103 if (originScriptId) |
| 112 exceptionDetails->setScriptId(String::number(originScriptId)); | 104 exceptionDetails->setScriptId(String::number(originScriptId)); |
| 113 return exceptionDetails.release(); | 105 return exceptionDetails.release(); |
| 114 } | 106 } |
| 115 | 107 |
| 116 InjectedScript::InjectedScript() | |
| 117 : m_inspectedStateAccessCheck(nullptr) | |
| 118 , m_contextId(0) | |
| 119 { | |
| 120 } | |
| 121 | |
| 122 InjectedScript::InjectedScript(ScriptValue injectedScriptObject, InspectedStateA ccessCheck accessCheck, PassRefPtr<InjectedScriptNative> injectedScriptNative, i nt contextId) | 108 InjectedScript::InjectedScript(ScriptValue injectedScriptObject, InspectedStateA ccessCheck accessCheck, PassRefPtr<InjectedScriptNative> injectedScriptNative, i nt contextId) |
| 123 : m_injectedScriptObject(injectedScriptObject) | 109 : m_isolate(injectedScriptObject.isolate()) |
| 110 , m_injectedScriptObject(injectedScriptObject) | |
| 124 , m_inspectedStateAccessCheck(accessCheck) | 111 , m_inspectedStateAccessCheck(accessCheck) |
| 125 , m_native(injectedScriptNative) | 112 , m_native(injectedScriptNative) |
| 126 , m_contextId(contextId) | 113 , m_contextId(contextId) |
| 127 { | 114 { |
| 128 } | 115 } |
| 129 | 116 |
| 130 InjectedScript::~InjectedScript() | 117 InjectedScript::~InjectedScript() |
| 131 { | 118 { |
| 132 } | 119 } |
| 133 | 120 |
| 134 void InjectedScript::evaluate(ErrorString* errorString, const String& expression , const String& objectGroup, bool includeCommandLineAPI, bool returnByValue, boo l generatePreview, RefPtr<TypeBuilder::Runtime::RemoteObject>* result, TypeBuild er::OptOutput<bool>* wasThrown, RefPtr<TypeBuilder::Debugger::ExceptionDetails>* exceptionDetails) | 121 void InjectedScript::evaluate(ErrorString* errorString, const String& expression , const String& objectGroup, bool includeCommandLineAPI, bool returnByValue, boo l generatePreview, RefPtr<TypeBuilder::Runtime::RemoteObject>* result, TypeBuild er::OptOutput<bool>* wasThrown, RefPtr<TypeBuilder::Debugger::ExceptionDetails>* exceptionDetails) |
| 135 { | 122 { |
| 136 ScriptFunctionCall function(injectedScriptObject(), "evaluate"); | 123 ScriptState::Scope scope(m_injectedScriptObject.scriptState()); |
|
dgozman
2016/01/26 02:45:14
Why do you need ScriptState::Scope at all?
pfeldman
2016/01/27 01:24:09
I need a handle scope and entered context.
| |
| 124 ScriptFunctionCall function(v8Context(), v8Value(), "evaluate"); | |
| 137 function.appendArgument(expression); | 125 function.appendArgument(expression); |
| 138 function.appendArgument(objectGroup); | 126 function.appendArgument(objectGroup); |
| 139 function.appendArgument(includeCommandLineAPI); | 127 function.appendArgument(includeCommandLineAPI); |
| 140 function.appendArgument(returnByValue); | 128 function.appendArgument(returnByValue); |
| 141 function.appendArgument(generatePreview); | 129 function.appendArgument(generatePreview); |
| 142 makeEvalCall(errorString, function, result, wasThrown, exceptionDetails); | 130 makeEvalCall(errorString, function, result, wasThrown, exceptionDetails); |
| 143 } | 131 } |
| 144 | 132 |
| 145 void InjectedScript::callFunctionOn(ErrorString* errorString, const String& obje ctId, const String& expression, const String& arguments, bool returnByValue, boo l generatePreview, RefPtr<TypeBuilder::Runtime::RemoteObject>* result, TypeBuild er::OptOutput<bool>* wasThrown) | 133 void InjectedScript::callFunctionOn(ErrorString* errorString, const String& obje ctId, const String& expression, const String& arguments, bool returnByValue, boo l generatePreview, RefPtr<TypeBuilder::Runtime::RemoteObject>* result, TypeBuild er::OptOutput<bool>* wasThrown) |
| 146 { | 134 { |
| 147 ScriptFunctionCall function(injectedScriptObject(), "callFunctionOn"); | 135 ScriptState::Scope scope(m_injectedScriptObject.scriptState()); |
| 136 ScriptFunctionCall function(v8Context(), v8Value(), "callFunctionOn"); | |
| 148 function.appendArgument(objectId); | 137 function.appendArgument(objectId); |
| 149 function.appendArgument(expression); | 138 function.appendArgument(expression); |
| 150 function.appendArgument(arguments); | 139 function.appendArgument(arguments); |
| 151 function.appendArgument(returnByValue); | 140 function.appendArgument(returnByValue); |
| 152 function.appendArgument(generatePreview); | 141 function.appendArgument(generatePreview); |
| 153 makeEvalCall(errorString, function, result, wasThrown); | 142 makeEvalCall(errorString, function, result, wasThrown); |
| 154 } | 143 } |
| 155 | 144 |
| 156 void InjectedScript::evaluateOnCallFrame(ErrorString* errorString, v8::Local<v8: :Object> callFrames, bool isAsyncCallStack, const String& callFrameId, const Str ing& expression, const String& objectGroup, bool includeCommandLineAPI, bool ret urnByValue, bool generatePreview, RefPtr<RemoteObject>* result, TypeBuilder::Opt Output<bool>* wasThrown, RefPtr<TypeBuilder::Debugger::ExceptionDetails>* except ionDetails) | 145 void InjectedScript::evaluateOnCallFrame(ErrorString* errorString, v8::Local<v8: :Object> callFrames, bool isAsyncCallStack, const String& callFrameId, const Str ing& expression, const String& objectGroup, bool includeCommandLineAPI, bool ret urnByValue, bool generatePreview, RefPtr<RemoteObject>* result, TypeBuilder::Opt Output<bool>* wasThrown, RefPtr<TypeBuilder::Debugger::ExceptionDetails>* except ionDetails) |
| 157 { | 146 { |
| 158 ScriptFunctionCall function(injectedScriptObject(), "evaluateOnCallFrame"); | 147 ScriptState::Scope scope(m_injectedScriptObject.scriptState()); |
| 148 ScriptFunctionCall function(v8Context(), v8Value(), "evaluateOnCallFrame"); | |
| 159 function.appendArgument(callFrames); | 149 function.appendArgument(callFrames); |
| 160 function.appendArgument(isAsyncCallStack); | 150 function.appendArgument(isAsyncCallStack); |
| 161 function.appendArgument(callFrameId); | 151 function.appendArgument(callFrameId); |
| 162 function.appendArgument(expression); | 152 function.appendArgument(expression); |
| 163 function.appendArgument(objectGroup); | 153 function.appendArgument(objectGroup); |
| 164 function.appendArgument(includeCommandLineAPI); | 154 function.appendArgument(includeCommandLineAPI); |
| 165 function.appendArgument(returnByValue); | 155 function.appendArgument(returnByValue); |
| 166 function.appendArgument(generatePreview); | 156 function.appendArgument(generatePreview); |
| 167 makeEvalCall(errorString, function, result, wasThrown, exceptionDetails); | 157 makeEvalCall(errorString, function, result, wasThrown, exceptionDetails); |
| 168 } | 158 } |
| 169 | 159 |
| 170 void InjectedScript::restartFrame(ErrorString* errorString, v8::Local<v8::Object > callFrames, const String& callFrameId) | 160 void InjectedScript::restartFrame(ErrorString* errorString, v8::Local<v8::Object > callFrames, const String& callFrameId) |
| 171 { | 161 { |
| 172 ScriptFunctionCall function(injectedScriptObject(), "restartFrame"); | 162 ScriptState::Scope scope(m_injectedScriptObject.scriptState()); |
| 163 ScriptFunctionCall function(v8Context(), v8Value(), "restartFrame"); | |
| 173 function.appendArgument(callFrames); | 164 function.appendArgument(callFrames); |
| 174 function.appendArgument(callFrameId); | 165 function.appendArgument(callFrameId); |
| 175 RefPtr<JSONValue> resultValue; | 166 RefPtr<JSONValue> resultValue; |
| 176 makeCall(function, &resultValue); | 167 makeCall(function, &resultValue); |
| 177 if (resultValue) { | 168 if (resultValue) { |
| 178 if (resultValue->type() == JSONValue::TypeString) { | 169 if (resultValue->type() == JSONValue::TypeString) { |
| 179 resultValue->asString(errorString); | 170 resultValue->asString(errorString); |
| 180 } else { | 171 } else { |
| 181 bool value; | 172 bool value; |
| 182 ASSERT_UNUSED(value, resultValue->asBoolean(&value) && value); | 173 ASSERT_UNUSED(value, resultValue->asBoolean(&value) && value); |
| 183 } | 174 } |
| 184 return; | 175 return; |
| 185 } | 176 } |
| 186 *errorString = "Internal error"; | 177 *errorString = "Internal error"; |
| 187 } | 178 } |
| 188 | 179 |
| 189 void InjectedScript::getStepInPositions(ErrorString* errorString, v8::Local<v8:: Object> callFrames, const String& callFrameId, RefPtr<Array<TypeBuilder::Debugge r::Location>>& positions) | 180 void InjectedScript::getStepInPositions(ErrorString* errorString, v8::Local<v8:: Object> callFrames, const String& callFrameId, RefPtr<Array<TypeBuilder::Debugge r::Location>>& positions) |
| 190 { | 181 { |
| 191 ScriptFunctionCall function(injectedScriptObject(), "getStepInPositions"); | 182 ScriptState::Scope scope(m_injectedScriptObject.scriptState()); |
| 183 ScriptFunctionCall function(v8Context(), v8Value(), "getStepInPositions"); | |
| 192 function.appendArgument(callFrames); | 184 function.appendArgument(callFrames); |
| 193 function.appendArgument(callFrameId); | 185 function.appendArgument(callFrameId); |
| 194 RefPtr<JSONValue> resultValue; | 186 RefPtr<JSONValue> resultValue; |
| 195 makeCall(function, &resultValue); | 187 makeCall(function, &resultValue); |
| 196 if (resultValue) { | 188 if (resultValue) { |
| 197 if (resultValue->type() == JSONValue::TypeString) { | 189 if (resultValue->type() == JSONValue::TypeString) { |
| 198 resultValue->asString(errorString); | 190 resultValue->asString(errorString); |
| 199 return; | 191 return; |
| 200 } | 192 } |
| 201 if (resultValue->type() == JSONValue::TypeArray) { | 193 if (resultValue->type() == JSONValue::TypeArray) { |
| 202 positions = Array<TypeBuilder::Debugger::Location>::runtimeCast(resu ltValue); | 194 positions = Array<TypeBuilder::Debugger::Location>::runtimeCast(resu ltValue); |
| 203 return; | 195 return; |
| 204 } | 196 } |
| 205 } | 197 } |
| 206 *errorString = "Internal error"; | 198 *errorString = "Internal error"; |
| 207 } | 199 } |
| 208 | 200 |
| 209 void InjectedScript::setVariableValue(ErrorString* errorString, v8::Local<v8::Ob ject> callFrames, const String* callFrameIdOpt, const String* functionObjectIdOp t, int scopeNumber, const String& variableName, const String& newValueStr) | 201 void InjectedScript::setVariableValue(ErrorString* errorString, v8::Local<v8::Ob ject> callFrames, const String* callFrameIdOpt, const String* functionObjectIdOp t, int scopeNumber, const String& variableName, const String& newValueStr) |
| 210 { | 202 { |
| 211 ScriptFunctionCall function(injectedScriptObject(), "setVariableValue"); | 203 ScriptState::Scope scope(m_injectedScriptObject.scriptState()); |
| 204 ScriptFunctionCall function(v8Context(), v8Value(), "setVariableValue"); | |
| 212 if (callFrameIdOpt) { | 205 if (callFrameIdOpt) { |
| 213 function.appendArgument(callFrames); | 206 function.appendArgument(callFrames); |
| 214 function.appendArgument(*callFrameIdOpt); | 207 function.appendArgument(*callFrameIdOpt); |
| 215 } else { | 208 } else { |
| 216 function.appendArgument(false); | 209 function.appendArgument(false); |
| 217 function.appendArgument(false); | 210 function.appendArgument(false); |
| 218 } | 211 } |
| 219 if (functionObjectIdOpt) | 212 if (functionObjectIdOpt) |
| 220 function.appendArgument(*functionObjectIdOpt); | 213 function.appendArgument(*functionObjectIdOpt); |
| 221 else | 214 else |
| 222 function.appendArgument(false); | 215 function.appendArgument(false); |
| 223 function.appendArgument(scopeNumber); | 216 function.appendArgument(scopeNumber); |
| 224 function.appendArgument(variableName); | 217 function.appendArgument(variableName); |
| 225 function.appendArgument(newValueStr); | 218 function.appendArgument(newValueStr); |
| 226 RefPtr<JSONValue> resultValue; | 219 RefPtr<JSONValue> resultValue; |
| 227 makeCall(function, &resultValue); | 220 makeCall(function, &resultValue); |
| 228 if (!resultValue) { | 221 if (!resultValue) { |
| 229 *errorString = "Internal error"; | 222 *errorString = "Internal error"; |
| 230 return; | 223 return; |
| 231 } | 224 } |
| 232 if (resultValue->type() == JSONValue::TypeString) { | 225 if (resultValue->type() == JSONValue::TypeString) { |
| 233 resultValue->asString(errorString); | 226 resultValue->asString(errorString); |
| 234 return; | 227 return; |
| 235 } | 228 } |
| 236 // Normal return. | 229 // Normal return. |
| 237 } | 230 } |
| 238 | 231 |
| 239 void InjectedScript::getFunctionDetails(ErrorString* errorString, const String& functionId, RefPtr<FunctionDetails>* result) | 232 void InjectedScript::getFunctionDetails(ErrorString* errorString, const String& functionId, RefPtr<FunctionDetails>* result) |
| 240 { | 233 { |
| 241 ScriptFunctionCall function(injectedScriptObject(), "getFunctionDetails"); | 234 ScriptState::Scope scope(m_injectedScriptObject.scriptState()); |
| 235 ScriptFunctionCall function(v8Context(), v8Value(), "getFunctionDetails"); | |
| 242 function.appendArgument(functionId); | 236 function.appendArgument(functionId); |
| 243 RefPtr<JSONValue> resultValue; | 237 RefPtr<JSONValue> resultValue; |
| 244 makeCall(function, &resultValue); | 238 makeCall(function, &resultValue); |
| 245 if (!resultValue || resultValue->type() != JSONValue::TypeObject) { | 239 if (!resultValue || resultValue->type() != JSONValue::TypeObject) { |
| 246 if (!resultValue->asString(errorString)) | 240 if (!resultValue->asString(errorString)) |
| 247 *errorString = "Internal error"; | 241 *errorString = "Internal error"; |
| 248 return; | 242 return; |
| 249 } | 243 } |
| 250 *result = FunctionDetails::runtimeCast(resultValue); | 244 *result = FunctionDetails::runtimeCast(resultValue); |
| 251 } | 245 } |
| 252 | 246 |
| 253 void InjectedScript::getGeneratorObjectDetails(ErrorString* errorString, const S tring& objectId, RefPtr<GeneratorObjectDetails>* result) | 247 void InjectedScript::getGeneratorObjectDetails(ErrorString* errorString, const S tring& objectId, RefPtr<GeneratorObjectDetails>* result) |
| 254 { | 248 { |
| 255 ScriptFunctionCall function(injectedScriptObject(), "getGeneratorObjectDetai ls"); | 249 ScriptState::Scope scope(m_injectedScriptObject.scriptState()); |
| 250 ScriptFunctionCall function(v8Context(), v8Value(), "getGeneratorObjectDetai ls"); | |
| 256 function.appendArgument(objectId); | 251 function.appendArgument(objectId); |
| 257 RefPtr<JSONValue> resultValue; | 252 RefPtr<JSONValue> resultValue; |
| 258 makeCall(function, &resultValue); | 253 makeCall(function, &resultValue); |
| 259 if (!resultValue || resultValue->type() != JSONValue::TypeObject) { | 254 if (!resultValue || resultValue->type() != JSONValue::TypeObject) { |
| 260 if (!resultValue->asString(errorString)) | 255 if (!resultValue->asString(errorString)) |
| 261 *errorString = "Internal error"; | 256 *errorString = "Internal error"; |
| 262 return; | 257 return; |
| 263 } | 258 } |
| 264 *result = GeneratorObjectDetails::runtimeCast(resultValue); | 259 *result = GeneratorObjectDetails::runtimeCast(resultValue); |
| 265 } | 260 } |
| 266 | 261 |
| 267 void InjectedScript::getCollectionEntries(ErrorString* errorString, const String & objectId, RefPtr<Array<CollectionEntry> >* result) | 262 void InjectedScript::getCollectionEntries(ErrorString* errorString, const String & objectId, RefPtr<Array<CollectionEntry> >* result) |
| 268 { | 263 { |
| 269 ScriptFunctionCall function(injectedScriptObject(), "getCollectionEntries"); | 264 ScriptState::Scope scope(m_injectedScriptObject.scriptState()); |
| 265 ScriptFunctionCall function(v8Context(), v8Value(), "getCollectionEntries"); | |
| 270 function.appendArgument(objectId); | 266 function.appendArgument(objectId); |
| 271 RefPtr<JSONValue> resultValue; | 267 RefPtr<JSONValue> resultValue; |
| 272 makeCall(function, &resultValue); | 268 makeCall(function, &resultValue); |
| 273 if (!resultValue || resultValue->type() != JSONValue::TypeArray) { | 269 if (!resultValue || resultValue->type() != JSONValue::TypeArray) { |
| 274 if (!resultValue->asString(errorString)) | 270 if (!resultValue->asString(errorString)) |
| 275 *errorString = "Internal error"; | 271 *errorString = "Internal error"; |
| 276 return; | 272 return; |
| 277 } | 273 } |
| 278 *result = Array<CollectionEntry>::runtimeCast(resultValue); | 274 *result = Array<CollectionEntry>::runtimeCast(resultValue); |
| 279 } | 275 } |
| 280 | 276 |
| 281 void InjectedScript::getProperties(ErrorString* errorString, const String& objec tId, bool ownProperties, bool accessorPropertiesOnly, bool generatePreview, RefP tr<Array<PropertyDescriptor>>* properties, RefPtr<TypeBuilder::Debugger::Excepti onDetails>* exceptionDetails) | 277 void InjectedScript::getProperties(ErrorString* errorString, const String& objec tId, bool ownProperties, bool accessorPropertiesOnly, bool generatePreview, RefP tr<Array<PropertyDescriptor>>* properties, RefPtr<TypeBuilder::Debugger::Excepti onDetails>* exceptionDetails) |
| 282 { | 278 { |
| 283 ScriptFunctionCall function(injectedScriptObject(), "getProperties"); | 279 ScriptState::Scope scope(m_injectedScriptObject.scriptState()); |
| 280 ScriptFunctionCall function(v8Context(), v8Value(), "getProperties"); | |
| 284 function.appendArgument(objectId); | 281 function.appendArgument(objectId); |
| 285 function.appendArgument(ownProperties); | 282 function.appendArgument(ownProperties); |
| 286 function.appendArgument(accessorPropertiesOnly); | 283 function.appendArgument(accessorPropertiesOnly); |
| 287 function.appendArgument(generatePreview); | 284 function.appendArgument(generatePreview); |
| 288 | 285 |
| 289 RefPtr<JSONValue> result; | 286 RefPtr<JSONValue> result; |
| 290 makeCallWithExceptionDetails(function, &result, exceptionDetails); | 287 makeCallWithExceptionDetails(function, &result, exceptionDetails); |
| 291 if (*exceptionDetails) { | 288 if (*exceptionDetails) { |
| 292 // FIXME: make properties optional | 289 // FIXME: make properties optional |
| 293 *properties = Array<PropertyDescriptor>::create(); | 290 *properties = Array<PropertyDescriptor>::create(); |
| 294 return; | 291 return; |
| 295 } | 292 } |
| 296 if (!result || result->type() != JSONValue::TypeArray) { | 293 if (!result || result->type() != JSONValue::TypeArray) { |
| 297 *errorString = "Internal error"; | 294 *errorString = "Internal error"; |
| 298 return; | 295 return; |
| 299 } | 296 } |
| 300 *properties = Array<PropertyDescriptor>::runtimeCast(result); | 297 *properties = Array<PropertyDescriptor>::runtimeCast(result); |
| 301 } | 298 } |
| 302 | 299 |
| 303 void InjectedScript::getInternalProperties(ErrorString* errorString, const Strin g& objectId, RefPtr<Array<InternalPropertyDescriptor>>* properties, RefPtr<TypeB uilder::Debugger::ExceptionDetails>* exceptionDetails) | 300 void InjectedScript::getInternalProperties(ErrorString* errorString, const Strin g& objectId, RefPtr<Array<InternalPropertyDescriptor>>* properties, RefPtr<TypeB uilder::Debugger::ExceptionDetails>* exceptionDetails) |
| 304 { | 301 { |
| 305 ScriptFunctionCall function(injectedScriptObject(), "getInternalProperties") ; | 302 ScriptState::Scope scope(m_injectedScriptObject.scriptState()); |
| 303 ScriptFunctionCall function(v8Context(), v8Value(), "getInternalProperties") ; | |
| 306 function.appendArgument(objectId); | 304 function.appendArgument(objectId); |
| 307 | 305 |
| 308 RefPtr<JSONValue> result; | 306 RefPtr<JSONValue> result; |
| 309 makeCallWithExceptionDetails(function, &result, exceptionDetails); | 307 makeCallWithExceptionDetails(function, &result, exceptionDetails); |
| 310 if (*exceptionDetails) | 308 if (*exceptionDetails) |
| 311 return; | 309 return; |
| 312 if (!result || result->type() != JSONValue::TypeArray) { | 310 if (!result || result->type() != JSONValue::TypeArray) { |
| 313 *errorString = "Internal error"; | 311 *errorString = "Internal error"; |
| 314 return; | 312 return; |
| 315 } | 313 } |
| (...skipping 11 matching lines...) Expand all Loading... | |
| 327 if (!parsedObjectId->asObject(&object)) | 325 if (!parsedObjectId->asObject(&object)) |
| 328 return; | 326 return; |
| 329 int boundId = 0; | 327 int boundId = 0; |
| 330 if (!object->getNumber("id", &boundId)) | 328 if (!object->getNumber("id", &boundId)) |
| 331 return; | 329 return; |
| 332 m_native->unbind(boundId); | 330 m_native->unbind(boundId); |
| 333 } | 331 } |
| 334 | 332 |
| 335 PassRefPtr<Array<CallFrame>> InjectedScript::wrapCallFrames(v8::Local<v8::Object > callFrames, int asyncOrdinal) | 333 PassRefPtr<Array<CallFrame>> InjectedScript::wrapCallFrames(v8::Local<v8::Object > callFrames, int asyncOrdinal) |
| 336 { | 334 { |
| 337 ScriptFunctionCall function(injectedScriptObject(), "wrapCallFrames"); | 335 ScriptState::Scope scope(m_injectedScriptObject.scriptState()); |
| 336 v8::Local<v8::Context> context = v8Context(); | |
| 337 ScriptFunctionCall function(context, v8Value(), "wrapCallFrames"); | |
| 338 function.appendArgument(callFrames); | 338 function.appendArgument(callFrames); |
| 339 function.appendArgument(asyncOrdinal); | 339 function.appendArgument(asyncOrdinal); |
| 340 bool hadException = false; | 340 bool hadException = false; |
| 341 ScriptValue callFramesValue = callFunctionWithEvalEnabled(function, hadExcep tion); | 341 v8::Local<v8::Value> callFramesValue = callFunctionWithEvalEnabled(function, hadException); |
| 342 ASSERT(!hadException); | 342 ASSERT(!hadException); |
| 343 RefPtr<JSONValue> result = toJSONValue(callFramesValue); | 343 RefPtr<JSONValue> result = toJSONValue(context, callFramesValue); |
| 344 if (result && result->type() == JSONValue::TypeArray) | 344 if (result && result->type() == JSONValue::TypeArray) |
| 345 return Array<CallFrame>::runtimeCast(result); | 345 return Array<CallFrame>::runtimeCast(result); |
| 346 return Array<CallFrame>::create(); | 346 return Array<CallFrame>::create(); |
| 347 } | 347 } |
| 348 | 348 |
| 349 PassRefPtr<TypeBuilder::Runtime::RemoteObject> InjectedScript::wrapObject(const ScriptValue& value, const String& groupName, bool generatePreview) const | 349 PassRefPtr<TypeBuilder::Runtime::RemoteObject> InjectedScript::wrapObject(const ScriptValue& value, const String& groupName, bool generatePreview) const |
| 350 { | 350 { |
| 351 ScriptFunctionCall wrapFunction(injectedScriptObject(), "wrapObject"); | 351 ScriptState::Scope scope(m_injectedScriptObject.scriptState()); |
| 352 wrapFunction.appendArgument(value); | 352 v8::Local<v8::Context> context = v8Context(); |
| 353 ScriptFunctionCall wrapFunction(context, v8Value(), "wrapObject"); | |
| 354 wrapFunction.appendArgument(value.v8Value()); | |
| 353 wrapFunction.appendArgument(groupName); | 355 wrapFunction.appendArgument(groupName); |
| 354 wrapFunction.appendArgument(canAccessInspectedWindow()); | 356 wrapFunction.appendArgument(canAccessInspectedWindow()); |
| 355 wrapFunction.appendArgument(generatePreview); | 357 wrapFunction.appendArgument(generatePreview); |
| 356 bool hadException = false; | 358 bool hadException = false; |
| 357 ScriptValue r = callFunctionWithEvalEnabled(wrapFunction, hadException); | 359 v8::Local<v8::Value> r = callFunctionWithEvalEnabled(wrapFunction, hadExcept ion); |
| 358 if (hadException) | 360 if (hadException) |
| 359 return nullptr; | 361 return nullptr; |
| 360 RefPtr<JSONObject> rawResult = toJSONValue(r)->asObject(); | 362 RefPtr<JSONObject> rawResult = toJSONValue(context, r)->asObject(); |
| 361 return TypeBuilder::Runtime::RemoteObject::runtimeCast(rawResult); | 363 return TypeBuilder::Runtime::RemoteObject::runtimeCast(rawResult); |
| 362 } | 364 } |
| 363 | 365 |
| 364 PassRefPtr<TypeBuilder::Runtime::RemoteObject> InjectedScript::wrapTable(const S criptValue& table, const ScriptValue& columns) const | 366 PassRefPtr<TypeBuilder::Runtime::RemoteObject> InjectedScript::wrapTable(const S criptValue& table, const ScriptValue& columns) const |
| 365 { | 367 { |
| 366 ScriptFunctionCall wrapFunction(injectedScriptObject(), "wrapTable"); | 368 ScriptState::Scope scope(m_injectedScriptObject.scriptState()); |
| 369 v8::Local<v8::Context> context = v8Context(); | |
| 370 ScriptFunctionCall wrapFunction(context, v8Value(), "wrapTable"); | |
| 367 wrapFunction.appendArgument(canAccessInspectedWindow()); | 371 wrapFunction.appendArgument(canAccessInspectedWindow()); |
| 368 wrapFunction.appendArgument(table); | 372 wrapFunction.appendArgument(table.v8Value()); |
| 369 if (columns.isEmpty()) | 373 if (columns.isEmpty()) |
| 370 wrapFunction.appendArgument(false); | 374 wrapFunction.appendArgument(false); |
| 371 else | 375 else |
| 372 wrapFunction.appendArgument(columns); | 376 wrapFunction.appendArgument(columns.v8Value()); |
| 373 bool hadException = false; | 377 bool hadException = false; |
| 374 ScriptValue r = callFunctionWithEvalEnabled(wrapFunction, hadException); | 378 v8::Local<v8::Value> r = callFunctionWithEvalEnabled(wrapFunction, hadExcep tion); |
| 375 if (hadException) | 379 if (hadException) |
| 376 return nullptr; | 380 return nullptr; |
| 377 RefPtr<JSONObject> rawResult = toJSONValue(r)->asObject(); | 381 RefPtr<JSONObject> rawResult = toJSONValue(context, r)->asObject(); |
| 378 return TypeBuilder::Runtime::RemoteObject::runtimeCast(rawResult); | 382 return TypeBuilder::Runtime::RemoteObject::runtimeCast(rawResult); |
| 379 } | 383 } |
| 380 | 384 |
| 381 v8::Local<v8::Value> InjectedScript::findObject(const RemoteObjectId& objectId) const | 385 v8::Local<v8::Value> InjectedScript::findObject(const RemoteObjectId& objectId) const |
| 382 { | 386 { |
| 383 return m_native->objectForId(objectId.id()); | 387 return m_native->objectForId(objectId.id()); |
| 384 } | 388 } |
| 385 | 389 |
| 386 String InjectedScript::objectIdToObjectGroupName(const String& objectId) const | 390 String InjectedScript::objectIdToObjectGroupName(const String& objectId) const |
| 387 { | 391 { |
| 388 RefPtr<JSONValue> parsedObjectId = parseJSON(objectId); | 392 RefPtr<JSONValue> parsedObjectId = parseJSON(objectId); |
| 389 if (!parsedObjectId) | 393 if (!parsedObjectId) |
| 390 return String(); | 394 return String(); |
| 391 RefPtr<JSONObject> object; | 395 RefPtr<JSONObject> object; |
| 392 if (!parsedObjectId->asObject(&object)) | 396 if (!parsedObjectId->asObject(&object)) |
| 393 return String(); | 397 return String(); |
| 394 int boundId = 0; | 398 int boundId = 0; |
| 395 if (!object->getNumber("id", &boundId)) | 399 if (!object->getNumber("id", &boundId)) |
| 396 return String(); | 400 return String(); |
| 397 return m_native->groupName(boundId); | 401 return m_native->groupName(boundId); |
| 398 } | 402 } |
| 399 | 403 |
| 400 void InjectedScript::releaseObjectGroup(const String& objectGroup) | 404 void InjectedScript::releaseObjectGroup(const String& objectGroup) |
| 401 { | 405 { |
| 406 ScriptState::Scope scope(m_injectedScriptObject.scriptState()); | |
| 402 m_native->releaseObjectGroup(objectGroup); | 407 m_native->releaseObjectGroup(objectGroup); |
| 403 if (objectGroup == "console") { | 408 if (objectGroup == "console") { |
| 404 ScriptFunctionCall releaseFunction(injectedScriptObject(), "clearLastEva luationResult"); | 409 ScriptFunctionCall releaseFunction(v8Context(), v8Value(), "clearLastEva luationResult"); |
| 405 bool hadException = false; | 410 bool hadException = false; |
| 406 callFunctionWithEvalEnabled(releaseFunction, hadException); | 411 callFunctionWithEvalEnabled(releaseFunction, hadException); |
| 407 ASSERT(!hadException); | 412 ASSERT(!hadException); |
| 408 } | 413 } |
| 409 } | 414 } |
| 410 | 415 |
| 411 void InjectedScript::setCustomObjectFormatterEnabled(bool enabled) | 416 void InjectedScript::setCustomObjectFormatterEnabled(bool enabled) |
| 412 { | 417 { |
| 413 ScriptFunctionCall function(injectedScriptObject(), "setCustomObjectFormatte rEnabled"); | 418 ScriptState::Scope scope(m_injectedScriptObject.scriptState()); |
| 419 ScriptFunctionCall function(v8Context(), v8Value(), "setCustomObjectFormatte rEnabled"); | |
| 414 function.appendArgument(enabled); | 420 function.appendArgument(enabled); |
| 415 RefPtr<JSONValue> result; | 421 RefPtr<JSONValue> result; |
| 416 makeCall(function, &result); | 422 makeCall(function, &result); |
| 417 } | 423 } |
| 418 | 424 |
| 419 void InjectedScript::initialize(ScriptValue injectedScriptObject, InspectedState AccessCheck accessCheck) | |
| 420 { | |
| 421 m_injectedScriptObject = injectedScriptObject; | |
| 422 m_inspectedStateAccessCheck = accessCheck; | |
| 423 } | |
| 424 | |
| 425 bool InjectedScript::canAccessInspectedWindow() const | 425 bool InjectedScript::canAccessInspectedWindow() const |
| 426 { | 426 { |
| 427 return m_inspectedStateAccessCheck(m_injectedScriptObject.scriptState()); | 427 return m_inspectedStateAccessCheck(m_injectedScriptObject.scriptState()); |
| 428 } | 428 } |
| 429 | 429 |
| 430 const ScriptValue& InjectedScript::injectedScriptObject() const | 430 v8::Local<v8::Context> InjectedScript::v8Context() const |
| 431 { | 431 { |
| 432 return m_injectedScriptObject; | 432 return m_injectedScriptObject.context(); |
| 433 } | 433 } |
| 434 | 434 |
| 435 ScriptValue InjectedScript::callFunctionWithEvalEnabled(ScriptFunctionCall& func tion, bool& hadException) const | 435 v8::Local<v8::Value> InjectedScript::v8Value() const |
| 436 { | 436 { |
| 437 ScriptState* scriptState = m_injectedScriptObject.scriptState(); | 437 return m_injectedScriptObject.v8Value(); |
| 438 ScriptState::Scope scope(scriptState); | 438 } |
| 439 bool evalIsDisabled = !scriptState->evalEnabled(); | 439 |
| 440 v8::Local<v8::Value> InjectedScript::callFunctionWithEvalEnabled(ScriptFunctionC all& function, bool& hadException) const | |
|
dgozman
2016/01/26 02:45:15
Non-const references are prohibited.
pfeldman
2016/01/27 01:24:09
this comes from lhs. i'll fix it.
| |
| 441 { | |
| 442 v8::Local<v8::Context> context = v8Context(); | |
| 443 bool evalIsDisabled = !context->IsCodeGenerationFromStringsAllowed(); | |
| 440 // Temporarily enable allow evals for inspector. | 444 // Temporarily enable allow evals for inspector. |
| 441 if (evalIsDisabled) | 445 if (evalIsDisabled) |
| 442 scriptState->setEvalEnabled(true); | 446 context->AllowCodeGenerationFromStrings(true); |
| 443 | 447 v8::Local<v8::Value> resultValue = function.call(hadException); |
| 444 ScriptValue resultValue = function.call(hadException); | |
| 445 | |
| 446 if (evalIsDisabled) | 448 if (evalIsDisabled) |
| 447 scriptState->setEvalEnabled(false); | 449 context->AllowCodeGenerationFromStrings(false); |
| 448 | |
| 449 TRACE_EVENT_INSTANT1(TRACE_DISABLED_BY_DEFAULT("devtools.timeline"), "Update Counters", TRACE_EVENT_SCOPE_THREAD, "data", InspectorUpdateCountersEvent::data( )); | 450 TRACE_EVENT_INSTANT1(TRACE_DISABLED_BY_DEFAULT("devtools.timeline"), "Update Counters", TRACE_EVENT_SCOPE_THREAD, "data", InspectorUpdateCountersEvent::data( )); |
| 450 return resultValue; | 451 return resultValue; |
| 451 } | 452 } |
| 452 | 453 |
| 453 void InjectedScript::makeCall(ScriptFunctionCall& function, RefPtr<JSONValue>* r esult) | 454 void InjectedScript::makeCall(ScriptFunctionCall& function, RefPtr<JSONValue>* r esult) |
| 454 { | 455 { |
| 455 if (!canAccessInspectedWindow()) { | 456 if (!canAccessInspectedWindow()) { |
| 456 *result = JSONValue::null(); | 457 *result = JSONValue::null(); |
| 457 return; | 458 return; |
| 458 } | 459 } |
| 459 | 460 |
| 460 bool hadException = false; | 461 bool hadException = false; |
| 461 ScriptValue resultValue = callFunctionWithEvalEnabled(function, hadException ); | 462 v8::Local<v8::Value> resultValue = callFunctionWithEvalEnabled(function, had Exception); |
| 462 | 463 |
| 463 ASSERT(!hadException); | 464 ASSERT(!hadException); |
| 464 if (!hadException) { | 465 if (!hadException) { |
| 465 *result = toJSONValue(resultValue); | 466 *result = toJSONValue(function.context(), resultValue); |
| 466 if (!*result) | 467 if (!*result) |
| 467 *result = JSONString::create(String::format("Object has too long ref erence chain(must not be longer than %d)", JSONValue::maxDepth)); | 468 *result = JSONString::create(String::format("Object has too long ref erence chain(must not be longer than %d)", JSONValue::maxDepth)); |
| 468 } else { | 469 } else { |
| 469 *result = JSONString::create("Exception while making a call."); | 470 *result = JSONString::create("Exception while making a call."); |
| 470 } | 471 } |
| 471 } | 472 } |
| 472 | 473 |
| 473 void InjectedScript::makeEvalCall(ErrorString* errorString, ScriptFunctionCall& function, RefPtr<TypeBuilder::Runtime::RemoteObject>* objectResult, TypeBuilder: :OptOutput<bool>* wasThrown, RefPtr<TypeBuilder::Debugger::ExceptionDetails>* ex ceptionDetails) | 474 void InjectedScript::makeEvalCall(ErrorString* errorString, ScriptFunctionCall& function, RefPtr<TypeBuilder::Runtime::RemoteObject>* objectResult, TypeBuilder: :OptOutput<bool>* wasThrown, RefPtr<TypeBuilder::Debugger::ExceptionDetails>* ex ceptionDetails) |
| 474 { | 475 { |
| 475 RefPtr<JSONValue> result; | 476 RefPtr<JSONValue> result; |
| (...skipping 22 matching lines...) Expand all Loading... | |
| 498 RefPtr<JSONObject> objectExceptionDetails = resultPair->getObject("excep tionDetails"); | 499 RefPtr<JSONObject> objectExceptionDetails = resultPair->getObject("excep tionDetails"); |
| 499 if (objectExceptionDetails) | 500 if (objectExceptionDetails) |
| 500 *exceptionDetails = toExceptionDetails(objectExceptionDetails.releas e()); | 501 *exceptionDetails = toExceptionDetails(objectExceptionDetails.releas e()); |
| 501 } | 502 } |
| 502 *objectResult = TypeBuilder::Runtime::RemoteObject::runtimeCast(resultObj); | 503 *objectResult = TypeBuilder::Runtime::RemoteObject::runtimeCast(resultObj); |
| 503 *wasThrown = wasThrownVal; | 504 *wasThrown = wasThrownVal; |
| 504 } | 505 } |
| 505 | 506 |
| 506 void InjectedScript::makeCallWithExceptionDetails(ScriptFunctionCall& function, RefPtr<JSONValue>* result, RefPtr<TypeBuilder::Debugger::ExceptionDetails>* exce ptionDetails) | 507 void InjectedScript::makeCallWithExceptionDetails(ScriptFunctionCall& function, RefPtr<JSONValue>* result, RefPtr<TypeBuilder::Debugger::ExceptionDetails>* exce ptionDetails) |
| 507 { | 508 { |
| 508 ScriptState::Scope scope(injectedScriptObject().scriptState()); | 509 v8::TryCatch tryCatch(m_isolate); |
| 509 v8::TryCatch tryCatch(injectedScriptObject().isolate()); | 510 v8::Local<v8::Value> resultValue = function.callWithoutExceptionHandling(); |
| 510 ScriptValue resultValue = function.callWithoutExceptionHandling(); | |
| 511 if (tryCatch.HasCaught()) { | 511 if (tryCatch.HasCaught()) { |
| 512 v8::Local<v8::Message> message = tryCatch.Message(); | 512 v8::Local<v8::Message> message = tryCatch.Message(); |
| 513 String text = !message.IsEmpty() ? toCoreStringWithUndefinedOrNullCheck( message->Get()) : "Internal error"; | 513 String text = !message.IsEmpty() ? toCoreStringWithUndefinedOrNullCheck( message->Get()) : "Internal error"; |
| 514 *exceptionDetails = TypeBuilder::Debugger::ExceptionDetails::create().se tText(text); | 514 *exceptionDetails = TypeBuilder::Debugger::ExceptionDetails::create().se tText(text); |
| 515 } else { | 515 } else { |
| 516 *result = toJSONValue(resultValue); | 516 *result = toJSONValue(function.context(), resultValue); |
| 517 if (!*result) | 517 if (!*result) |
| 518 *result = JSONString::create(String::format("Object has too long ref erence chain(must not be longer than %d)", JSONValue::maxDepth)); | 518 *result = JSONString::create(String::format("Object has too long ref erence chain(must not be longer than %d)", JSONValue::maxDepth)); |
| 519 } | 519 } |
| 520 } | 520 } |
| 521 | 521 |
| 522 } // namespace blink | 522 } // namespace blink |
| OLD | NEW |