Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(774)

Unified Diff: third_party/WebKit/Source/devtools/front_end/sdk/TracingModel.js

Issue 2378843003: Timeline: fix screenshots for headless shell (Closed)
Patch Set: review comments addressed Created 4 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: third_party/WebKit/Source/devtools/front_end/sdk/TracingModel.js
diff --git a/third_party/WebKit/Source/devtools/front_end/sdk/TracingModel.js b/third_party/WebKit/Source/devtools/front_end/sdk/TracingModel.js
index 725e0e4752c501ea7c3f5a7f934c826d98d7837e..a5e281dc61eaa6c7422a155e730b0ef7e5ef7a9c 100644
--- a/third_party/WebKit/Source/devtools/front_end/sdk/TracingModel.js
+++ b/third_party/WebKit/Source/devtools/front_end/sdk/TracingModel.js
@@ -117,6 +117,35 @@ WebInspector.TracingModel._extractId = function(payload)
}
/**
+ * @param {!WebInspector.TracingModel} tracingModel
+ * @return {?WebInspector.TracingModel.Thread}
+ *
+ * TODO: Move this to a better place. This is here just for convenience o
+ * re-use between modules. This really belongs to a higher level, since it
+ * is specific to chrome's usage of tracing.
+ */
+WebInspector.TracingModel.browserMainThread = function(tracingModel)
+{
+ var processes = tracingModel.sortedProcesses();
+ var browserProcesses = [];
+ var crRendererMainThreads = [];
+ for (var process of processes) {
+ if (process.name().toLowerCase().endsWith("browser"))
+ browserProcesses.push(process);
+ crRendererMainThreads.push(...process.sortedThreads().filter(t => t.name() === "CrBrowserMain"));
+ }
+ if (crRendererMainThreads.length === 1)
+ return crRendererMainThreads[0];
+ if (browserProcesses.length === 1)
+ return browserProcesses[0].threadByName("CrBrowserMain");
+ var tracingStartedInBrowser = tracingModel.devToolsMetadataEvents().filter(e => e.name === "TracingStartedInBrowser");
+ if (tracingStartedInBrowser.length === 1)
+ return tracingStartedInBrowser[0].thread;
+ WebInspector.console.error("Failed to find browser main thread in trace, some timeline features may be unavailable");
+ return null;
+}
+
+/**
* @interface
*/
WebInspector.BackingStorage = function()

Powered by Google App Engine
This is Rietveld 408576698