devtools-tracing 1.1.1 → 1.2.1

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 (527) hide show
  1. package/dist/index.d.ts +4 -0
  2. package/dist/index.js +28854 -0
  3. package/package.json +11 -8
  4. package/generate.ts +0 -649
  5. package/index.ts +0 -17
  6. package/lib/extension-api/ExtensionAPI.d.ts +0 -357
  7. package/lib/front_end/core/common/App.ts +0 -7
  8. package/lib/front_end/core/common/AppProvider.ts +0 -32
  9. package/lib/front_end/core/common/Base64.ts +0 -47
  10. package/lib/front_end/core/common/CharacterIdMap.ts +0 -30
  11. package/lib/front_end/core/common/Color.ts +0 -2506
  12. package/lib/front_end/core/common/ColorConverter.ts +0 -402
  13. package/lib/front_end/core/common/ColorUtils.ts +0 -252
  14. package/lib/front_end/core/common/Console.ts +0 -114
  15. package/lib/front_end/core/common/Debouncer.ts +0 -15
  16. package/lib/front_end/core/common/EventTarget.ts +0 -52
  17. package/lib/front_end/core/common/Gzip.ts +0 -74
  18. package/lib/front_end/core/common/JavaScriptMetaData.ts +0 -29
  19. package/lib/front_end/core/common/Lazy.ts +0 -31
  20. package/lib/front_end/core/common/Linkifier.ts +0 -55
  21. package/lib/front_end/core/common/MapWithDefault.ts +0 -26
  22. package/lib/front_end/core/common/Mutex.ts +0 -55
  23. package/lib/front_end/core/common/Object.ts +0 -145
  24. package/lib/front_end/core/common/ParsedURL.ts +0 -554
  25. package/lib/front_end/core/common/Progress.ts +0 -180
  26. package/lib/front_end/core/common/QueryParamHandler.ts +0 -7
  27. package/lib/front_end/core/common/ResolverBase.ts +0 -85
  28. package/lib/front_end/core/common/ResourceType.ts +0 -588
  29. package/lib/front_end/core/common/ReturnToPanel.ts +0 -17
  30. package/lib/front_end/core/common/Revealer.ts +0 -192
  31. package/lib/front_end/core/common/Runnable.ts +0 -41
  32. package/lib/front_end/core/common/SegmentedRange.ts +0 -87
  33. package/lib/front_end/core/common/SettingRegistration.ts +0 -339
  34. package/lib/front_end/core/common/Settings.ts +0 -1497
  35. package/lib/front_end/core/common/SimpleHistoryManager.ts +0 -124
  36. package/lib/front_end/core/common/StringOutputStream.ts +0 -26
  37. package/lib/front_end/core/common/TextDictionary.ts +0 -48
  38. package/lib/front_end/core/common/Throttler.ts +0 -99
  39. package/lib/front_end/core/common/Trie.ts +0 -152
  40. package/lib/front_end/core/common/Worker.ts +0 -60
  41. package/lib/front_end/core/common/common.ts +0 -81
  42. package/lib/front_end/core/host/AidaClient.ts +0 -733
  43. package/lib/front_end/core/host/GdpClient.ts +0 -316
  44. package/lib/front_end/core/host/InspectorFrontendHost.ts +0 -648
  45. package/lib/front_end/core/host/InspectorFrontendHostAPI.ts +0 -551
  46. package/lib/front_end/core/host/Platform.ts +0 -76
  47. package/lib/front_end/core/host/ResourceLoader.ts +0 -282
  48. package/lib/front_end/core/host/UserMetrics.ts +0 -1230
  49. package/lib/front_end/core/host/host.ts +0 -23
  50. package/lib/front_end/core/i18n/ByteUtilities.ts +0 -82
  51. package/lib/front_end/core/i18n/DevToolsLocale.ts +0 -87
  52. package/lib/front_end/core/i18n/NumberFormatter.ts +0 -82
  53. package/lib/front_end/core/i18n/i18n.ts +0 -17
  54. package/lib/front_end/core/i18n/i18nImpl.ts +0 -204
  55. package/lib/front_end/core/i18n/i18nTypes.ts +0 -10
  56. package/lib/front_end/core/i18n/locales.js +0 -14
  57. package/lib/front_end/core/i18n/time-utilities.ts +0 -174
  58. package/lib/front_end/core/platform/ArrayUtilities.ts +0 -271
  59. package/lib/front_end/core/platform/Brand.ts +0 -23
  60. package/lib/front_end/core/platform/Constructor.ts +0 -10
  61. package/lib/front_end/core/platform/DOMUtilities.ts +0 -138
  62. package/lib/front_end/core/platform/DateUtilities.ts +0 -15
  63. package/lib/front_end/core/platform/DevToolsPath.ts +0 -53
  64. package/lib/front_end/core/platform/KeyboardUtilities.ts +0 -38
  65. package/lib/front_end/core/platform/MapUtilities.ts +0 -95
  66. package/lib/front_end/core/platform/MimeType.ts +0 -175
  67. package/lib/front_end/core/platform/NumberUtilities.ts +0 -80
  68. package/lib/front_end/core/platform/StringUtilities.ts +0 -588
  69. package/lib/front_end/core/platform/Timing.ts +0 -17
  70. package/lib/front_end/core/platform/TypedArrayUtilities.ts +0 -189
  71. package/lib/front_end/core/platform/TypescriptUtilities.ts +0 -86
  72. package/lib/front_end/core/platform/UIString.ts +0 -39
  73. package/lib/front_end/core/platform/UserVisibleError.ts +0 -28
  74. package/lib/front_end/core/platform/platform.ts +0 -45
  75. package/lib/front_end/core/protocol_client/ConnectionTransport.ts +0 -26
  76. package/lib/front_end/core/protocol_client/InspectorBackend.ts +0 -1050
  77. package/lib/front_end/core/protocol_client/NodeURL.ts +0 -42
  78. package/lib/front_end/core/protocol_client/protocol_client.ts +0 -13
  79. package/lib/front_end/core/root/Runtime.ts +0 -609
  80. package/lib/front_end/core/root/root.ts +0 -6
  81. package/lib/front_end/core/sdk/AccessibilityModel.ts +0 -353
  82. package/lib/front_end/core/sdk/AnimationModel.ts +0 -1041
  83. package/lib/front_end/core/sdk/AutofillModel.ts +0 -184
  84. package/lib/front_end/core/sdk/CPUProfilerModel.ts +0 -148
  85. package/lib/front_end/core/sdk/CPUThrottlingManager.ts +0 -282
  86. package/lib/front_end/core/sdk/CSSContainerQuery.ts +0 -139
  87. package/lib/front_end/core/sdk/CSSFontFace.ts +0 -40
  88. package/lib/front_end/core/sdk/CSSLayer.ts +0 -30
  89. package/lib/front_end/core/sdk/CSSMatchedStyles.ts +0 -1646
  90. package/lib/front_end/core/sdk/CSSMedia.ts +0 -121
  91. package/lib/front_end/core/sdk/CSSMetadata.ts +0 -1647
  92. package/lib/front_end/core/sdk/CSSModel.ts +0 -1128
  93. package/lib/front_end/core/sdk/CSSProperty.ts +0 -384
  94. package/lib/front_end/core/sdk/CSSPropertyParser.ts +0 -681
  95. package/lib/front_end/core/sdk/CSSPropertyParserMatchers.ts +0 -1395
  96. package/lib/front_end/core/sdk/CSSQuery.ts +0 -72
  97. package/lib/front_end/core/sdk/CSSRule.ts +0 -465
  98. package/lib/front_end/core/sdk/CSSScope.ts +0 -30
  99. package/lib/front_end/core/sdk/CSSStartingStyle.ts +0 -29
  100. package/lib/front_end/core/sdk/CSSStyleDeclaration.ts +0 -313
  101. package/lib/front_end/core/sdk/CSSStyleSheetHeader.ts +0 -196
  102. package/lib/front_end/core/sdk/CSSSupports.ts +0 -33
  103. package/lib/front_end/core/sdk/CategorizedBreakpoint.ts +0 -64
  104. package/lib/front_end/core/sdk/ChildTargetManager.ts +0 -314
  105. package/lib/front_end/core/sdk/CompilerSourceMappingContentProvider.ts +0 -62
  106. package/lib/front_end/core/sdk/Connections.ts +0 -293
  107. package/lib/front_end/core/sdk/ConsoleModel.ts +0 -808
  108. package/lib/front_end/core/sdk/ConsoleModelTypes.ts +0 -15
  109. package/lib/front_end/core/sdk/Cookie.ts +0 -319
  110. package/lib/front_end/core/sdk/CookieModel.ts +0 -239
  111. package/lib/front_end/core/sdk/CookieParser.ts +0 -185
  112. package/lib/front_end/core/sdk/DOMDebuggerModel.ts +0 -787
  113. package/lib/front_end/core/sdk/DOMModel.ts +0 -1961
  114. package/lib/front_end/core/sdk/DebuggerModel.ts +0 -1605
  115. package/lib/front_end/core/sdk/EmulationModel.ts +0 -648
  116. package/lib/front_end/core/sdk/EnhancedTracesParser.ts +0 -515
  117. package/lib/front_end/core/sdk/EventBreakpointsModel.ts +0 -183
  118. package/lib/front_end/core/sdk/FrameAssociated.ts +0 -11
  119. package/lib/front_end/core/sdk/FrameManager.ts +0 -259
  120. package/lib/front_end/core/sdk/HeapProfilerModel.ts +0 -225
  121. package/lib/front_end/core/sdk/HttpReasonPhraseStrings.ts +0 -77
  122. package/lib/front_end/core/sdk/IOModel.ts +0 -91
  123. package/lib/front_end/core/sdk/IsolateManager.ts +0 -257
  124. package/lib/front_end/core/sdk/IssuesModel.ts +0 -70
  125. package/lib/front_end/core/sdk/LayerTreeBase.ts +0 -169
  126. package/lib/front_end/core/sdk/LogModel.ts +0 -56
  127. package/lib/front_end/core/sdk/NetworkManager.ts +0 -2823
  128. package/lib/front_end/core/sdk/NetworkRequest.ts +0 -2253
  129. package/lib/front_end/core/sdk/OverlayColorGenerator.ts +0 -52
  130. package/lib/front_end/core/sdk/OverlayModel.ts +0 -1011
  131. package/lib/front_end/core/sdk/OverlayPersistentHighlighter.ts +0 -522
  132. package/lib/front_end/core/sdk/PageLoad.ts +0 -35
  133. package/lib/front_end/core/sdk/PageResourceLoader.ts +0 -435
  134. package/lib/front_end/core/sdk/PaintProfiler.ts +0 -110
  135. package/lib/front_end/core/sdk/PerformanceMetricsModel.ts +0 -84
  136. package/lib/front_end/core/sdk/PreloadingModel.ts +0 -863
  137. package/lib/front_end/core/sdk/RehydratingConnection.ts +0 -386
  138. package/lib/front_end/core/sdk/RehydratingObject.ts +0 -66
  139. package/lib/front_end/core/sdk/RemoteObject.ts +0 -1160
  140. package/lib/front_end/core/sdk/Resource.ts +0 -232
  141. package/lib/front_end/core/sdk/ResourceTreeModel.ts +0 -1160
  142. package/lib/front_end/core/sdk/RuntimeModel.ts +0 -732
  143. package/lib/front_end/core/sdk/SDKModel.ts +0 -65
  144. package/lib/front_end/core/sdk/ScopeTreeCache.ts +0 -45
  145. package/lib/front_end/core/sdk/ScreenCaptureModel.ts +0 -255
  146. package/lib/front_end/core/sdk/Script.ts +0 -534
  147. package/lib/front_end/core/sdk/SecurityOriginManager.ts +0 -76
  148. package/lib/front_end/core/sdk/ServerSentEvents.ts +0 -80
  149. package/lib/front_end/core/sdk/ServerSentEventsProtocol.ts +0 -122
  150. package/lib/front_end/core/sdk/ServerTiming.ts +0 -260
  151. package/lib/front_end/core/sdk/ServiceWorkerCacheModel.ts +0 -377
  152. package/lib/front_end/core/sdk/ServiceWorkerManager.ts +0 -605
  153. package/lib/front_end/core/sdk/SourceMap.ts +0 -867
  154. package/lib/front_end/core/sdk/SourceMapCache.ts +0 -54
  155. package/lib/front_end/core/sdk/SourceMapFunctionRanges.ts +0 -156
  156. package/lib/front_end/core/sdk/SourceMapManager.ts +0 -239
  157. package/lib/front_end/core/sdk/SourceMapScopeChainEntry.ts +0 -189
  158. package/lib/front_end/core/sdk/SourceMapScopesInfo.ts +0 -508
  159. package/lib/front_end/core/sdk/StorageBucketsModel.ts +0 -204
  160. package/lib/front_end/core/sdk/StorageKeyManager.ts +0 -98
  161. package/lib/front_end/core/sdk/Target.ts +0 -332
  162. package/lib/front_end/core/sdk/TargetManager.ts +0 -453
  163. package/lib/front_end/core/sdk/TraceObject.ts +0 -61
  164. package/lib/front_end/core/sdk/WebAuthnModel.ts +0 -104
  165. package/lib/front_end/core/sdk/sdk.ts +0 -174
  166. package/lib/front_end/entrypoints/formatter_worker/FormatterActions.ts +0 -59
  167. package/lib/front_end/generated/InspectorBackendCommands.js +0 -1617
  168. package/lib/front_end/generated/SupportedCSSProperties.js +0 -7512
  169. package/lib/front_end/generated/protocol-proxy-api.d.ts +0 -5022
  170. package/lib/front_end/generated/protocol.ts +0 -22014
  171. package/lib/front_end/models/bindings/CSSWorkspaceBinding.ts +0 -318
  172. package/lib/front_end/models/bindings/CompilerScriptMapping.ts +0 -536
  173. package/lib/front_end/models/bindings/ContentProviderBasedProject.ts +0 -187
  174. package/lib/front_end/models/bindings/DebuggerLanguagePlugins.ts +0 -1197
  175. package/lib/front_end/models/bindings/DebuggerWorkspaceBinding.ts +0 -733
  176. package/lib/front_end/models/bindings/DefaultScriptMapping.ts +0 -141
  177. package/lib/front_end/models/bindings/FileUtils.ts +0 -228
  178. package/lib/front_end/models/bindings/LiveLocation.ts +0 -81
  179. package/lib/front_end/models/bindings/NetworkProject.ts +0 -157
  180. package/lib/front_end/models/bindings/PresentationConsoleMessageHelper.ts +0 -312
  181. package/lib/front_end/models/bindings/ResourceMapping.ts +0 -539
  182. package/lib/front_end/models/bindings/ResourceScriptMapping.ts +0 -491
  183. package/lib/front_end/models/bindings/ResourceUtils.ts +0 -103
  184. package/lib/front_end/models/bindings/SASSSourceMapping.ts +0 -222
  185. package/lib/front_end/models/bindings/StylesSourceMapping.ts +0 -316
  186. package/lib/front_end/models/bindings/TempFile.ts +0 -67
  187. package/lib/front_end/models/bindings/bindings.ts +0 -39
  188. package/lib/front_end/models/cpu_profile/CPUProfileDataModel.ts +0 -571
  189. package/lib/front_end/models/cpu_profile/ProfileTreeModel.ts +0 -103
  190. package/lib/front_end/models/cpu_profile/cpu_profile.ts +0 -11
  191. package/lib/front_end/models/formatter/FormatterWorkerPool.ts +0 -219
  192. package/lib/front_end/models/formatter/ScriptFormatter.ts +0 -112
  193. package/lib/front_end/models/formatter/formatter.ts +0 -8
  194. package/lib/front_end/models/source_map_scopes/NamesResolver.ts +0 -765
  195. package/lib/front_end/models/source_map_scopes/ScopeChainModel.ts +0 -84
  196. package/lib/front_end/models/source_map_scopes/source_map_scopes.ts +0 -11
  197. package/lib/front_end/models/stack_trace/StackTrace.ts +0 -53
  198. package/lib/front_end/models/stack_trace/StackTraceImpl.ts +0 -85
  199. package/lib/front_end/models/stack_trace/StackTraceModel.ts +0 -128
  200. package/lib/front_end/models/stack_trace/Trie.ts +0 -163
  201. package/lib/front_end/models/stack_trace/stack_trace.ts +0 -9
  202. package/lib/front_end/models/stack_trace/stack_trace_impl.ts +0 -13
  203. package/lib/front_end/models/text_utils/CodeMirrorUtils.ts +0 -37
  204. package/lib/front_end/models/text_utils/ContentData.ts +0 -199
  205. package/lib/front_end/models/text_utils/ContentProvider.ts +0 -68
  206. package/lib/front_end/models/text_utils/StaticContentProvider.ts +0 -49
  207. package/lib/front_end/models/text_utils/StreamingContentData.ts +0 -108
  208. package/lib/front_end/models/text_utils/Text.ts +0 -90
  209. package/lib/front_end/models/text_utils/TextCursor.ts +0 -44
  210. package/lib/front_end/models/text_utils/TextRange.ts +0 -266
  211. package/lib/front_end/models/text_utils/TextUtils.ts +0 -401
  212. package/lib/front_end/models/text_utils/WasmDisassembly.ts +0 -87
  213. package/lib/front_end/models/text_utils/text_utils.ts +0 -27
  214. package/lib/front_end/models/trace/EntityMapper.ts +0 -141
  215. package/lib/front_end/models/trace/EventsSerializer.ts +0 -101
  216. package/lib/front_end/models/trace/LanternComputationData.ts +0 -438
  217. package/lib/front_end/models/trace/ModelImpl.ts +0 -236
  218. package/lib/front_end/models/trace/Name.ts +0 -136
  219. package/lib/front_end/models/trace/Processor.ts +0 -652
  220. package/lib/front_end/models/trace/Styles.ts +0 -1138
  221. package/lib/front_end/models/trace/extras/FilmStrip.ts +0 -78
  222. package/lib/front_end/models/trace/extras/MainThreadActivity.ts +0 -86
  223. package/lib/front_end/models/trace/extras/ScriptDuplication.ts +0 -236
  224. package/lib/front_end/models/trace/extras/StackTraceForEvent.ts +0 -203
  225. package/lib/front_end/models/trace/extras/ThirdParties.ts +0 -164
  226. package/lib/front_end/models/trace/extras/TraceFilter.ts +0 -62
  227. package/lib/front_end/models/trace/extras/TraceTree.ts +0 -701
  228. package/lib/front_end/models/trace/extras/extras.ts +0 -11
  229. package/lib/front_end/models/trace/handlers/AnimationFramesHandler.ts +0 -128
  230. package/lib/front_end/models/trace/handlers/AnimationHandler.ts +0 -36
  231. package/lib/front_end/models/trace/handlers/AsyncJSCallsHandler.ts +0 -239
  232. package/lib/front_end/models/trace/handlers/AuctionWorkletsHandler.ts +0 -183
  233. package/lib/front_end/models/trace/handlers/DOMStatsHandler.ts +0 -31
  234. package/lib/front_end/models/trace/handlers/ExtensionTraceDataHandler.ts +0 -306
  235. package/lib/front_end/models/trace/handlers/FlowsHandler.ts +0 -175
  236. package/lib/front_end/models/trace/handlers/FramesHandler.ts +0 -571
  237. package/lib/front_end/models/trace/handlers/GPUHandler.ts +0 -50
  238. package/lib/front_end/models/trace/handlers/ImagePaintingHandler.ts +0 -183
  239. package/lib/front_end/models/trace/handlers/InitiatorsHandler.ts +0 -193
  240. package/lib/front_end/models/trace/handlers/InvalidationsHandler.ts +0 -168
  241. package/lib/front_end/models/trace/handlers/LargestImagePaintHandler.ts +0 -109
  242. package/lib/front_end/models/trace/handlers/LargestTextPaintHandler.ts +0 -35
  243. package/lib/front_end/models/trace/handlers/LayerTreeHandler.ts +0 -123
  244. package/lib/front_end/models/trace/handlers/LayoutShiftsHandler.ts +0 -573
  245. package/lib/front_end/models/trace/handlers/MemoryHandler.ts +0 -31
  246. package/lib/front_end/models/trace/handlers/MetaHandler.ts +0 -525
  247. package/lib/front_end/models/trace/handlers/ModelHandlers.ts +0 -34
  248. package/lib/front_end/models/trace/handlers/NetworkRequestsHandler.ts +0 -672
  249. package/lib/front_end/models/trace/handlers/PageFramesHandler.ts +0 -52
  250. package/lib/front_end/models/trace/handlers/PageLoadMetricsHandler.ts +0 -460
  251. package/lib/front_end/models/trace/handlers/RendererHandler.ts +0 -428
  252. package/lib/front_end/models/trace/handlers/SamplesHandler.ts +0 -271
  253. package/lib/front_end/models/trace/handlers/ScreenshotsHandler.ts +0 -122
  254. package/lib/front_end/models/trace/handlers/ScriptsHandler.ts +0 -336
  255. package/lib/front_end/models/trace/handlers/SelectorStatsHandler.ts +0 -110
  256. package/lib/front_end/models/trace/handlers/Threads.ts +0 -139
  257. package/lib/front_end/models/trace/handlers/UserInteractionsHandler.ts +0 -400
  258. package/lib/front_end/models/trace/handlers/UserTimingsHandler.ts +0 -233
  259. package/lib/front_end/models/trace/handlers/WarningsHandler.ts +0 -162
  260. package/lib/front_end/models/trace/handlers/WorkersHandler.ts +0 -45
  261. package/lib/front_end/models/trace/handlers/handlers.ts +0 -8
  262. package/lib/front_end/models/trace/handlers/helpers.ts +0 -196
  263. package/lib/front_end/models/trace/handlers/types.ts +0 -75
  264. package/lib/front_end/models/trace/helpers/Extensions.ts +0 -54
  265. package/lib/front_end/models/trace/helpers/Network.ts +0 -129
  266. package/lib/front_end/models/trace/helpers/SamplesIntegrator.ts +0 -544
  267. package/lib/front_end/models/trace/helpers/SyntheticEvents.ts +0 -87
  268. package/lib/front_end/models/trace/helpers/Timing.ts +0 -248
  269. package/lib/front_end/models/trace/helpers/Trace.ts +0 -928
  270. package/lib/front_end/models/trace/helpers/TreeHelpers.ts +0 -320
  271. package/lib/front_end/models/trace/helpers/helpers.ts +0 -11
  272. package/lib/front_end/models/trace/insights/CLSCulprits.ts +0 -668
  273. package/lib/front_end/models/trace/insights/Cache.ts +0 -269
  274. package/lib/front_end/models/trace/insights/Common.ts +0 -453
  275. package/lib/front_end/models/trace/insights/DOMSize.ts +0 -223
  276. package/lib/front_end/models/trace/insights/DocumentLatency.ts +0 -319
  277. package/lib/front_end/models/trace/insights/DuplicatedJavaScript.ts +0 -126
  278. package/lib/front_end/models/trace/insights/FontDisplay.ts +0 -119
  279. package/lib/front_end/models/trace/insights/ForcedReflow.ts +0 -220
  280. package/lib/front_end/models/trace/insights/INPBreakdown.ts +0 -171
  281. package/lib/front_end/models/trace/insights/ImageDelivery.ts +0 -348
  282. package/lib/front_end/models/trace/insights/LCPBreakdown.ts +0 -268
  283. package/lib/front_end/models/trace/insights/LCPDiscovery.ts +0 -237
  284. package/lib/front_end/models/trace/insights/LegacyJavaScript.ts +0 -138
  285. package/lib/front_end/models/trace/insights/Models.ts +0 -22
  286. package/lib/front_end/models/trace/insights/ModernHTTP.ts +0 -257
  287. package/lib/front_end/models/trace/insights/NetworkDependencyTree.ts +0 -726
  288. package/lib/front_end/models/trace/insights/RenderBlocking.ts +0 -257
  289. package/lib/front_end/models/trace/insights/SlowCSSSelector.ts +0 -175
  290. package/lib/front_end/models/trace/insights/Statistics.ts +0 -101
  291. package/lib/front_end/models/trace/insights/ThirdParties.ts +0 -130
  292. package/lib/front_end/models/trace/insights/Viewport.ts +0 -138
  293. package/lib/front_end/models/trace/insights/insights.ts +0 -10
  294. package/lib/front_end/models/trace/insights/types.ts +0 -157
  295. package/lib/front_end/models/trace/lantern/core/LanternError.ts +0 -7
  296. package/lib/front_end/models/trace/lantern/core/NetworkAnalyzer.ts +0 -619
  297. package/lib/front_end/models/trace/lantern/core/core.ts +0 -6
  298. package/lib/front_end/models/trace/lantern/graph/BaseNode.ts +0 -345
  299. package/lib/front_end/models/trace/lantern/graph/CPUNode.ts +0 -80
  300. package/lib/front_end/models/trace/lantern/graph/NetworkNode.ts +0 -101
  301. package/lib/front_end/models/trace/lantern/graph/PageDependencyGraph.ts +0 -636
  302. package/lib/front_end/models/trace/lantern/graph/graph.ts +0 -8
  303. package/lib/front_end/models/trace/lantern/lantern.ts +0 -17
  304. package/lib/front_end/models/trace/lantern/metrics/FirstContentfulPaint.ts +0 -187
  305. package/lib/front_end/models/trace/lantern/metrics/Interactive.ts +0 -88
  306. package/lib/front_end/models/trace/lantern/metrics/LargestContentfulPaint.ts +0 -92
  307. package/lib/front_end/models/trace/lantern/metrics/MaxPotentialFID.ts +0 -72
  308. package/lib/front_end/models/trace/lantern/metrics/Metric.ts +0 -126
  309. package/lib/front_end/models/trace/lantern/metrics/SpeedIndex.ts +0 -126
  310. package/lib/front_end/models/trace/lantern/metrics/TBTUtils.ts +0 -82
  311. package/lib/front_end/models/trace/lantern/metrics/TotalBlockingTime.ts +0 -112
  312. package/lib/front_end/models/trace/lantern/metrics/metrics.ts +0 -12
  313. package/lib/front_end/models/trace/lantern/simulation/ConnectionPool.ts +0 -150
  314. package/lib/front_end/models/trace/lantern/simulation/Constants.ts +0 -46
  315. package/lib/front_end/models/trace/lantern/simulation/DNSCache.ts +0 -61
  316. package/lib/front_end/models/trace/lantern/simulation/SimulationTimingMap.ts +0 -196
  317. package/lib/front_end/models/trace/lantern/simulation/Simulator.ts +0 -556
  318. package/lib/front_end/models/trace/lantern/simulation/TCPConnection.ts +0 -192
  319. package/lib/front_end/models/trace/lantern/simulation/simulation.ts +0 -10
  320. package/lib/front_end/models/trace/lantern/types/Lantern.ts +0 -220
  321. package/lib/front_end/models/trace/lantern/types/types.ts +0 -5
  322. package/lib/front_end/models/trace/trace.ts +0 -33
  323. package/lib/front_end/models/trace/types/Configuration.ts +0 -110
  324. package/lib/front_end/models/trace/types/Extensions.ts +0 -136
  325. package/lib/front_end/models/trace/types/File.ts +0 -281
  326. package/lib/front_end/models/trace/types/Overlays.ts +0 -138
  327. package/lib/front_end/models/trace/types/Timing.ts +0 -30
  328. package/lib/front_end/models/trace/types/TraceEvents.ts +0 -3277
  329. package/lib/front_end/models/trace/types/types.ts +0 -10
  330. package/lib/front_end/models/trace_source_maps_resolver/SourceMapsResolver.ts +0 -240
  331. package/lib/front_end/models/trace_source_maps_resolver/trace_source_maps_resolver.ts +0 -5
  332. package/lib/front_end/models/workspace/FileManager.ts +0 -97
  333. package/lib/front_end/models/workspace/IgnoreListManager.ts +0 -628
  334. package/lib/front_end/models/workspace/SearchConfig.ts +0 -149
  335. package/lib/front_end/models/workspace/UISourceCode.ts +0 -698
  336. package/lib/front_end/models/workspace/WorkspaceImpl.ts +0 -339
  337. package/lib/front_end/models/workspace/workspace.ts +0 -17
  338. package/lib/front_end/panels/timeline/TimelineUIUtils.ts +0 -1029
  339. package/lib/front_end/panels/timeline/extensions/ExtensionUI.ts +0 -49
  340. package/lib/front_end/panels/timeline/extensions/extensions.ts +0 -9
  341. package/lib/front_end/third_party/codemirror.next/LICENSE +0 -21
  342. package/lib/front_end/third_party/codemirror.next/README.chromium +0 -30
  343. package/lib/front_end/third_party/codemirror.next/bundle-tsconfig.json +0 -24
  344. package/lib/front_end/third_party/codemirror.next/bundle.ts +0 -135
  345. package/lib/front_end/third_party/codemirror.next/chunk/angular.js +0 -2
  346. package/lib/front_end/third_party/codemirror.next/chunk/angular.js.map +0 -1
  347. package/lib/front_end/third_party/codemirror.next/chunk/codemirror.js +0 -2
  348. package/lib/front_end/third_party/codemirror.next/chunk/codemirror.js.map +0 -1
  349. package/lib/front_end/third_party/codemirror.next/chunk/cpp.js +0 -2
  350. package/lib/front_end/third_party/codemirror.next/chunk/cpp.js.map +0 -1
  351. package/lib/front_end/third_party/codemirror.next/chunk/css.js +0 -2
  352. package/lib/front_end/third_party/codemirror.next/chunk/html.js +0 -4
  353. package/lib/front_end/third_party/codemirror.next/chunk/java.js +0 -2
  354. package/lib/front_end/third_party/codemirror.next/chunk/java.js.map +0 -1
  355. package/lib/front_end/third_party/codemirror.next/chunk/javascript.js +0 -2
  356. package/lib/front_end/third_party/codemirror.next/chunk/legacy.js +0 -2
  357. package/lib/front_end/third_party/codemirror.next/chunk/legacy.js.map +0 -1
  358. package/lib/front_end/third_party/codemirror.next/chunk/less.js +0 -2
  359. package/lib/front_end/third_party/codemirror.next/chunk/less.js.map +0 -1
  360. package/lib/front_end/third_party/codemirror.next/chunk/markdown.js +0 -2
  361. package/lib/front_end/third_party/codemirror.next/chunk/markdown.js.map +0 -1
  362. package/lib/front_end/third_party/codemirror.next/chunk/php.js +0 -2
  363. package/lib/front_end/third_party/codemirror.next/chunk/php.js.map +0 -1
  364. package/lib/front_end/third_party/codemirror.next/chunk/python.js +0 -2
  365. package/lib/front_end/third_party/codemirror.next/chunk/python.js.map +0 -1
  366. package/lib/front_end/third_party/codemirror.next/chunk/sass.js +0 -2
  367. package/lib/front_end/third_party/codemirror.next/chunk/sass.js.map +0 -1
  368. package/lib/front_end/third_party/codemirror.next/chunk/svelte.js +0 -2
  369. package/lib/front_end/third_party/codemirror.next/chunk/svelte.js.map +0 -1
  370. package/lib/front_end/third_party/codemirror.next/chunk/vue.js +0 -2
  371. package/lib/front_end/third_party/codemirror.next/chunk/vue.js.map +0 -1
  372. package/lib/front_end/third_party/codemirror.next/chunk/wast.js +0 -2
  373. package/lib/front_end/third_party/codemirror.next/chunk/wast.js.map +0 -1
  374. package/lib/front_end/third_party/codemirror.next/chunk/xml.js +0 -2
  375. package/lib/front_end/third_party/codemirror.next/chunk/xml.js.map +0 -1
  376. package/lib/front_end/third_party/codemirror.next/codemirror.next.d.ts +0 -8057
  377. package/lib/front_end/third_party/codemirror.next/codemirror.next.js +0 -2
  378. package/lib/front_end/third_party/codemirror.next/codemirror.next.js.map +0 -1
  379. package/lib/front_end/third_party/codemirror.next/package.json +0 -43
  380. package/lib/front_end/third_party/codemirror.next/rebuild.sh +0 -6
  381. package/lib/front_end/third_party/codemirror.next/rollup.config.mjs +0 -49
  382. package/lib/front_end/third_party/i18n/LICENSE +0 -202
  383. package/lib/front_end/third_party/i18n/README.chromium +0 -15
  384. package/lib/front_end/third_party/i18n/i18n-impl.ts +0 -61
  385. package/lib/front_end/third_party/i18n/i18n.ts +0 -11
  386. package/lib/front_end/third_party/i18n/localized-string-set.ts +0 -129
  387. package/lib/front_end/third_party/intl-messageformat/LICENSE +0 -33
  388. package/lib/front_end/third_party/intl-messageformat/README.chromium +0 -24
  389. package/lib/front_end/third_party/intl-messageformat/intl-messageformat-tsconfig.json +0 -16
  390. package/lib/front_end/third_party/intl-messageformat/intl-messageformat.ts +0 -6
  391. package/lib/front_end/third_party/intl-messageformat/package/LICENSE.md +0 -33
  392. package/lib/front_end/third_party/intl-messageformat/package/README.md +0 -3
  393. package/lib/front_end/third_party/intl-messageformat/package/index.d.ts +0 -6
  394. package/lib/front_end/third_party/intl-messageformat/package/index.d.ts.map +0 -1
  395. package/lib/front_end/third_party/intl-messageformat/package/index.js +0 -13
  396. package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.esm.d.ts +0 -5
  397. package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.esm.js +0 -1710
  398. package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.iife.js +0 -1815
  399. package/lib/front_end/third_party/intl-messageformat/package/lib/index.d.ts +0 -6
  400. package/lib/front_end/third_party/intl-messageformat/package/lib/index.d.ts.map +0 -1
  401. package/lib/front_end/third_party/intl-messageformat/package/lib/index.js +0 -10
  402. package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.d.ts +0 -34
  403. package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.d.ts.map +0 -1
  404. package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.js +0 -229
  405. package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.d.ts +0 -28
  406. package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.d.ts.map +0 -1
  407. package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.js +0 -48
  408. package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.d.ts +0 -34
  409. package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.d.ts.map +0 -1
  410. package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.js +0 -179
  411. package/lib/front_end/third_party/intl-messageformat/package/package.json +0 -42
  412. package/lib/front_end/third_party/intl-messageformat/package/src/core.d.ts +0 -34
  413. package/lib/front_end/third_party/intl-messageformat/package/src/core.d.ts.map +0 -1
  414. package/lib/front_end/third_party/intl-messageformat/package/src/core.js +0 -230
  415. package/lib/front_end/third_party/intl-messageformat/package/src/error.d.ts +0 -28
  416. package/lib/front_end/third_party/intl-messageformat/package/src/error.d.ts.map +0 -1
  417. package/lib/front_end/third_party/intl-messageformat/package/src/error.js +0 -51
  418. package/lib/front_end/third_party/intl-messageformat/package/src/formatters.d.ts +0 -34
  419. package/lib/front_end/third_party/intl-messageformat/package/src/formatters.d.ts.map +0 -1
  420. package/lib/front_end/third_party/intl-messageformat/package/src/formatters.js +0 -182
  421. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/error.d.ts +0 -79
  422. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/index.d.ts +0 -15
  423. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/parser.d.ts +0 -153
  424. package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/types.d.ts +0 -139
  425. package/lib/front_end/third_party/legacy-javascript/LICENSE +0 -202
  426. package/lib/front_end/third_party/legacy-javascript/README.chromium +0 -13
  427. package/lib/front_end/third_party/legacy-javascript/legacy-javascript-tsconfig.json +0 -8
  428. package/lib/front_end/third_party/legacy-javascript/legacy-javascript.ts +0 -3
  429. package/lib/front_end/third_party/legacy-javascript/lib/legacy-javascript.d.ts +0 -18
  430. package/lib/front_end/third_party/legacy-javascript/lib/legacy-javascript.js +0 -943
  431. package/lib/front_end/third_party/legacy-javascript/package.json +0 -8
  432. package/lib/front_end/third_party/legacy-javascript/rebuild.sh +0 -9
  433. package/lib/front_end/third_party/source-map-scopes-codec/LICENSE +0 -26
  434. package/lib/front_end/third_party/source-map-scopes-codec/README.chromium +0 -31
  435. package/lib/front_end/third_party/source-map-scopes-codec/package/CONTRIBUTING.md +0 -33
  436. package/lib/front_end/third_party/source-map-scopes-codec/package/LICENSE +0 -26
  437. package/lib/front_end/third_party/source-map-scopes-codec/package/README.md +0 -64
  438. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/builder.d.ts +0 -62
  439. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/builder.d.ts.map +0 -1
  440. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/safe_builder.d.ts +0 -37
  441. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/safe_builder.d.ts.map +0 -1
  442. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/decode/decode.d.ts +0 -29
  443. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/decode/decode.d.ts.map +0 -1
  444. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/encode/encode.d.ts +0 -8
  445. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/encode/encode.d.ts.map +0 -1
  446. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/mod.d.ts +0 -6
  447. package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/mod.d.ts.map +0 -1
  448. package/lib/front_end/third_party/source-map-scopes-codec/package/deno.json +0 -21
  449. package/lib/front_end/third_party/source-map-scopes-codec/package/package.json +0 -14
  450. package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/builder.js +0 -196
  451. package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/builder.js.map +0 -1
  452. package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/builder.ts +0 -262
  453. package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/safe_builder.js +0 -235
  454. package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/safe_builder.js.map +0 -1
  455. package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/safe_builder.ts +0 -359
  456. package/lib/front_end/third_party/source-map-scopes-codec/package/src/codec.js +0 -39
  457. package/lib/front_end/third_party/source-map-scopes-codec/package/src/codec.js.map +0 -1
  458. package/lib/front_end/third_party/source-map-scopes-codec/package/src/codec.ts +0 -53
  459. package/lib/front_end/third_party/source-map-scopes-codec/package/src/decode/decode.js +0 -438
  460. package/lib/front_end/third_party/source-map-scopes-codec/package/src/decode/decode.js.map +0 -1
  461. package/lib/front_end/third_party/source-map-scopes-codec/package/src/decode/decode.ts +0 -539
  462. package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encode.js +0 -23
  463. package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encode.js.map +0 -1
  464. package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encode.ts +0 -35
  465. package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encoder.js +0 -257
  466. package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encoder.js.map +0 -1
  467. package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encoder.ts +0 -348
  468. package/lib/front_end/third_party/source-map-scopes-codec/package/src/mod.js +0 -8
  469. package/lib/front_end/third_party/source-map-scopes-codec/package/src/mod.js.map +0 -1
  470. package/lib/front_end/third_party/source-map-scopes-codec/package/src/mod.ts +0 -20
  471. package/lib/front_end/third_party/source-map-scopes-codec/package/src/scopes-tsconfig.json +0 -8
  472. package/lib/front_end/third_party/source-map-scopes-codec/package/src/scopes.d.ts +0 -184
  473. package/lib/front_end/third_party/source-map-scopes-codec/package/src/util.js +0 -9
  474. package/lib/front_end/third_party/source-map-scopes-codec/package/src/util.js.map +0 -1
  475. package/lib/front_end/third_party/source-map-scopes-codec/package/src/util.ts +0 -12
  476. package/lib/front_end/third_party/source-map-scopes-codec/package/src/vlq.js +0 -82
  477. package/lib/front_end/third_party/source-map-scopes-codec/package/src/vlq.js.map +0 -1
  478. package/lib/front_end/third_party/source-map-scopes-codec/package/src/vlq.ts +0 -99
  479. package/lib/front_end/third_party/source-map-scopes-codec/source-map-scopes-codec.ts +0 -5
  480. package/lib/front_end/third_party/third-party-web/LICENSE +0 -20
  481. package/lib/front_end/third_party/third-party-web/README.chromium +0 -13
  482. package/lib/front_end/third_party/third-party-web/lib/nostats-subset.d.ts +0 -2
  483. package/lib/front_end/third_party/third-party-web/lib/nostats-subset.js +0 -149
  484. package/lib/front_end/third_party/third-party-web/package/LICENSE +0 -20
  485. package/lib/front_end/third_party/third-party-web/package/README.md +0 -929
  486. package/lib/front_end/third_party/third-party-web/package/dist/entities-httparchive-nostats.json +0 -1
  487. package/lib/front_end/third_party/third-party-web/package/dist/entities-httparchive.json +0 -1
  488. package/lib/front_end/third_party/third-party-web/package/dist/entities-nostats.json +0 -1
  489. package/lib/front_end/third_party/third-party-web/package/dist/entities.json +0 -1
  490. package/lib/front_end/third_party/third-party-web/package/facades.md +0 -46
  491. package/lib/front_end/third_party/third-party-web/package/httparchive-nostats-subset.d.ts +0 -1
  492. package/lib/front_end/third_party/third-party-web/package/httparchive-nostats-subset.js +0 -1
  493. package/lib/front_end/third_party/third-party-web/package/httparchive-subset.d.ts +0 -1
  494. package/lib/front_end/third_party/third-party-web/package/httparchive-subset.js +0 -1
  495. package/lib/front_end/third_party/third-party-web/package/lib/__snapshots__/index.test.js.snap +0 -1006
  496. package/lib/front_end/third_party/third-party-web/package/lib/create-entity-finder-api.js +0 -139
  497. package/lib/front_end/third_party/third-party-web/package/lib/create-entity-finder-api.test.js +0 -44
  498. package/lib/front_end/third_party/third-party-web/package/lib/entities.test.js +0 -27
  499. package/lib/front_end/third_party/third-party-web/package/lib/index.d.ts +0 -34
  500. package/lib/front_end/third_party/third-party-web/package/lib/index.js +0 -3
  501. package/lib/front_end/third_party/third-party-web/package/lib/index.test.js +0 -246
  502. package/lib/front_end/third_party/third-party-web/package/lib/markdown/faqs.partial.md +0 -36
  503. package/lib/front_end/third_party/third-party-web/package/lib/markdown/goals.partial.md +0 -9
  504. package/lib/front_end/third_party/third-party-web/package/lib/markdown/methodology.partial.md +0 -5
  505. package/lib/front_end/third_party/third-party-web/package/lib/markdown/template.md +0 -151
  506. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-02-01.md +0 -1
  507. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-03-01.md +0 -1
  508. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-05-06.md +0 -1
  509. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-05-13.md +0 -14
  510. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2021-01-01.md +0 -1
  511. package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2024-07-01.md +0 -3
  512. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive-nostats.d.ts +0 -1
  513. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive-nostats.js +0 -3
  514. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive.d.ts +0 -1
  515. package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive.js +0 -3
  516. package/lib/front_end/third_party/third-party-web/package/lib/subsets/nostats.d.ts +0 -1
  517. package/lib/front_end/third_party/third-party-web/package/lib/subsets/nostats.js +0 -3
  518. package/lib/front_end/third_party/third-party-web/package/nostats-subset.d.ts +0 -1
  519. package/lib/front_end/third_party/third-party-web/package/nostats-subset.js +0 -1
  520. package/lib/front_end/third_party/third-party-web/package/package.json +0 -46
  521. package/lib/front_end/third_party/third-party-web/package.json +0 -8
  522. package/lib/front_end/third_party/third-party-web/rebuild.sh +0 -13
  523. package/lib/front_end/third_party/third-party-web/third-party-web-tsconfig.json +0 -8
  524. package/lib/front_end/third_party/third-party-web/third-party-web.ts +0 -3
  525. package/lib/front_end/ui/legacy/theme_support/ThemeSupport.ts +0 -222
  526. package/lib/front_end/ui/legacy/theme_support/theme_support.ts +0 -5
  527. 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
- }