devtools-tracing 1.1.1 → 1.2.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 (528) hide show
  1. package/.claude/settings.local.json +14 -0
  2. package/dist/index.d.ts +4 -0
  3. package/dist/index.js +28854 -0
  4. package/package.json +11 -8
  5. package/generate.ts +0 -649
  6. package/index.ts +0 -17
  7. package/lib/extension-api/ExtensionAPI.d.ts +0 -357
  8. package/lib/front_end/core/common/App.ts +0 -7
  9. package/lib/front_end/core/common/AppProvider.ts +0 -32
  10. package/lib/front_end/core/common/Base64.ts +0 -47
  11. package/lib/front_end/core/common/CharacterIdMap.ts +0 -30
  12. package/lib/front_end/core/common/Color.ts +0 -2506
  13. package/lib/front_end/core/common/ColorConverter.ts +0 -402
  14. package/lib/front_end/core/common/ColorUtils.ts +0 -252
  15. package/lib/front_end/core/common/Console.ts +0 -114
  16. package/lib/front_end/core/common/Debouncer.ts +0 -15
  17. package/lib/front_end/core/common/EventTarget.ts +0 -52
  18. package/lib/front_end/core/common/Gzip.ts +0 -74
  19. package/lib/front_end/core/common/JavaScriptMetaData.ts +0 -29
  20. package/lib/front_end/core/common/Lazy.ts +0 -31
  21. package/lib/front_end/core/common/Linkifier.ts +0 -55
  22. package/lib/front_end/core/common/MapWithDefault.ts +0 -26
  23. package/lib/front_end/core/common/Mutex.ts +0 -55
  24. package/lib/front_end/core/common/Object.ts +0 -145
  25. package/lib/front_end/core/common/ParsedURL.ts +0 -554
  26. package/lib/front_end/core/common/Progress.ts +0 -180
  27. package/lib/front_end/core/common/QueryParamHandler.ts +0 -7
  28. package/lib/front_end/core/common/ResolverBase.ts +0 -85
  29. package/lib/front_end/core/common/ResourceType.ts +0 -588
  30. package/lib/front_end/core/common/ReturnToPanel.ts +0 -17
  31. package/lib/front_end/core/common/Revealer.ts +0 -192
  32. package/lib/front_end/core/common/Runnable.ts +0 -41
  33. package/lib/front_end/core/common/SegmentedRange.ts +0 -87
  34. package/lib/front_end/core/common/SettingRegistration.ts +0 -339
  35. package/lib/front_end/core/common/Settings.ts +0 -1497
  36. package/lib/front_end/core/common/SimpleHistoryManager.ts +0 -124
  37. package/lib/front_end/core/common/StringOutputStream.ts +0 -26
  38. package/lib/front_end/core/common/TextDictionary.ts +0 -48
  39. package/lib/front_end/core/common/Throttler.ts +0 -99
  40. package/lib/front_end/core/common/Trie.ts +0 -152
  41. package/lib/front_end/core/common/Worker.ts +0 -60
  42. package/lib/front_end/core/common/common.ts +0 -81
  43. package/lib/front_end/core/host/AidaClient.ts +0 -733
  44. package/lib/front_end/core/host/GdpClient.ts +0 -316
  45. package/lib/front_end/core/host/InspectorFrontendHost.ts +0 -648
  46. package/lib/front_end/core/host/InspectorFrontendHostAPI.ts +0 -551
  47. package/lib/front_end/core/host/Platform.ts +0 -76
  48. package/lib/front_end/core/host/ResourceLoader.ts +0 -282
  49. package/lib/front_end/core/host/UserMetrics.ts +0 -1230
  50. package/lib/front_end/core/host/host.ts +0 -23
  51. package/lib/front_end/core/i18n/ByteUtilities.ts +0 -82
  52. package/lib/front_end/core/i18n/DevToolsLocale.ts +0 -87
  53. package/lib/front_end/core/i18n/NumberFormatter.ts +0 -82
  54. package/lib/front_end/core/i18n/i18n.ts +0 -17
  55. package/lib/front_end/core/i18n/i18nImpl.ts +0 -204
  56. package/lib/front_end/core/i18n/i18nTypes.ts +0 -10
  57. package/lib/front_end/core/i18n/locales.js +0 -14
  58. package/lib/front_end/core/i18n/time-utilities.ts +0 -174
  59. package/lib/front_end/core/platform/ArrayUtilities.ts +0 -271
  60. package/lib/front_end/core/platform/Brand.ts +0 -23
  61. package/lib/front_end/core/platform/Constructor.ts +0 -10
  62. package/lib/front_end/core/platform/DOMUtilities.ts +0 -138
  63. package/lib/front_end/core/platform/DateUtilities.ts +0 -15
  64. package/lib/front_end/core/platform/DevToolsPath.ts +0 -53
  65. package/lib/front_end/core/platform/KeyboardUtilities.ts +0 -38
  66. package/lib/front_end/core/platform/MapUtilities.ts +0 -95
  67. package/lib/front_end/core/platform/MimeType.ts +0 -175
  68. package/lib/front_end/core/platform/NumberUtilities.ts +0 -80
  69. package/lib/front_end/core/platform/StringUtilities.ts +0 -588
  70. package/lib/front_end/core/platform/Timing.ts +0 -17
  71. package/lib/front_end/core/platform/TypedArrayUtilities.ts +0 -189
  72. package/lib/front_end/core/platform/TypescriptUtilities.ts +0 -86
  73. package/lib/front_end/core/platform/UIString.ts +0 -39
  74. package/lib/front_end/core/platform/UserVisibleError.ts +0 -28
  75. package/lib/front_end/core/platform/platform.ts +0 -45
  76. package/lib/front_end/core/protocol_client/ConnectionTransport.ts +0 -26
  77. package/lib/front_end/core/protocol_client/InspectorBackend.ts +0 -1050
  78. package/lib/front_end/core/protocol_client/NodeURL.ts +0 -42
  79. package/lib/front_end/core/protocol_client/protocol_client.ts +0 -13
  80. package/lib/front_end/core/root/Runtime.ts +0 -609
  81. package/lib/front_end/core/root/root.ts +0 -6
  82. package/lib/front_end/core/sdk/AccessibilityModel.ts +0 -353
  83. package/lib/front_end/core/sdk/AnimationModel.ts +0 -1041
  84. package/lib/front_end/core/sdk/AutofillModel.ts +0 -184
  85. package/lib/front_end/core/sdk/CPUProfilerModel.ts +0 -148
  86. package/lib/front_end/core/sdk/CPUThrottlingManager.ts +0 -282
  87. package/lib/front_end/core/sdk/CSSContainerQuery.ts +0 -139
  88. package/lib/front_end/core/sdk/CSSFontFace.ts +0 -40
  89. package/lib/front_end/core/sdk/CSSLayer.ts +0 -30
  90. package/lib/front_end/core/sdk/CSSMatchedStyles.ts +0 -1646
  91. package/lib/front_end/core/sdk/CSSMedia.ts +0 -121
  92. package/lib/front_end/core/sdk/CSSMetadata.ts +0 -1647
  93. package/lib/front_end/core/sdk/CSSModel.ts +0 -1128
  94. package/lib/front_end/core/sdk/CSSProperty.ts +0 -384
  95. package/lib/front_end/core/sdk/CSSPropertyParser.ts +0 -681
  96. package/lib/front_end/core/sdk/CSSPropertyParserMatchers.ts +0 -1395
  97. package/lib/front_end/core/sdk/CSSQuery.ts +0 -72
  98. package/lib/front_end/core/sdk/CSSRule.ts +0 -465
  99. package/lib/front_end/core/sdk/CSSScope.ts +0 -30
  100. package/lib/front_end/core/sdk/CSSStartingStyle.ts +0 -29
  101. package/lib/front_end/core/sdk/CSSStyleDeclaration.ts +0 -313
  102. package/lib/front_end/core/sdk/CSSStyleSheetHeader.ts +0 -196
  103. package/lib/front_end/core/sdk/CSSSupports.ts +0 -33
  104. package/lib/front_end/core/sdk/CategorizedBreakpoint.ts +0 -64
  105. package/lib/front_end/core/sdk/ChildTargetManager.ts +0 -314
  106. package/lib/front_end/core/sdk/CompilerSourceMappingContentProvider.ts +0 -62
  107. package/lib/front_end/core/sdk/Connections.ts +0 -293
  108. package/lib/front_end/core/sdk/ConsoleModel.ts +0 -808
  109. package/lib/front_end/core/sdk/ConsoleModelTypes.ts +0 -15
  110. package/lib/front_end/core/sdk/Cookie.ts +0 -319
  111. package/lib/front_end/core/sdk/CookieModel.ts +0 -239
  112. package/lib/front_end/core/sdk/CookieParser.ts +0 -185
  113. package/lib/front_end/core/sdk/DOMDebuggerModel.ts +0 -787
  114. package/lib/front_end/core/sdk/DOMModel.ts +0 -1961
  115. package/lib/front_end/core/sdk/DebuggerModel.ts +0 -1605
  116. package/lib/front_end/core/sdk/EmulationModel.ts +0 -648
  117. package/lib/front_end/core/sdk/EnhancedTracesParser.ts +0 -515
  118. package/lib/front_end/core/sdk/EventBreakpointsModel.ts +0 -183
  119. package/lib/front_end/core/sdk/FrameAssociated.ts +0 -11
  120. package/lib/front_end/core/sdk/FrameManager.ts +0 -259
  121. package/lib/front_end/core/sdk/HeapProfilerModel.ts +0 -225
  122. package/lib/front_end/core/sdk/HttpReasonPhraseStrings.ts +0 -77
  123. package/lib/front_end/core/sdk/IOModel.ts +0 -91
  124. package/lib/front_end/core/sdk/IsolateManager.ts +0 -257
  125. package/lib/front_end/core/sdk/IssuesModel.ts +0 -70
  126. package/lib/front_end/core/sdk/LayerTreeBase.ts +0 -169
  127. package/lib/front_end/core/sdk/LogModel.ts +0 -56
  128. package/lib/front_end/core/sdk/NetworkManager.ts +0 -2823
  129. package/lib/front_end/core/sdk/NetworkRequest.ts +0 -2253
  130. package/lib/front_end/core/sdk/OverlayColorGenerator.ts +0 -52
  131. package/lib/front_end/core/sdk/OverlayModel.ts +0 -1011
  132. package/lib/front_end/core/sdk/OverlayPersistentHighlighter.ts +0 -522
  133. package/lib/front_end/core/sdk/PageLoad.ts +0 -35
  134. package/lib/front_end/core/sdk/PageResourceLoader.ts +0 -435
  135. package/lib/front_end/core/sdk/PaintProfiler.ts +0 -110
  136. package/lib/front_end/core/sdk/PerformanceMetricsModel.ts +0 -84
  137. package/lib/front_end/core/sdk/PreloadingModel.ts +0 -863
  138. package/lib/front_end/core/sdk/RehydratingConnection.ts +0 -386
  139. package/lib/front_end/core/sdk/RehydratingObject.ts +0 -66
  140. package/lib/front_end/core/sdk/RemoteObject.ts +0 -1160
  141. package/lib/front_end/core/sdk/Resource.ts +0 -232
  142. package/lib/front_end/core/sdk/ResourceTreeModel.ts +0 -1160
  143. package/lib/front_end/core/sdk/RuntimeModel.ts +0 -732
  144. package/lib/front_end/core/sdk/SDKModel.ts +0 -65
  145. package/lib/front_end/core/sdk/ScopeTreeCache.ts +0 -45
  146. package/lib/front_end/core/sdk/ScreenCaptureModel.ts +0 -255
  147. package/lib/front_end/core/sdk/Script.ts +0 -534
  148. package/lib/front_end/core/sdk/SecurityOriginManager.ts +0 -76
  149. package/lib/front_end/core/sdk/ServerSentEvents.ts +0 -80
  150. package/lib/front_end/core/sdk/ServerSentEventsProtocol.ts +0 -122
  151. package/lib/front_end/core/sdk/ServerTiming.ts +0 -260
  152. package/lib/front_end/core/sdk/ServiceWorkerCacheModel.ts +0 -377
  153. package/lib/front_end/core/sdk/ServiceWorkerManager.ts +0 -605
  154. package/lib/front_end/core/sdk/SourceMap.ts +0 -867
  155. package/lib/front_end/core/sdk/SourceMapCache.ts +0 -54
  156. package/lib/front_end/core/sdk/SourceMapFunctionRanges.ts +0 -156
  157. package/lib/front_end/core/sdk/SourceMapManager.ts +0 -239
  158. package/lib/front_end/core/sdk/SourceMapScopeChainEntry.ts +0 -189
  159. package/lib/front_end/core/sdk/SourceMapScopesInfo.ts +0 -508
  160. package/lib/front_end/core/sdk/StorageBucketsModel.ts +0 -204
  161. package/lib/front_end/core/sdk/StorageKeyManager.ts +0 -98
  162. package/lib/front_end/core/sdk/Target.ts +0 -332
  163. package/lib/front_end/core/sdk/TargetManager.ts +0 -453
  164. package/lib/front_end/core/sdk/TraceObject.ts +0 -61
  165. package/lib/front_end/core/sdk/WebAuthnModel.ts +0 -104
  166. package/lib/front_end/core/sdk/sdk.ts +0 -174
  167. package/lib/front_end/entrypoints/formatter_worker/FormatterActions.ts +0 -59
  168. package/lib/front_end/generated/InspectorBackendCommands.js +0 -1617
  169. package/lib/front_end/generated/SupportedCSSProperties.js +0 -7512
  170. package/lib/front_end/generated/protocol-proxy-api.d.ts +0 -5022
  171. package/lib/front_end/generated/protocol.ts +0 -22014
  172. package/lib/front_end/models/bindings/CSSWorkspaceBinding.ts +0 -318
  173. package/lib/front_end/models/bindings/CompilerScriptMapping.ts +0 -536
  174. package/lib/front_end/models/bindings/ContentProviderBasedProject.ts +0 -187
  175. package/lib/front_end/models/bindings/DebuggerLanguagePlugins.ts +0 -1197
  176. package/lib/front_end/models/bindings/DebuggerWorkspaceBinding.ts +0 -733
  177. package/lib/front_end/models/bindings/DefaultScriptMapping.ts +0 -141
  178. package/lib/front_end/models/bindings/FileUtils.ts +0 -228
  179. package/lib/front_end/models/bindings/LiveLocation.ts +0 -81
  180. package/lib/front_end/models/bindings/NetworkProject.ts +0 -157
  181. package/lib/front_end/models/bindings/PresentationConsoleMessageHelper.ts +0 -312
  182. package/lib/front_end/models/bindings/ResourceMapping.ts +0 -539
  183. package/lib/front_end/models/bindings/ResourceScriptMapping.ts +0 -491
  184. package/lib/front_end/models/bindings/ResourceUtils.ts +0 -103
  185. package/lib/front_end/models/bindings/SASSSourceMapping.ts +0 -222
  186. package/lib/front_end/models/bindings/StylesSourceMapping.ts +0 -316
  187. package/lib/front_end/models/bindings/TempFile.ts +0 -67
  188. package/lib/front_end/models/bindings/bindings.ts +0 -39
  189. package/lib/front_end/models/cpu_profile/CPUProfileDataModel.ts +0 -571
  190. package/lib/front_end/models/cpu_profile/ProfileTreeModel.ts +0 -103
  191. package/lib/front_end/models/cpu_profile/cpu_profile.ts +0 -11
  192. package/lib/front_end/models/formatter/FormatterWorkerPool.ts +0 -219
  193. package/lib/front_end/models/formatter/ScriptFormatter.ts +0 -112
  194. package/lib/front_end/models/formatter/formatter.ts +0 -8
  195. package/lib/front_end/models/source_map_scopes/NamesResolver.ts +0 -765
  196. package/lib/front_end/models/source_map_scopes/ScopeChainModel.ts +0 -84
  197. package/lib/front_end/models/source_map_scopes/source_map_scopes.ts +0 -11
  198. package/lib/front_end/models/stack_trace/StackTrace.ts +0 -53
  199. package/lib/front_end/models/stack_trace/StackTraceImpl.ts +0 -85
  200. package/lib/front_end/models/stack_trace/StackTraceModel.ts +0 -128
  201. package/lib/front_end/models/stack_trace/Trie.ts +0 -163
  202. package/lib/front_end/models/stack_trace/stack_trace.ts +0 -9
  203. package/lib/front_end/models/stack_trace/stack_trace_impl.ts +0 -13
  204. package/lib/front_end/models/text_utils/CodeMirrorUtils.ts +0 -37
  205. package/lib/front_end/models/text_utils/ContentData.ts +0 -199
  206. package/lib/front_end/models/text_utils/ContentProvider.ts +0 -68
  207. package/lib/front_end/models/text_utils/StaticContentProvider.ts +0 -49
  208. package/lib/front_end/models/text_utils/StreamingContentData.ts +0 -108
  209. package/lib/front_end/models/text_utils/Text.ts +0 -90
  210. package/lib/front_end/models/text_utils/TextCursor.ts +0 -44
  211. package/lib/front_end/models/text_utils/TextRange.ts +0 -266
  212. package/lib/front_end/models/text_utils/TextUtils.ts +0 -401
  213. package/lib/front_end/models/text_utils/WasmDisassembly.ts +0 -87
  214. package/lib/front_end/models/text_utils/text_utils.ts +0 -27
  215. package/lib/front_end/models/trace/EntityMapper.ts +0 -141
  216. package/lib/front_end/models/trace/EventsSerializer.ts +0 -101
  217. package/lib/front_end/models/trace/LanternComputationData.ts +0 -438
  218. package/lib/front_end/models/trace/ModelImpl.ts +0 -236
  219. package/lib/front_end/models/trace/Name.ts +0 -136
  220. package/lib/front_end/models/trace/Processor.ts +0 -652
  221. package/lib/front_end/models/trace/Styles.ts +0 -1138
  222. package/lib/front_end/models/trace/extras/FilmStrip.ts +0 -78
  223. package/lib/front_end/models/trace/extras/MainThreadActivity.ts +0 -86
  224. package/lib/front_end/models/trace/extras/ScriptDuplication.ts +0 -236
  225. package/lib/front_end/models/trace/extras/StackTraceForEvent.ts +0 -203
  226. package/lib/front_end/models/trace/extras/ThirdParties.ts +0 -164
  227. package/lib/front_end/models/trace/extras/TraceFilter.ts +0 -62
  228. package/lib/front_end/models/trace/extras/TraceTree.ts +0 -701
  229. package/lib/front_end/models/trace/extras/extras.ts +0 -11
  230. package/lib/front_end/models/trace/handlers/AnimationFramesHandler.ts +0 -128
  231. package/lib/front_end/models/trace/handlers/AnimationHandler.ts +0 -36
  232. package/lib/front_end/models/trace/handlers/AsyncJSCallsHandler.ts +0 -239
  233. package/lib/front_end/models/trace/handlers/AuctionWorkletsHandler.ts +0 -183
  234. package/lib/front_end/models/trace/handlers/DOMStatsHandler.ts +0 -31
  235. package/lib/front_end/models/trace/handlers/ExtensionTraceDataHandler.ts +0 -306
  236. package/lib/front_end/models/trace/handlers/FlowsHandler.ts +0 -175
  237. package/lib/front_end/models/trace/handlers/FramesHandler.ts +0 -571
  238. package/lib/front_end/models/trace/handlers/GPUHandler.ts +0 -50
  239. package/lib/front_end/models/trace/handlers/ImagePaintingHandler.ts +0 -183
  240. package/lib/front_end/models/trace/handlers/InitiatorsHandler.ts +0 -193
  241. package/lib/front_end/models/trace/handlers/InvalidationsHandler.ts +0 -168
  242. package/lib/front_end/models/trace/handlers/LargestImagePaintHandler.ts +0 -109
  243. package/lib/front_end/models/trace/handlers/LargestTextPaintHandler.ts +0 -35
  244. package/lib/front_end/models/trace/handlers/LayerTreeHandler.ts +0 -123
  245. package/lib/front_end/models/trace/handlers/LayoutShiftsHandler.ts +0 -573
  246. package/lib/front_end/models/trace/handlers/MemoryHandler.ts +0 -31
  247. package/lib/front_end/models/trace/handlers/MetaHandler.ts +0 -525
  248. package/lib/front_end/models/trace/handlers/ModelHandlers.ts +0 -34
  249. package/lib/front_end/models/trace/handlers/NetworkRequestsHandler.ts +0 -672
  250. package/lib/front_end/models/trace/handlers/PageFramesHandler.ts +0 -52
  251. package/lib/front_end/models/trace/handlers/PageLoadMetricsHandler.ts +0 -460
  252. package/lib/front_end/models/trace/handlers/RendererHandler.ts +0 -428
  253. package/lib/front_end/models/trace/handlers/SamplesHandler.ts +0 -271
  254. package/lib/front_end/models/trace/handlers/ScreenshotsHandler.ts +0 -122
  255. package/lib/front_end/models/trace/handlers/ScriptsHandler.ts +0 -336
  256. package/lib/front_end/models/trace/handlers/SelectorStatsHandler.ts +0 -110
  257. package/lib/front_end/models/trace/handlers/Threads.ts +0 -139
  258. package/lib/front_end/models/trace/handlers/UserInteractionsHandler.ts +0 -400
  259. package/lib/front_end/models/trace/handlers/UserTimingsHandler.ts +0 -233
  260. package/lib/front_end/models/trace/handlers/WarningsHandler.ts +0 -162
  261. package/lib/front_end/models/trace/handlers/WorkersHandler.ts +0 -45
  262. package/lib/front_end/models/trace/handlers/handlers.ts +0 -8
  263. package/lib/front_end/models/trace/handlers/helpers.ts +0 -196
  264. package/lib/front_end/models/trace/handlers/types.ts +0 -75
  265. package/lib/front_end/models/trace/helpers/Extensions.ts +0 -54
  266. package/lib/front_end/models/trace/helpers/Network.ts +0 -129
  267. package/lib/front_end/models/trace/helpers/SamplesIntegrator.ts +0 -544
  268. package/lib/front_end/models/trace/helpers/SyntheticEvents.ts +0 -87
  269. package/lib/front_end/models/trace/helpers/Timing.ts +0 -248
  270. package/lib/front_end/models/trace/helpers/Trace.ts +0 -928
  271. package/lib/front_end/models/trace/helpers/TreeHelpers.ts +0 -320
  272. package/lib/front_end/models/trace/helpers/helpers.ts +0 -11
  273. package/lib/front_end/models/trace/insights/CLSCulprits.ts +0 -668
  274. package/lib/front_end/models/trace/insights/Cache.ts +0 -269
  275. package/lib/front_end/models/trace/insights/Common.ts +0 -453
  276. package/lib/front_end/models/trace/insights/DOMSize.ts +0 -223
  277. package/lib/front_end/models/trace/insights/DocumentLatency.ts +0 -319
  278. package/lib/front_end/models/trace/insights/DuplicatedJavaScript.ts +0 -126
  279. package/lib/front_end/models/trace/insights/FontDisplay.ts +0 -119
  280. package/lib/front_end/models/trace/insights/ForcedReflow.ts +0 -220
  281. package/lib/front_end/models/trace/insights/INPBreakdown.ts +0 -171
  282. package/lib/front_end/models/trace/insights/ImageDelivery.ts +0 -348
  283. package/lib/front_end/models/trace/insights/LCPBreakdown.ts +0 -268
  284. package/lib/front_end/models/trace/insights/LCPDiscovery.ts +0 -237
  285. package/lib/front_end/models/trace/insights/LegacyJavaScript.ts +0 -138
  286. package/lib/front_end/models/trace/insights/Models.ts +0 -22
  287. package/lib/front_end/models/trace/insights/ModernHTTP.ts +0 -257
  288. package/lib/front_end/models/trace/insights/NetworkDependencyTree.ts +0 -726
  289. package/lib/front_end/models/trace/insights/RenderBlocking.ts +0 -257
  290. package/lib/front_end/models/trace/insights/SlowCSSSelector.ts +0 -175
  291. package/lib/front_end/models/trace/insights/Statistics.ts +0 -101
  292. package/lib/front_end/models/trace/insights/ThirdParties.ts +0 -130
  293. package/lib/front_end/models/trace/insights/Viewport.ts +0 -138
  294. package/lib/front_end/models/trace/insights/insights.ts +0 -10
  295. package/lib/front_end/models/trace/insights/types.ts +0 -157
  296. package/lib/front_end/models/trace/lantern/core/LanternError.ts +0 -7
  297. package/lib/front_end/models/trace/lantern/core/NetworkAnalyzer.ts +0 -619
  298. package/lib/front_end/models/trace/lantern/core/core.ts +0 -6
  299. package/lib/front_end/models/trace/lantern/graph/BaseNode.ts +0 -345
  300. package/lib/front_end/models/trace/lantern/graph/CPUNode.ts +0 -80
  301. package/lib/front_end/models/trace/lantern/graph/NetworkNode.ts +0 -101
  302. package/lib/front_end/models/trace/lantern/graph/PageDependencyGraph.ts +0 -636
  303. package/lib/front_end/models/trace/lantern/graph/graph.ts +0 -8
  304. package/lib/front_end/models/trace/lantern/lantern.ts +0 -17
  305. package/lib/front_end/models/trace/lantern/metrics/FirstContentfulPaint.ts +0 -187
  306. package/lib/front_end/models/trace/lantern/metrics/Interactive.ts +0 -88
  307. package/lib/front_end/models/trace/lantern/metrics/LargestContentfulPaint.ts +0 -92
  308. package/lib/front_end/models/trace/lantern/metrics/MaxPotentialFID.ts +0 -72
  309. package/lib/front_end/models/trace/lantern/metrics/Metric.ts +0 -126
  310. package/lib/front_end/models/trace/lantern/metrics/SpeedIndex.ts +0 -126
  311. package/lib/front_end/models/trace/lantern/metrics/TBTUtils.ts +0 -82
  312. package/lib/front_end/models/trace/lantern/metrics/TotalBlockingTime.ts +0 -112
  313. package/lib/front_end/models/trace/lantern/metrics/metrics.ts +0 -12
  314. package/lib/front_end/models/trace/lantern/simulation/ConnectionPool.ts +0 -150
  315. package/lib/front_end/models/trace/lantern/simulation/Constants.ts +0 -46
  316. package/lib/front_end/models/trace/lantern/simulation/DNSCache.ts +0 -61
  317. package/lib/front_end/models/trace/lantern/simulation/SimulationTimingMap.ts +0 -196
  318. package/lib/front_end/models/trace/lantern/simulation/Simulator.ts +0 -556
  319. package/lib/front_end/models/trace/lantern/simulation/TCPConnection.ts +0 -192
  320. package/lib/front_end/models/trace/lantern/simulation/simulation.ts +0 -10
  321. package/lib/front_end/models/trace/lantern/types/Lantern.ts +0 -220
  322. package/lib/front_end/models/trace/lantern/types/types.ts +0 -5
  323. package/lib/front_end/models/trace/trace.ts +0 -33
  324. package/lib/front_end/models/trace/types/Configuration.ts +0 -110
  325. package/lib/front_end/models/trace/types/Extensions.ts +0 -136
  326. package/lib/front_end/models/trace/types/File.ts +0 -281
  327. package/lib/front_end/models/trace/types/Overlays.ts +0 -138
  328. package/lib/front_end/models/trace/types/Timing.ts +0 -30
  329. package/lib/front_end/models/trace/types/TraceEvents.ts +0 -3277
  330. package/lib/front_end/models/trace/types/types.ts +0 -10
  331. package/lib/front_end/models/trace_source_maps_resolver/SourceMapsResolver.ts +0 -240
  332. package/lib/front_end/models/trace_source_maps_resolver/trace_source_maps_resolver.ts +0 -5
  333. package/lib/front_end/models/workspace/FileManager.ts +0 -97
  334. package/lib/front_end/models/workspace/IgnoreListManager.ts +0 -628
  335. package/lib/front_end/models/workspace/SearchConfig.ts +0 -149
  336. package/lib/front_end/models/workspace/UISourceCode.ts +0 -698
  337. package/lib/front_end/models/workspace/WorkspaceImpl.ts +0 -339
  338. package/lib/front_end/models/workspace/workspace.ts +0 -17
  339. package/lib/front_end/panels/timeline/TimelineUIUtils.ts +0 -1029
  340. package/lib/front_end/panels/timeline/extensions/ExtensionUI.ts +0 -49
  341. package/lib/front_end/panels/timeline/extensions/extensions.ts +0 -9
  342. package/lib/front_end/third_party/codemirror.next/LICENSE +0 -21
  343. package/lib/front_end/third_party/codemirror.next/README.chromium +0 -30
  344. package/lib/front_end/third_party/codemirror.next/bundle-tsconfig.json +0 -24
  345. package/lib/front_end/third_party/codemirror.next/bundle.ts +0 -135
  346. package/lib/front_end/third_party/codemirror.next/chunk/angular.js +0 -2
  347. package/lib/front_end/third_party/codemirror.next/chunk/angular.js.map +0 -1
  348. package/lib/front_end/third_party/codemirror.next/chunk/codemirror.js +0 -2
  349. package/lib/front_end/third_party/codemirror.next/chunk/codemirror.js.map +0 -1
  350. package/lib/front_end/third_party/codemirror.next/chunk/cpp.js +0 -2
  351. package/lib/front_end/third_party/codemirror.next/chunk/cpp.js.map +0 -1
  352. package/lib/front_end/third_party/codemirror.next/chunk/css.js +0 -2
  353. package/lib/front_end/third_party/codemirror.next/chunk/html.js +0 -4
  354. package/lib/front_end/third_party/codemirror.next/chunk/java.js +0 -2
  355. package/lib/front_end/third_party/codemirror.next/chunk/java.js.map +0 -1
  356. package/lib/front_end/third_party/codemirror.next/chunk/javascript.js +0 -2
  357. package/lib/front_end/third_party/codemirror.next/chunk/legacy.js +0 -2
  358. package/lib/front_end/third_party/codemirror.next/chunk/legacy.js.map +0 -1
  359. package/lib/front_end/third_party/codemirror.next/chunk/less.js +0 -2
  360. package/lib/front_end/third_party/codemirror.next/chunk/less.js.map +0 -1
  361. package/lib/front_end/third_party/codemirror.next/chunk/markdown.js +0 -2
  362. package/lib/front_end/third_party/codemirror.next/chunk/markdown.js.map +0 -1
  363. package/lib/front_end/third_party/codemirror.next/chunk/php.js +0 -2
  364. package/lib/front_end/third_party/codemirror.next/chunk/php.js.map +0 -1
  365. package/lib/front_end/third_party/codemirror.next/chunk/python.js +0 -2
  366. package/lib/front_end/third_party/codemirror.next/chunk/python.js.map +0 -1
  367. package/lib/front_end/third_party/codemirror.next/chunk/sass.js +0 -2
  368. package/lib/front_end/third_party/codemirror.next/chunk/sass.js.map +0 -1
  369. package/lib/front_end/third_party/codemirror.next/chunk/svelte.js +0 -2
  370. package/lib/front_end/third_party/codemirror.next/chunk/svelte.js.map +0 -1
  371. package/lib/front_end/third_party/codemirror.next/chunk/vue.js +0 -2
  372. package/lib/front_end/third_party/codemirror.next/chunk/vue.js.map +0 -1
  373. package/lib/front_end/third_party/codemirror.next/chunk/wast.js +0 -2
  374. package/lib/front_end/third_party/codemirror.next/chunk/wast.js.map +0 -1
  375. package/lib/front_end/third_party/codemirror.next/chunk/xml.js +0 -2
  376. package/lib/front_end/third_party/codemirror.next/chunk/xml.js.map +0 -1
  377. package/lib/front_end/third_party/codemirror.next/codemirror.next.d.ts +0 -8057
  378. package/lib/front_end/third_party/codemirror.next/codemirror.next.js +0 -2
  379. package/lib/front_end/third_party/codemirror.next/codemirror.next.js.map +0 -1
  380. package/lib/front_end/third_party/codemirror.next/package.json +0 -43
  381. package/lib/front_end/third_party/codemirror.next/rebuild.sh +0 -6
  382. package/lib/front_end/third_party/codemirror.next/rollup.config.mjs +0 -49
  383. package/lib/front_end/third_party/i18n/LICENSE +0 -202
  384. package/lib/front_end/third_party/i18n/README.chromium +0 -15
  385. package/lib/front_end/third_party/i18n/i18n-impl.ts +0 -61
  386. package/lib/front_end/third_party/i18n/i18n.ts +0 -11
  387. package/lib/front_end/third_party/i18n/localized-string-set.ts +0 -129
  388. package/lib/front_end/third_party/intl-messageformat/LICENSE +0 -33
  389. package/lib/front_end/third_party/intl-messageformat/README.chromium +0 -24
  390. package/lib/front_end/third_party/intl-messageformat/intl-messageformat-tsconfig.json +0 -16
  391. package/lib/front_end/third_party/intl-messageformat/intl-messageformat.ts +0 -6
  392. package/lib/front_end/third_party/intl-messageformat/package/LICENSE.md +0 -33
  393. package/lib/front_end/third_party/intl-messageformat/package/README.md +0 -3
  394. package/lib/front_end/third_party/intl-messageformat/package/index.d.ts +0 -6
  395. package/lib/front_end/third_party/intl-messageformat/package/index.d.ts.map +0 -1
  396. package/lib/front_end/third_party/intl-messageformat/package/index.js +0 -13
  397. package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.esm.d.ts +0 -5
  398. package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.esm.js +0 -1710
  399. package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.iife.js +0 -1815
  400. package/lib/front_end/third_party/intl-messageformat/package/lib/index.d.ts +0 -6
  401. package/lib/front_end/third_party/intl-messageformat/package/lib/index.d.ts.map +0 -1
  402. package/lib/front_end/third_party/intl-messageformat/package/lib/index.js +0 -10
  403. package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.d.ts +0 -34
  404. package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.d.ts.map +0 -1
  405. package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.js +0 -229
  406. package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.d.ts +0 -28
  407. package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.d.ts.map +0 -1
  408. package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.js +0 -48
  409. package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.d.ts +0 -34
  410. package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.d.ts.map +0 -1
  411. package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.js +0 -179
  412. package/lib/front_end/third_party/intl-messageformat/package/package.json +0 -42
  413. package/lib/front_end/third_party/intl-messageformat/package/src/core.d.ts +0 -34
  414. package/lib/front_end/third_party/intl-messageformat/package/src/core.d.ts.map +0 -1
  415. package/lib/front_end/third_party/intl-messageformat/package/src/core.js +0 -230
  416. package/lib/front_end/third_party/intl-messageformat/package/src/error.d.ts +0 -28
  417. package/lib/front_end/third_party/intl-messageformat/package/src/error.d.ts.map +0 -1
  418. package/lib/front_end/third_party/intl-messageformat/package/src/error.js +0 -51
  419. package/lib/front_end/third_party/intl-messageformat/package/src/formatters.d.ts +0 -34
  420. package/lib/front_end/third_party/intl-messageformat/package/src/formatters.d.ts.map +0 -1
  421. package/lib/front_end/third_party/intl-messageformat/package/src/formatters.js +0 -182
  422. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/error.d.ts +0 -79
  423. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/index.d.ts +0 -15
  424. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/parser.d.ts +0 -153
  425. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/types.d.ts +0 -139
  426. package/lib/front_end/third_party/legacy-javascript/LICENSE +0 -202
  427. package/lib/front_end/third_party/legacy-javascript/README.chromium +0 -13
  428. package/lib/front_end/third_party/legacy-javascript/legacy-javascript-tsconfig.json +0 -8
  429. package/lib/front_end/third_party/legacy-javascript/legacy-javascript.ts +0 -3
  430. package/lib/front_end/third_party/legacy-javascript/lib/legacy-javascript.d.ts +0 -18
  431. package/lib/front_end/third_party/legacy-javascript/lib/legacy-javascript.js +0 -943
  432. package/lib/front_end/third_party/legacy-javascript/package.json +0 -8
  433. package/lib/front_end/third_party/legacy-javascript/rebuild.sh +0 -9
  434. package/lib/front_end/third_party/source-map-scopes-codec/LICENSE +0 -26
  435. package/lib/front_end/third_party/source-map-scopes-codec/README.chromium +0 -31
  436. package/lib/front_end/third_party/source-map-scopes-codec/package/CONTRIBUTING.md +0 -33
  437. package/lib/front_end/third_party/source-map-scopes-codec/package/LICENSE +0 -26
  438. package/lib/front_end/third_party/source-map-scopes-codec/package/README.md +0 -64
  439. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/builder.d.ts +0 -62
  440. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/builder.d.ts.map +0 -1
  441. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/safe_builder.d.ts +0 -37
  442. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/safe_builder.d.ts.map +0 -1
  443. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/decode/decode.d.ts +0 -29
  444. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/decode/decode.d.ts.map +0 -1
  445. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/encode/encode.d.ts +0 -8
  446. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/encode/encode.d.ts.map +0 -1
  447. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/mod.d.ts +0 -6
  448. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/mod.d.ts.map +0 -1
  449. package/lib/front_end/third_party/source-map-scopes-codec/package/deno.json +0 -21
  450. package/lib/front_end/third_party/source-map-scopes-codec/package/package.json +0 -14
  451. package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/builder.js +0 -196
  452. package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/builder.js.map +0 -1
  453. package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/builder.ts +0 -262
  454. package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/safe_builder.js +0 -235
  455. package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/safe_builder.js.map +0 -1
  456. package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/safe_builder.ts +0 -359
  457. package/lib/front_end/third_party/source-map-scopes-codec/package/src/codec.js +0 -39
  458. package/lib/front_end/third_party/source-map-scopes-codec/package/src/codec.js.map +0 -1
  459. package/lib/front_end/third_party/source-map-scopes-codec/package/src/codec.ts +0 -53
  460. package/lib/front_end/third_party/source-map-scopes-codec/package/src/decode/decode.js +0 -438
  461. package/lib/front_end/third_party/source-map-scopes-codec/package/src/decode/decode.js.map +0 -1
  462. package/lib/front_end/third_party/source-map-scopes-codec/package/src/decode/decode.ts +0 -539
  463. package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encode.js +0 -23
  464. package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encode.js.map +0 -1
  465. package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encode.ts +0 -35
  466. package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encoder.js +0 -257
  467. package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encoder.js.map +0 -1
  468. package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encoder.ts +0 -348
  469. package/lib/front_end/third_party/source-map-scopes-codec/package/src/mod.js +0 -8
  470. package/lib/front_end/third_party/source-map-scopes-codec/package/src/mod.js.map +0 -1
  471. package/lib/front_end/third_party/source-map-scopes-codec/package/src/mod.ts +0 -20
  472. package/lib/front_end/third_party/source-map-scopes-codec/package/src/scopes-tsconfig.json +0 -8
  473. package/lib/front_end/third_party/source-map-scopes-codec/package/src/scopes.d.ts +0 -184
  474. package/lib/front_end/third_party/source-map-scopes-codec/package/src/util.js +0 -9
  475. package/lib/front_end/third_party/source-map-scopes-codec/package/src/util.js.map +0 -1
  476. package/lib/front_end/third_party/source-map-scopes-codec/package/src/util.ts +0 -12
  477. package/lib/front_end/third_party/source-map-scopes-codec/package/src/vlq.js +0 -82
  478. package/lib/front_end/third_party/source-map-scopes-codec/package/src/vlq.js.map +0 -1
  479. package/lib/front_end/third_party/source-map-scopes-codec/package/src/vlq.ts +0 -99
  480. package/lib/front_end/third_party/source-map-scopes-codec/source-map-scopes-codec.ts +0 -5
  481. package/lib/front_end/third_party/third-party-web/LICENSE +0 -20
  482. package/lib/front_end/third_party/third-party-web/README.chromium +0 -13
  483. package/lib/front_end/third_party/third-party-web/lib/nostats-subset.d.ts +0 -2
  484. package/lib/front_end/third_party/third-party-web/lib/nostats-subset.js +0 -149
  485. package/lib/front_end/third_party/third-party-web/package/LICENSE +0 -20
  486. package/lib/front_end/third_party/third-party-web/package/README.md +0 -929
  487. package/lib/front_end/third_party/third-party-web/package/dist/entities-httparchive-nostats.json +0 -1
  488. package/lib/front_end/third_party/third-party-web/package/dist/entities-httparchive.json +0 -1
  489. package/lib/front_end/third_party/third-party-web/package/dist/entities-nostats.json +0 -1
  490. package/lib/front_end/third_party/third-party-web/package/dist/entities.json +0 -1
  491. package/lib/front_end/third_party/third-party-web/package/facades.md +0 -46
  492. package/lib/front_end/third_party/third-party-web/package/httparchive-nostats-subset.d.ts +0 -1
  493. package/lib/front_end/third_party/third-party-web/package/httparchive-nostats-subset.js +0 -1
  494. package/lib/front_end/third_party/third-party-web/package/httparchive-subset.d.ts +0 -1
  495. package/lib/front_end/third_party/third-party-web/package/httparchive-subset.js +0 -1
  496. package/lib/front_end/third_party/third-party-web/package/lib/__snapshots__/index.test.js.snap +0 -1006
  497. package/lib/front_end/third_party/third-party-web/package/lib/create-entity-finder-api.js +0 -139
  498. package/lib/front_end/third_party/third-party-web/package/lib/create-entity-finder-api.test.js +0 -44
  499. package/lib/front_end/third_party/third-party-web/package/lib/entities.test.js +0 -27
  500. package/lib/front_end/third_party/third-party-web/package/lib/index.d.ts +0 -34
  501. package/lib/front_end/third_party/third-party-web/package/lib/index.js +0 -3
  502. package/lib/front_end/third_party/third-party-web/package/lib/index.test.js +0 -246
  503. package/lib/front_end/third_party/third-party-web/package/lib/markdown/faqs.partial.md +0 -36
  504. package/lib/front_end/third_party/third-party-web/package/lib/markdown/goals.partial.md +0 -9
  505. package/lib/front_end/third_party/third-party-web/package/lib/markdown/methodology.partial.md +0 -5
  506. package/lib/front_end/third_party/third-party-web/package/lib/markdown/template.md +0 -151
  507. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-02-01.md +0 -1
  508. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-03-01.md +0 -1
  509. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-05-06.md +0 -1
  510. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-05-13.md +0 -14
  511. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2021-01-01.md +0 -1
  512. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2024-07-01.md +0 -3
  513. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive-nostats.d.ts +0 -1
  514. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive-nostats.js +0 -3
  515. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive.d.ts +0 -1
  516. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive.js +0 -3
  517. package/lib/front_end/third_party/third-party-web/package/lib/subsets/nostats.d.ts +0 -1
  518. package/lib/front_end/third_party/third-party-web/package/lib/subsets/nostats.js +0 -3
  519. package/lib/front_end/third_party/third-party-web/package/nostats-subset.d.ts +0 -1
  520. package/lib/front_end/third_party/third-party-web/package/nostats-subset.js +0 -1
  521. package/lib/front_end/third_party/third-party-web/package/package.json +0 -46
  522. package/lib/front_end/third_party/third-party-web/package.json +0 -8
  523. package/lib/front_end/third_party/third-party-web/rebuild.sh +0 -13
  524. package/lib/front_end/third_party/third-party-web/third-party-web-tsconfig.json +0 -8
  525. package/lib/front_end/third_party/third-party-web/third-party-web.ts +0 -3
  526. package/lib/front_end/ui/legacy/theme_support/ThemeSupport.ts +0 -222
  527. package/lib/front_end/ui/legacy/theme_support/theme_support.ts +0 -5
  528. package/patches/chrome-devtools-frontend+1.0.1533544.patch +0 -1716
