devtools-tracing 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (397) hide show
  1. package/generate.ts +643 -0
  2. package/index.ts +16 -0
  3. package/lib/front_end/core/common/App.ts +7 -0
  4. package/lib/front_end/core/common/AppProvider.ts +32 -0
  5. package/lib/front_end/core/common/Base64.ts +47 -0
  6. package/lib/front_end/core/common/CharacterIdMap.ts +30 -0
  7. package/lib/front_end/core/common/Color.ts +2506 -0
  8. package/lib/front_end/core/common/ColorConverter.ts +402 -0
  9. package/lib/front_end/core/common/ColorUtils.ts +252 -0
  10. package/lib/front_end/core/common/Console.ts +114 -0
  11. package/lib/front_end/core/common/Debouncer.ts +15 -0
  12. package/lib/front_end/core/common/EventTarget.ts +52 -0
  13. package/lib/front_end/core/common/Gzip.ts +74 -0
  14. package/lib/front_end/core/common/JavaScriptMetaData.ts +29 -0
  15. package/lib/front_end/core/common/Lazy.ts +31 -0
  16. package/lib/front_end/core/common/Linkifier.ts +55 -0
  17. package/lib/front_end/core/common/MapWithDefault.ts +26 -0
  18. package/lib/front_end/core/common/Mutex.ts +55 -0
  19. package/lib/front_end/core/common/Object.ts +145 -0
  20. package/lib/front_end/core/common/ParsedURL.ts +554 -0
  21. package/lib/front_end/core/common/Progress.ts +180 -0
  22. package/lib/front_end/core/common/QueryParamHandler.ts +7 -0
  23. package/lib/front_end/core/common/ResolverBase.ts +85 -0
  24. package/lib/front_end/core/common/ResourceType.ts +588 -0
  25. package/lib/front_end/core/common/ReturnToPanel.ts +17 -0
  26. package/lib/front_end/core/common/Revealer.ts +192 -0
  27. package/lib/front_end/core/common/Runnable.ts +41 -0
  28. package/lib/front_end/core/common/SegmentedRange.ts +87 -0
  29. package/lib/front_end/core/common/SettingRegistration.ts +339 -0
  30. package/lib/front_end/core/common/Settings.ts +1497 -0
  31. package/lib/front_end/core/common/SimpleHistoryManager.ts +124 -0
  32. package/lib/front_end/core/common/StringOutputStream.ts +26 -0
  33. package/lib/front_end/core/common/TextDictionary.ts +48 -0
  34. package/lib/front_end/core/common/Throttler.ts +99 -0
  35. package/lib/front_end/core/common/Trie.ts +152 -0
  36. package/lib/front_end/core/common/Worker.ts +60 -0
  37. package/lib/front_end/core/common/common.ts +81 -0
  38. package/lib/front_end/core/host/AidaClient.ts +733 -0
  39. package/lib/front_end/core/host/GdpClient.ts +316 -0
  40. package/lib/front_end/core/host/InspectorFrontendHost.ts +648 -0
  41. package/lib/front_end/core/host/InspectorFrontendHostAPI.ts +551 -0
  42. package/lib/front_end/core/host/Platform.ts +76 -0
  43. package/lib/front_end/core/host/ResourceLoader.ts +282 -0
  44. package/lib/front_end/core/host/UserMetrics.ts +1230 -0
  45. package/lib/front_end/core/host/host.ts +23 -0
  46. package/lib/front_end/core/i18n/ByteUtilities.ts +82 -0
  47. package/lib/front_end/core/i18n/DevToolsLocale.ts +87 -0
  48. package/lib/front_end/core/i18n/NumberFormatter.ts +82 -0
  49. package/lib/front_end/core/i18n/i18n.ts +17 -0
  50. package/lib/front_end/core/i18n/i18nImpl.ts +204 -0
  51. package/lib/front_end/core/i18n/i18nTypes.ts +10 -0
  52. package/lib/front_end/core/i18n/locales.js +14 -0
  53. package/lib/front_end/core/i18n/time-utilities.ts +174 -0
  54. package/lib/front_end/core/platform/ArrayUtilities.ts +271 -0
  55. package/lib/front_end/core/platform/Brand.ts +23 -0
  56. package/lib/front_end/core/platform/Constructor.ts +10 -0
  57. package/lib/front_end/core/platform/DOMUtilities.ts +138 -0
  58. package/lib/front_end/core/platform/DateUtilities.ts +15 -0
  59. package/lib/front_end/core/platform/DevToolsPath.ts +53 -0
  60. package/lib/front_end/core/platform/KeyboardUtilities.ts +38 -0
  61. package/lib/front_end/core/platform/MapUtilities.ts +95 -0
  62. package/lib/front_end/core/platform/MimeType.ts +175 -0
  63. package/lib/front_end/core/platform/NumberUtilities.ts +80 -0
  64. package/lib/front_end/core/platform/StringUtilities.ts +588 -0
  65. package/lib/front_end/core/platform/Timing.ts +17 -0
  66. package/lib/front_end/core/platform/TypedArrayUtilities.ts +189 -0
  67. package/lib/front_end/core/platform/TypescriptUtilities.ts +86 -0
  68. package/lib/front_end/core/platform/UIString.ts +39 -0
  69. package/lib/front_end/core/platform/UserVisibleError.ts +28 -0
  70. package/lib/front_end/core/platform/platform.ts +45 -0
  71. package/lib/front_end/core/protocol_client/ConnectionTransport.ts +26 -0
  72. package/lib/front_end/core/protocol_client/InspectorBackend.ts +1050 -0
  73. package/lib/front_end/core/protocol_client/NodeURL.ts +42 -0
  74. package/lib/front_end/core/protocol_client/protocol_client.ts +13 -0
  75. package/lib/front_end/core/root/Runtime.ts +609 -0
  76. package/lib/front_end/core/root/root.ts +6 -0
  77. package/lib/front_end/core/sdk/AccessibilityModel.ts +353 -0
  78. package/lib/front_end/core/sdk/AnimationModel.ts +1041 -0
  79. package/lib/front_end/core/sdk/AutofillModel.ts +184 -0
  80. package/lib/front_end/core/sdk/CPUProfilerModel.ts +148 -0
  81. package/lib/front_end/core/sdk/CPUThrottlingManager.ts +282 -0
  82. package/lib/front_end/core/sdk/CSSContainerQuery.ts +139 -0
  83. package/lib/front_end/core/sdk/CSSFontFace.ts +40 -0
  84. package/lib/front_end/core/sdk/CSSLayer.ts +30 -0
  85. package/lib/front_end/core/sdk/CSSMatchedStyles.ts +1646 -0
  86. package/lib/front_end/core/sdk/CSSMedia.ts +121 -0
  87. package/lib/front_end/core/sdk/CSSMetadata.ts +1647 -0
  88. package/lib/front_end/core/sdk/CSSModel.ts +1128 -0
  89. package/lib/front_end/core/sdk/CSSProperty.ts +384 -0
  90. package/lib/front_end/core/sdk/CSSPropertyParser.ts +681 -0
  91. package/lib/front_end/core/sdk/CSSPropertyParserMatchers.ts +1395 -0
  92. package/lib/front_end/core/sdk/CSSQuery.ts +72 -0
  93. package/lib/front_end/core/sdk/CSSRule.ts +465 -0
  94. package/lib/front_end/core/sdk/CSSScope.ts +30 -0
  95. package/lib/front_end/core/sdk/CSSStartingStyle.ts +29 -0
  96. package/lib/front_end/core/sdk/CSSStyleDeclaration.ts +313 -0
  97. package/lib/front_end/core/sdk/CSSStyleSheetHeader.ts +196 -0
  98. package/lib/front_end/core/sdk/CSSSupports.ts +33 -0
  99. package/lib/front_end/core/sdk/CategorizedBreakpoint.ts +64 -0
  100. package/lib/front_end/core/sdk/ChildTargetManager.ts +314 -0
  101. package/lib/front_end/core/sdk/CompilerSourceMappingContentProvider.ts +62 -0
  102. package/lib/front_end/core/sdk/Connections.ts +293 -0
  103. package/lib/front_end/core/sdk/ConsoleModel.ts +808 -0
  104. package/lib/front_end/core/sdk/ConsoleModelTypes.ts +15 -0
  105. package/lib/front_end/core/sdk/Cookie.ts +319 -0
  106. package/lib/front_end/core/sdk/CookieModel.ts +239 -0
  107. package/lib/front_end/core/sdk/CookieParser.ts +185 -0
  108. package/lib/front_end/core/sdk/DOMDebuggerModel.ts +787 -0
  109. package/lib/front_end/core/sdk/DOMModel.ts +1961 -0
  110. package/lib/front_end/core/sdk/DebuggerModel.ts +1605 -0
  111. package/lib/front_end/core/sdk/EmulationModel.ts +648 -0
  112. package/lib/front_end/core/sdk/EnhancedTracesParser.ts +515 -0
  113. package/lib/front_end/core/sdk/EventBreakpointsModel.ts +183 -0
  114. package/lib/front_end/core/sdk/FrameAssociated.ts +11 -0
  115. package/lib/front_end/core/sdk/FrameManager.ts +259 -0
  116. package/lib/front_end/core/sdk/HeapProfilerModel.ts +225 -0
  117. package/lib/front_end/core/sdk/HttpReasonPhraseStrings.ts +77 -0
  118. package/lib/front_end/core/sdk/IOModel.ts +91 -0
  119. package/lib/front_end/core/sdk/IsolateManager.ts +257 -0
  120. package/lib/front_end/core/sdk/IssuesModel.ts +70 -0
  121. package/lib/front_end/core/sdk/LayerTreeBase.ts +169 -0
  122. package/lib/front_end/core/sdk/LogModel.ts +56 -0
  123. package/lib/front_end/core/sdk/NetworkManager.ts +2823 -0
  124. package/lib/front_end/core/sdk/NetworkRequest.ts +2253 -0
  125. package/lib/front_end/core/sdk/OverlayColorGenerator.ts +52 -0
  126. package/lib/front_end/core/sdk/OverlayModel.ts +1011 -0
  127. package/lib/front_end/core/sdk/OverlayPersistentHighlighter.ts +522 -0
  128. package/lib/front_end/core/sdk/PageLoad.ts +35 -0
  129. package/lib/front_end/core/sdk/PageResourceLoader.ts +435 -0
  130. package/lib/front_end/core/sdk/PaintProfiler.ts +110 -0
  131. package/lib/front_end/core/sdk/PerformanceMetricsModel.ts +84 -0
  132. package/lib/front_end/core/sdk/PreloadingModel.ts +863 -0
  133. package/lib/front_end/core/sdk/RehydratingConnection.ts +386 -0
  134. package/lib/front_end/core/sdk/RehydratingObject.ts +66 -0
  135. package/lib/front_end/core/sdk/RemoteObject.ts +1160 -0
  136. package/lib/front_end/core/sdk/Resource.ts +232 -0
  137. package/lib/front_end/core/sdk/ResourceTreeModel.ts +1160 -0
  138. package/lib/front_end/core/sdk/RuntimeModel.ts +732 -0
  139. package/lib/front_end/core/sdk/SDKModel.ts +65 -0
  140. package/lib/front_end/core/sdk/ScopeTreeCache.ts +45 -0
  141. package/lib/front_end/core/sdk/ScreenCaptureModel.ts +255 -0
  142. package/lib/front_end/core/sdk/Script.ts +534 -0
  143. package/lib/front_end/core/sdk/SecurityOriginManager.ts +76 -0
  144. package/lib/front_end/core/sdk/ServerSentEvents.ts +80 -0
  145. package/lib/front_end/core/sdk/ServerSentEventsProtocol.ts +122 -0
  146. package/lib/front_end/core/sdk/ServerTiming.ts +260 -0
  147. package/lib/front_end/core/sdk/ServiceWorkerCacheModel.ts +377 -0
  148. package/lib/front_end/core/sdk/ServiceWorkerManager.ts +605 -0
  149. package/lib/front_end/core/sdk/SourceMap.ts +867 -0
  150. package/lib/front_end/core/sdk/SourceMapCache.ts +54 -0
  151. package/lib/front_end/core/sdk/SourceMapFunctionRanges.ts +156 -0
  152. package/lib/front_end/core/sdk/SourceMapManager.ts +239 -0
  153. package/lib/front_end/core/sdk/SourceMapScopeChainEntry.ts +189 -0
  154. package/lib/front_end/core/sdk/SourceMapScopesInfo.ts +508 -0
  155. package/lib/front_end/core/sdk/StorageBucketsModel.ts +204 -0
  156. package/lib/front_end/core/sdk/StorageKeyManager.ts +98 -0
  157. package/lib/front_end/core/sdk/Target.ts +332 -0
  158. package/lib/front_end/core/sdk/TargetManager.ts +453 -0
  159. package/lib/front_end/core/sdk/TraceObject.ts +61 -0
  160. package/lib/front_end/core/sdk/WebAuthnModel.ts +104 -0
  161. package/lib/front_end/core/sdk/sdk.ts +174 -0
  162. package/lib/front_end/entrypoints/formatter_worker/FormatterActions.ts +59 -0
  163. package/lib/front_end/generated/InspectorBackendCommands.js +1617 -0
  164. package/lib/front_end/generated/SupportedCSSProperties.js +7512 -0
  165. package/lib/front_end/generated/protocol-proxy-api.d.ts +5022 -0
  166. package/lib/front_end/generated/protocol.ts +22014 -0
  167. package/lib/front_end/models/cpu_profile/CPUProfileDataModel.ts +571 -0
  168. package/lib/front_end/models/cpu_profile/ProfileTreeModel.ts +103 -0
  169. package/lib/front_end/models/cpu_profile/cpu_profile.ts +11 -0
  170. package/lib/front_end/models/formatter/FormatterWorkerPool.ts +219 -0
  171. package/lib/front_end/models/formatter/ScriptFormatter.ts +112 -0
  172. package/lib/front_end/models/formatter/formatter.ts +8 -0
  173. package/lib/front_end/models/text_utils/CodeMirrorUtils.ts +37 -0
  174. package/lib/front_end/models/text_utils/ContentData.ts +199 -0
  175. package/lib/front_end/models/text_utils/ContentProvider.ts +68 -0
  176. package/lib/front_end/models/text_utils/StaticContentProvider.ts +49 -0
  177. package/lib/front_end/models/text_utils/StreamingContentData.ts +108 -0
  178. package/lib/front_end/models/text_utils/Text.ts +90 -0
  179. package/lib/front_end/models/text_utils/TextCursor.ts +44 -0
  180. package/lib/front_end/models/text_utils/TextRange.ts +266 -0
  181. package/lib/front_end/models/text_utils/TextUtils.ts +401 -0
  182. package/lib/front_end/models/text_utils/WasmDisassembly.ts +87 -0
  183. package/lib/front_end/models/text_utils/text_utils.ts +27 -0
  184. package/lib/front_end/models/trace/EntityMapper.ts +141 -0
  185. package/lib/front_end/models/trace/EventsSerializer.ts +101 -0
  186. package/lib/front_end/models/trace/LanternComputationData.ts +438 -0
  187. package/lib/front_end/models/trace/ModelImpl.ts +236 -0
  188. package/lib/front_end/models/trace/Name.ts +136 -0
  189. package/lib/front_end/models/trace/Processor.ts +652 -0
  190. package/lib/front_end/models/trace/Styles.ts +1138 -0
  191. package/lib/front_end/models/trace/extras/FilmStrip.ts +78 -0
  192. package/lib/front_end/models/trace/extras/MainThreadActivity.ts +86 -0
  193. package/lib/front_end/models/trace/extras/ScriptDuplication.ts +236 -0
  194. package/lib/front_end/models/trace/extras/StackTraceForEvent.ts +203 -0
  195. package/lib/front_end/models/trace/extras/ThirdParties.ts +164 -0
  196. package/lib/front_end/models/trace/extras/TraceFilter.ts +62 -0
  197. package/lib/front_end/models/trace/extras/TraceTree.ts +701 -0
  198. package/lib/front_end/models/trace/extras/extras.ts +11 -0
  199. package/lib/front_end/models/trace/handlers/AnimationFramesHandler.ts +128 -0
  200. package/lib/front_end/models/trace/handlers/AnimationHandler.ts +36 -0
  201. package/lib/front_end/models/trace/handlers/AsyncJSCallsHandler.ts +239 -0
  202. package/lib/front_end/models/trace/handlers/AuctionWorkletsHandler.ts +183 -0
  203. package/lib/front_end/models/trace/handlers/DOMStatsHandler.ts +31 -0
  204. package/lib/front_end/models/trace/handlers/ExtensionTraceDataHandler.ts +306 -0
  205. package/lib/front_end/models/trace/handlers/FlowsHandler.ts +175 -0
  206. package/lib/front_end/models/trace/handlers/FramesHandler.ts +571 -0
  207. package/lib/front_end/models/trace/handlers/GPUHandler.ts +50 -0
  208. package/lib/front_end/models/trace/handlers/ImagePaintingHandler.ts +183 -0
  209. package/lib/front_end/models/trace/handlers/InitiatorsHandler.ts +193 -0
  210. package/lib/front_end/models/trace/handlers/InvalidationsHandler.ts +168 -0
  211. package/lib/front_end/models/trace/handlers/LargestImagePaintHandler.ts +109 -0
  212. package/lib/front_end/models/trace/handlers/LargestTextPaintHandler.ts +35 -0
  213. package/lib/front_end/models/trace/handlers/LayerTreeHandler.ts +123 -0
  214. package/lib/front_end/models/trace/handlers/LayoutShiftsHandler.ts +573 -0
  215. package/lib/front_end/models/trace/handlers/MemoryHandler.ts +31 -0
  216. package/lib/front_end/models/trace/handlers/MetaHandler.ts +525 -0
  217. package/lib/front_end/models/trace/handlers/ModelHandlers.ts +34 -0
  218. package/lib/front_end/models/trace/handlers/NetworkRequestsHandler.ts +672 -0
  219. package/lib/front_end/models/trace/handlers/PageFramesHandler.ts +52 -0
  220. package/lib/front_end/models/trace/handlers/PageLoadMetricsHandler.ts +460 -0
  221. package/lib/front_end/models/trace/handlers/RendererHandler.ts +428 -0
  222. package/lib/front_end/models/trace/handlers/SamplesHandler.ts +271 -0
  223. package/lib/front_end/models/trace/handlers/ScreenshotsHandler.ts +122 -0
  224. package/lib/front_end/models/trace/handlers/ScriptsHandler.ts +336 -0
  225. package/lib/front_end/models/trace/handlers/SelectorStatsHandler.ts +110 -0
  226. package/lib/front_end/models/trace/handlers/Threads.ts +139 -0
  227. package/lib/front_end/models/trace/handlers/UserInteractionsHandler.ts +400 -0
  228. package/lib/front_end/models/trace/handlers/UserTimingsHandler.ts +233 -0
  229. package/lib/front_end/models/trace/handlers/WarningsHandler.ts +162 -0
  230. package/lib/front_end/models/trace/handlers/WorkersHandler.ts +45 -0
  231. package/lib/front_end/models/trace/handlers/handlers.ts +8 -0
  232. package/lib/front_end/models/trace/handlers/helpers.ts +196 -0
  233. package/lib/front_end/models/trace/handlers/types.ts +75 -0
  234. package/lib/front_end/models/trace/helpers/Extensions.ts +54 -0
  235. package/lib/front_end/models/trace/helpers/Network.ts +129 -0
  236. package/lib/front_end/models/trace/helpers/SamplesIntegrator.ts +544 -0
  237. package/lib/front_end/models/trace/helpers/SyntheticEvents.ts +87 -0
  238. package/lib/front_end/models/trace/helpers/Timing.ts +248 -0
  239. package/lib/front_end/models/trace/helpers/Trace.ts +928 -0
  240. package/lib/front_end/models/trace/helpers/TreeHelpers.ts +320 -0
  241. package/lib/front_end/models/trace/helpers/helpers.ts +11 -0
  242. package/lib/front_end/models/trace/insights/CLSCulprits.ts +668 -0
  243. package/lib/front_end/models/trace/insights/Cache.ts +269 -0
  244. package/lib/front_end/models/trace/insights/Common.ts +453 -0
  245. package/lib/front_end/models/trace/insights/DOMSize.ts +223 -0
  246. package/lib/front_end/models/trace/insights/DocumentLatency.ts +319 -0
  247. package/lib/front_end/models/trace/insights/DuplicatedJavaScript.ts +126 -0
  248. package/lib/front_end/models/trace/insights/FontDisplay.ts +119 -0
  249. package/lib/front_end/models/trace/insights/ForcedReflow.ts +220 -0
  250. package/lib/front_end/models/trace/insights/INPBreakdown.ts +171 -0
  251. package/lib/front_end/models/trace/insights/ImageDelivery.ts +348 -0
  252. package/lib/front_end/models/trace/insights/LCPBreakdown.ts +268 -0
  253. package/lib/front_end/models/trace/insights/LCPDiscovery.ts +237 -0
  254. package/lib/front_end/models/trace/insights/LegacyJavaScript.ts +138 -0
  255. package/lib/front_end/models/trace/insights/Models.ts +22 -0
  256. package/lib/front_end/models/trace/insights/ModernHTTP.ts +257 -0
  257. package/lib/front_end/models/trace/insights/NetworkDependencyTree.ts +726 -0
  258. package/lib/front_end/models/trace/insights/RenderBlocking.ts +257 -0
  259. package/lib/front_end/models/trace/insights/SlowCSSSelector.ts +175 -0
  260. package/lib/front_end/models/trace/insights/Statistics.ts +101 -0
  261. package/lib/front_end/models/trace/insights/ThirdParties.ts +130 -0
  262. package/lib/front_end/models/trace/insights/Viewport.ts +138 -0
  263. package/lib/front_end/models/trace/insights/insights.ts +10 -0
  264. package/lib/front_end/models/trace/insights/types.ts +157 -0
  265. package/lib/front_end/models/trace/lantern/core/LanternError.ts +7 -0
  266. package/lib/front_end/models/trace/lantern/core/NetworkAnalyzer.ts +619 -0
  267. package/lib/front_end/models/trace/lantern/core/core.ts +6 -0
  268. package/lib/front_end/models/trace/lantern/graph/BaseNode.ts +345 -0
  269. package/lib/front_end/models/trace/lantern/graph/CPUNode.ts +80 -0
  270. package/lib/front_end/models/trace/lantern/graph/NetworkNode.ts +101 -0
  271. package/lib/front_end/models/trace/lantern/graph/PageDependencyGraph.ts +636 -0
  272. package/lib/front_end/models/trace/lantern/graph/graph.ts +8 -0
  273. package/lib/front_end/models/trace/lantern/lantern.ts +17 -0
  274. package/lib/front_end/models/trace/lantern/metrics/FirstContentfulPaint.ts +187 -0
  275. package/lib/front_end/models/trace/lantern/metrics/Interactive.ts +88 -0
  276. package/lib/front_end/models/trace/lantern/metrics/LargestContentfulPaint.ts +92 -0
  277. package/lib/front_end/models/trace/lantern/metrics/MaxPotentialFID.ts +72 -0
  278. package/lib/front_end/models/trace/lantern/metrics/Metric.ts +126 -0
  279. package/lib/front_end/models/trace/lantern/metrics/SpeedIndex.ts +126 -0
  280. package/lib/front_end/models/trace/lantern/metrics/TBTUtils.ts +82 -0
  281. package/lib/front_end/models/trace/lantern/metrics/TotalBlockingTime.ts +112 -0
  282. package/lib/front_end/models/trace/lantern/metrics/metrics.ts +12 -0
  283. package/lib/front_end/models/trace/lantern/simulation/ConnectionPool.ts +150 -0
  284. package/lib/front_end/models/trace/lantern/simulation/Constants.ts +46 -0
  285. package/lib/front_end/models/trace/lantern/simulation/DNSCache.ts +61 -0
  286. package/lib/front_end/models/trace/lantern/simulation/SimulationTimingMap.ts +196 -0
  287. package/lib/front_end/models/trace/lantern/simulation/Simulator.ts +556 -0
  288. package/lib/front_end/models/trace/lantern/simulation/TCPConnection.ts +192 -0
  289. package/lib/front_end/models/trace/lantern/simulation/simulation.ts +10 -0
  290. package/lib/front_end/models/trace/lantern/types/Lantern.ts +220 -0
  291. package/lib/front_end/models/trace/lantern/types/types.ts +5 -0
  292. package/lib/front_end/models/trace/trace.ts +33 -0
  293. package/lib/front_end/models/trace/types/Configuration.ts +110 -0
  294. package/lib/front_end/models/trace/types/Extensions.ts +136 -0
  295. package/lib/front_end/models/trace/types/File.ts +281 -0
  296. package/lib/front_end/models/trace/types/Overlays.ts +138 -0
  297. package/lib/front_end/models/trace/types/Timing.ts +30 -0
  298. package/lib/front_end/models/trace/types/TraceEvents.ts +3277 -0
  299. package/lib/front_end/models/trace/types/types.ts +10 -0
  300. package/lib/front_end/third_party/i18n/LICENSE +202 -0
  301. package/lib/front_end/third_party/i18n/README.chromium +15 -0
  302. package/lib/front_end/third_party/i18n/i18n-impl.ts +61 -0
  303. package/lib/front_end/third_party/i18n/i18n.ts +11 -0
  304. package/lib/front_end/third_party/i18n/localized-string-set.ts +129 -0
  305. package/lib/front_end/third_party/intl-messageformat/LICENSE +33 -0
  306. package/lib/front_end/third_party/intl-messageformat/README.chromium +24 -0
  307. package/lib/front_end/third_party/intl-messageformat/intl-messageformat-tsconfig.json +16 -0
  308. package/lib/front_end/third_party/intl-messageformat/intl-messageformat.ts +6 -0
  309. package/lib/front_end/third_party/intl-messageformat/package/LICENSE.md +33 -0
  310. package/lib/front_end/third_party/intl-messageformat/package/README.md +3 -0
  311. package/lib/front_end/third_party/intl-messageformat/package/index.d.ts +6 -0
  312. package/lib/front_end/third_party/intl-messageformat/package/index.d.ts.map +1 -0
  313. package/lib/front_end/third_party/intl-messageformat/package/index.js +13 -0
  314. package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.esm.d.ts +5 -0
  315. package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.esm.js +1710 -0
  316. package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.iife.js +1815 -0
  317. package/lib/front_end/third_party/intl-messageformat/package/lib/index.d.ts +6 -0
  318. package/lib/front_end/third_party/intl-messageformat/package/lib/index.d.ts.map +1 -0
  319. package/lib/front_end/third_party/intl-messageformat/package/lib/index.js +10 -0
  320. package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.d.ts +34 -0
  321. package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.d.ts.map +1 -0
  322. package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.js +229 -0
  323. package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.d.ts +28 -0
  324. package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.d.ts.map +1 -0
  325. package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.js +48 -0
  326. package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.d.ts +34 -0
  327. package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.d.ts.map +1 -0
  328. package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.js +179 -0
  329. package/lib/front_end/third_party/intl-messageformat/package/package.json +42 -0
  330. package/lib/front_end/third_party/intl-messageformat/package/src/core.d.ts +34 -0
  331. package/lib/front_end/third_party/intl-messageformat/package/src/core.d.ts.map +1 -0
  332. package/lib/front_end/third_party/intl-messageformat/package/src/core.js +230 -0
  333. package/lib/front_end/third_party/intl-messageformat/package/src/error.d.ts +28 -0
  334. package/lib/front_end/third_party/intl-messageformat/package/src/error.d.ts.map +1 -0
  335. package/lib/front_end/third_party/intl-messageformat/package/src/error.js +51 -0
  336. package/lib/front_end/third_party/intl-messageformat/package/src/formatters.d.ts +34 -0
  337. package/lib/front_end/third_party/intl-messageformat/package/src/formatters.d.ts.map +1 -0
  338. package/lib/front_end/third_party/intl-messageformat/package/src/formatters.js +182 -0
  339. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/error.d.ts +79 -0
  340. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/index.d.ts +15 -0
  341. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/parser.d.ts +153 -0
  342. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/types.d.ts +139 -0
  343. package/lib/front_end/third_party/legacy-javascript/LICENSE +202 -0
  344. package/lib/front_end/third_party/legacy-javascript/README.chromium +13 -0
  345. package/lib/front_end/third_party/legacy-javascript/legacy-javascript-tsconfig.json +8 -0
  346. package/lib/front_end/third_party/legacy-javascript/legacy-javascript.ts +3 -0
  347. package/lib/front_end/third_party/legacy-javascript/lib/legacy-javascript.d.ts +18 -0
  348. package/lib/front_end/third_party/legacy-javascript/lib/legacy-javascript.js +943 -0
  349. package/lib/front_end/third_party/legacy-javascript/package.json +8 -0
  350. package/lib/front_end/third_party/legacy-javascript/rebuild.sh +9 -0
  351. package/lib/front_end/third_party/third-party-web/LICENSE +20 -0
  352. package/lib/front_end/third_party/third-party-web/README.chromium +13 -0
  353. package/lib/front_end/third_party/third-party-web/lib/nostats-subset.d.ts +2 -0
  354. package/lib/front_end/third_party/third-party-web/lib/nostats-subset.js +149 -0
  355. package/lib/front_end/third_party/third-party-web/package/LICENSE +20 -0
  356. package/lib/front_end/third_party/third-party-web/package/README.md +929 -0
  357. package/lib/front_end/third_party/third-party-web/package/dist/entities-httparchive-nostats.json +1 -0
  358. package/lib/front_end/third_party/third-party-web/package/dist/entities-httparchive.json +1 -0
  359. package/lib/front_end/third_party/third-party-web/package/dist/entities-nostats.json +1 -0
  360. package/lib/front_end/third_party/third-party-web/package/dist/entities.json +1 -0
  361. package/lib/front_end/third_party/third-party-web/package/facades.md +46 -0
  362. package/lib/front_end/third_party/third-party-web/package/httparchive-nostats-subset.d.ts +1 -0
  363. package/lib/front_end/third_party/third-party-web/package/httparchive-nostats-subset.js +1 -0
  364. package/lib/front_end/third_party/third-party-web/package/httparchive-subset.d.ts +1 -0
  365. package/lib/front_end/third_party/third-party-web/package/httparchive-subset.js +1 -0
  366. package/lib/front_end/third_party/third-party-web/package/lib/__snapshots__/index.test.js.snap +1006 -0
  367. package/lib/front_end/third_party/third-party-web/package/lib/create-entity-finder-api.js +139 -0
  368. package/lib/front_end/third_party/third-party-web/package/lib/create-entity-finder-api.test.js +44 -0
  369. package/lib/front_end/third_party/third-party-web/package/lib/entities.test.js +27 -0
  370. package/lib/front_end/third_party/third-party-web/package/lib/index.d.ts +34 -0
  371. package/lib/front_end/third_party/third-party-web/package/lib/index.js +3 -0
  372. package/lib/front_end/third_party/third-party-web/package/lib/index.test.js +246 -0
  373. package/lib/front_end/third_party/third-party-web/package/lib/markdown/faqs.partial.md +36 -0
  374. package/lib/front_end/third_party/third-party-web/package/lib/markdown/goals.partial.md +9 -0
  375. package/lib/front_end/third_party/third-party-web/package/lib/markdown/methodology.partial.md +5 -0
  376. package/lib/front_end/third_party/third-party-web/package/lib/markdown/template.md +151 -0
  377. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-02-01.md +1 -0
  378. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-03-01.md +1 -0
  379. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-05-06.md +1 -0
  380. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-05-13.md +14 -0
  381. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2021-01-01.md +1 -0
  382. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2024-07-01.md +3 -0
  383. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive-nostats.d.ts +1 -0
  384. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive-nostats.js +3 -0
  385. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive.d.ts +1 -0
  386. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive.js +3 -0
  387. package/lib/front_end/third_party/third-party-web/package/lib/subsets/nostats.d.ts +1 -0
  388. package/lib/front_end/third_party/third-party-web/package/lib/subsets/nostats.js +3 -0
  389. package/lib/front_end/third_party/third-party-web/package/nostats-subset.d.ts +1 -0
  390. package/lib/front_end/third_party/third-party-web/package/nostats-subset.js +1 -0
  391. package/lib/front_end/third_party/third-party-web/package/package.json +46 -0
  392. package/lib/front_end/third_party/third-party-web/package.json +8 -0
  393. package/lib/front_end/third_party/third-party-web/rebuild.sh +13 -0
  394. package/lib/front_end/third_party/third-party-web/third-party-web-tsconfig.json +8 -0
  395. package/lib/front_end/third_party/third-party-web/third-party-web.ts +3 -0
  396. package/package.json +24 -0
  397. package/patches/chrome-devtools-frontend+1.0.1533544.patch +187 -0
