| OLD | NEW | 
|---|
| 1 /* | 1 /* | 
| 2  * Copyright (C) 2010 Apple Inc. All rights reserved. | 2  * Copyright (C) 2010 Apple Inc. All rights reserved. | 
| 3  * Copyright (C) 2013 Google Inc. All rights reserved. | 3  * Copyright (C) 2013 Google Inc. All rights reserved. | 
| 4  * | 4  * | 
| 5  * Redistribution and use in source and binary forms, with or without | 5  * Redistribution and use in source and binary forms, with or without | 
| 6  * modification, are permitted provided that the following conditions | 6  * modification, are permitted provided that the following conditions | 
| 7  * are met: | 7  * are met: | 
| 8  * | 8  * | 
| 9  * 1.  Redistributions of source code must retain the above copyright | 9  * 1.  Redistributions of source code must retain the above copyright | 
| 10  *     notice, this list of conditions and the following disclaimer. | 10  *     notice, this list of conditions and the following disclaimer. | 
| (...skipping 1456 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 1467 String InspectorDebuggerAgent::sourceMapURLForScript(const Script& script, Compi
      leResult compileResult) | 1467 String InspectorDebuggerAgent::sourceMapURLForScript(const Script& script, Compi
      leResult compileResult) | 
| 1468 { | 1468 { | 
| 1469     bool hasSyntaxError = compileResult != CompileSuccess; | 1469     bool hasSyntaxError = compileResult != CompileSuccess; | 
| 1470     if (!hasSyntaxError) | 1470     if (!hasSyntaxError) | 
| 1471         return script.sourceMappingURL(); | 1471         return script.sourceMappingURL(); | 
| 1472     return ContentSearchUtils::findSourceMapURL(script.source(), ContentSearchUt
      ils::JavaScriptMagicComment); | 1472     return ContentSearchUtils::findSourceMapURL(script.source(), ContentSearchUt
      ils::JavaScriptMagicComment); | 
| 1473 } | 1473 } | 
| 1474 | 1474 | 
| 1475 // ScriptDebugListener functions | 1475 // ScriptDebugListener functions | 
| 1476 | 1476 | 
| 1477 void InspectorDebuggerAgent::didParseSource(const String& scriptId, const Script
      & parsedScript, CompileResult compileResult) | 1477 void InspectorDebuggerAgent::didParseSource(const ParsedScript& parsedScript) | 
| 1478 { | 1478 { | 
| 1479     Script script = parsedScript; | 1479     Script script = parsedScript.script; | 
| 1480 | 1480 | 
| 1481     bool hasSyntaxError = compileResult != CompileSuccess; | 1481     bool hasSyntaxError = parsedScript.compileResult != CompileSuccess; | 
| 1482     if (hasSyntaxError) | 1482     if (hasSyntaxError) | 
| 1483         script.setSourceURL(ContentSearchUtils::findSourceURL(script.source(), C
      ontentSearchUtils::JavaScriptMagicComment)); | 1483         script.setSourceURL(ContentSearchUtils::findSourceURL(script.source(), C
      ontentSearchUtils::JavaScriptMagicComment)); | 
| 1484 | 1484 | 
| 1485     bool isContentScript = script.isContentScript(); | 1485     bool isContentScript = script.isContentScript(); | 
| 1486     bool isInternalScript = script.isInternalScript(); | 1486     bool isInternalScript = script.isInternalScript(); | 
| 1487     bool hasSourceURL = script.hasSourceURL(); | 1487     bool hasSourceURL = script.hasSourceURL(); | 
| 1488     String scriptURL = script.sourceURL(); | 1488     String scriptURL = script.sourceURL(); | 
| 1489     String sourceMapURL = sourceMapURLForScript(script, compileResult); | 1489     String sourceMapURL = sourceMapURLForScript(script, parsedScript.compileResu
      lt); | 
| 1490 | 1490 | 
| 1491     const String* sourceMapURLParam = sourceMapURL.isNull() ? nullptr : &sourceM
      apURL; | 1491     const String* sourceMapURLParam = sourceMapURL.isNull() ? nullptr : &sourceM
      apURL; | 
| 1492     const bool* isContentScriptParam = isContentScript ? &isContentScript : null
      ptr; | 1492     const bool* isContentScriptParam = isContentScript ? &isContentScript : null
      ptr; | 
| 1493     const bool* isInternalScriptParam = isInternalScript ? &isInternalScript : n
      ullptr; | 1493     const bool* isInternalScriptParam = isInternalScript ? &isInternalScript : n
      ullptr; | 
| 1494     const bool* hasSourceURLParam = hasSourceURL ? &hasSourceURL : nullptr; | 1494     const bool* hasSourceURLParam = hasSourceURL ? &hasSourceURL : nullptr; | 
| 1495     if (!hasSyntaxError) | 1495     if (!hasSyntaxError) | 
| 1496         frontend()->scriptParsed(scriptId, scriptURL, script.startLine(), script
      .startColumn(), script.endLine(), script.endColumn(), isContentScriptParam, isIn
      ternalScriptParam, sourceMapURLParam, hasSourceURLParam); | 1496         frontend()->scriptParsed(parsedScript.scriptId, scriptURL, script.startL
      ine(), script.startColumn(), script.endLine(), script.endColumn(), isContentScri
      ptParam, isInternalScriptParam, sourceMapURLParam, hasSourceURLParam); | 
| 1497     else | 1497     else | 
| 1498         frontend()->scriptFailedToParse(scriptId, scriptURL, script.startLine(),
       script.startColumn(), script.endLine(), script.endColumn(), isContentScriptPara
      m, isInternalScriptParam, sourceMapURLParam, hasSourceURLParam); | 1498         frontend()->scriptFailedToParse(parsedScript.scriptId, scriptURL, script
      .startLine(), script.startColumn(), script.endLine(), script.endColumn(), isCont
      entScriptParam, isInternalScriptParam, sourceMapURLParam, hasSourceURLParam); | 
| 1499 | 1499 | 
| 1500     m_scripts.set(scriptId, script); | 1500     m_scripts.set(parsedScript.scriptId, script); | 
| 1501 | 1501 | 
| 1502     if (scriptURL.isEmpty() || hasSyntaxError) | 1502     if (scriptURL.isEmpty() || hasSyntaxError) | 
| 1503         return; | 1503         return; | 
| 1504 | 1504 | 
| 1505     RefPtr<JSONObject> breakpointsCookie = m_state->getObject(DebuggerAgentState
      ::javaScriptBreakpoints); | 1505     RefPtr<JSONObject> breakpointsCookie = m_state->getObject(DebuggerAgentState
      ::javaScriptBreakpoints); | 
| 1506     for (auto& cookie : *breakpointsCookie) { | 1506     for (auto& cookie : *breakpointsCookie) { | 
| 1507         RefPtr<JSONObject> breakpointObject = cookie.value->asObject(); | 1507         RefPtr<JSONObject> breakpointObject = cookie.value->asObject(); | 
| 1508         bool isRegex; | 1508         bool isRegex; | 
| 1509         breakpointObject->getBoolean(DebuggerAgentState::isRegex, &isRegex); | 1509         breakpointObject->getBoolean(DebuggerAgentState::isRegex, &isRegex); | 
| 1510         String url; | 1510         String url; | 
| 1511         breakpointObject->getString(DebuggerAgentState::url, &url); | 1511         breakpointObject->getString(DebuggerAgentState::url, &url); | 
| 1512         if (!matches(scriptURL, url, isRegex)) | 1512         if (!matches(scriptURL, url, isRegex)) | 
| 1513             continue; | 1513             continue; | 
| 1514         ScriptBreakpoint breakpoint; | 1514         ScriptBreakpoint breakpoint; | 
| 1515         breakpointObject->getNumber(DebuggerAgentState::lineNumber, &breakpoint.
      lineNumber); | 1515         breakpointObject->getNumber(DebuggerAgentState::lineNumber, &breakpoint.
      lineNumber); | 
| 1516         breakpointObject->getNumber(DebuggerAgentState::columnNumber, &breakpoin
      t.columnNumber); | 1516         breakpointObject->getNumber(DebuggerAgentState::columnNumber, &breakpoin
      t.columnNumber); | 
| 1517         breakpointObject->getString(DebuggerAgentState::condition, &breakpoint.c
      ondition); | 1517         breakpointObject->getString(DebuggerAgentState::condition, &breakpoint.c
      ondition); | 
| 1518         RefPtr<TypeBuilder::Debugger::Location> location = resolveBreakpoint(coo
      kie.key, scriptId, breakpoint, UserBreakpointSource); | 1518         RefPtr<TypeBuilder::Debugger::Location> location = resolveBreakpoint(coo
      kie.key, parsedScript.scriptId, breakpoint, UserBreakpointSource); | 
| 1519         if (location) | 1519         if (location) | 
| 1520             frontend()->breakpointResolved(cookie.key, location); | 1520             frontend()->breakpointResolved(cookie.key, location); | 
| 1521     } | 1521     } | 
| 1522 } | 1522 } | 
| 1523 | 1523 | 
| 1524 ScriptDebugListener::SkipPauseRequest InspectorDebuggerAgent::didPause(ScriptSta
      te* scriptState, const ScriptValue& callFrames, const ScriptValue& exception, co
      nst Vector<String>& hitBreakpoints, bool isPromiseRejection) | 1524 ScriptDebugListener::SkipPauseRequest InspectorDebuggerAgent::didPause(ScriptSta
      te* scriptState, const ScriptValue& callFrames, const ScriptValue& exception, co
      nst Vector<String>& hitBreakpoints, bool isPromiseRejection) | 
| 1525 { | 1525 { | 
| 1526     ScriptDebugListener::SkipPauseRequest result; | 1526     ScriptDebugListener::SkipPauseRequest result; | 
| 1527     if (m_skipAllPauses) | 1527     if (m_skipAllPauses) | 
| 1528         result = ScriptDebugListener::Continue; | 1528         result = ScriptDebugListener::Continue; | 
| (...skipping 183 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 1712     RefPtr<ExceptionDetails> exceptionDetails = ExceptionDetails::create().setTe
      xt(toCoreStringWithUndefinedOrNullCheck(message->Get())); | 1712     RefPtr<ExceptionDetails> exceptionDetails = ExceptionDetails::create().setTe
      xt(toCoreStringWithUndefinedOrNullCheck(message->Get())); | 
| 1713     exceptionDetails->setLine(message->GetLineNumber()); | 1713     exceptionDetails->setLine(message->GetLineNumber()); | 
| 1714     exceptionDetails->setColumn(message->GetStartColumn()); | 1714     exceptionDetails->setColumn(message->GetStartColumn()); | 
| 1715     v8::Local<v8::StackTrace> messageStackTrace = message->GetStackTrace(); | 1715     v8::Local<v8::StackTrace> messageStackTrace = message->GetStackTrace(); | 
| 1716     if (!messageStackTrace.IsEmpty() && messageStackTrace->GetFrameCount() > 0) | 1716     if (!messageStackTrace.IsEmpty() && messageStackTrace->GetFrameCount() > 0) | 
| 1717         exceptionDetails->setStackTrace(createScriptCallStack(isolate, messageSt
      ackTrace, messageStackTrace->GetFrameCount())->buildInspectorArray()); | 1717         exceptionDetails->setStackTrace(createScriptCallStack(isolate, messageSt
      ackTrace, messageStackTrace->GetFrameCount())->buildInspectorArray()); | 
| 1718     return exceptionDetails.release(); | 1718     return exceptionDetails.release(); | 
| 1719 } | 1719 } | 
| 1720 | 1720 | 
| 1721 } // namespace blink | 1721 } // namespace blink | 
| OLD | NEW | 
|---|