@@ -1,1197 +0,0 @@
1
- // Copyright 2020 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 type {Chrome} from '../../../extension-api/ExtensionAPI.js';
6
- import * as Common from '../../core/common/common.js';
7
- import * as i18n from '../../core/i18n/i18n.js';
8
- import type * as Platform from '../../core/platform/platform.js';
9
- import {assertNotNullOrUndefined} from '../../core/platform/platform.js';
10
- import * as SDK from '../../core/sdk/sdk.js';
11
- import * as Protocol from '../../generated/protocol.js';
12
- import * as StackTrace from '../stack_trace/stack_trace.js';
13
- import type * as StackTraceImpl from '../stack_trace/stack_trace_impl.js';
14
- import * as TextUtils from '../text_utils/text_utils.js';
15
- import * as Workspace from '../workspace/workspace.js';
16
-
17
- import {ContentProviderBasedProject} from './ContentProviderBasedProject.js';
18
- import type {DebuggerWorkspaceBinding} from './DebuggerWorkspaceBinding.js';
19
- import {NetworkProject} from './NetworkProject.js';
20
-
21
- const UIStrings = {
22
- /**
23
- * @description Error message that is displayed in the Console when language #plugins report errors
24
- * @example {File not found} PH1
25
- */
26
- errorInDebuggerLanguagePlugin: 'Error in debugger language plugin: {PH1}',
27
- /**
28
- * @description Status message that is shown in the Console when debugging information is being
29
- *loaded. The 2nd and 3rd placeholders are URLs.
30
- * @example {C/C++ DevTools Support (DWARF)} PH1
31
- * @example {http://web.dev/file.wasm} PH2
32
- * @example {http://web.dev/file.wasm.debug.wasm} PH3
33
- */
34
- loadingDebugSymbolsForVia: '[{PH1}] Loading debug symbols for {PH2} (via {PH3})…',
35
- /**
36
- * @description Status message that is shown in the Console when debugging information is being loaded
37
- * @example {C/C++ DevTools Support (DWARF)} PH1
38
- * @example {http://web.dev/file.wasm} PH2
39
- */
40
- loadingDebugSymbolsFor: '[{PH1}] Loading debug symbols for {PH2}…',
41
- /**
42
- * @description Warning message that is displayed in the Console when debugging information was loaded, but no source files were found
43
- * @example {C/C++ DevTools Support (DWARF)} PH1
44
- * @example {http://web.dev/file.wasm} PH2
45
- */
46
- loadedDebugSymbolsForButDidnt: '[{PH1}] Loaded debug symbols for {PH2}, but didn\'t find any source files',
47
- /**
48
- * @description Status message that is shown in the Console when debugging information is successfully loaded
49
- * @example {C/C++ DevTools Support (DWARF)} PH1
50
- * @example {http://web.dev/file.wasm} PH2
51
- * @example {42} PH3
52
- */
53
- loadedDebugSymbolsForFound: '[{PH1}] Loaded debug symbols for {PH2}, found {PH3} source file(s)',
54
- /**
55
- * @description Error message that is displayed in the Console when debugging information cannot be loaded
56
- * @example {C/C++ DevTools Support (DWARF)} PH1
57
- * @example {http://web.dev/file.wasm} PH2
58
- * @example {File not found} PH3
59
- */
60
- failedToLoadDebugSymbolsFor: '[{PH1}] Failed to load debug symbols for {PH2} ({PH3})',
61
- /**
62
- * @description Error message that is displayed in UI debugging information cannot be found for a call frame
63
- * @example {main} PH1
64
- */
65
- failedToLoadDebugSymbolsForFunction: 'No debug information for function "{PH1}"',
66
- /**
67
- * @description Error message that is displayed in UI when a file needed for debugging information for a call frame is missing
68
- * @example {mainp.debug.wasm.dwp} PH1
69
- */
70
- debugSymbolsIncomplete: 'The debug information for function {PH1} is incomplete',
71
- } as const;
72
- const str_ = i18n.i18n.registerUIStrings('models/bindings/DebuggerLanguagePlugins.ts', UIStrings);
73
- const i18nString = i18n.i18n.getLocalizedString.bind(undefined, str_);
74
-
75
- /**
76
- * Generates the raw module ID for a script, which is used
77
- * to uniquely identify the debugging data for a script on
78
- * the responsible language #plugin.
79
- *
80
- * @param script the unique raw module ID for the script.
81
- */
82
- function rawModuleIdForScript(script: SDK.Script.Script): string {
83
- return `${script.sourceURL}@${script.hash}`;
84
- }
85
-
86
- function getRawLocation(callFrame: SDK.DebuggerModel.CallFrame): Chrome.DevTools.RawLocation {
87
- const {script} = callFrame;
88
- return {
89
- rawModuleId: rawModuleIdForScript(script),
90
- codeOffset: callFrame.location().columnNumber - (script.codeOffset() || 0),
91
- inlineFrameIndex: callFrame.inlineFrameIndex,
92
- };
93
- }
94
-
95
- class FormattingError extends Error {
96
- exception: SDK.RemoteObject.RemoteObject;
97
- exceptionDetails: Protocol.Runtime.ExceptionDetails;
98
- constructor(exception: SDK.RemoteObject.RemoteObject, exceptionDetails: Protocol.Runtime.ExceptionDetails) {
99
- const {description} = exceptionDetails.exception || {};
100
- super(description || exceptionDetails.text);
101
- this.exception = exception;
102
- this.exceptionDetails = exceptionDetails;
103
- }
104
-
105
- static makeLocal(callFrame: SDK.DebuggerModel.CallFrame, message: string): FormattingError {
106
- const exception: Protocol.Runtime.RemoteObject = {
107
- type: Protocol.Runtime.RemoteObjectType.Object,
108
- subtype: Protocol.Runtime.RemoteObjectSubtype.Error,
109
- description: message,
110
- };
111
- const exceptionDetails: Protocol.Runtime
112
- .ExceptionDetails = {text: 'Uncaught', exceptionId: -1, columnNumber: 0, lineNumber: 0, exception};
113
- const errorObject = callFrame.debuggerModel.runtimeModel().createRemoteObject(exception);
114
- return new FormattingError(errorObject, exceptionDetails);
115
- }
116
- }
117
-
118
- class NamespaceObject extends SDK.RemoteObject.LocalJSONObject {
119
- override get description(): string {
120
- return this.type;
121
- }
122
-
123
- override get type(): string {
124
- return 'namespace';
125
- }
126
- }
127
-
128
- async function getRemoteObject(callFrame: SDK.DebuggerModel.CallFrame, object: Chrome.DevTools.ForeignObject):
129
- Promise<Protocol.Runtime.RemoteObject> {
130
- if (!/^(local|global|operand)$/.test(object.valueClass)) {
131
- return {type: Protocol.Runtime.RemoteObjectType.Undefined};
132
- }
133
- const index = Number(object.index);
134
- const expression = `${object.valueClass}s[${index}]`;
135
- const response = await callFrame.debuggerModel.agent.invoke_evaluateOnCallFrame({
136
- callFrameId: callFrame.id,
137
- expression,
138
- silent: true,
139
- generatePreview: true,
140
- throwOnSideEffect: true,
141
- });
142
- if (response.getError() || response.exceptionDetails) {
143
- return {type: Protocol.Runtime.RemoteObjectType.Undefined};
144
- }
145
- return response.result;
146
- }
147
-
148
- async function wrapRemoteObject(
149
- callFrame: SDK.DebuggerModel.CallFrame, object: Chrome.DevTools.RemoteObject|Chrome.DevTools.ForeignObject,
150
- plugin: DebuggerLanguagePlugin): Promise<SDK.RemoteObject.RemoteObject> {
151
- if (object.type === 'reftype') {
152
- const obj = await getRemoteObject(callFrame, object);
153
- return callFrame.debuggerModel.runtimeModel().createRemoteObject(obj);
154
- }
155
- return new ExtensionRemoteObject(callFrame, object, plugin);
156
- }
157
-
158
- class SourceScopeRemoteObject extends SDK.RemoteObject.RemoteObjectImpl {
159
- variables: Chrome.DevTools.Variable[];
160
- #callFrame: SDK.DebuggerModel.CallFrame;
161
- #plugin: DebuggerLanguagePlugin;
162
- stopId: StopId;
163
-
164
- constructor(callFrame: SDK.DebuggerModel.CallFrame, stopId: StopId, plugin: DebuggerLanguagePlugin) {
165
- super(callFrame.debuggerModel.runtimeModel(), undefined, 'object', undefined, null);
166
- this.variables = [];
167
- this.#callFrame = callFrame;
168
- this.#plugin = plugin;
169
- this.stopId = stopId;
170
- }
171
-
172
- override async doGetProperties(_ownProperties: boolean, accessorPropertiesOnly: boolean, _generatePreview: boolean):
173
- Promise<SDK.RemoteObject.GetPropertiesResult> {
174
- if (accessorPropertiesOnly) {
175
- return {properties: [], internalProperties: []} as SDK.RemoteObject.GetPropertiesResult;
176
- }
177
-
178
- const properties = [];
179
- const namespaces: Record<string, SDK.RemoteObject.RemoteObject> = {};
180
-
181
- function makeProperty(name: string, obj: SDK.RemoteObject.RemoteObject): SDK.RemoteObject.RemoteObjectProperty {
182
- return new SDK.RemoteObject.RemoteObjectProperty(
183
- name, obj,
184
- /* enumerable=*/ false, /* writable=*/ false, /* isOwn=*/ true, /* wasThrown=*/ false);
185
- }
186
-
187
- for (const variable of this.variables) {
188
- let sourceVar: SDK.RemoteObject.RemoteObject|undefined;
189
- try {
190
- const evalResult = await this.#plugin.evaluate(variable.name, getRawLocation(this.#callFrame), this.stopId);
191
- sourceVar = evalResult ? await wrapRemoteObject(this.#callFrame, evalResult, this.#plugin) :
192
- new SDK.RemoteObject.LocalJSONObject(undefined);
193
- } catch (e) {
194
- console.warn(e);
195
- sourceVar = new SDK.RemoteObject.LocalJSONObject(undefined);
196
- }
197
- if (variable.nestedName && variable.nestedName.length > 1) {
198
- let parent: Record<string, SDK.RemoteObject.RemoteObject> = namespaces;
199
- for (let index = 0; index < variable.nestedName.length - 1; index++) {
200
- const nestedName = variable.nestedName[index];
201
- let child: NamespaceObject|SDK.RemoteObject.RemoteObject = parent[nestedName];
202
- if (!child) {
203
- child = new NamespaceObject({});
204
- parent[nestedName] = child;
205
- }
206
- parent = child.value;
207
- }
208
- const name = variable.nestedName[variable.nestedName.length - 1];
209
- parent[name] = sourceVar;
210
- } else {
211
- properties.push(makeProperty(variable.name, sourceVar));
212
- }
213
- }
214
-
215
- for (const namespace in namespaces) {
216
- properties.push(makeProperty(namespace, (namespaces[namespace])));
217
- }
218
-
219
- return {properties, internalProperties: []};
220
- }
221
- }
222
-
223
- export class SourceScope implements SDK.DebuggerModel.ScopeChainEntry {
224
- readonly #callFrame: SDK.DebuggerModel.CallFrame;
225
- readonly #type: string;
226
- readonly #typeName: string;
227
- readonly #icon: string|undefined;
228
- readonly #object: SourceScopeRemoteObject;
229
- constructor(
230
- callFrame: SDK.DebuggerModel.CallFrame, stopId: StopId, type: string, typeName: string, icon: string|undefined,
231
- plugin: DebuggerLanguagePlugin) {
232
- if (icon && new URL(icon).protocol !== 'data:') {
233
- throw new Error('The icon must be a data:-URL');
234
- }
235
- this.#callFrame = callFrame;
236
- this.#type = type;
237
- this.#typeName = typeName;
238
- this.#icon = icon;
239
- this.#object = new SourceScopeRemoteObject(callFrame, stopId, plugin);
240
- }
241
-
242
- async getVariableValue(name: string): Promise<SDK.RemoteObject.RemoteObject|null> {
243
- for (let v = 0; v < this.#object.variables.length; ++v) {
244
- if (this.#object.variables[v].name !== name) {
245
- continue;
246
- }
247
- const properties = await this.#object.getAllProperties(false, false);
248
- if (!properties.properties) {
249
- continue;
250
- }
251
- const {value} = properties.properties[v];
252
- if (value) {
253
- return value;
254
- }
255
- }
256
- return null;
257
- }
258
-
259
- callFrame(): SDK.DebuggerModel.CallFrame {
260
- return this.#callFrame;
261
- }
262
-
263
- type(): string {
264
- return this.#type;
265
- }
266
-
267
- typeName(): string {
268
- return this.#typeName;
269
- }
270
-
271
- name(): string|undefined {
272
- return undefined;
273
- }
274
-
275
- range(): null {
276
- return null;
277
- }
278
-
279
- object(): SourceScopeRemoteObject {
280
- return this.#object;
281
- }
282
-
283
- description(): string {
284
- return '';
285
- }
286
-
287
- icon(): string|undefined {
288
- return this.#icon;
289
- }
290
-
291
- extraProperties(): SDK.RemoteObject.RemoteObjectProperty[] {
292
- return [];
293
- }
294
- }
295
-
296
- export class ExtensionRemoteObject extends SDK.RemoteObject.RemoteObject {
297
- private readonly extensionObject: Chrome.DevTools.RemoteObject;
298
- private readonly plugin: DebuggerLanguagePlugin;
299
- readonly callFrame: SDK.DebuggerModel.CallFrame;
300
- constructor(
301
- callFrame: SDK.DebuggerModel.CallFrame, extensionObject: Chrome.DevTools.RemoteObject,
302
- plugin: DebuggerLanguagePlugin) {
303
- super();
304
- this.extensionObject = extensionObject;
305
- this.plugin = plugin;
306
- this.callFrame = callFrame;
307
- }
308
-
309
- get linearMemoryAddress(): number|undefined {
310
- return this.extensionObject.linearMemoryAddress;
311
- }
312
-
313
- get linearMemorySize(): number|undefined {
314
- return this.extensionObject.linearMemorySize;
315
- }
316
-
317
- override get objectId(): Protocol.Runtime.RemoteObjectId|undefined {
318
- return this.extensionObject.objectId as Protocol.Runtime.RemoteObjectId;
319
- }
320
-
321
- override get type(): string {
322
- if (this.extensionObject.type === 'array' || this.extensionObject.type === 'null') {
323
- return 'object';
324
- }
325
- return this.extensionObject.type;
326
- }
327
-
328
- override get subtype(): string|undefined {
329
- if (this.extensionObject.type === 'array' || this.extensionObject.type === 'null') {
330
- return this.extensionObject.type;
331
- }
332
- return undefined;
333
- }
334
-
335
- override get value(): unknown {
336
- return this.extensionObject.value;
337
- }
338
-
339
- override unserializableValue(): string|undefined {
340
- return undefined;
341
- }
342
-
343
- override get description(): string|undefined {
344
- return this.extensionObject.description;
345
- }
346
-
347
- override set description(_description: string|undefined) {
348
- }
349
-
350
- override get hasChildren(): boolean {
351
- return this.extensionObject.hasChildren;
352
- }
353
-
354
- override get preview(): Protocol.Runtime.ObjectPreview|undefined {
355
- return undefined;
356
- }
357
-
358
- override get className(): string|null {
359
- return this.extensionObject.className ?? null;
360
- }
361
-
362
- override arrayLength(): number {
363
- return 0;
364
- }
365
-
366
- override arrayBufferByteLength(): number {
367
- return 0;
368
- }
369
-
370
- override getOwnProperties(_generatePreview: boolean, _nonIndexedPropertiesOnly?: boolean):
371
- Promise<SDK.RemoteObject.GetPropertiesResult> {
372
- return this.getAllProperties(false, _generatePreview, _nonIndexedPropertiesOnly);
373
- }
374
-
375
- override async getAllProperties(
376
- _accessorPropertiesOnly: boolean, _generatePreview: boolean,
377
- _nonIndexedPropertiesOnly?: boolean): Promise<SDK.RemoteObject.GetPropertiesResult> {
378
- const {objectId} = this.extensionObject;
379
- if (objectId) {
380
- assertNotNullOrUndefined(this.plugin.getProperties);
381
- const extensionObjectProperties = await this.plugin.getProperties(objectId);
382
- const properties = await Promise.all(extensionObjectProperties.map(
383
- async p => new SDK.RemoteObject.RemoteObjectProperty(
384
- p.name, await wrapRemoteObject(this.callFrame, p.value, this.plugin))));
385
- return {properties, internalProperties: null};
386
- }
387
-
388
- return {properties: null, internalProperties: null};
389
- }
390
-
391
- override release(): void {
392
- const {objectId} = this.extensionObject;
393
- if (objectId) {
394
- assertNotNullOrUndefined(this.plugin.releaseObject);
395
- void this.plugin.releaseObject(objectId);
396
- }
397
- }
398
-
399
- override debuggerModel(): SDK.DebuggerModel.DebuggerModel {
400
- return this.callFrame.debuggerModel;
401
- }
402
-
403
- override runtimeModel(): SDK.RuntimeModel.RuntimeModel {
404
- return this.callFrame.debuggerModel.runtimeModel();
405
- }
406
-
407
- override isLinearMemoryInspectable(): boolean {
408
- return this.extensionObject.linearMemoryAddress !== undefined;
409
- }
410
- }
411
-
412
- export type StopId = bigint;
413
- export class DebuggerLanguagePluginManager implements
414
- SDK.TargetManager.SDKModelObserver<SDK.DebuggerModel.DebuggerModel> {
415
- readonly #workspace: Workspace.Workspace.WorkspaceImpl;
416
- readonly #debuggerWorkspaceBinding: DebuggerWorkspaceBinding;
417
- #plugins: DebuggerLanguagePlugin[];
418
- readonly #debuggerModelToData: Map<SDK.DebuggerModel.DebuggerModel, ModelData>;
419
- readonly #rawModuleHandles: Map<string, {
420
- rawModuleId: string,
421
- plugin: DebuggerLanguagePlugin,
422
- scripts: SDK.Script.Script[],
423
- addRawModulePromise:
424
- Promise<Platform.DevToolsPath.UrlString[]|{missingSymbolFiles: SDK.DebuggerModel.MissingDebugFiles[]}>,
425
- }>;
426
- private readonly callFrameByStopId = new Map<StopId, SDK.DebuggerModel.CallFrame>();
427
- private readonly stopIdByCallFrame = new Map<SDK.DebuggerModel.CallFrame, StopId>();
428
- private nextStopId: StopId = 0n;
429
-
430
- constructor(
431
- targetManager: SDK.TargetManager.TargetManager, workspace: Workspace.Workspace.WorkspaceImpl,
432
- debuggerWorkspaceBinding: DebuggerWorkspaceBinding) {
433
- this.#workspace = workspace;
434
- this.#debuggerWorkspaceBinding = debuggerWorkspaceBinding;
435
-
436
- this.#plugins = [];
437
-
438
- this.#debuggerModelToData = new Map();
439
- targetManager.observeModels(SDK.DebuggerModel.DebuggerModel, this);
440
-
441
- this.#rawModuleHandles = new Map();
442
- }
443
-
444
- private async evaluateOnCallFrame(
445
- callFrame: SDK.DebuggerModel.CallFrame, options: SDK.RuntimeModel.EvaluationOptions): Promise<{
446
- object: SDK.RemoteObject.RemoteObject,
447
- exceptionDetails: Protocol.Runtime.ExceptionDetails|undefined,
448
- }|{
449
- error: string,
450
- }|null> {
451
- const {script} = callFrame;
452
- const {expression, returnByValue, throwOnSideEffect} = options;
453
- const {plugin} = await this.rawModuleIdAndPluginForScript(script);
454
- if (!plugin) {
455
- return null;
456
- }
457
- const location = getRawLocation(callFrame);
458
- const sourceLocations = await plugin.rawLocationToSourceLocation(location);
459
- if (sourceLocations.length === 0) {
460
- return null;
461
- }
462
-
463
- if (returnByValue) {
464
- return {error: 'Cannot return by value'};
465
- }
466
- if (throwOnSideEffect) {
467
- return {error: 'Cannot guarantee side-effect freedom'};
468
- }
469
-
470
- try {
471
- const object = await plugin.evaluate(expression, location, this.stopIdForCallFrame(callFrame));
472
- if (object) {
473
- return {object: await wrapRemoteObject(callFrame, object, plugin), exceptionDetails: undefined};
474
- }
475
- return {object: new SDK.RemoteObject.LocalJSONObject(undefined), exceptionDetails: undefined};
476
- } catch (error) {
477
- if (error instanceof FormattingError) {
478
- const {exception: object, exceptionDetails} = error;
479
- return {object, exceptionDetails};
480
- }
481
- const {exception: object, exceptionDetails} = FormattingError.makeLocal(callFrame, error.message);
482
- return {object, exceptionDetails};
483
- }
484
- }
485
-
486
- stopIdForCallFrame(callFrame: SDK.DebuggerModel.CallFrame): StopId {
487
- let stopId = this.stopIdByCallFrame.get(callFrame);
488
- if (stopId !== undefined) {
489
- return stopId;
490
- }
491
-
492
- stopId = this.nextStopId++;
493
- this.stopIdByCallFrame.set(callFrame, stopId);
494
- this.callFrameByStopId.set(stopId, callFrame);
495
- return stopId;
496
- }
497
-
498
- callFrameForStopId(stopId: StopId): SDK.DebuggerModel.CallFrame|undefined {
499
- return this.callFrameByStopId.get(stopId);
500
- }
501
-
502
- private expandCallFrames(callFrames: SDK.DebuggerModel.CallFrame[]): Promise<SDK.DebuggerModel.CallFrame[]> {
503
- return Promise
504
- .all(callFrames.map(async callFrame => {
505
- const functionInfo = await this.getFunctionInfo(callFrame.script, callFrame.location());
506
- if (functionInfo) {
507
- if ('frames' in functionInfo && functionInfo.frames.length) {
508
- return functionInfo.frames.map(({name}, index) => callFrame.createVirtualCallFrame(index, name));
509
- }
510
- if ('missingSymbolFiles' in functionInfo && functionInfo.missingSymbolFiles.length) {
511
- const resources = functionInfo.missingSymbolFiles;
512
- const details = i18nString(UIStrings.debugSymbolsIncomplete, {PH1: callFrame.functionName});
513
- callFrame.missingDebugInfoDetails = {details, resources};
514
- } else {
515
- callFrame.missingDebugInfoDetails = {
516
- details: i18nString(UIStrings.failedToLoadDebugSymbolsForFunction, {PH1: callFrame.functionName}),
517
- resources: [],
518
- };
519
- }
520
- }
521
- return callFrame;
522
- }))
523
- .then(callFrames => callFrames.flat());
524
- }
525
-
526
- modelAdded(debuggerModel: SDK.DebuggerModel.DebuggerModel): void {
527
- this.#debuggerModelToData.set(debuggerModel, new ModelData(debuggerModel, this.#workspace));
528
- debuggerModel.addEventListener(SDK.DebuggerModel.Events.GlobalObjectCleared, this.globalObjectCleared, this);
529
- debuggerModel.addEventListener(SDK.DebuggerModel.Events.ParsedScriptSource, this.parsedScriptSource, this);
530
- debuggerModel.addEventListener(SDK.DebuggerModel.Events.DebuggerResumed, this.debuggerResumed, this);
531
- debuggerModel.setEvaluateOnCallFrameCallback(this.evaluateOnCallFrame.bind(this));
532
- debuggerModel.setExpandCallFramesCallback(this.expandCallFrames.bind(this));
533
- }
534
-
535
- modelRemoved(debuggerModel: SDK.DebuggerModel.DebuggerModel): void {
536
- debuggerModel.removeEventListener(SDK.DebuggerModel.Events.GlobalObjectCleared, this.globalObjectCleared, this);
537
- debuggerModel.removeEventListener(SDK.DebuggerModel.Events.ParsedScriptSource, this.parsedScriptSource, this);
538
- debuggerModel.removeEventListener(SDK.DebuggerModel.Events.DebuggerResumed, this.debuggerResumed, this);
539
- debuggerModel.setEvaluateOnCallFrameCallback(null);
540
- debuggerModel.setExpandCallFramesCallback(null);
541
- const modelData = this.#debuggerModelToData.get(debuggerModel);
542
- if (modelData) {
543
- modelData.dispose();
544
- this.#debuggerModelToData.delete(debuggerModel);
545
- }
546
- this.#rawModuleHandles.forEach((rawModuleHandle, rawModuleId) => {
547
- const scripts = rawModuleHandle.scripts.filter(script => script.debuggerModel !== debuggerModel);
548
- if (scripts.length === 0) {
549
- rawModuleHandle.plugin.removeRawModule(rawModuleId).catch(error => {
550
- Common.Console.Console.instance().error(
551
- i18nString(UIStrings.errorInDebuggerLanguagePlugin, {PH1: error.message}), /* show=*/ false);
552
- });
553
- this.#rawModuleHandles.delete(rawModuleId);
554
- } else {
555
- rawModuleHandle.scripts = scripts;
556
- }
557
- });
558
- }
559
-
560
- private globalObjectCleared(event: Common.EventTarget.EventTargetEvent<SDK.DebuggerModel.DebuggerModel>): void {
561
- const debuggerModel = event.data;
562
- this.modelRemoved(debuggerModel);
563
- this.modelAdded(debuggerModel);
564
- }
565
-
566
- addPlugin(plugin: DebuggerLanguagePlugin): void {
567
- this.#plugins.push(plugin);
568
- for (const debuggerModel of this.#debuggerModelToData.keys()) {
569
- for (const script of debuggerModel.scripts()) {
570
- if (this.hasPluginForScript(script)) {
571
- continue;
572
- }
573
- this.parsedScriptSource({data: script});
574
- }
575
- }
576
- }
577
-
578
- removePlugin(plugin: DebuggerLanguagePlugin): void {
579
- this.#plugins = this.#plugins.filter(p => p !== plugin);
580
- const scripts = new Set<SDK.Script.Script>();
581
- this.#rawModuleHandles.forEach((rawModuleHandle, rawModuleId) => {
582
- if (rawModuleHandle.plugin !== plugin) {
583
- return;
584
- }
585
- rawModuleHandle.scripts.forEach(script => scripts.add(script));
586
- this.#rawModuleHandles.delete(rawModuleId);
587
- });
588
- for (const script of scripts) {
589
- const modelData = (this.#debuggerModelToData.get(script.debuggerModel) as ModelData);
590
- modelData.removeScript(script);
591
-
592
- // Let's see if we have another #plugin that's happy to
593
- // take this orphaned script now. This is important to
594
- // get right, since the same #plugin might race during
595
- // unregister/register and we might already have the
596
- // new instance of the #plugin added before we remove
597
- // the previous instance.
598
- this.parsedScriptSource({data: script});
599
- }
600
- }
601
-
602
- hasPluginForScript(script: SDK.Script.Script): boolean {
603
- const rawModuleId = rawModuleIdForScript(script);
604
- const rawModuleHandle = this.#rawModuleHandles.get(rawModuleId);
605
- return rawModuleHandle?.scripts.includes(script) ?? false;
606
- }
607
-
608
- /**
609
- * Returns the responsible language #plugin and the raw module ID for a script.
610
- *
611
- * This ensures that the `addRawModule` call finishes first such that the
612
- * caller can immediately issue calls to the returned #plugin without the
613
- * risk of racing with the `addRawModule` call. The returned #plugin will be
614
- * set to undefined to indicate that there's no #plugin for the script.
615
- */
616
- private async rawModuleIdAndPluginForScript(script: SDK.Script.Script): Promise<{
617
- rawModuleId: string,
618
- plugin: DebuggerLanguagePlugin|null,
619
- }> {
620
- const rawModuleId = rawModuleIdForScript(script);
621
- const rawModuleHandle = this.#rawModuleHandles.get(rawModuleId);
622
- if (rawModuleHandle) {
623
- await rawModuleHandle.addRawModulePromise;
624
- if (rawModuleHandle === this.#rawModuleHandles.get(rawModuleId)) {
625
- return {rawModuleId, plugin: rawModuleHandle.plugin};
626
- }
627
- }
628
- return {rawModuleId, plugin: null};
629
- }
630
-
631
- uiSourceCodeForURL(debuggerModel: SDK.DebuggerModel.DebuggerModel, url: Platform.DevToolsPath.UrlString):
632
- Workspace.UISourceCode.UISourceCode|null {
633
- const modelData = this.#debuggerModelToData.get(debuggerModel);
634
- if (modelData) {
635
- return modelData.getProject().uiSourceCodeForURL(url);
636
- }
637
- return null;
638
- }
639
-
640
- async rawLocationToUILocation(rawLocation: SDK.DebuggerModel.Location):
641
- Promise<Workspace.UISourceCode.UILocation|null> {
642
- const script = rawLocation.script();
643
- if (!script) {
644
- return null;
645
- }
646
- const {rawModuleId, plugin} = await this.rawModuleIdAndPluginForScript(script);
647
- if (!plugin) {
648
- return null;
649
- }
650
-
651
- const pluginLocation = {
652
- rawModuleId,
653
- // RawLocation.#columnNumber is the byte offset in the full raw wasm module. Plugins expect the offset in the code
654
- // section, so subtract the offset of the code section in the module here.
655
- codeOffset: rawLocation.columnNumber - (script.codeOffset() || 0),
656
- inlineFrameIndex: rawLocation.inlineFrameIndex,
657
- };
658
-
659
- try {
660
- const sourceLocations = await plugin.rawLocationToSourceLocation(pluginLocation);
661
- for (const sourceLocation of sourceLocations) {
662
- const uiSourceCode = this.uiSourceCodeForURL(
663
- script.debuggerModel, sourceLocation.sourceFileURL as Platform.DevToolsPath.UrlString);
664
- if (!uiSourceCode) {
665
- continue;
666
- }
667
- // Absence of column information is indicated by the value `-1` in talking to language #plugins.
668
- return uiSourceCode.uiLocation(
669
- sourceLocation.lineNumber, sourceLocation.columnNumber >= 0 ? sourceLocation.columnNumber : undefined);
670
- }
671
- } catch (error) {
672
- Common.Console.Console.instance().error(
673
- i18nString(UIStrings.errorInDebuggerLanguagePlugin, {PH1: error.message}), /* show=*/ false);
674
- }
675
- return null;
676
- }
677
-
678
- uiLocationToRawLocationRanges(
679
- uiSourceCode: Workspace.UISourceCode.UISourceCode, lineNumber: number,
680
- columnNumber: number|undefined = -1): Promise<Array<{
681
- start: SDK.DebuggerModel.Location,
682
- end: SDK.DebuggerModel.Location,
683
- }>|null> {
684
- const locationPromises: Array<Promise<Array<{
685
- start: SDK.DebuggerModel.Location,
686
- end: SDK.DebuggerModel.Location,
687
- }>>> = [];
688
- this.scriptsForUISourceCode(uiSourceCode).forEach(script => {
689
- const rawModuleId = rawModuleIdForScript(script);
690
- const rawModuleHandle = this.#rawModuleHandles.get(rawModuleId);
691
- if (!rawModuleHandle) {
692
- return;
693
- }
694
- const {plugin} = rawModuleHandle;
695
- locationPromises.push(getLocations(rawModuleId, plugin, script));
696
- });
697
- if (locationPromises.length === 0) {
698
- return Promise.resolve(null);
699
- }
700
-
701
- return Promise.all(locationPromises).then(locations => locations.flat()).catch(error => {
702
- Common.Console.Console.instance().error(
703
- i18nString(UIStrings.errorInDebuggerLanguagePlugin, {PH1: error.message}), /* show=*/ false);
704
- return null;
705
- });
706
-
707
- async function getLocations(
708
- rawModuleId: string, plugin: DebuggerLanguagePlugin, script: SDK.Script.Script): Promise<Array<{
709
- start: SDK.DebuggerModel.Location,
710
- end: SDK.DebuggerModel.Location,
711
- }>> {
712
- const pluginLocation = {rawModuleId, sourceFileURL: uiSourceCode.url(), lineNumber, columnNumber};
713
-
714
- const rawLocations = await plugin.sourceLocationToRawLocation(pluginLocation);
715
- if (!rawLocations) {
716
- return [];
717
- }
718
- return rawLocations.map(
719
- m => ({
720
- start: new SDK.DebuggerModel.Location(
721
- script.debuggerModel, script.scriptId, 0, Number(m.startOffset) + (script.codeOffset() || 0)),
722
- end: new SDK.DebuggerModel.Location(
723
- script.debuggerModel, script.scriptId, 0, Number(m.endOffset) + (script.codeOffset() || 0)),
724
- }));
725
- }
726
- }
727
-
728
- async uiLocationToRawLocations(
729
- uiSourceCode: Workspace.UISourceCode.UISourceCode, lineNumber: number,
730
- columnNumber?: number): Promise<SDK.DebuggerModel.Location[]|null> {
731
- const locationRanges = await this.uiLocationToRawLocationRanges(uiSourceCode, lineNumber, columnNumber);
732
- if (!locationRanges) {
733
- return null;
734
- }
735
- return locationRanges.map(({start}) => start);
736
- }
737
-
738
- async uiLocationRangeToRawLocationRanges(
739
- uiSourceCode: Workspace.UISourceCode.UISourceCode,
740
- textRange: TextUtils.TextRange.TextRange): Promise<SDK.DebuggerModel.LocationRange[]|null> {
741
- const locationRangesPromises = [];
742
- for (let line = textRange.startLine; line <= textRange.endLine; ++line) {
743
- locationRangesPromises.push(this.uiLocationToRawLocationRanges(uiSourceCode, line));
744
- }
745
- const ranges = [];
746
- for (const locationRanges of await Promise.all(locationRangesPromises)) {
747
- if (locationRanges === null) {
748
- return null;
749
- }
750
- for (const range of locationRanges) {
751
- const [startLocation, endLocation] = await Promise.all([
752
- this.rawLocationToUILocation(range.start),
753
- this.rawLocationToUILocation(range.end),
754
- ]);
755
- if (startLocation === null || endLocation === null) {
756
- continue;
757
- }
758
- // Report all ranges that somehow intersect with the `textRange`. It's the
759
- // responsibility of the caller to filter / clamp these ranges appropriately.
760
- const overlap = textRange.intersection(new TextUtils.TextRange.TextRange(
761
- startLocation.lineNumber, startLocation.columnNumber ?? 0, endLocation.lineNumber,
762
- endLocation.columnNumber ?? Infinity));
763
- if (!overlap.isEmpty()) {
764
- ranges.push(range);
765
- }
766
- }
767
- }
768
- return ranges;
769
- }
770
-
771
- async translateRawFramesStep(
772
- rawFrames: StackTraceImpl.Trie.RawFrame[],
773
- translatedFrames: Awaited<ReturnType<StackTraceImpl.StackTraceModel.TranslateRawFrames>>,
774
- target: SDK.Target.Target): Promise<boolean> {
775
- const frame = rawFrames[0];
776
- const script = target.model(SDK.DebuggerModel.DebuggerModel)?.scriptForId(frame.scriptId ?? '');
777
- if (!script) {
778
- return false;
779
- }
780
-
781
- const functionInfo = await this.getFunctionInfo(script, frame);
782
- if (!functionInfo) {
783
- return false;
784
- }
785
-
786
- // The plugin is responsible for translating this frame. The only question is whether it was successful,
787
- // or if we identity map the raw frame and attach the "missing debug info details".
788
- rawFrames.shift();
789
-
790
- if ('frames' in functionInfo && functionInfo.frames.length) {
791
- const framePromises = functionInfo.frames.map(async ({name}, index) => {
792
- const rawLocation = new SDK.DebuggerModel.Location(
793
- script.debuggerModel, script.scriptId, frame.lineNumber, frame.columnNumber, index);
794
- const uiLocation = await this.rawLocationToUILocation(rawLocation);
795
- return {
796
- uiSourceCode: uiLocation?.uiSourceCode,
797
- url: uiLocation ? undefined : frame.url,
798
- name,
799
- line: uiLocation?.lineNumber ?? frame.lineNumber,
800
- column: uiLocation?.columnNumber ?? frame.columnNumber,
801
- };
802
- });
803
-
804
- translatedFrames.push(await Promise.all(framePromises));
805
- return true;
806
- }
807
-
808
- // Identity map the frame, then add the missing debug info details.
809
- const mappedFrame: (typeof translatedFrames)[number][number] = {
810
- url: frame.url,
811
- name: frame.functionName,
812
- line: frame.lineNumber,
813
- column: frame.columnNumber,
814
- };
815
-
816
- if ('missingSymbolFiles' in functionInfo && functionInfo.missingSymbolFiles.length) {
817
- translatedFrames.push([{
818
- ...mappedFrame,
819
- missingDebugInfo: {
820
- type: StackTrace.StackTrace.MissingDebugInfoType.PARTIAL_INFO,
821
- missingDebugFiles: functionInfo.missingSymbolFiles,
822
- },
823
- }]);
824
- } else {
825
- translatedFrames.push([{
826
- ...mappedFrame,
827
- missingDebugInfo: {
828
- type: StackTrace.StackTrace.MissingDebugInfoType.NO_INFO,
829
- },
830
- }]);
831
- }
832
-
833
- return true;
834
- }
835
-
836
- scriptsForUISourceCode(uiSourceCode: Workspace.UISourceCode.UISourceCode): SDK.Script.Script[] {
837
- for (const modelData of this.#debuggerModelToData.values()) {
838
- const scripts = modelData.uiSourceCodeToScripts.get(uiSourceCode);
839
- if (scripts) {
840
- return scripts;
841
- }
842
- }
843
- return [];
844
- }
845
-
846
- setDebugInfoURL(script: SDK.Script.Script, externalURL: Platform.DevToolsPath.UrlString): void {
847
- if (this.hasPluginForScript(script)) {
848
- return;
849
- }
850
- script.debugSymbols = {type: Protocol.Debugger.DebugSymbolsType.ExternalDWARF, externalURL};
851
- this.parsedScriptSource({data: script});
852
- void script.debuggerModel.setDebugInfoURL(script, externalURL);
853
- }
854
-
855
- private parsedScriptSource(event: Common.EventTarget.EventTargetEvent<SDK.Script.Script>): void {
856
- const script = event.data;
857
- if (!script.sourceURL) {
858
- return;
859
- }
860
-
861
- for (const plugin of this.#plugins) {
862
- if (!plugin.handleScript(script)) {
863
- continue;
864
- }
865
- const rawModuleId = rawModuleIdForScript(script);
866
- let rawModuleHandle = this.#rawModuleHandles.get(rawModuleId);
867
- if (!rawModuleHandle) {
868
- const sourceFileURLsPromise = (async () => {
869
- const console = Common.Console.Console.instance();
870
- const url = script.sourceURL;
871
- const symbolsUrl = (script.debugSymbols?.externalURL) || '';
872
- if (symbolsUrl) {
873
- console.log(i18nString(UIStrings.loadingDebugSymbolsForVia, {PH1: plugin.name, PH2: url, PH3: symbolsUrl}));
874
- } else {
875
- console.log(i18nString(UIStrings.loadingDebugSymbolsFor, {PH1: plugin.name, PH2: url}));
876
- }
877
- try {
878
- const code =
879
- (!symbolsUrl && Common.ParsedURL.schemeIs(url, 'wasm:')) ? await script.getWasmBytecode() : undefined;
880
- const addModuleResult = await plugin.addRawModule(rawModuleId, symbolsUrl, {url, code});
881
- // Check that the handle isn't stale by now. This works because the code that assigns to
882
- // `rawModuleHandle` below will run before this code because of the `await` in the preceding
883
- // line. This is primarily to avoid logging the message below, which would give the developer
884
- // the misleading information that we're done, while in reality it was a stale call that finished.
885
- if (rawModuleHandle !== this.#rawModuleHandles.get(rawModuleId)) {
886
- return [];
887
- }
888
- if ('missingSymbolFiles' in addModuleResult) {
889
- const initiator = plugin.createPageResourceLoadInitiator();
890
- const missingSymbolFiles = addModuleResult.missingSymbolFiles.map(resource => {
891
- const resourceUrl = resource as Platform.DevToolsPath.UrlString;
892
- return {resourceUrl, initiator};
893
- });
894
- return {missingSymbolFiles};
895
- }
896
- const sourceFileURLs = addModuleResult as Platform.DevToolsPath.UrlString[];
897
- if (sourceFileURLs.length === 0) {
898
- console.warn(i18nString(UIStrings.loadedDebugSymbolsForButDidnt, {PH1: plugin.name, PH2: url}));
899
- } else {
900
- console.log(i18nString(
901
- UIStrings.loadedDebugSymbolsForFound, {PH1: plugin.name, PH2: url, PH3: sourceFileURLs.length}));
902
- }
903
- return sourceFileURLs;
904
- } catch (error) {
905
- console.error(
906
- i18nString(UIStrings.failedToLoadDebugSymbolsFor, {PH1: plugin.name, PH2: url, PH3: error.message}),
907
- /* show=*/ false);
908
- this.#rawModuleHandles.delete(rawModuleId);
909
- return [];
910
- }
911
- })();
912
- rawModuleHandle = {rawModuleId, plugin, scripts: [script], addRawModulePromise: sourceFileURLsPromise};
913
- this.#rawModuleHandles.set(rawModuleId, rawModuleHandle);
914
- } else {
915
- rawModuleHandle.scripts.push(script);
916
- }
917
-
918
- // Wait for the addRawModule call to finish and
919
- // update the #project. It's important to check
920
- // for the DebuggerModel again, which may disappear
921
- // in the meantime...
922
- void rawModuleHandle.addRawModulePromise.then(sourceFileURLs => {
923
- if (!('missingSymbolFiles' in sourceFileURLs)) {
924
- // The script might have disappeared meanwhile...
925
- if (script.debuggerModel.scriptForId(script.scriptId) === script) {
926
- const modelData = this.#debuggerModelToData.get(script.debuggerModel);
927
- if (modelData) { // The DebuggerModel could have disappeared meanwhile...
928
- modelData.addSourceFiles(script, sourceFileURLs);
929
- void this.#debuggerWorkspaceBinding.updateLocations(script);
930
- }
931
- }
932
- }
933
- });
934
- return;
935
- }
936
- }
937
-
938
- private debuggerResumed(event: Common.EventTarget.EventTargetEvent<SDK.DebuggerModel.DebuggerModel>): void {
939
- const resumedFrames =
940
- Array.from(this.callFrameByStopId.values()).filter(callFrame => callFrame.debuggerModel === event.data);
941
- for (const callFrame of resumedFrames) {
942
- const stopId = this.stopIdByCallFrame.get(callFrame);
943
- assertNotNullOrUndefined(stopId);
944
- this.stopIdByCallFrame.delete(callFrame);
945
- this.callFrameByStopId.delete(stopId);
946
- }
947
- }
948
-
949
- getSourcesForScript(script: SDK.Script.Script):
950
- Promise<Platform.DevToolsPath.UrlString[]|{missingSymbolFiles: SDK.DebuggerModel.MissingDebugFiles[]}|undefined> {
951
- const rawModuleId = rawModuleIdForScript(script);
952
- const rawModuleHandle = this.#rawModuleHandles.get(rawModuleId);
953
- if (rawModuleHandle) {
954
- return rawModuleHandle.addRawModulePromise;
955
- }
956
- return Promise.resolve(undefined);
957
- }
958
-
959
- async resolveScopeChain(callFrame: SDK.DebuggerModel.CallFrame): Promise<SourceScope[]|null> {
960
- const script = callFrame.script;
961
- const {rawModuleId, plugin} = await this.rawModuleIdAndPluginForScript(script);
962
- if (!plugin) {
963
- return null;
964
- }
965
-
966
- const location = {
967
- rawModuleId,
968
- codeOffset: callFrame.location().columnNumber - (script.codeOffset() || 0),
969
- inlineFrameIndex: callFrame.inlineFrameIndex,
970
- };
971
-
972
- const stopId = this.stopIdForCallFrame(callFrame);
973
-
974
- try {
975
- const sourceMapping = await plugin.rawLocationToSourceLocation(location);
976
- if (sourceMapping.length === 0) {
977
- return null;
978
- }
979
- const scopes = new Map<string, SourceScope>();
980
- const variables = await plugin.listVariablesInScope(location);
981
- for (const variable of variables || []) {
982
- let scope = scopes.get(variable.scope);
983
- if (!scope) {
984
- const {type, typeName, icon} = await plugin.getScopeInfo(variable.scope);
985
- scope = new SourceScope(callFrame, stopId, type, typeName, icon, plugin);
986
- scopes.set(variable.scope, scope);
987
- }
988
- scope.object().variables.push(variable);
989
- }
990
- return Array.from(scopes.values());
991
- } catch (error) {
992
- Common.Console.Console.instance().error(
993
- i18nString(UIStrings.errorInDebuggerLanguagePlugin, {PH1: error.message}), /* show=*/ false);
994
- return null;
995
- }
996
- }
997
-
998
- async getFunctionInfo(script: SDK.Script.Script, location: Pick<SDK.DebuggerModel.Location, 'columnNumber'>):
999
- Promise<{frames: Chrome.DevTools.FunctionInfo[], missingSymbolFiles: SDK.DebuggerModel.MissingDebugFiles[]}|
1000
- {frames: Chrome.DevTools.FunctionInfo[]}|{missingSymbolFiles: SDK.DebuggerModel.MissingDebugFiles[]}|
1001
- null> {
1002
- const {rawModuleId, plugin} = await this.rawModuleIdAndPluginForScript(script);
1003
- if (!plugin) {
1004
- return null;
1005
- }
1006
-
1007
- const rawLocation: Chrome.DevTools.RawLocation = {
1008
- rawModuleId,
1009
- codeOffset: location.columnNumber - (script.codeOffset() || 0),
1010
- inlineFrameIndex: 0,
1011
- };
1012
-
1013
- try {
1014
- const functionInfo = await plugin.getFunctionInfo(rawLocation);
1015
- if ('missingSymbolFiles' in functionInfo) {
1016
- const initiator = plugin.createPageResourceLoadInitiator();
1017
- const missingSymbolFiles = functionInfo.missingSymbolFiles.map(resource => {
1018
- const resourceUrl = resource as Platform.DevToolsPath.UrlString;
1019
- return {resourceUrl, initiator};
1020
- });
1021
- return {missingSymbolFiles, ...('frames' in functionInfo && {frames: functionInfo.frames})};
1022
- }
1023
- return functionInfo;
1024
- } catch (error) {
1025
- Common.Console.Console.instance().warn(i18nString(UIStrings.errorInDebuggerLanguagePlugin, {PH1: error.message}));
1026
- return {frames: []};
1027
- }
1028
- }
1029
-
1030
- async getInlinedFunctionRanges(rawLocation: SDK.DebuggerModel.Location): Promise<Array<{
1031
- start: SDK.DebuggerModel.Location,
1032
- end: SDK.DebuggerModel.Location,
1033
- }>> {
1034
- const script = rawLocation.script();
1035
- if (!script) {
1036
- return [];
1037
- }
1038
- const {rawModuleId, plugin} = await this.rawModuleIdAndPluginForScript(script);
1039
- if (!plugin) {
1040
- return [];
1041
- }
1042
-
1043
- const pluginLocation = {
1044
- rawModuleId,
1045
- // RawLocation.#columnNumber is the byte offset in the full raw wasm module. Plugins expect the offset in the code
1046
- // section, so subtract the offset of the code section in the module here.
1047
- codeOffset: rawLocation.columnNumber - (script.codeOffset() || 0),
1048
- };
1049
-
1050
- try {
1051
- // TODO(crbug.com/1172300) Ignored during the jsdoc to ts migration)
1052
- // @ts-expect-error
1053
- const locations = await plugin.getInlinedFunctionRanges(pluginLocation);
1054
- return locations.map(
1055
- m => ({
1056
- start: new SDK.DebuggerModel.Location(
1057
- script.debuggerModel, script.scriptId, 0, Number(m.startOffset) + (script.codeOffset() || 0)),
1058
- end: new SDK.DebuggerModel.Location(
1059
- script.debuggerModel, script.scriptId, 0, Number(m.endOffset) + (script.codeOffset() || 0)),
1060
- }));
1061
- } catch (error) {
1062
- Common.Console.Console.instance().warn(i18nString(UIStrings.errorInDebuggerLanguagePlugin, {PH1: error.message}));
1063
- return [];
1064
- }
1065
- }
1066
-
1067
- async getInlinedCalleesRanges(rawLocation: SDK.DebuggerModel.Location): Promise<Array<{
1068
- start: SDK.DebuggerModel.Location,
1069
- end: SDK.DebuggerModel.Location,
1070
- }>> {
1071
- const script = rawLocation.script();
1072
- if (!script) {
1073
- return [];
1074
- }
1075
- const {rawModuleId, plugin} = await this.rawModuleIdAndPluginForScript(script);
1076
- if (!plugin) {
1077
- return [];
1078
- }
1079
-
1080
- const pluginLocation = {
1081
- rawModuleId,
1082
- // RawLocation.#columnNumber is the byte offset in the full raw wasm module. Plugins expect the offset in the code
1083
- // section, so subtract the offset of the code section in the module here.
1084
- codeOffset: rawLocation.columnNumber - (script.codeOffset() || 0),
1085
- };
1086
-
1087
- try {
1088
- // TODO(crbug.com/1172300) Ignored during the jsdoc to ts migration)
1089
- // @ts-expect-error
1090
- const locations = await plugin.getInlinedCalleesRanges(pluginLocation);
1091
- return locations.map(
1092
- m => ({
1093
- start: new SDK.DebuggerModel.Location(
1094
- script.debuggerModel, script.scriptId, 0, Number(m.startOffset) + (script.codeOffset() || 0)),
1095
- end: new SDK.DebuggerModel.Location(
1096
- script.debuggerModel, script.scriptId, 0, Number(m.endOffset) + (script.codeOffset() || 0)),
1097
- }));
1098
- } catch (error) {
1099
- Common.Console.Console.instance().warn(i18nString(UIStrings.errorInDebuggerLanguagePlugin, {PH1: error.message}));
1100
- return [];
1101
- }
1102
- }
1103
-
1104
- async getMappedLines(uiSourceCode: Workspace.UISourceCode.UISourceCode): Promise<Set<number>|null> {
1105
- const rawModuleIds =
1106
- await Promise.all(this.scriptsForUISourceCode(uiSourceCode).map(s => this.rawModuleIdAndPluginForScript(s)));
1107
-
1108
- let mappedLines: Set<number>|null = null;
1109
- for (const {rawModuleId, plugin} of rawModuleIds) {
1110
- if (!plugin) {
1111
- continue;
1112
- }
1113
- const lines = await plugin.getMappedLines(rawModuleId, uiSourceCode.url());
1114
-
1115
- if (lines === undefined) {
1116
- continue;
1117
- }
1118
- if (mappedLines === null) {
1119
- mappedLines = new Set(lines);
1120
- } else {
1121
- lines.forEach(l => (mappedLines as Set<number>).add(l));
1122
- }
1123
- }
1124
- return mappedLines;
1125
- }
1126
- }
1127
-
1128
- class ModelData {
1129
- project: ContentProviderBasedProject;
1130
- readonly uiSourceCodeToScripts: Map<Workspace.UISourceCode.UISourceCode, SDK.Script.Script[]>;
1131
- constructor(debuggerModel: SDK.DebuggerModel.DebuggerModel, workspace: Workspace.Workspace.WorkspaceImpl) {
1132
- this.project = new ContentProviderBasedProject(
1133
- workspace, 'language_plugins::' + debuggerModel.target().id(), Workspace.Workspace.projectTypes.Network, '',
1134
- false /* isServiceProject */);
1135
- NetworkProject.setTargetForProject(this.project, debuggerModel.target());
1136
-
1137
- this.uiSourceCodeToScripts = new Map();
1138
- }
1139
-
1140
- addSourceFiles(script: SDK.Script.Script, urls: Platform.DevToolsPath.UrlString[]): void {
1141
- const initiator = script.createPageResourceLoadInitiator();
1142
- for (const url of urls) {
1143
- let uiSourceCode = this.project.uiSourceCodeForURL(url);
1144
- if (!uiSourceCode) {
1145
- uiSourceCode = this.project.createUISourceCode(url, Common.ResourceType.resourceTypes.SourceMapScript);
1146
- NetworkProject.setInitialFrameAttribution(uiSourceCode, script.frameId);
1147
-
1148
- // Bind the uiSourceCode to the script first before we add the
1149
- // uiSourceCode to the #project and thereby notify the rest of
1150
- // the system about the new source file.
1151
- // https://crbug.com/1150295 is an example where the breakpoint
1152
- // resolution logic kicks in right after adding the uiSourceCode
1153
- // and at that point we already need to have the mapping in place
1154
- // otherwise we will not get the breakpoint right.
1155
- this.uiSourceCodeToScripts.set(uiSourceCode, [script]);
1156
-
1157
- const contentProvider = new SDK.CompilerSourceMappingContentProvider.CompilerSourceMappingContentProvider(
1158
- url, Common.ResourceType.resourceTypes.SourceMapScript, initiator);
1159
- const mimeType = Common.ResourceType.ResourceType.mimeFromURL(url) || 'text/javascript';
1160
- this.project.addUISourceCodeWithProvider(uiSourceCode, contentProvider, null, mimeType);
1161
- } else {
1162
- // The same uiSourceCode can be provided by different scripts,
1163
- // but we don't expect that to happen frequently.
1164
- const scripts = (this.uiSourceCodeToScripts.get(uiSourceCode) as SDK.Script.Script[]);
1165
- if (!scripts.includes(script)) {
1166
- scripts.push(script);
1167
- }
1168
- }
1169
- }
1170
- }
1171
-
1172
- removeScript(script: SDK.Script.Script): void {
1173
- this.uiSourceCodeToScripts.forEach((scripts, uiSourceCode) => {
1174
- scripts = scripts.filter(s => s !== script);
1175
- if (scripts.length === 0) {
1176
- this.uiSourceCodeToScripts.delete(uiSourceCode);
1177
- this.project.removeUISourceCode(uiSourceCode.url());
1178
- } else {
1179
- this.uiSourceCodeToScripts.set(uiSourceCode, scripts);
1180
- }
1181
- });
1182
- }
1183
-
1184
- dispose(): void {
1185
- this.project.dispose();
1186
- }
1187
-
1188
- getProject(): ContentProviderBasedProject {
1189
- return this.project;
1190
- }
1191
- }
1192
-
1193
- export interface DebuggerLanguagePlugin extends Chrome.DevTools.LanguageExtensionPlugin {
1194
- name: string;
1195
- handleScript(script: SDK.Script.Script): boolean;
1196
- createPageResourceLoadInitiator(): SDK.PageResourceLoader.PageResourceLoadInitiator;
1197
- }