| Index: Source/devtools/front_end/TimelinePresentationModel.js
|
| diff --git a/Source/devtools/front_end/TimelinePresentationModel.js b/Source/devtools/front_end/TimelinePresentationModel.js
|
| index bd499a9af0757976d1148178d7f60dda06821435..eb4ad843674d08c6a65a3926558a0a6ffd119d6e 100644
|
| --- a/Source/devtools/front_end/TimelinePresentationModel.js
|
| +++ b/Source/devtools/front_end/TimelinePresentationModel.js
|
| @@ -744,52 +744,6 @@ WebInspector.TimelinePresentationModel.Record.prototype = {
|
| },
|
|
|
| /**
|
| - * @param {!WebInspector.TimelinePresentationModel.Record} record
|
| - * @param {!WebInspector.Linkifier} linkifier
|
| - * @param {function(!DocumentFragment)} callback
|
| - */
|
| - generatePopupContent: function(record, linkifier, callback)
|
| - {
|
| - var imageElement = /** @type {?Element} */ (record.getUserObject("TimelinePresentationModel::preview-element") || null);
|
| - var relatedNode = /** @type {?WebInspector.DOMNode} */ (record.getUserObject("TimelinePresentationModel::related-node") || null);
|
| -
|
| - var barrier = new CallbackBarrier();
|
| - if (!imageElement && WebInspector.TimelineUIUtils.needsPreviewElement(record.type))
|
| - WebInspector.DOMPresentationUtils.buildImagePreviewContents(record.url, false, barrier.createCallback(saveImage));
|
| - if (!relatedNode && record.relatedBackendNodeId())
|
| - WebInspector.domAgent.pushNodeByBackendIdToFrontend(record.relatedBackendNodeId(), barrier.createCallback(saveNode));
|
| - barrier.callWhenDone(callbackWrapper.bind(this));
|
| -
|
| - /**
|
| - * @param {!Element=} element
|
| - */
|
| - function saveImage(element)
|
| - {
|
| - imageElement = element || null;
|
| - record.setUserObject("TimelinePresentationModel::preview-element", element);
|
| - }
|
| -
|
| - /**
|
| - * @param {?DOMAgent.NodeId} nodeId
|
| - */
|
| - function saveNode(nodeId)
|
| - {
|
| - if (nodeId !== null) {
|
| - relatedNode = WebInspector.domAgent.nodeForId(nodeId);
|
| - record.setUserObject("TimelinePresentationModel::related-node", relatedNode);
|
| - }
|
| - }
|
| -
|
| - /**
|
| - * @this {WebInspector.TimelinePresentationModel.Record}
|
| - */
|
| - function callbackWrapper()
|
| - {
|
| - callback(this._generatePopupContentSynchronously(record, linkifier, imageElement, relatedNode));
|
| - }
|
| - },
|
| -
|
| - /**
|
| * @param {string} key
|
| * @return {?Object}
|
| */
|
| @@ -819,319 +773,6 @@ WebInspector.TimelinePresentationModel.Record.prototype = {
|
| return this._relatedBackendNodeId;
|
| },
|
|
|
| - /**
|
| - * @param {!WebInspector.TimelinePresentationModel.Record} record
|
| - * @param {!WebInspector.Linkifier} linkifier
|
| - * @param {?Element} imagePreviewElement
|
| - * @param {?WebInspector.DOMNode} relatedNode
|
| - * @return {!DocumentFragment}
|
| - */
|
| - _generatePopupContentSynchronously: function(record, linkifier, imagePreviewElement, relatedNode)
|
| - {
|
| - var fragment = document.createDocumentFragment();
|
| - if (!record.coalesced && record.children.length)
|
| - fragment.appendChild(WebInspector.TimelineUIUtils.generatePieChart(record.aggregatedStats, record.category, record.selfTime));
|
| - else
|
| - fragment.appendChild(WebInspector.TimelineUIUtils.generatePieChart(record.aggregatedStats));
|
| -
|
| - if (record.coalesced)
|
| - return fragment;
|
| -
|
| - const recordTypes = WebInspector.TimelineModel.RecordType;
|
| -
|
| - // The messages may vary per record type;
|
| - var callSiteStackTraceLabel;
|
| - var callStackLabel;
|
| - var relatedNodeLabel;
|
| -
|
| - var contentHelper = new WebInspector.TimelineDetailsContentHelper(linkifier, true);
|
| - contentHelper.appendTextRow(WebInspector.UIString("Self Time"), Number.millisToString(record.selfTime, true));
|
| - contentHelper.appendTextRow(WebInspector.UIString("Start Time"), Number.millisToString(record.startTimeOffset));
|
| -
|
| - switch (record.type) {
|
| - case recordTypes.GCEvent:
|
| - contentHelper.appendTextRow(WebInspector.UIString("Collected"), Number.bytesToString(record.data["usedHeapSizeDelta"]));
|
| - break;
|
| - case recordTypes.TimerFire:
|
| - callSiteStackTraceLabel = WebInspector.UIString("Timer installed");
|
| - // Fall-through intended.
|
| -
|
| - case recordTypes.TimerInstall:
|
| - case recordTypes.TimerRemove:
|
| - contentHelper.appendTextRow(WebInspector.UIString("Timer ID"), record.data["timerId"]);
|
| - if (typeof record.timeout === "number") {
|
| - contentHelper.appendTextRow(WebInspector.UIString("Timeout"), Number.millisToString(record.timeout));
|
| - contentHelper.appendTextRow(WebInspector.UIString("Repeats"), !record.singleShot);
|
| - }
|
| - break;
|
| - case recordTypes.FireAnimationFrame:
|
| - callSiteStackTraceLabel = WebInspector.UIString("Animation frame requested");
|
| - contentHelper.appendTextRow(WebInspector.UIString("Callback ID"), record.data["id"]);
|
| - break;
|
| - case recordTypes.FunctionCall:
|
| - if (record.scriptName)
|
| - contentHelper.appendLocationRow(WebInspector.UIString("Location"), record.scriptName, record.scriptLine);
|
| - break;
|
| - case recordTypes.ScheduleResourceRequest:
|
| - case recordTypes.ResourceSendRequest:
|
| - case recordTypes.ResourceReceiveResponse:
|
| - case recordTypes.ResourceReceivedData:
|
| - case recordTypes.ResourceFinish:
|
| - contentHelper.appendElementRow(WebInspector.UIString("Resource"), WebInspector.linkifyResourceAsNode(record.url));
|
| - if (imagePreviewElement)
|
| - contentHelper.appendElementRow(WebInspector.UIString("Preview"), imagePreviewElement);
|
| - if (record.data["requestMethod"])
|
| - contentHelper.appendTextRow(WebInspector.UIString("Request Method"), record.data["requestMethod"]);
|
| - if (typeof record.data["statusCode"] === "number")
|
| - contentHelper.appendTextRow(WebInspector.UIString("Status Code"), record.data["statusCode"]);
|
| - if (record.data["mimeType"])
|
| - contentHelper.appendTextRow(WebInspector.UIString("MIME Type"), record.data["mimeType"]);
|
| - if (record.data["encodedDataLength"])
|
| - contentHelper.appendTextRow(WebInspector.UIString("Encoded Data Length"), WebInspector.UIString("%d Bytes", record.data["encodedDataLength"]));
|
| - break;
|
| - case recordTypes.EvaluateScript:
|
| - if (record.data && record.url)
|
| - contentHelper.appendLocationRow(WebInspector.UIString("Script"), record.url, record.data["lineNumber"]);
|
| - break;
|
| - case recordTypes.Paint:
|
| - var clip = record.data["clip"];
|
| - if (clip) {
|
| - contentHelper.appendTextRow(WebInspector.UIString("Location"), WebInspector.UIString("(%d, %d)", clip[0], clip[1]));
|
| - var clipWidth = WebInspector.TimelinePresentationModel.quadWidth(clip);
|
| - var clipHeight = WebInspector.TimelinePresentationModel.quadHeight(clip);
|
| - contentHelper.appendTextRow(WebInspector.UIString("Dimensions"), WebInspector.UIString("%d × %d", clipWidth, clipHeight));
|
| - } else {
|
| - // Backward compatibility: older version used x, y, width, height fields directly in data.
|
| - if (typeof record.data["x"] !== "undefined" && typeof record.data["y"] !== "undefined")
|
| - contentHelper.appendTextRow(WebInspector.UIString("Location"), WebInspector.UIString("(%d, %d)", record.data["x"], record.data["y"]));
|
| - if (typeof record.data["width"] !== "undefined" && typeof record.data["height"] !== "undefined")
|
| - contentHelper.appendTextRow(WebInspector.UIString("Dimensions"), WebInspector.UIString("%d\u2009\u00d7\u2009%d", record.data["width"], record.data["height"]));
|
| - }
|
| - // Fall-through intended.
|
| -
|
| - case recordTypes.PaintSetup:
|
| - case recordTypes.Rasterize:
|
| - case recordTypes.ScrollLayer:
|
| - relatedNodeLabel = WebInspector.UIString("Layer root");
|
| - break;
|
| - case recordTypes.AutosizeText:
|
| - relatedNodeLabel = WebInspector.UIString("Root node");
|
| - break;
|
| - case recordTypes.DecodeImage:
|
| - case recordTypes.ResizeImage:
|
| - relatedNodeLabel = WebInspector.UIString("Image element");
|
| - if (record.url)
|
| - contentHelper.appendElementRow(WebInspector.UIString("Image URL"), WebInspector.linkifyResourceAsNode(record.url));
|
| - break;
|
| - case recordTypes.RecalculateStyles: // We don't want to see default details.
|
| - if (record.data["elementCount"])
|
| - contentHelper.appendTextRow(WebInspector.UIString("Elements affected"), record.data["elementCount"]);
|
| - callStackLabel = WebInspector.UIString("Styles recalculation forced");
|
| - break;
|
| - case recordTypes.Layout:
|
| - if (record.data["dirtyObjects"])
|
| - contentHelper.appendTextRow(WebInspector.UIString("Nodes that need layout"), record.data["dirtyObjects"]);
|
| - if (record.data["totalObjects"])
|
| - contentHelper.appendTextRow(WebInspector.UIString("Layout tree size"), record.data["totalObjects"]);
|
| - if (typeof record.data["partialLayout"] === "boolean") {
|
| - contentHelper.appendTextRow(WebInspector.UIString("Layout scope"),
|
| - record.data["partialLayout"] ? WebInspector.UIString("Partial") : WebInspector.UIString("Whole document"));
|
| - }
|
| - callSiteStackTraceLabel = WebInspector.UIString("Layout invalidated");
|
| - callStackLabel = WebInspector.UIString("Layout forced");
|
| - relatedNodeLabel = WebInspector.UIString("Layout root");
|
| - break;
|
| - case recordTypes.ConsoleTime:
|
| - contentHelper.appendTextRow(WebInspector.UIString("Message"), record.data["message"]);
|
| - break;
|
| - case recordTypes.WebSocketCreate:
|
| - case recordTypes.WebSocketSendHandshakeRequest:
|
| - case recordTypes.WebSocketReceiveHandshakeResponse:
|
| - case recordTypes.WebSocketDestroy:
|
| - if (typeof record.webSocketURL !== "undefined")
|
| - contentHelper.appendTextRow(WebInspector.UIString("URL"), record.webSocketURL);
|
| - if (typeof record.webSocketProtocol !== "undefined")
|
| - contentHelper.appendTextRow(WebInspector.UIString("WebSocket Protocol"), record.webSocketProtocol);
|
| - if (typeof record.data["message"] !== "undefined")
|
| - contentHelper.appendTextRow(WebInspector.UIString("Message"), record.data["message"]);
|
| - break;
|
| - case recordTypes.EmbedderCallback:
|
| - contentHelper.appendTextRow(WebInspector.UIString("Callback Function"), record.embedderCallbackName);
|
| - break;
|
| - default:
|
| - var detailsNode = record.buildDetailsNode(record, linkifier);
|
| - if (detailsNode)
|
| - contentHelper.appendElementRow(WebInspector.UIString("Details"), detailsNode);
|
| - break;
|
| - }
|
| -
|
| - /**
|
| - * @param {!WebInspector.DOMNode} node
|
| - */
|
| - function createNodeAnchor(node)
|
| - {
|
| - var span = document.createElement("span");
|
| - span.classList.add("node-link");
|
| - span.addEventListener("click", WebInspector.Revealer.reveal.bind(WebInspector.Revealer, node, undefined), false);
|
| - WebInspector.DOMPresentationUtils.decorateNodeLabel(node, span);
|
| - return span;
|
| - }
|
| -
|
| - if (relatedNode)
|
| - contentHelper.appendElementRow(relatedNodeLabel || WebInspector.UIString("Related node"), createNodeAnchor(relatedNode));
|
| -
|
| - if (record.scriptName && record.type !== recordTypes.FunctionCall)
|
| - contentHelper.appendLocationRow(WebInspector.UIString("Function Call"), record.scriptName, record.scriptLine);
|
| -
|
| - if (record.jsHeapSizeUsed) {
|
| - if (record.usedHeapSizeDelta) {
|
| - var sign = record.usedHeapSizeDelta > 0 ? "+" : "-";
|
| - contentHelper.appendTextRow(WebInspector.UIString("Used JavaScript Heap Size"),
|
| - WebInspector.UIString("%s (%s%s)", Number.bytesToString(record.jsHeapSizeUsed), sign, Number.bytesToString(Math.abs(record.usedHeapSizeDelta))));
|
| - } else if (record.category === WebInspector.TimelineUIUtils.categories().scripting)
|
| - contentHelper.appendTextRow(WebInspector.UIString("Used JavaScript Heap Size"), Number.bytesToString(record.jsHeapSizeUsed));
|
| - }
|
| -
|
| - if (record.callSiteStackTrace)
|
| - contentHelper.appendStackTrace(callSiteStackTraceLabel || WebInspector.UIString("Call Site stack"), record.callSiteStackTrace);
|
| -
|
| - if (record.stackTrace)
|
| - contentHelper.appendStackTrace(callStackLabel || WebInspector.UIString("Call Stack"), record.stackTrace);
|
| -
|
| - if (record.warnings) {
|
| - var ul = document.createElement("ul");
|
| - for (var i = 0; i < record.warnings.length; ++i)
|
| - ul.createChild("li").textContent = record.warnings[i];
|
| - contentHelper.appendElementRow(WebInspector.UIString("Warning"), ul);
|
| - }
|
| - fragment.appendChild(contentHelper.element);
|
| - return fragment;
|
| - },
|
| -
|
| - /**
|
| - * @param {!WebInspector.TimelinePresentationModel.Record} record
|
| - * @param {!WebInspector.Linkifier} linkifier
|
| - * @return {?Node}
|
| - */
|
| - buildDetailsNode: function(record, linkifier)
|
| - {
|
| - var details;
|
| - var detailsText;
|
| - if (record.coalesced) {
|
| - var node = document.createElement("span");
|
| - node.textContent = WebInspector.UIString("× %d", record.children.length);
|
| - return node;
|
| - }
|
| -
|
| - switch (record.type) {
|
| - case WebInspector.TimelineModel.RecordType.GCEvent:
|
| - detailsText = WebInspector.UIString("%s collected", Number.bytesToString(record.data["usedHeapSizeDelta"]));
|
| - break;
|
| - case WebInspector.TimelineModel.RecordType.TimerFire:
|
| - details = linkifyScriptLocation();
|
| - detailsText = record.data["timerId"];
|
| - break;
|
| - case WebInspector.TimelineModel.RecordType.FunctionCall:
|
| - if (record.scriptName)
|
| - details = linkifyLocation(record.scriptName, record.scriptLine, 0);
|
| - break;
|
| - case WebInspector.TimelineModel.RecordType.FireAnimationFrame:
|
| - details = linkifyScriptLocation();
|
| - detailsText = record.data["id"];
|
| - break;
|
| - case WebInspector.TimelineModel.RecordType.EventDispatch:
|
| - detailsText = record.data ? record.data["type"] : null;
|
| - break;
|
| - case WebInspector.TimelineModel.RecordType.Paint:
|
| - var width = record.data.clip ? WebInspector.TimelinePresentationModel.quadWidth(record.data.clip) : record.data.width;
|
| - var height = record.data.clip ? WebInspector.TimelinePresentationModel.quadHeight(record.data.clip) : record.data.height;
|
| - if (width && height)
|
| - detailsText = WebInspector.UIString("%d\u2009\u00d7\u2009%d", width, height);
|
| - break;
|
| - case WebInspector.TimelineModel.RecordType.TimerInstall:
|
| - case WebInspector.TimelineModel.RecordType.TimerRemove:
|
| - details = linkifyTopCallFrame();
|
| - detailsText = record.data["timerId"];
|
| - break;
|
| - case WebInspector.TimelineModel.RecordType.RequestAnimationFrame:
|
| - case WebInspector.TimelineModel.RecordType.CancelAnimationFrame:
|
| - details = linkifyTopCallFrame();
|
| - detailsText = record.data["id"];
|
| - break;
|
| - case WebInspector.TimelineModel.RecordType.ParseHTML:
|
| - case WebInspector.TimelineModel.RecordType.RecalculateStyles:
|
| - details = linkifyTopCallFrame();
|
| - break;
|
| - case WebInspector.TimelineModel.RecordType.EvaluateScript:
|
| - details = record.url ? linkifyLocation(record.url, record.data["lineNumber"], 0) : null;
|
| - break;
|
| - case WebInspector.TimelineModel.RecordType.XHRReadyStateChange:
|
| - case WebInspector.TimelineModel.RecordType.XHRLoad:
|
| - case WebInspector.TimelineModel.RecordType.ScheduleResourceRequest:
|
| - case WebInspector.TimelineModel.RecordType.ResourceSendRequest:
|
| - case WebInspector.TimelineModel.RecordType.ResourceReceivedData:
|
| - case WebInspector.TimelineModel.RecordType.ResourceReceiveResponse:
|
| - case WebInspector.TimelineModel.RecordType.ResourceFinish:
|
| - case WebInspector.TimelineModel.RecordType.DecodeImage:
|
| - case WebInspector.TimelineModel.RecordType.ResizeImage:
|
| - detailsText = WebInspector.displayNameForURL(record.url);
|
| - break;
|
| - case WebInspector.TimelineModel.RecordType.ConsoleTime:
|
| - detailsText = record.data["message"];
|
| - break;
|
| - case WebInspector.TimelineModel.RecordType.EmbedderCallback:
|
| - detailsText = record.data["callbackName"];
|
| - break;
|
| - default:
|
| - details = record.scriptName ? linkifyLocation(record.scriptName, record.scriptLine, 0) : linkifyTopCallFrame();
|
| - break;
|
| - }
|
| -
|
| - if (!details && detailsText)
|
| - details = document.createTextNode(detailsText);
|
| - return details;
|
| -
|
| - /**
|
| - * @param {string} url
|
| - * @param {number} lineNumber
|
| - * @param {number=} columnNumber
|
| - */
|
| - function linkifyLocation(url, lineNumber, columnNumber)
|
| - {
|
| - // FIXME(62725): stack trace line/column numbers are one-based.
|
| - columnNumber = columnNumber ? columnNumber - 1 : 0;
|
| - return linkifier.linkifyLocation(url, lineNumber - 1, columnNumber, "timeline-details");
|
| - }
|
| -
|
| - /**
|
| - * @param {!ConsoleAgent.CallFrame} callFrame
|
| - */
|
| - function linkifyCallFrame(callFrame)
|
| - {
|
| - return linkifyLocation(callFrame.url, callFrame.lineNumber, callFrame.columnNumber);
|
| - }
|
| -
|
| - /**
|
| - * @return {?Element}
|
| - */
|
| - function linkifyTopCallFrame()
|
| - {
|
| - if (record.stackTrace)
|
| - return linkifyCallFrame(record.stackTrace[0]);
|
| - if (record.callSiteStackTrace)
|
| - return linkifyCallFrame(record.callSiteStackTrace[0]);
|
| - return null;
|
| - }
|
| -
|
| - /**
|
| - * @return {?Element}
|
| - */
|
| - function linkifyScriptLocation()
|
| - {
|
| - return record.scriptName ? linkifyLocation(record.scriptName, record.scriptLine, 0) : null;
|
| - }
|
| - },
|
| -
|
| calculateAggregatedStats: function()
|
| {
|
| this._aggregatedStats = {};
|
|
|