@@ -0,0 +1,306 @@
1
+ // Copyright 2024 The Chromium Authors
2
+ // Use of this source code is governed by a BSD-style license that can be
3
+ // found in the LICENSE file.
4
+
5
+ import * as Helpers from '../helpers/helpers.js';
6
+ import * as Types from '../types/types.js';
7
+
8
+ import type {HandlerName} from './types.js';
9
+ import {data as userTimingsData} from './UserTimingsHandler.js';
10
+
11
+ let extensionTrackEntries: Types.Extensions.SyntheticExtensionTrackEntry[] = [];
12
+ let extensionTrackData: Types.Extensions.ExtensionTrackData[] = [];
13
+ let extensionMarkers: Types.Extensions.SyntheticExtensionMarker[] = [];
14
+ let entryToNode = new Map<Types.Events.Event, Helpers.TreeHelpers.TraceEntryNode>();
15
+ let timeStampByName = new Map<string, Types.Events.ConsoleTimeStamp>();
16
+
17
+ let syntheticConsoleEntriesForTimingsTrack: Types.Events.SyntheticConsoleTimeStamp[] = [];
18
+
19
+ export interface ExtensionTraceData {
20
+ extensionTrackData: readonly Types.Extensions.ExtensionTrackData[];
21
+ extensionMarkers: readonly Types.Extensions.SyntheticExtensionMarker[];
22
+ // TODO(andoli): Can we augment Renderer's entryToNode instead? To avoid the split of TimelineUIUtils's getEventSelfTime()?
23
+ entryToNode: Map<Types.Events.Event, Helpers.TreeHelpers.TraceEntryNode>;
24
+ syntheticConsoleEntriesForTimingsTrack: Types.Events.SyntheticConsoleTimeStamp[];
25
+ }
26
+
27
+ export function handleEvent(_event: Types.Events.Event): void {
28
+ // Implementation not needed because data is sourced from UserTimingsHandler
29
+ }
30
+
31
+ export function reset(): void {
32
+ extensionTrackEntries = [];
33
+ syntheticConsoleEntriesForTimingsTrack = [];
34
+ extensionTrackData = [];
35
+ extensionMarkers = [];
36
+ entryToNode = new Map();
37
+ timeStampByName = new Map();
38
+ }
39
+
40
+ export async function finalize(): Promise<void> {
41
+ createExtensionFlameChartEntries();
42
+ }
43
+
44
+ function createExtensionFlameChartEntries(): void {
45
+ const pairedMeasures: readonly Types.Events.SyntheticUserTimingPair[] = userTimingsData().performanceMeasures;
46
+ const marks: readonly Types.Events.PerformanceMark[] = userTimingsData().performanceMarks;
47
+ const mergedRawExtensionEvents = Helpers.Trace.mergeEventsInOrder(pairedMeasures, marks);
48
+
49
+ extractPerformanceAPIExtensionEntries(mergedRawExtensionEvents);
50
+ extractConsoleAPIExtensionEntries();
51
+ // extensionTrackEntries is filled by the above two calls.
52
+ Helpers.Trace.sortTraceEventsInPlace(extensionTrackEntries);
53
+ Helpers.Extensions.buildTrackDataFromExtensionEntries(extensionTrackEntries, extensionTrackData, entryToNode);
54
+ }
55
+
56
+ /**
57
+ * Extracts extension entries from console.timeStamp events.
58
+ *
59
+ * Entries are built by pairing `console.timeStamp` events based on
60
+ * their names. When a `console.timeStamp` event includes a `start`
61
+ * argument (and optionally an `end` argument), it attempts to find
62
+ * previously recorded `console.timeStamp` events with names matching
63
+ * the `start` and `end` values. These matching events are then used to
64
+ * determine the start and end times of the new entry.
65
+ *
66
+ * If a `console.timeStamp` event includes data for a custom track
67
+ * (specified by the `track` argument), an extension track entry is
68
+ * created and added to the `extensionTrackEntries` array. These entries
69
+ * are used to visualize custom tracks in the Performance panel.
70
+ *
71
+ * If a `console.timeStamp` event includes data for a custom track
72
+ * (specified by the `track` argument), an extension track entry is
73
+ * created and added to the `extensionTrackEntries` array. These entries
74
+ * are used to visualize custom tracks in the Performance panel.
75
+ *
76
+ * If a `console.timeStamp` event does not specify a custom track but
77
+ * includes a start and/or end time (referencing other
78
+ * `console.timeStamp` names), a synthetic console time stamp entry is
79
+ * created and added to the `syntheticConsoleEntriesForTimingsTrack`
80
+ * array. These entries are displayed in the "Timings" track.
81
+ */
82
+ export function extractConsoleAPIExtensionEntries(): void {
83
+ const consoleTimeStamps: readonly Types.Events.ConsoleTimeStamp[] = userTimingsData().timestampEvents;
84
+ for (const currentTimeStamp of consoleTimeStamps) {
85
+ if (!currentTimeStamp.args.data) {
86
+ continue;
87
+ }
88
+ const timeStampName = String(currentTimeStamp.args.data.name ?? currentTimeStamp.args.data.message);
89
+ timeStampByName.set(timeStampName, currentTimeStamp);
90
+ const {devtoolsObj: extensionData, userDetail} = extensionDataInConsoleTimeStamp(currentTimeStamp);
91
+ const start = currentTimeStamp.args.data.start;
92
+ const end = currentTimeStamp.args.data.end;
93
+ if (!extensionData && !start && !end) {
94
+ continue;
95
+ }
96
+ // If the start or end is a number, it's assumed to be a timestamp
97
+ // from the tracing clock, so we use that directly, otherwise we
98
+ // assume it's the label of a previous console timestamp, in which
99
+ // case we use its corresponding timestamp.
100
+ const startTimeStamp =
101
+ typeof start === 'number' ? Types.Timing.Micro(start) : timeStampByName.get(String(start))?.ts;
102
+ const endTimeStamp = typeof end === 'number' ? Types.Timing.Micro(end) : timeStampByName.get(String(end))?.ts;
103
+ if (endTimeStamp !== undefined && startTimeStamp === undefined) {
104
+ // Invalid data
105
+ continue;
106
+ }
107
+ const entryStartTime = startTimeStamp ?? currentTimeStamp.ts;
108
+ const entryEndTime = endTimeStamp ?? currentTimeStamp.ts;
109
+ if (extensionData) {
110
+ const unregisteredExtensionEntry: Omit<Types.Extensions.SyntheticExtensionTrackEntry, '_tag'> = {
111
+ ...currentTimeStamp,
112
+ name: timeStampName,
113
+ cat: 'devtools.extension',
114
+ devtoolsObj: extensionData,
115
+ userDetail,
116
+ rawSourceEvent: currentTimeStamp,
117
+ dur: Types.Timing.Micro(entryEndTime - entryStartTime),
118
+ ts: entryStartTime,
119
+ ph: Types.Events.Phase.COMPLETE,
120
+ };
121
+ const extensionEntry =
122
+ Helpers.SyntheticEvents.SyntheticEventsManager
123
+ .registerSyntheticEvent<Types.Extensions.SyntheticExtensionTrackEntry>(unregisteredExtensionEntry);
124
+ extensionTrackEntries.push(extensionEntry);
125
+ continue;
126
+ }
127
+ // If no extension data is found in the entry (no custom track name
128
+ // was passed), but the entry has a duration. we still save it here
129
+ // to be added in the timings track. Note that timings w/o duration
130
+ // and extension data are already handled by the UserTimingsHandler.
131
+ const unregisteredSyntheticTimeStamp: Omit<Types.Events.SyntheticConsoleTimeStamp, '_tag'> = {
132
+ ...currentTimeStamp,
133
+ name: timeStampName,
134
+ cat: 'disabled-by-default-v8.inspector',
135
+ ph: Types.Events.Phase.COMPLETE,
136
+ ts: entryStartTime,
137
+ dur: Types.Timing.Micro(entryEndTime - entryStartTime),
138
+ rawSourceEvent: currentTimeStamp
139
+ };
140
+ const syntheticTimeStamp =
141
+ Helpers.SyntheticEvents.SyntheticEventsManager.registerSyntheticEvent<Types.Events.SyntheticConsoleTimeStamp>(
142
+ unregisteredSyntheticTimeStamp);
143
+ syntheticConsoleEntriesForTimingsTrack.push(syntheticTimeStamp);
144
+ }
145
+ }
146
+
147
+ /**
148
+ * Extracts extension entries from Performance API events (marks and
149
+ * measures).
150
+ * It specifically looks for events that contain extension-specific data
151
+ * within their `detail` property.
152
+ *
153
+ * If an event's `detail` property can be parsed as a JSON object and
154
+ * contains a `devtools` field with a valid extension payload, a
155
+ * synthetic extension entry is created. The type of extension entry
156
+ * created depends on the payload:
157
+ *
158
+ * - If the payload conforms to `ExtensionPayloadMarker`, a
159
+ * `SyntheticExtensionMarker` is created and added to the
160
+ * `extensionMarkers` array. These markers represent single points in
161
+ * time.
162
+ * - If the payload conforms to `ExtensionPayloadTrackEntry`, a
163
+ * `SyntheticExtensionTrackEntry` is created and added to the
164
+ * `extensionTrackEntries` array. These entries represent events with
165
+ * a duration and are displayed on custom tracks in the Performance
166
+ * panel.
167
+ *
168
+ * **Note:** Only events with a `detail` property that contains valid
169
+ * extension data are processed. Other `performance.mark` and
170
+ * `performance.measure` events are ignored.
171
+ *
172
+ * @param timings An array of `SyntheticUserTimingPair` or
173
+ * `PerformanceMark` events, typically obtained from the
174
+ * `UserTimingsHandler`.
175
+ */
176
+ export function extractPerformanceAPIExtensionEntries(
177
+ timings: Array<Types.Events.SyntheticUserTimingPair|Types.Events.PerformanceMark>): void {
178
+ for (const timing of timings) {
179
+ const {devtoolsObj, userDetail} = extensionDataInPerformanceTiming(timing);
180
+ if (!devtoolsObj) {
181
+ // Not an extension user timing.
182
+ continue;
183
+ }
184
+
185
+ const extensionSyntheticEntry = {
186
+ name: timing.name,
187
+ ph: Types.Extensions.isExtensionPayloadMarker(devtoolsObj) ? Types.Events.Phase.INSTANT :
188
+ Types.Events.Phase.COMPLETE,
189
+ pid: timing.pid,
190
+ tid: timing.tid,
191
+ ts: timing.ts,
192
+ dur: timing.dur as Types.Timing.Micro,
193
+ cat: 'devtools.extension',
194
+ devtoolsObj,
195
+ userDetail,
196
+ rawSourceEvent: Types.Events.isSyntheticUserTiming(timing) ? timing.rawSourceEvent : timing,
197
+ };
198
+
199
+ if (Types.Extensions.isExtensionPayloadMarker(devtoolsObj)) {
200
+ const extensionMarker =
201
+ Helpers.SyntheticEvents.SyntheticEventsManager
202
+ .registerSyntheticEvent<Types.Extensions.SyntheticExtensionMarker>(
203
+ extensionSyntheticEntry as Omit<Types.Extensions.SyntheticExtensionMarker, '_tag'>);
204
+ extensionMarkers.push(extensionMarker);
205
+ continue;
206
+ }
207
+
208
+ if (Types.Extensions.isExtensionEntryObj(extensionSyntheticEntry.devtoolsObj)) {
209
+ const extensionTrackEntry =
210
+ Helpers.SyntheticEvents.SyntheticEventsManager
211
+ .registerSyntheticEvent<Types.Extensions.SyntheticExtensionTrackEntry>(
212
+ extensionSyntheticEntry as Omit<Types.Extensions.SyntheticExtensionTrackEntry, '_tag'>);
213
+ extensionTrackEntries.push(extensionTrackEntry);
214
+ continue;
215
+ }
216
+ }
217
+ }
218
+
219
+ /**
220
+ * Parses out the data in a performance.measure / mark call into two parts:
221
+ * 1. devtoolsObj: this is the data required to be passed by the user for the
222
+ * event to be used to create a custom track in the performance panel.
223
+ * 2. userDetail: this is arbitrary data the user has attached to the event
224
+ * that we show in the summary drawer.
225
+ */
226
+ export function extensionDataInPerformanceTiming(
227
+ timing: Types.Events.SyntheticUserTimingPair|Types.Events.PerformanceMark):
228
+ {devtoolsObj: Types.Extensions.DevToolsObj|null, userDetail: Types.Extensions.JsonValue|null} {
229
+ const timingDetail =
230
+ Types.Events.isPerformanceMark(timing) ? timing.args.data?.detail : timing.args.data.beginEvent.args.detail;
231
+ if (!timingDetail) {
232
+ return {devtoolsObj: null, userDetail: null};
233
+ }
234
+ const devtoolsObj = Helpers.Trace.parseDevtoolsDetails(timingDetail, 'devtools') as Types.Extensions.DevToolsObj;
235
+
236
+ let userDetail = null;
237
+ try {
238
+ userDetail = JSON.parse(timingDetail);
239
+ delete userDetail.devtools;
240
+ } catch {
241
+ // Nothing to do here, we still want to return the `devtools` part to make
242
+ // this a custom event, even if the user detail failed to parse.
243
+ }
244
+
245
+ return {devtoolsObj, userDetail};
246
+ }
247
+
248
+ /**
249
+ * Extracts extension data from a `console.timeStamp` event.
250
+ *
251
+ * Checks if a `console.timeStamp` event contains data intended for
252
+ * creating a custom track entry in the DevTools Performance panel. It
253
+ * specifically looks for a `track` argument within the event's data.
254
+ *
255
+ * If a `track` argument is present (and not an empty string), the
256
+ * function constructs an `ExtensionTrackEntryPayload` object containing
257
+ * the track name, an optional color, an optional track group. This
258
+ * payload is then used to create a `SyntheticExtensionTrackEntry`.
259
+ *
260
+ * **Note:** The `color` argument is optional and its type is validated
261
+ * against a predefined palette (see
262
+ * `ExtensionUI::extensionEntryColor`).
263
+ *
264
+ * @param timeStamp The `ConsoleTimeStamp` event to extract data from.
265
+ * @returns An `ExtensionTrackEntryPayload` object if the event contains
266
+ * valid extension data for a track entry, or `null` otherwise.
267
+ */
268
+ export function extensionDataInConsoleTimeStamp(timeStamp: Types.Events.ConsoleTimeStamp):
269
+ {devtoolsObj: Types.Extensions.DevToolsObjEntry|null, userDetail: Types.Extensions.JsonValue|null} {
270
+ if (!timeStamp.args.data || !timeStamp.args.data.track) {
271
+ return {devtoolsObj: null, userDetail: null};
272
+ }
273
+
274
+ let userDetail = null;
275
+ try {
276
+ // While it's in the trace as 'devtools', it's just the 7th argument to console.timeStamp(), stringified.
277
+ // If no data, fall back to falsy empty string.
278
+ userDetail = JSON.parse(timeStamp.args.data?.devtools || '""') as Types.Extensions.JsonValue;
279
+ } catch {
280
+ }
281
+
282
+ const devtoolsObj: Types.Extensions.DevToolsObjEntry = {
283
+ // the color is defaulted to primary if it's value isn't one from
284
+ // the defined palette (see ExtensionUI::extensionEntryColor) so
285
+ // we don't need to check the value is valid here.
286
+ color: String(timeStamp.args.data.color) as Types.Extensions.DevToolsObjEntry['color'],
287
+ track: String(timeStamp.args.data.track),
288
+ dataType: 'track-entry',
289
+ trackGroup: timeStamp.args.data.trackGroup !== undefined ? String(timeStamp.args.data.trackGroup) : undefined,
290
+ };
291
+
292
+ return {devtoolsObj, userDetail};
293
+ }
294
+
295
+ export function data(): ExtensionTraceData {
296
+ return {
297
+ entryToNode,
298
+ extensionTrackData,
299
+ extensionMarkers,
300
+ syntheticConsoleEntriesForTimingsTrack,
301
+ };
302
+ }
303
+
304
+ export function deps(): HandlerName[] {
305
+ return ['UserTimings'];
306
+ }
@@ -0,0 +1,175 @@
1
+ // Copyright 2024 The Chromium Authors
2
+ // Use of this source code is governed by a BSD-style license that can be
3
+ // found in the LICENSE file.
4
+ import * as Platform from '../../../core/platform/platform.js';
5
+ import * as Types from '../types/types.js';
6
+
7
+ // A flow is a logic connection between trace events. We display this
8
+ // connection as arrows between trace events belonging to the same flow.
9
+
10
+ // In the trace event format, flows are represented with pairing "flow
11
+ // phase" events. Each flow phase event corresponds to one trace event
12
+ // and indicates the role a trace event plays in a flow (start, step or
13
+ // end). For each flow, one `start` and one `end` phase events are
14
+ // included, while the amount of `step` phase events can be >= 0.
15
+
16
+ // A flow phase event is assigned to a trace event when their cat, tid,
17
+ // pid and ts are equal (see @flowPhaseBindingTokenForEvent ).
18
+
19
+ // It's possible for a single event to belong to multiple flows. In that
20
+ // case, it will have multiple corresponding flow phase events (one
21
+ // per flow).
22
+
23
+ // To parse flows, we first handle flow phase events, by creating unique
24
+ // flows with the timestamps of each phase. Then, we place trace events
25
+ // in the flows where their corresponding phase events were placed (if
26
+ // there are any corresponding flow phase events at all).
27
+ let flowDataByGroupToken = new Map<string, number>();
28
+
29
+ interface EventFlowData {
30
+ flows: Set<number>;
31
+ bindingParsed: boolean;
32
+ }
33
+ type FlowBindingTuple =
34
+ Map<Types.Timing.Micro, Map<Types.Events.ProcessID, Map<Types.Events.ThreadID, Map<string, EventFlowData>>>>;
35
+
36
+ // Given a trace event's flow binding tuple (timestamp, process id,
37
+ // thread id and category) we determine if there is any flow data bound
38
+ // to it by using this map's content. It's built when processing flow
39
+ // events in a trace.
40
+ // An alternative to having a map of four levels is having single map
41
+ // from a string token built from concatenating the binding data to the
42
+ // corresponding flow data. However, this token would be calculated for
43
+ // every event in a trace, resulting in a lot of memory overhead and
44
+ // major GC triggering. So we are trading off readability for
45
+ // performance.
46
+ let boundFlowData: FlowBindingTuple = new Map();
47
+
48
+ let flowsById = new Map<number, Map<Types.Timing.Micro, Types.Events.Event>>();
49
+ let flowEvents: Types.Events.FlowEvent[] = [];
50
+ let nonFlowEvents: Types.Events.Event[] = [];
51
+ let flows: Types.Events.Event[][] = [];
52
+ const ID_COMPONENT_SEPARATOR = '-$-';
53
+ export function reset(): void {
54
+ flows = [];
55
+ flowEvents = [];
56
+ nonFlowEvents = [];
57
+ flowDataByGroupToken = new Map();
58
+ boundFlowData = new Map();
59
+ flowsById = new Map();
60
+ }
61
+
62
+ export function handleEvent(event: Types.Events.Event): void {
63
+ if (Types.Events.isFlowPhaseEvent(event)) {
64
+ flowEvents.push(event);
65
+ return;
66
+ }
67
+ nonFlowEvents.push(event);
68
+ }
69
+
70
+ function processNonFlowEvent(event: Types.Events.Event): void {
71
+ const flowDataForEvent = boundFlowData.get(event.ts)?.get(event.pid)?.get(event.tid)?.get(event.cat);
72
+ if (!flowDataForEvent) {
73
+ return;
74
+ }
75
+ const {flows, bindingParsed} = flowDataForEvent;
76
+ if (bindingParsed) {
77
+ // We only consider the first event for a given flow binding tuple.
78
+ return;
79
+ }
80
+ for (const flowId of flows) {
81
+ const flow = Platform.MapUtilities.getWithDefault(
82
+ flowsById, flowId, () => new Map<Types.Timing.Micro, Types.Events.Event>());
83
+ flow.set(event.ts, event);
84
+ }
85
+ flowDataForEvent.bindingParsed = true;
86
+ }
87
+
88
+ /**
89
+ * Creates unique flows by tracking flow phase events. A new created
90
+ * flow whenever a flow start phase event is detected.
91
+ * Subsequent flow phase events with the same group token are added to
92
+ * this flow until a flow end phase is detected.
93
+ */
94
+ function processFlowEvent(flowPhaseEvent: Types.Events.FlowEvent): void {
95
+ const flowGroup = flowGroupTokenForFlowPhaseEvent(flowPhaseEvent);
96
+ switch (flowPhaseEvent.ph) {
97
+ case (Types.Events.Phase.FLOW_START): {
98
+ const flowMetadata = {flowId: flowPhaseEvent.id, times: new Map([[flowPhaseEvent.ts, undefined]])};
99
+ flowDataByGroupToken.set(flowGroup, flowPhaseEvent.id);
100
+ addFlowIdToEventBinding(flowPhaseEvent, flowMetadata.flowId);
101
+ return;
102
+ }
103
+ case (Types.Events.Phase.FLOW_STEP): {
104
+ const flowId = flowDataByGroupToken.get(flowGroup);
105
+ if (flowId === undefined) {
106
+ // Found non-start flow event with no corresponding start flow,
107
+ // start event. Quietly ignore the problematic event.
108
+ return;
109
+ }
110
+ addFlowIdToEventBinding(flowPhaseEvent, flowId);
111
+ return;
112
+ }
113
+ case (Types.Events.Phase.FLOW_END): {
114
+ const flowId = flowDataByGroupToken.get(flowGroup);
115
+ if (flowId === undefined) {
116
+ // Found non-start flow event with no corresponding start flow,
117
+ // start event. Quietly ignore the problematic event.
118
+ return;
119
+ }
120
+ addFlowIdToEventBinding(flowPhaseEvent, flowId);
121
+ // We don't need this data anymore as the flow has been finished,
122
+ // so we can drop it.
123
+ flowDataByGroupToken.delete(flowGroup);
124
+ }
125
+ }
126
+ }
127
+
128
+ type MapValueType<T extends Map<unknown, unknown>> = NonNullable<ReturnType<T['get']>>;
129
+ /**
130
+ * A single trace event can belong to multiple flows. This method
131
+ * tracks which flows (flowId) an event belongs to given its flow
132
+ * binding tuple (made of its ts, pid, tid and cat).
133
+ */
134
+ function addFlowIdToEventBinding(event: Types.Events.Event, flowId: number): void {
135
+ const flowsByPid = Platform.MapUtilities.getWithDefault<Types.Timing.Micro, MapValueType<typeof boundFlowData>>(
136
+ boundFlowData, event.ts, () => new Map());
137
+ const flowsByTid = Platform.MapUtilities.getWithDefault<Types.Events.ProcessID, MapValueType<typeof flowsByPid>>(
138
+ flowsByPid, event.pid, () => new Map());
139
+ const flowsByCat = Platform.MapUtilities.getWithDefault<Types.Events.ThreadID, MapValueType<typeof flowsByTid>>(
140
+ flowsByTid, event.tid, () => new Map());
141
+ const flowData =
142
+ Platform.MapUtilities.getWithDefault(flowsByCat, event.cat, () => ({flows: new Set(), bindingParsed: false}));
143
+ flowData.flows.add(flowId);
144
+ }
145
+
146
+ /**
147
+ * Returns a token to group flow phase events (start, step and end)
148
+ * belonging to the same flow. Flow phase events belonging to the same
149
+ * flow share category, thread id, process id and name.
150
+ *
151
+ * Note that other phase events of other flows can share these
152
+ * attributes too. For this reason, we group flow phase events in
153
+ * cycles. A cycle starts on a flow start phase event and finishes on a
154
+ * flow end phase event. For this reason, flow phase events need to be
155
+ * handled in timestamp order.
156
+ */
157
+ function flowGroupTokenForFlowPhaseEvent(event: Types.Events.FlowEvent): string {
158
+ return `${event.cat}${ID_COMPONENT_SEPARATOR}${event.name}${ID_COMPONENT_SEPARATOR}${event.id}`;
159
+ }
160
+
161
+ export async function finalize(): Promise<void> {
162
+ // Order is important: flow events need to be handled first.
163
+ flowEvents.forEach(processFlowEvent);
164
+ nonFlowEvents.forEach(processNonFlowEvent);
165
+ flows = [...flowsById.values()]
166
+ .map(flowMapping => [...flowMapping.values()])
167
+ .map(flow => flow.filter(event => event !== undefined))
168
+ .filter(flow => flow.length > 1);
169
+ }
170
+
171
+ export function data(): {flows: Types.Events.Event[][]} {
172
+ return {
173
+ flows,
174
+ };
175
+ }