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