| /* |
| * Copyright (C) 2011 Google Inc. All rights reserved. |
| * |
| * Redistribution and use in source and binary forms, with or without |
| * modification, are permitted provided that the following conditions are |
| * met: |
| * |
| * * Redistributions of source code must retain the above copyright |
| * notice, this list of conditions and the following disclaimer. |
| * * Redistributions in binary form must reproduce the above |
| * copyright notice, this list of conditions and the following disclaimer |
| * in the documentation and/or other materials provided with the |
| * distribution. |
| * * Neither the name of Google Inc. nor the names of its |
| * contributors may be used to endorse or promote products derived from |
| * this software without specific prior written permission. |
| * |
| * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
| * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
| * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
| * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
| * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
| * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
| * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
| * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
| * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| */ |
| |
| /** |
| * @implements {SDK.TargetManager.Observer} |
| */ |
| ConsoleModel.ConsoleModel = class extends Common.Object { |
| constructor() { |
| super(); |
| |
| /** @type {!Array.<!ConsoleModel.ConsoleMessage>} */ |
| this._messages = []; |
| /** @type {!Map<!SDK.RuntimeModel, !Map<number, !ConsoleModel.ConsoleMessage>>} */ |
| this._messageByExceptionId = new Map(); |
| this._warnings = 0; |
| this._errors = 0; |
| |
| SDK.targetManager.observeTargets(this); |
| } |
| |
| /** |
| * @override |
| * @param {!SDK.Target} target |
| */ |
| targetAdded(target) { |
| var resourceTreeModel = target.model(SDK.ResourceTreeModel); |
| if (!resourceTreeModel || resourceTreeModel.cachedResourcesLoaded()) { |
| this._initTarget(target); |
| return; |
| } |
| |
| var eventListener = resourceTreeModel.addEventListener(SDK.ResourceTreeModel.Events.CachedResourcesLoaded, () => { |
| Common.EventTarget.removeEventListeners([eventListener]); |
| this._initTarget(target); |
| }); |
| } |
| |
| /** |
| * @param {!SDK.Target} target |
| */ |
| _initTarget(target) { |
| var eventListeners = []; |
| |
| var logModel = target.model(SDK.LogModel); |
| if (logModel) |
| eventListeners.push(logModel.addEventListener(SDK.LogModel.Events.EntryAdded, this._logEntryAdded, this)); |
| |
| var cpuProfilerModel = target.model(SDK.CPUProfilerModel); |
| if (cpuProfilerModel) { |
| eventListeners.push(cpuProfilerModel.addEventListener( |
| SDK.CPUProfilerModel.Events.ConsoleProfileStarted, this._consoleProfileStarted.bind(this, cpuProfilerModel))); |
| eventListeners.push(cpuProfilerModel.addEventListener( |
| SDK.CPUProfilerModel.Events.ConsoleProfileFinished, |
| this._consoleProfileFinished.bind(this, cpuProfilerModel))); |
| } |
| |
| var resourceTreeModel = target.model(SDK.ResourceTreeModel); |
| if (resourceTreeModel) { |
| eventListeners.push(resourceTreeModel.addEventListener( |
| SDK.ResourceTreeModel.Events.MainFrameNavigated, this._mainFrameNavigated, this)); |
| } |
| |
| var runtimeModel = target.model(SDK.RuntimeModel); |
| if (runtimeModel) { |
| eventListeners.push(runtimeModel.addEventListener( |
| SDK.RuntimeModel.Events.ExceptionThrown, this._exceptionThrown.bind(this, runtimeModel))); |
| eventListeners.push(runtimeModel.addEventListener( |
| SDK.RuntimeModel.Events.ExceptionRevoked, this._exceptionRevoked.bind(this, runtimeModel))); |
| eventListeners.push(runtimeModel.addEventListener( |
| SDK.RuntimeModel.Events.ConsoleAPICalled, this._consoleAPICalled.bind(this, runtimeModel))); |
| eventListeners.push(runtimeModel.debuggerModel().addEventListener( |
| SDK.DebuggerModel.Events.GlobalObjectCleared, this._clearIfNecessary, this)); |
| } |
| |
| var networkManager = target.model(SDK.NetworkManager); |
| if (networkManager) { |
| eventListeners.push(networkManager.addEventListener( |
| SDK.NetworkManager.Events.MessageGenerated, this._networkMessageGenerated.bind(this, networkManager))); |
| } |
| |
| target[ConsoleModel.ConsoleModel._events] = eventListeners; |
| } |
| |
| /** |
| * @override |
| * @param {!SDK.Target} target |
| */ |
| targetRemoved(target) { |
| var runtimeModel = target.model(SDK.RuntimeModel); |
| if (runtimeModel) |
| this._messageByExceptionId.delete(runtimeModel); |
| Common.EventTarget.removeEventListeners(target[ConsoleModel.ConsoleModel._events] || []); |
| } |
| |
| /** |
| * @param {!SDK.ExecutionContext} executionContext |
| * @param {!ConsoleModel.ConsoleMessage} originatingMessage |
| * @param {string} expression |
| * @param {boolean} useCommandLineAPI |
| * @param {boolean} awaitPromise |
| */ |
| async evaluateCommandInConsole(executionContext, originatingMessage, expression, useCommandLineAPI, awaitPromise) { |
| var result = await executionContext.evaluate( |
| { |
| expression: expression, |
| objectGroup: 'console', |
| includeCommandLineAPI: useCommandLineAPI, |
| silent: false, |
| returnByValue: false, |
| generatePreview: true |
| }, |
| /* userGesture */ true, awaitPromise); |
| Host.userMetrics.actionTaken(Host.UserMetrics.Action.ConsoleEvaluated); |
| if (result.error) |
| return; |
| await Common.console.showPromise(); |
| this.dispatchEventToListeners( |
| ConsoleModel.ConsoleModel.Events.CommandEvaluated, |
| {result: result.object, commandMessage: originatingMessage, exceptionDetails: result.exceptionDetails}); |
| } |
| |
| /** |
| * @param {!SDK.ExecutionContext} executionContext |
| * @param {string} text |
| * @return {!ConsoleModel.ConsoleMessage} |
| */ |
| addCommandMessage(executionContext, text) { |
| var commandMessage = new ConsoleModel.ConsoleMessage( |
| executionContext.runtimeModel, ConsoleModel.ConsoleMessage.MessageSource.JS, null, text, |
| ConsoleModel.ConsoleMessage.MessageType.Command); |
| commandMessage.setExecutionContextId(executionContext.id); |
| this.addMessage(commandMessage); |
| return commandMessage; |
| } |
| |
| /** |
| * @param {!ConsoleModel.ConsoleMessage} msg |
| */ |
| addMessage(msg) { |
| if (msg.source === ConsoleModel.ConsoleMessage.MessageSource.Worker && SDK.targetManager.targetById(msg.workerId)) |
| return; |
| |
| if (msg.source === ConsoleModel.ConsoleMessage.MessageSource.ConsoleAPI && |
| msg.type === ConsoleModel.ConsoleMessage.MessageType.Clear) |
| this._clearIfNecessary(); |
| |
| this._messages.push(msg); |
| var runtimeModel = msg.runtimeModel(); |
| if (msg._exceptionId && runtimeModel) { |
| var modelMap = this._messageByExceptionId.get(runtimeModel); |
| if (!modelMap) { |
| modelMap = new Map(); |
| this._messageByExceptionId.set(runtimeModel, modelMap); |
| } |
| modelMap.set(msg._exceptionId, msg); |
| } |
| this._incrementErrorWarningCount(msg); |
| this.dispatchEventToListeners(ConsoleModel.ConsoleModel.Events.MessageAdded, msg); |
| } |
| |
| /** |
| * @param {!Common.Event} event |
| */ |
| _logEntryAdded(event) { |
| var data = /** @type {{logModel: !SDK.LogModel, entry: !Protocol.Log.LogEntry}} */ (event.data); |
| var consoleMessage = new ConsoleModel.ConsoleMessage( |
| data.logModel.target().model(SDK.RuntimeModel), data.entry.source, data.entry.level, data.entry.text, undefined, |
| data.entry.url, data.entry.lineNumber, undefined, data.entry.networkRequestId, undefined, data.entry.stackTrace, |
| data.entry.timestamp, undefined, undefined, data.entry.workerId); |
| this.addMessage(consoleMessage); |
| } |
| |
| /** |
| * @param {!SDK.RuntimeModel} runtimeModel |
| * @param {!Common.Event} event |
| */ |
| _exceptionThrown(runtimeModel, event) { |
| var exceptionWithTimestamp = /** @type {!SDK.RuntimeModel.ExceptionWithTimestamp} */ (event.data); |
| var consoleMessage = ConsoleModel.ConsoleMessage.fromException( |
| runtimeModel, exceptionWithTimestamp.details, undefined, exceptionWithTimestamp.timestamp, undefined); |
| consoleMessage.setExceptionId(exceptionWithTimestamp.details.exceptionId); |
| this.addMessage(consoleMessage); |
| } |
| |
| /** |
| * @param {!SDK.RuntimeModel} runtimeModel |
| * @param {!Common.Event} event |
| */ |
| _exceptionRevoked(runtimeModel, event) { |
| var exceptionId = /** @type {number} */ (event.data); |
| var modelMap = this._messageByExceptionId.get(runtimeModel); |
| var exceptionMessage = modelMap ? modelMap.get(exceptionId) : null; |
| if (!exceptionMessage) |
| return; |
| this._errors--; |
| exceptionMessage.level = ConsoleModel.ConsoleMessage.MessageLevel.Info; |
| this.dispatchEventToListeners(ConsoleModel.ConsoleModel.Events.MessageUpdated, exceptionMessage); |
| } |
| |
| /** |
| * @param {!SDK.RuntimeModel} runtimeModel |
| * @param {!Common.Event} event |
| */ |
| _consoleAPICalled(runtimeModel, event) { |
| var call = /** @type {!SDK.RuntimeModel.ConsoleAPICall} */ (event.data); |
| var level = ConsoleModel.ConsoleMessage.MessageLevel.Info; |
| if (call.type === ConsoleModel.ConsoleMessage.MessageType.Debug) |
| level = ConsoleModel.ConsoleMessage.MessageLevel.Verbose; |
| else if ( |
| call.type === ConsoleModel.ConsoleMessage.MessageType.Error || |
| call.type === ConsoleModel.ConsoleMessage.MessageType.Assert) |
| level = ConsoleModel.ConsoleMessage.MessageLevel.Error; |
| else if (call.type === ConsoleModel.ConsoleMessage.MessageType.Warning) |
| level = ConsoleModel.ConsoleMessage.MessageLevel.Warning; |
| else if ( |
| call.type === ConsoleModel.ConsoleMessage.MessageType.Info || |
| call.type === ConsoleModel.ConsoleMessage.MessageType.Log) |
| level = ConsoleModel.ConsoleMessage.MessageLevel.Info; |
| var message = ''; |
| if (call.args.length && typeof call.args[0].value === 'string') |
| message = call.args[0].value; |
| else if (call.args.length && call.args[0].description) |
| message = call.args[0].description; |
| var callFrame = call.stackTrace && call.stackTrace.callFrames.length ? call.stackTrace.callFrames[0] : null; |
| var consoleMessage = new ConsoleModel.ConsoleMessage( |
| runtimeModel, ConsoleModel.ConsoleMessage.MessageSource.ConsoleAPI, level, |
| /** @type {string} */ (message), call.type, callFrame ? callFrame.url : undefined, |
| callFrame ? callFrame.lineNumber : undefined, callFrame ? callFrame.columnNumber : undefined, undefined, |
| call.args, call.stackTrace, call.timestamp, call.executionContextId, undefined, undefined, call.context); |
| this.addMessage(consoleMessage); |
| } |
| |
| _clearIfNecessary() { |
| if (!Common.moduleSetting('preserveConsoleLog').get()) |
| this._clear(); |
| } |
| |
| /** |
| * @param {!Common.Event} event |
| */ |
| _mainFrameNavigated(event) { |
| if (Common.moduleSetting('preserveConsoleLog').get()) |
| Common.console.log(Common.UIString('Navigated to %s', event.data.url)); |
| } |
| |
| /** |
| * @param {!SDK.CPUProfilerModel} cpuProfilerModel |
| * @param {!Common.Event} event |
| */ |
| _consoleProfileStarted(cpuProfilerModel, event) { |
| var data = /** @type {!SDK.CPUProfilerModel.EventData} */ (event.data); |
| this._addConsoleProfileMessage( |
| cpuProfilerModel, ConsoleModel.ConsoleMessage.MessageType.Profile, data.scriptLocation, |
| Common.UIString('Profile \'%s\' started.', data.title)); |
| } |
| |
| /** |
| * @param {!SDK.CPUProfilerModel} cpuProfilerModel |
| * @param {!Common.Event} event |
| */ |
| _consoleProfileFinished(cpuProfilerModel, event) { |
| var data = /** @type {!SDK.CPUProfilerModel.EventData} */ (event.data); |
| this._addConsoleProfileMessage( |
| cpuProfilerModel, ConsoleModel.ConsoleMessage.MessageType.ProfileEnd, data.scriptLocation, |
| Common.UIString('Profile \'%s\' finished.', data.title)); |
| } |
| |
| /** |
| * @param {!SDK.CPUProfilerModel} cpuProfilerModel |
| * @param {string} type |
| * @param {!SDK.DebuggerModel.Location} scriptLocation |
| * @param {string} messageText |
| */ |
| _addConsoleProfileMessage(cpuProfilerModel, type, scriptLocation, messageText) { |
| var stackTrace = [{ |
| functionName: '', |
| scriptId: scriptLocation.scriptId, |
| url: scriptLocation.script() ? scriptLocation.script().contentURL() : '', |
| lineNumber: scriptLocation.lineNumber, |
| columnNumber: scriptLocation.columnNumber || 0 |
| }]; |
| this.addMessage(new ConsoleModel.ConsoleMessage( |
| cpuProfilerModel.runtimeModel(), ConsoleModel.ConsoleMessage.MessageSource.ConsoleAPI, |
| ConsoleModel.ConsoleMessage.MessageLevel.Info, messageText, type, undefined, undefined, undefined, undefined, |
| stackTrace)); |
| } |
| |
| /** |
| * @param {!SDK.NetworkManager} networkManager |
| * @param {!Common.Event} event |
| */ |
| _networkMessageGenerated(networkManager, event) { |
| var message = /** @type {!SDK.NetworkManager.Message} */ (event.data); |
| this.addMessage(new ConsoleModel.ConsoleMessage( |
| networkManager.target().model(SDK.RuntimeModel), ConsoleModel.ConsoleMessage.MessageSource.Network, |
| message.warning ? ConsoleModel.ConsoleMessage.MessageLevel.Warning : |
| ConsoleModel.ConsoleMessage.MessageLevel.Info, |
| message.message, undefined, undefined, undefined, undefined, message.requestId)); |
| } |
| |
| /** |
| * @param {!ConsoleModel.ConsoleMessage} msg |
| */ |
| _incrementErrorWarningCount(msg) { |
| if (msg.source === ConsoleModel.ConsoleMessage.MessageSource.Violation) |
| return; |
| switch (msg.level) { |
| case ConsoleModel.ConsoleMessage.MessageLevel.Warning: |
| this._warnings++; |
| break; |
| case ConsoleModel.ConsoleMessage.MessageLevel.Error: |
| this._errors++; |
| break; |
| } |
| } |
| |
| /** |
| * @return {!Array.<!ConsoleModel.ConsoleMessage>} |
| */ |
| messages() { |
| return this._messages; |
| } |
| |
| requestClearMessages() { |
| for (var logModel of SDK.targetManager.models(SDK.LogModel)) |
| logModel.requestClear(); |
| for (var runtimeModel of SDK.targetManager.models(SDK.RuntimeModel)) |
| runtimeModel.discardConsoleEntries(); |
| this._clear(); |
| } |
| |
| _clear() { |
| this._messages = []; |
| this._messageByExceptionId.clear(); |
| this._errors = 0; |
| this._warnings = 0; |
| this.dispatchEventToListeners(ConsoleModel.ConsoleModel.Events.ConsoleCleared); |
| } |
| |
| /** |
| * @return {number} |
| */ |
| errors() { |
| return this._errors; |
| } |
| |
| /** |
| * @return {number} |
| */ |
| warnings() { |
| return this._warnings; |
| } |
| }; |
| |
| /** @enum {symbol} */ |
| ConsoleModel.ConsoleModel.Events = { |
| ConsoleCleared: Symbol('ConsoleCleared'), |
| MessageAdded: Symbol('MessageAdded'), |
| MessageUpdated: Symbol('MessageUpdated'), |
| CommandEvaluated: Symbol('CommandEvaluated') |
| }; |
| |
| |
| /** |
| * @unrestricted |
| */ |
| ConsoleModel.ConsoleMessage = class { |
| /** |
| * @param {?SDK.RuntimeModel} runtimeModel |
| * @param {string} source |
| * @param {?string} level |
| * @param {string} messageText |
| * @param {string=} type |
| * @param {?string=} url |
| * @param {number=} line |
| * @param {number=} column |
| * @param {!Protocol.Network.RequestId=} requestId |
| * @param {!Array.<!Protocol.Runtime.RemoteObject>=} parameters |
| * @param {!Protocol.Runtime.StackTrace=} stackTrace |
| * @param {number=} timestamp |
| * @param {!Protocol.Runtime.ExecutionContextId=} executionContextId |
| * @param {?string=} scriptId |
| * @param {?string=} workerId |
| * @param {string=} context |
| */ |
| constructor( |
| runtimeModel, source, level, messageText, type, url, line, column, requestId, parameters, stackTrace, timestamp, |
| executionContextId, scriptId, workerId, context) { |
| this._runtimeModel = runtimeModel; |
| this.source = source; |
| this.level = /** @type {?ConsoleModel.ConsoleMessage.MessageLevel} */ (level); |
| this.messageText = messageText; |
| this.type = type || ConsoleModel.ConsoleMessage.MessageType.Log; |
| /** @type {string|undefined} */ |
| this.url = url || undefined; |
| /** @type {number} */ |
| this.line = line || 0; |
| /** @type {number} */ |
| this.column = column || 0; |
| this.parameters = parameters; |
| /** @type {!Protocol.Runtime.StackTrace|undefined} */ |
| this.stackTrace = stackTrace; |
| this.timestamp = timestamp || Date.now(); |
| this.executionContextId = executionContextId || 0; |
| this.scriptId = scriptId || null; |
| this.workerId = workerId || null; |
| |
| var manager = runtimeModel ? runtimeModel.target().model(SDK.NetworkManager) : null; |
| this.request = (manager && requestId) ? NetworkLog.networkLog.requestByManagerAndId(manager, requestId) : null; |
| |
| if (this.request) { |
| var initiator = this.request.initiator(); |
| if (initiator) { |
| this.stackTrace = initiator.stack || undefined; |
| if (initiator.url) { |
| this.url = initiator.url; |
| this.line = initiator.lineNumber || 0; |
| } |
| } |
| } |
| if (!this.executionContextId && this._runtimeModel) { |
| if (this.scriptId) |
| this.executionContextId = this._runtimeModel.executionContextIdForScriptId(this.scriptId); |
| else if (this.stackTrace) |
| this.executionContextId = this._runtimeModel.executionContextForStackTrace(this.stackTrace); |
| } |
| |
| if (context) |
| this.context = context.match(/[^#]*/)[0]; |
| } |
| |
| /** |
| * @param {!SDK.RuntimeModel} runtimeModel |
| * @param {!Protocol.Runtime.ExceptionDetails} exceptionDetails |
| * @param {string=} messageType |
| * @param {number=} timestamp |
| * @param {string=} forceUrl |
| * @return {!ConsoleModel.ConsoleMessage} |
| */ |
| static fromException(runtimeModel, exceptionDetails, messageType, timestamp, forceUrl) { |
| return new ConsoleModel.ConsoleMessage( |
| runtimeModel, ConsoleModel.ConsoleMessage.MessageSource.JS, ConsoleModel.ConsoleMessage.MessageLevel.Error, |
| SDK.RuntimeModel.simpleTextFromException(exceptionDetails), messageType, forceUrl || exceptionDetails.url, |
| exceptionDetails.lineNumber, exceptionDetails.columnNumber, undefined, |
| exceptionDetails.exception ? |
| [SDK.RemoteObject.fromLocalObject(exceptionDetails.text), exceptionDetails.exception] : |
| undefined, |
| exceptionDetails.stackTrace, timestamp, exceptionDetails.executionContextId, exceptionDetails.scriptId); |
| } |
| |
| /** |
| * @return {?SDK.RuntimeModel} |
| */ |
| runtimeModel() { |
| return this._runtimeModel; |
| } |
| |
| /** |
| * @param {!ConsoleModel.ConsoleMessage} originatingMessage |
| */ |
| setOriginatingMessage(originatingMessage) { |
| this._originatingConsoleMessage = originatingMessage; |
| this.executionContextId = originatingMessage.executionContextId; |
| } |
| |
| /** |
| * @param {!Protocol.Runtime.ExecutionContextId} executionContextId |
| */ |
| setExecutionContextId(executionContextId) { |
| this.executionContextId = executionContextId; |
| } |
| |
| /** |
| * @param {number} exceptionId |
| */ |
| setExceptionId(exceptionId) { |
| this._exceptionId = exceptionId; |
| } |
| |
| /** |
| * @return {?ConsoleModel.ConsoleMessage} |
| */ |
| originatingMessage() { |
| return this._originatingConsoleMessage; |
| } |
| |
| /** |
| * @return {boolean} |
| */ |
| isGroupMessage() { |
| return this.type === ConsoleModel.ConsoleMessage.MessageType.StartGroup || |
| this.type === ConsoleModel.ConsoleMessage.MessageType.StartGroupCollapsed || |
| this.type === ConsoleModel.ConsoleMessage.MessageType.EndGroup; |
| } |
| |
| /** |
| * @return {boolean} |
| */ |
| isGroupStartMessage() { |
| return this.type === ConsoleModel.ConsoleMessage.MessageType.StartGroup || |
| this.type === ConsoleModel.ConsoleMessage.MessageType.StartGroupCollapsed; |
| } |
| |
| /** |
| * @return {boolean} |
| */ |
| isErrorOrWarning() { |
| return ( |
| this.level === ConsoleModel.ConsoleMessage.MessageLevel.Warning || |
| this.level === ConsoleModel.ConsoleMessage.MessageLevel.Error); |
| } |
| |
| /** |
| * @param {?ConsoleModel.ConsoleMessage} msg |
| * @return {boolean} |
| */ |
| isEqual(msg) { |
| if (!msg) |
| return false; |
| |
| if (!this._isEqualStackTraces(this.stackTrace, msg.stackTrace)) |
| return false; |
| |
| if (this.parameters) { |
| if (!msg.parameters || this.parameters.length !== msg.parameters.length) |
| return false; |
| |
| for (var i = 0; i < msg.parameters.length; ++i) { |
| // Never treat objects as equal - their properties might change over time. Errors can be treated as equal |
| // since they are always formatted as strings. |
| if (msg.parameters[i].type === 'object' && msg.parameters[i].subtype !== 'error') |
| return false; |
| if (this.parameters[i].type !== msg.parameters[i].type || |
| this.parameters[i].value !== msg.parameters[i].value || |
| this.parameters[i].description !== msg.parameters[i].description) |
| return false; |
| } |
| } |
| |
| return (this.runtimeModel() === msg.runtimeModel()) && (this.source === msg.source) && (this.type === msg.type) && |
| (this.level === msg.level) && (this.line === msg.line) && (this.url === msg.url) && |
| (this.messageText === msg.messageText) && (this.request === msg.request) && |
| (this.executionContextId === msg.executionContextId); |
| } |
| |
| /** |
| * @param {!Protocol.Runtime.StackTrace|undefined} stackTrace1 |
| * @param {!Protocol.Runtime.StackTrace|undefined} stackTrace2 |
| * @return {boolean} |
| */ |
| _isEqualStackTraces(stackTrace1, stackTrace2) { |
| if (!stackTrace1 !== !stackTrace2) |
| return false; |
| if (!stackTrace1) |
| return true; |
| var callFrames1 = stackTrace1.callFrames; |
| var callFrames2 = stackTrace2.callFrames; |
| if (callFrames1.length !== callFrames2.length) |
| return false; |
| for (var i = 0, n = callFrames1.length; i < n; ++i) { |
| if (callFrames1[i].url !== callFrames2[i].url || callFrames1[i].functionName !== callFrames2[i].functionName || |
| callFrames1[i].lineNumber !== callFrames2[i].lineNumber || |
| callFrames1[i].columnNumber !== callFrames2[i].columnNumber) |
| return false; |
| } |
| return this._isEqualStackTraces(stackTrace1.parent, stackTrace2.parent); |
| } |
| }; |
| |
| // Note: Keep these constants in sync with the ones in Console.h |
| /** |
| * @enum {string} |
| */ |
| ConsoleModel.ConsoleMessage.MessageSource = { |
| XML: 'xml', |
| JS: 'javascript', |
| Network: 'network', |
| ConsoleAPI: 'console-api', |
| Storage: 'storage', |
| AppCache: 'appcache', |
| Rendering: 'rendering', |
| CSS: 'css', |
| Security: 'security', |
| Deprecation: 'deprecation', |
| Worker: 'worker', |
| Violation: 'violation', |
| Intervention: 'intervention', |
| Other: 'other' |
| }; |
| |
| /** |
| * @enum {string} |
| */ |
| ConsoleModel.ConsoleMessage.MessageType = { |
| Log: 'log', |
| Debug: 'debug', |
| Info: 'info', |
| Error: 'error', |
| Warning: 'warning', |
| Dir: 'dir', |
| DirXML: 'dirxml', |
| Table: 'table', |
| Trace: 'trace', |
| Clear: 'clear', |
| StartGroup: 'startGroup', |
| StartGroupCollapsed: 'startGroupCollapsed', |
| EndGroup: 'endGroup', |
| Assert: 'assert', |
| Result: 'result', |
| Profile: 'profile', |
| ProfileEnd: 'profileEnd', |
| Command: 'command' |
| }; |
| |
| /** |
| * @enum {string} |
| */ |
| ConsoleModel.ConsoleMessage.MessageLevel = { |
| Verbose: 'verbose', |
| Info: 'info', |
| Warning: 'warning', |
| Error: 'error' |
| }; |
| |
| ConsoleModel.ConsoleModel._events = Symbol('ConsoleModel.ConsoleModel.events'); |
| |
| /** |
| * @type {!ConsoleModel.ConsoleModel} |
| */ |
| ConsoleModel.consoleModel; |