devtools-tracing 1.1.0 → 1.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.claude/settings.local.json +14 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.js +28854 -0
- package/package.json +10 -8
- package/generate.ts +0 -649
- package/index.ts +0 -17
- package/lib/extension-api/ExtensionAPI.d.ts +0 -357
- package/lib/front_end/core/common/App.ts +0 -7
- package/lib/front_end/core/common/AppProvider.ts +0 -32
- package/lib/front_end/core/common/Base64.ts +0 -47
- package/lib/front_end/core/common/CharacterIdMap.ts +0 -30
- package/lib/front_end/core/common/Color.ts +0 -2506
- package/lib/front_end/core/common/ColorConverter.ts +0 -402
- package/lib/front_end/core/common/ColorUtils.ts +0 -252
- package/lib/front_end/core/common/Console.ts +0 -114
- package/lib/front_end/core/common/Debouncer.ts +0 -15
- package/lib/front_end/core/common/EventTarget.ts +0 -52
- package/lib/front_end/core/common/Gzip.ts +0 -74
- package/lib/front_end/core/common/JavaScriptMetaData.ts +0 -29
- package/lib/front_end/core/common/Lazy.ts +0 -31
- package/lib/front_end/core/common/Linkifier.ts +0 -55
- package/lib/front_end/core/common/MapWithDefault.ts +0 -26
- package/lib/front_end/core/common/Mutex.ts +0 -55
- package/lib/front_end/core/common/Object.ts +0 -145
- package/lib/front_end/core/common/ParsedURL.ts +0 -554
- package/lib/front_end/core/common/Progress.ts +0 -180
- package/lib/front_end/core/common/QueryParamHandler.ts +0 -7
- package/lib/front_end/core/common/ResolverBase.ts +0 -85
- package/lib/front_end/core/common/ResourceType.ts +0 -588
- package/lib/front_end/core/common/ReturnToPanel.ts +0 -17
- package/lib/front_end/core/common/Revealer.ts +0 -192
- package/lib/front_end/core/common/Runnable.ts +0 -41
- package/lib/front_end/core/common/SegmentedRange.ts +0 -87
- package/lib/front_end/core/common/SettingRegistration.ts +0 -339
- package/lib/front_end/core/common/Settings.ts +0 -1497
- package/lib/front_end/core/common/SimpleHistoryManager.ts +0 -124
- package/lib/front_end/core/common/StringOutputStream.ts +0 -26
- package/lib/front_end/core/common/TextDictionary.ts +0 -48
- package/lib/front_end/core/common/Throttler.ts +0 -99
- package/lib/front_end/core/common/Trie.ts +0 -152
- package/lib/front_end/core/common/Worker.ts +0 -60
- package/lib/front_end/core/common/common.ts +0 -81
- package/lib/front_end/core/host/AidaClient.ts +0 -733
- package/lib/front_end/core/host/GdpClient.ts +0 -316
- package/lib/front_end/core/host/InspectorFrontendHost.ts +0 -648
- package/lib/front_end/core/host/InspectorFrontendHostAPI.ts +0 -551
- package/lib/front_end/core/host/Platform.ts +0 -76
- package/lib/front_end/core/host/ResourceLoader.ts +0 -282
- package/lib/front_end/core/host/UserMetrics.ts +0 -1230
- package/lib/front_end/core/host/host.ts +0 -23
- package/lib/front_end/core/i18n/ByteUtilities.ts +0 -82
- package/lib/front_end/core/i18n/DevToolsLocale.ts +0 -87
- package/lib/front_end/core/i18n/NumberFormatter.ts +0 -82
- package/lib/front_end/core/i18n/i18n.ts +0 -17
- package/lib/front_end/core/i18n/i18nImpl.ts +0 -204
- package/lib/front_end/core/i18n/i18nTypes.ts +0 -10
- package/lib/front_end/core/i18n/locales.js +0 -14
- package/lib/front_end/core/i18n/time-utilities.ts +0 -174
- package/lib/front_end/core/platform/ArrayUtilities.ts +0 -271
- package/lib/front_end/core/platform/Brand.ts +0 -23
- package/lib/front_end/core/platform/Constructor.ts +0 -10
- package/lib/front_end/core/platform/DOMUtilities.ts +0 -138
- package/lib/front_end/core/platform/DateUtilities.ts +0 -15
- package/lib/front_end/core/platform/DevToolsPath.ts +0 -53
- package/lib/front_end/core/platform/KeyboardUtilities.ts +0 -38
- package/lib/front_end/core/platform/MapUtilities.ts +0 -95
- package/lib/front_end/core/platform/MimeType.ts +0 -175
- package/lib/front_end/core/platform/NumberUtilities.ts +0 -80
- package/lib/front_end/core/platform/StringUtilities.ts +0 -588
- package/lib/front_end/core/platform/Timing.ts +0 -17
- package/lib/front_end/core/platform/TypedArrayUtilities.ts +0 -189
- package/lib/front_end/core/platform/TypescriptUtilities.ts +0 -86
- package/lib/front_end/core/platform/UIString.ts +0 -39
- package/lib/front_end/core/platform/UserVisibleError.ts +0 -28
- package/lib/front_end/core/platform/platform.ts +0 -45
- package/lib/front_end/core/protocol_client/ConnectionTransport.ts +0 -26
- package/lib/front_end/core/protocol_client/InspectorBackend.ts +0 -1050
- package/lib/front_end/core/protocol_client/NodeURL.ts +0 -42
- package/lib/front_end/core/protocol_client/protocol_client.ts +0 -13
- package/lib/front_end/core/root/Runtime.ts +0 -609
- package/lib/front_end/core/root/root.ts +0 -6
- package/lib/front_end/core/sdk/AccessibilityModel.ts +0 -353
- package/lib/front_end/core/sdk/AnimationModel.ts +0 -1041
- package/lib/front_end/core/sdk/AutofillModel.ts +0 -184
- package/lib/front_end/core/sdk/CPUProfilerModel.ts +0 -148
- package/lib/front_end/core/sdk/CPUThrottlingManager.ts +0 -282
- package/lib/front_end/core/sdk/CSSContainerQuery.ts +0 -139
- package/lib/front_end/core/sdk/CSSFontFace.ts +0 -40
- package/lib/front_end/core/sdk/CSSLayer.ts +0 -30
- package/lib/front_end/core/sdk/CSSMatchedStyles.ts +0 -1646
- package/lib/front_end/core/sdk/CSSMedia.ts +0 -121
- package/lib/front_end/core/sdk/CSSMetadata.ts +0 -1647
- package/lib/front_end/core/sdk/CSSModel.ts +0 -1128
- package/lib/front_end/core/sdk/CSSProperty.ts +0 -384
- package/lib/front_end/core/sdk/CSSPropertyParser.ts +0 -681
- package/lib/front_end/core/sdk/CSSPropertyParserMatchers.ts +0 -1395
- package/lib/front_end/core/sdk/CSSQuery.ts +0 -72
- package/lib/front_end/core/sdk/CSSRule.ts +0 -465
- package/lib/front_end/core/sdk/CSSScope.ts +0 -30
- package/lib/front_end/core/sdk/CSSStartingStyle.ts +0 -29
- package/lib/front_end/core/sdk/CSSStyleDeclaration.ts +0 -313
- package/lib/front_end/core/sdk/CSSStyleSheetHeader.ts +0 -196
- package/lib/front_end/core/sdk/CSSSupports.ts +0 -33
- package/lib/front_end/core/sdk/CategorizedBreakpoint.ts +0 -64
- package/lib/front_end/core/sdk/ChildTargetManager.ts +0 -314
- package/lib/front_end/core/sdk/CompilerSourceMappingContentProvider.ts +0 -62
- package/lib/front_end/core/sdk/Connections.ts +0 -293
- package/lib/front_end/core/sdk/ConsoleModel.ts +0 -808
- package/lib/front_end/core/sdk/ConsoleModelTypes.ts +0 -15
- package/lib/front_end/core/sdk/Cookie.ts +0 -319
- package/lib/front_end/core/sdk/CookieModel.ts +0 -239
- package/lib/front_end/core/sdk/CookieParser.ts +0 -185
- package/lib/front_end/core/sdk/DOMDebuggerModel.ts +0 -787
- package/lib/front_end/core/sdk/DOMModel.ts +0 -1961
- package/lib/front_end/core/sdk/DebuggerModel.ts +0 -1605
- package/lib/front_end/core/sdk/EmulationModel.ts +0 -648
- package/lib/front_end/core/sdk/EnhancedTracesParser.ts +0 -515
- package/lib/front_end/core/sdk/EventBreakpointsModel.ts +0 -183
- package/lib/front_end/core/sdk/FrameAssociated.ts +0 -11
- package/lib/front_end/core/sdk/FrameManager.ts +0 -259
- package/lib/front_end/core/sdk/HeapProfilerModel.ts +0 -225
- package/lib/front_end/core/sdk/HttpReasonPhraseStrings.ts +0 -77
- package/lib/front_end/core/sdk/IOModel.ts +0 -91
- package/lib/front_end/core/sdk/IsolateManager.ts +0 -257
- package/lib/front_end/core/sdk/IssuesModel.ts +0 -70
- package/lib/front_end/core/sdk/LayerTreeBase.ts +0 -169
- package/lib/front_end/core/sdk/LogModel.ts +0 -56
- package/lib/front_end/core/sdk/NetworkManager.ts +0 -2823
- package/lib/front_end/core/sdk/NetworkRequest.ts +0 -2253
- package/lib/front_end/core/sdk/OverlayColorGenerator.ts +0 -52
- package/lib/front_end/core/sdk/OverlayModel.ts +0 -1011
- package/lib/front_end/core/sdk/OverlayPersistentHighlighter.ts +0 -522
- package/lib/front_end/core/sdk/PageLoad.ts +0 -35
- package/lib/front_end/core/sdk/PageResourceLoader.ts +0 -435
- package/lib/front_end/core/sdk/PaintProfiler.ts +0 -110
- package/lib/front_end/core/sdk/PerformanceMetricsModel.ts +0 -84
- package/lib/front_end/core/sdk/PreloadingModel.ts +0 -863
- package/lib/front_end/core/sdk/RehydratingConnection.ts +0 -386
- package/lib/front_end/core/sdk/RehydratingObject.ts +0 -66
- package/lib/front_end/core/sdk/RemoteObject.ts +0 -1160
- package/lib/front_end/core/sdk/Resource.ts +0 -232
- package/lib/front_end/core/sdk/ResourceTreeModel.ts +0 -1160
- package/lib/front_end/core/sdk/RuntimeModel.ts +0 -732
- package/lib/front_end/core/sdk/SDKModel.ts +0 -65
- package/lib/front_end/core/sdk/ScopeTreeCache.ts +0 -45
- package/lib/front_end/core/sdk/ScreenCaptureModel.ts +0 -255
- package/lib/front_end/core/sdk/Script.ts +0 -534
- package/lib/front_end/core/sdk/SecurityOriginManager.ts +0 -76
- package/lib/front_end/core/sdk/ServerSentEvents.ts +0 -80
- package/lib/front_end/core/sdk/ServerSentEventsProtocol.ts +0 -122
- package/lib/front_end/core/sdk/ServerTiming.ts +0 -260
- package/lib/front_end/core/sdk/ServiceWorkerCacheModel.ts +0 -377
- package/lib/front_end/core/sdk/ServiceWorkerManager.ts +0 -605
- package/lib/front_end/core/sdk/SourceMap.ts +0 -867
- package/lib/front_end/core/sdk/SourceMapCache.ts +0 -54
- package/lib/front_end/core/sdk/SourceMapFunctionRanges.ts +0 -156
- package/lib/front_end/core/sdk/SourceMapManager.ts +0 -239
- package/lib/front_end/core/sdk/SourceMapScopeChainEntry.ts +0 -189
- package/lib/front_end/core/sdk/SourceMapScopesInfo.ts +0 -508
- package/lib/front_end/core/sdk/StorageBucketsModel.ts +0 -204
- package/lib/front_end/core/sdk/StorageKeyManager.ts +0 -98
- package/lib/front_end/core/sdk/Target.ts +0 -332
- package/lib/front_end/core/sdk/TargetManager.ts +0 -453
- package/lib/front_end/core/sdk/TraceObject.ts +0 -61
- package/lib/front_end/core/sdk/WebAuthnModel.ts +0 -104
- package/lib/front_end/core/sdk/sdk.ts +0 -174
- package/lib/front_end/entrypoints/formatter_worker/FormatterActions.ts +0 -59
- package/lib/front_end/generated/InspectorBackendCommands.js +0 -1617
- package/lib/front_end/generated/SupportedCSSProperties.js +0 -7512
- package/lib/front_end/generated/protocol-proxy-api.d.ts +0 -5022
- package/lib/front_end/generated/protocol.ts +0 -22014
- package/lib/front_end/models/bindings/CSSWorkspaceBinding.ts +0 -318
- package/lib/front_end/models/bindings/CompilerScriptMapping.ts +0 -536
- package/lib/front_end/models/bindings/ContentProviderBasedProject.ts +0 -187
- package/lib/front_end/models/bindings/DebuggerLanguagePlugins.ts +0 -1197
- package/lib/front_end/models/bindings/DebuggerWorkspaceBinding.ts +0 -733
- package/lib/front_end/models/bindings/DefaultScriptMapping.ts +0 -141
- package/lib/front_end/models/bindings/FileUtils.ts +0 -228
- package/lib/front_end/models/bindings/LiveLocation.ts +0 -81
- package/lib/front_end/models/bindings/NetworkProject.ts +0 -157
- package/lib/front_end/models/bindings/PresentationConsoleMessageHelper.ts +0 -312
- package/lib/front_end/models/bindings/ResourceMapping.ts +0 -539
- package/lib/front_end/models/bindings/ResourceScriptMapping.ts +0 -491
- package/lib/front_end/models/bindings/ResourceUtils.ts +0 -103
- package/lib/front_end/models/bindings/SASSSourceMapping.ts +0 -222
- package/lib/front_end/models/bindings/StylesSourceMapping.ts +0 -316
- package/lib/front_end/models/bindings/TempFile.ts +0 -67
- package/lib/front_end/models/bindings/bindings.ts +0 -39
- package/lib/front_end/models/cpu_profile/CPUProfileDataModel.ts +0 -571
- package/lib/front_end/models/cpu_profile/ProfileTreeModel.ts +0 -103
- package/lib/front_end/models/cpu_profile/cpu_profile.ts +0 -11
- package/lib/front_end/models/formatter/FormatterWorkerPool.ts +0 -219
- package/lib/front_end/models/formatter/ScriptFormatter.ts +0 -112
- package/lib/front_end/models/formatter/formatter.ts +0 -8
- package/lib/front_end/models/source_map_scopes/NamesResolver.ts +0 -765
- package/lib/front_end/models/source_map_scopes/ScopeChainModel.ts +0 -84
- package/lib/front_end/models/source_map_scopes/source_map_scopes.ts +0 -11
- package/lib/front_end/models/stack_trace/StackTrace.ts +0 -53
- package/lib/front_end/models/stack_trace/StackTraceImpl.ts +0 -85
- package/lib/front_end/models/stack_trace/StackTraceModel.ts +0 -128
- package/lib/front_end/models/stack_trace/Trie.ts +0 -163
- package/lib/front_end/models/stack_trace/stack_trace.ts +0 -9
- package/lib/front_end/models/stack_trace/stack_trace_impl.ts +0 -13
- package/lib/front_end/models/text_utils/CodeMirrorUtils.ts +0 -37
- package/lib/front_end/models/text_utils/ContentData.ts +0 -199
- package/lib/front_end/models/text_utils/ContentProvider.ts +0 -68
- package/lib/front_end/models/text_utils/StaticContentProvider.ts +0 -49
- package/lib/front_end/models/text_utils/StreamingContentData.ts +0 -108
- package/lib/front_end/models/text_utils/Text.ts +0 -90
- package/lib/front_end/models/text_utils/TextCursor.ts +0 -44
- package/lib/front_end/models/text_utils/TextRange.ts +0 -266
- package/lib/front_end/models/text_utils/TextUtils.ts +0 -401
- package/lib/front_end/models/text_utils/WasmDisassembly.ts +0 -87
- package/lib/front_end/models/text_utils/text_utils.ts +0 -27
- package/lib/front_end/models/trace/EntityMapper.ts +0 -141
- package/lib/front_end/models/trace/EventsSerializer.ts +0 -101
- package/lib/front_end/models/trace/LanternComputationData.ts +0 -438
- package/lib/front_end/models/trace/ModelImpl.ts +0 -236
- package/lib/front_end/models/trace/Name.ts +0 -136
- package/lib/front_end/models/trace/Processor.ts +0 -652
- package/lib/front_end/models/trace/Styles.ts +0 -1138
- package/lib/front_end/models/trace/extras/FilmStrip.ts +0 -78
- package/lib/front_end/models/trace/extras/MainThreadActivity.ts +0 -86
- package/lib/front_end/models/trace/extras/ScriptDuplication.ts +0 -236
- package/lib/front_end/models/trace/extras/StackTraceForEvent.ts +0 -203
- package/lib/front_end/models/trace/extras/ThirdParties.ts +0 -164
- package/lib/front_end/models/trace/extras/TraceFilter.ts +0 -62
- package/lib/front_end/models/trace/extras/TraceTree.ts +0 -701
- package/lib/front_end/models/trace/extras/extras.ts +0 -11
- package/lib/front_end/models/trace/handlers/AnimationFramesHandler.ts +0 -128
- package/lib/front_end/models/trace/handlers/AnimationHandler.ts +0 -36
- package/lib/front_end/models/trace/handlers/AsyncJSCallsHandler.ts +0 -239
- package/lib/front_end/models/trace/handlers/AuctionWorkletsHandler.ts +0 -183
- package/lib/front_end/models/trace/handlers/DOMStatsHandler.ts +0 -31
- package/lib/front_end/models/trace/handlers/ExtensionTraceDataHandler.ts +0 -306
- package/lib/front_end/models/trace/handlers/FlowsHandler.ts +0 -175
- package/lib/front_end/models/trace/handlers/FramesHandler.ts +0 -571
- package/lib/front_end/models/trace/handlers/GPUHandler.ts +0 -50
- package/lib/front_end/models/trace/handlers/ImagePaintingHandler.ts +0 -183
- package/lib/front_end/models/trace/handlers/InitiatorsHandler.ts +0 -193
- package/lib/front_end/models/trace/handlers/InvalidationsHandler.ts +0 -168
- package/lib/front_end/models/trace/handlers/LargestImagePaintHandler.ts +0 -109
- package/lib/front_end/models/trace/handlers/LargestTextPaintHandler.ts +0 -35
- package/lib/front_end/models/trace/handlers/LayerTreeHandler.ts +0 -123
- package/lib/front_end/models/trace/handlers/LayoutShiftsHandler.ts +0 -573
- package/lib/front_end/models/trace/handlers/MemoryHandler.ts +0 -31
- package/lib/front_end/models/trace/handlers/MetaHandler.ts +0 -525
- package/lib/front_end/models/trace/handlers/ModelHandlers.ts +0 -34
- package/lib/front_end/models/trace/handlers/NetworkRequestsHandler.ts +0 -672
- package/lib/front_end/models/trace/handlers/PageFramesHandler.ts +0 -52
- package/lib/front_end/models/trace/handlers/PageLoadMetricsHandler.ts +0 -460
- package/lib/front_end/models/trace/handlers/RendererHandler.ts +0 -428
- package/lib/front_end/models/trace/handlers/SamplesHandler.ts +0 -271
- package/lib/front_end/models/trace/handlers/ScreenshotsHandler.ts +0 -122
- package/lib/front_end/models/trace/handlers/ScriptsHandler.ts +0 -336
- package/lib/front_end/models/trace/handlers/SelectorStatsHandler.ts +0 -110
- package/lib/front_end/models/trace/handlers/Threads.ts +0 -139
- package/lib/front_end/models/trace/handlers/UserInteractionsHandler.ts +0 -400
- package/lib/front_end/models/trace/handlers/UserTimingsHandler.ts +0 -233
- package/lib/front_end/models/trace/handlers/WarningsHandler.ts +0 -162
- package/lib/front_end/models/trace/handlers/WorkersHandler.ts +0 -45
- package/lib/front_end/models/trace/handlers/handlers.ts +0 -8
- package/lib/front_end/models/trace/handlers/helpers.ts +0 -196
- package/lib/front_end/models/trace/handlers/types.ts +0 -75
- package/lib/front_end/models/trace/helpers/Extensions.ts +0 -54
- package/lib/front_end/models/trace/helpers/Network.ts +0 -129
- package/lib/front_end/models/trace/helpers/SamplesIntegrator.ts +0 -544
- package/lib/front_end/models/trace/helpers/SyntheticEvents.ts +0 -87
- package/lib/front_end/models/trace/helpers/Timing.ts +0 -248
- package/lib/front_end/models/trace/helpers/Trace.ts +0 -928
- package/lib/front_end/models/trace/helpers/TreeHelpers.ts +0 -320
- package/lib/front_end/models/trace/helpers/helpers.ts +0 -11
- package/lib/front_end/models/trace/insights/CLSCulprits.ts +0 -668
- package/lib/front_end/models/trace/insights/Cache.ts +0 -269
- package/lib/front_end/models/trace/insights/Common.ts +0 -453
- package/lib/front_end/models/trace/insights/DOMSize.ts +0 -223
- package/lib/front_end/models/trace/insights/DocumentLatency.ts +0 -319
- package/lib/front_end/models/trace/insights/DuplicatedJavaScript.ts +0 -126
- package/lib/front_end/models/trace/insights/FontDisplay.ts +0 -119
- package/lib/front_end/models/trace/insights/ForcedReflow.ts +0 -220
- package/lib/front_end/models/trace/insights/INPBreakdown.ts +0 -171
- package/lib/front_end/models/trace/insights/ImageDelivery.ts +0 -348
- package/lib/front_end/models/trace/insights/LCPBreakdown.ts +0 -268
- package/lib/front_end/models/trace/insights/LCPDiscovery.ts +0 -237
- package/lib/front_end/models/trace/insights/LegacyJavaScript.ts +0 -138
- package/lib/front_end/models/trace/insights/Models.ts +0 -22
- package/lib/front_end/models/trace/insights/ModernHTTP.ts +0 -257
- package/lib/front_end/models/trace/insights/NetworkDependencyTree.ts +0 -726
- package/lib/front_end/models/trace/insights/RenderBlocking.ts +0 -257
- package/lib/front_end/models/trace/insights/SlowCSSSelector.ts +0 -175
- package/lib/front_end/models/trace/insights/Statistics.ts +0 -101
- package/lib/front_end/models/trace/insights/ThirdParties.ts +0 -130
- package/lib/front_end/models/trace/insights/Viewport.ts +0 -138
- package/lib/front_end/models/trace/insights/insights.ts +0 -10
- package/lib/front_end/models/trace/insights/types.ts +0 -157
- package/lib/front_end/models/trace/lantern/core/LanternError.ts +0 -7
- package/lib/front_end/models/trace/lantern/core/NetworkAnalyzer.ts +0 -619
- package/lib/front_end/models/trace/lantern/core/core.ts +0 -6
- package/lib/front_end/models/trace/lantern/graph/BaseNode.ts +0 -345
- package/lib/front_end/models/trace/lantern/graph/CPUNode.ts +0 -80
- package/lib/front_end/models/trace/lantern/graph/NetworkNode.ts +0 -101
- package/lib/front_end/models/trace/lantern/graph/PageDependencyGraph.ts +0 -636
- package/lib/front_end/models/trace/lantern/graph/graph.ts +0 -8
- package/lib/front_end/models/trace/lantern/lantern.ts +0 -17
- package/lib/front_end/models/trace/lantern/metrics/FirstContentfulPaint.ts +0 -187
- package/lib/front_end/models/trace/lantern/metrics/Interactive.ts +0 -88
- package/lib/front_end/models/trace/lantern/metrics/LargestContentfulPaint.ts +0 -92
- package/lib/front_end/models/trace/lantern/metrics/MaxPotentialFID.ts +0 -72
- package/lib/front_end/models/trace/lantern/metrics/Metric.ts +0 -126
- package/lib/front_end/models/trace/lantern/metrics/SpeedIndex.ts +0 -126
- package/lib/front_end/models/trace/lantern/metrics/TBTUtils.ts +0 -82
- package/lib/front_end/models/trace/lantern/metrics/TotalBlockingTime.ts +0 -112
- package/lib/front_end/models/trace/lantern/metrics/metrics.ts +0 -12
- package/lib/front_end/models/trace/lantern/simulation/ConnectionPool.ts +0 -150
- package/lib/front_end/models/trace/lantern/simulation/Constants.ts +0 -46
- package/lib/front_end/models/trace/lantern/simulation/DNSCache.ts +0 -61
- package/lib/front_end/models/trace/lantern/simulation/SimulationTimingMap.ts +0 -196
- package/lib/front_end/models/trace/lantern/simulation/Simulator.ts +0 -556
- package/lib/front_end/models/trace/lantern/simulation/TCPConnection.ts +0 -192
- package/lib/front_end/models/trace/lantern/simulation/simulation.ts +0 -10
- package/lib/front_end/models/trace/lantern/types/Lantern.ts +0 -220
- package/lib/front_end/models/trace/lantern/types/types.ts +0 -5
- package/lib/front_end/models/trace/trace.ts +0 -33
- package/lib/front_end/models/trace/types/Configuration.ts +0 -110
- package/lib/front_end/models/trace/types/Extensions.ts +0 -136
- package/lib/front_end/models/trace/types/File.ts +0 -281
- package/lib/front_end/models/trace/types/Overlays.ts +0 -138
- package/lib/front_end/models/trace/types/Timing.ts +0 -30
- package/lib/front_end/models/trace/types/TraceEvents.ts +0 -3277
- package/lib/front_end/models/trace/types/types.ts +0 -10
- package/lib/front_end/models/trace_source_maps_resolver/SourceMapsResolver.ts +0 -240
- package/lib/front_end/models/trace_source_maps_resolver/trace_source_maps_resolver.ts +0 -5
- package/lib/front_end/models/workspace/FileManager.ts +0 -97
- package/lib/front_end/models/workspace/IgnoreListManager.ts +0 -628
- package/lib/front_end/models/workspace/SearchConfig.ts +0 -149
- package/lib/front_end/models/workspace/UISourceCode.ts +0 -698
- package/lib/front_end/models/workspace/WorkspaceImpl.ts +0 -339
- package/lib/front_end/models/workspace/workspace.ts +0 -17
- package/lib/front_end/panels/timeline/TimelineUIUtils.ts +0 -1029
- package/lib/front_end/panels/timeline/extensions/ExtensionUI.ts +0 -49
- package/lib/front_end/panels/timeline/extensions/extensions.ts +0 -9
- package/lib/front_end/third_party/codemirror.next/LICENSE +0 -21
- package/lib/front_end/third_party/codemirror.next/README.chromium +0 -30
- package/lib/front_end/third_party/codemirror.next/bundle-tsconfig.json +0 -24
- package/lib/front_end/third_party/codemirror.next/bundle.ts +0 -135
- package/lib/front_end/third_party/codemirror.next/chunk/angular.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/angular.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/codemirror.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/codemirror.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/cpp.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/cpp.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/css.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/html.js +0 -4
- package/lib/front_end/third_party/codemirror.next/chunk/java.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/java.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/javascript.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/legacy.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/legacy.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/less.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/less.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/markdown.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/markdown.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/php.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/php.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/python.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/python.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/sass.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/sass.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/svelte.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/svelte.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/vue.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/vue.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/wast.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/wast.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/chunk/xml.js +0 -2
- package/lib/front_end/third_party/codemirror.next/chunk/xml.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/codemirror.next.d.ts +0 -8057
- package/lib/front_end/third_party/codemirror.next/codemirror.next.js +0 -2
- package/lib/front_end/third_party/codemirror.next/codemirror.next.js.map +0 -1
- package/lib/front_end/third_party/codemirror.next/package.json +0 -43
- package/lib/front_end/third_party/codemirror.next/rebuild.sh +0 -6
- package/lib/front_end/third_party/codemirror.next/rollup.config.mjs +0 -49
- package/lib/front_end/third_party/i18n/LICENSE +0 -202
- package/lib/front_end/third_party/i18n/README.chromium +0 -15
- package/lib/front_end/third_party/i18n/i18n-impl.ts +0 -61
- package/lib/front_end/third_party/i18n/i18n.ts +0 -11
- package/lib/front_end/third_party/i18n/localized-string-set.ts +0 -129
- package/lib/front_end/third_party/intl-messageformat/LICENSE +0 -33
- package/lib/front_end/third_party/intl-messageformat/README.chromium +0 -24
- package/lib/front_end/third_party/intl-messageformat/intl-messageformat-tsconfig.json +0 -16
- package/lib/front_end/third_party/intl-messageformat/intl-messageformat.ts +0 -6
- package/lib/front_end/third_party/intl-messageformat/package/LICENSE.md +0 -33
- package/lib/front_end/third_party/intl-messageformat/package/README.md +0 -3
- package/lib/front_end/third_party/intl-messageformat/package/index.d.ts +0 -6
- package/lib/front_end/third_party/intl-messageformat/package/index.d.ts.map +0 -1
- package/lib/front_end/third_party/intl-messageformat/package/index.js +0 -13
- package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.esm.d.ts +0 -5
- package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.esm.js +0 -1710
- package/lib/front_end/third_party/intl-messageformat/package/intl-messageformat.iife.js +0 -1815
- package/lib/front_end/third_party/intl-messageformat/package/lib/index.d.ts +0 -6
- package/lib/front_end/third_party/intl-messageformat/package/lib/index.d.ts.map +0 -1
- package/lib/front_end/third_party/intl-messageformat/package/lib/index.js +0 -10
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.d.ts +0 -34
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.d.ts.map +0 -1
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/core.js +0 -229
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.d.ts +0 -28
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.d.ts.map +0 -1
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/error.js +0 -48
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.d.ts +0 -34
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.d.ts.map +0 -1
- package/lib/front_end/third_party/intl-messageformat/package/lib/src/formatters.js +0 -179
- package/lib/front_end/third_party/intl-messageformat/package/package.json +0 -42
- package/lib/front_end/third_party/intl-messageformat/package/src/core.d.ts +0 -34
- package/lib/front_end/third_party/intl-messageformat/package/src/core.d.ts.map +0 -1
- package/lib/front_end/third_party/intl-messageformat/package/src/core.js +0 -230
- package/lib/front_end/third_party/intl-messageformat/package/src/error.d.ts +0 -28
- package/lib/front_end/third_party/intl-messageformat/package/src/error.d.ts.map +0 -1
- package/lib/front_end/third_party/intl-messageformat/package/src/error.js +0 -51
- package/lib/front_end/third_party/intl-messageformat/package/src/formatters.d.ts +0 -34
- package/lib/front_end/third_party/intl-messageformat/package/src/formatters.d.ts.map +0 -1
- package/lib/front_end/third_party/intl-messageformat/package/src/formatters.js +0 -182
- package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/error.d.ts +0 -79
- package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/index.d.ts +0 -15
- package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/parser.d.ts +0 -153
- package/lib/front_end/third_party/intl-messageformat/package/src/icu-messageformat-parser/types.d.ts +0 -139
- package/lib/front_end/third_party/legacy-javascript/LICENSE +0 -202
- package/lib/front_end/third_party/legacy-javascript/README.chromium +0 -13
- package/lib/front_end/third_party/legacy-javascript/legacy-javascript-tsconfig.json +0 -8
- package/lib/front_end/third_party/legacy-javascript/legacy-javascript.ts +0 -3
- package/lib/front_end/third_party/legacy-javascript/lib/legacy-javascript.d.ts +0 -18
- package/lib/front_end/third_party/legacy-javascript/lib/legacy-javascript.js +0 -943
- package/lib/front_end/third_party/legacy-javascript/package.json +0 -8
- package/lib/front_end/third_party/legacy-javascript/rebuild.sh +0 -9
- package/lib/front_end/third_party/source-map-scopes-codec/LICENSE +0 -26
- package/lib/front_end/third_party/source-map-scopes-codec/README.chromium +0 -31
- package/lib/front_end/third_party/source-map-scopes-codec/package/CONTRIBUTING.md +0 -33
- package/lib/front_end/third_party/source-map-scopes-codec/package/LICENSE +0 -26
- package/lib/front_end/third_party/source-map-scopes-codec/package/README.md +0 -64
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/builder.d.ts +0 -62
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/builder.d.ts.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/safe_builder.d.ts +0 -37
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/builder/safe_builder.d.ts.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/decode/decode.d.ts +0 -29
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/decode/decode.d.ts.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/encode/encode.d.ts +0 -8
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/encode/encode.d.ts.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/mod.d.ts +0 -6
- package/lib/front_end/third_party/source-map-scopes-codec/package/_dist/src/mod.d.ts.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/deno.json +0 -21
- package/lib/front_end/third_party/source-map-scopes-codec/package/package.json +0 -14
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/builder.js +0 -196
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/builder.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/builder.ts +0 -262
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/safe_builder.js +0 -235
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/safe_builder.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/builder/safe_builder.ts +0 -359
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/codec.js +0 -39
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/codec.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/codec.ts +0 -53
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/decode/decode.js +0 -438
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/decode/decode.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/decode/decode.ts +0 -539
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encode.js +0 -23
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encode.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encode.ts +0 -35
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encoder.js +0 -257
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encoder.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/encode/encoder.ts +0 -348
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/mod.js +0 -8
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/mod.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/mod.ts +0 -20
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/scopes-tsconfig.json +0 -8
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/scopes.d.ts +0 -184
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/util.js +0 -9
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/util.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/util.ts +0 -12
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/vlq.js +0 -82
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/vlq.js.map +0 -1
- package/lib/front_end/third_party/source-map-scopes-codec/package/src/vlq.ts +0 -99
- package/lib/front_end/third_party/source-map-scopes-codec/source-map-scopes-codec.ts +0 -5
- package/lib/front_end/third_party/third-party-web/LICENSE +0 -20
- package/lib/front_end/third_party/third-party-web/README.chromium +0 -13
- package/lib/front_end/third_party/third-party-web/lib/nostats-subset.d.ts +0 -2
- package/lib/front_end/third_party/third-party-web/lib/nostats-subset.js +0 -149
- package/lib/front_end/third_party/third-party-web/package/LICENSE +0 -20
- package/lib/front_end/third_party/third-party-web/package/README.md +0 -929
- package/lib/front_end/third_party/third-party-web/package/dist/entities-httparchive-nostats.json +0 -1
- package/lib/front_end/third_party/third-party-web/package/dist/entities-httparchive.json +0 -1
- package/lib/front_end/third_party/third-party-web/package/dist/entities-nostats.json +0 -1
- package/lib/front_end/third_party/third-party-web/package/dist/entities.json +0 -1
- package/lib/front_end/third_party/third-party-web/package/facades.md +0 -46
- package/lib/front_end/third_party/third-party-web/package/httparchive-nostats-subset.d.ts +0 -1
- package/lib/front_end/third_party/third-party-web/package/httparchive-nostats-subset.js +0 -1
- package/lib/front_end/third_party/third-party-web/package/httparchive-subset.d.ts +0 -1
- package/lib/front_end/third_party/third-party-web/package/httparchive-subset.js +0 -1
- package/lib/front_end/third_party/third-party-web/package/lib/__snapshots__/index.test.js.snap +0 -1006
- package/lib/front_end/third_party/third-party-web/package/lib/create-entity-finder-api.js +0 -139
- package/lib/front_end/third_party/third-party-web/package/lib/create-entity-finder-api.test.js +0 -44
- package/lib/front_end/third_party/third-party-web/package/lib/entities.test.js +0 -27
- package/lib/front_end/third_party/third-party-web/package/lib/index.d.ts +0 -34
- package/lib/front_end/third_party/third-party-web/package/lib/index.js +0 -3
- package/lib/front_end/third_party/third-party-web/package/lib/index.test.js +0 -246
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/faqs.partial.md +0 -36
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/goals.partial.md +0 -9
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/methodology.partial.md +0 -5
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/template.md +0 -151
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-02-01.md +0 -1
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-03-01.md +0 -1
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-05-06.md +0 -1
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2019-05-13.md +0 -14
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2021-01-01.md +0 -1
- package/lib/front_end/third_party/third-party-web/package/lib/markdown/updates/2024-07-01.md +0 -3
- package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive-nostats.d.ts +0 -1
- package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive-nostats.js +0 -3
- package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive.d.ts +0 -1
- package/lib/front_end/third_party/third-party-web/package/lib/subsets/httparchive.js +0 -3
- package/lib/front_end/third_party/third-party-web/package/lib/subsets/nostats.d.ts +0 -1
- package/lib/front_end/third_party/third-party-web/package/lib/subsets/nostats.js +0 -3
- package/lib/front_end/third_party/third-party-web/package/nostats-subset.d.ts +0 -1
- package/lib/front_end/third_party/third-party-web/package/nostats-subset.js +0 -1
- package/lib/front_end/third_party/third-party-web/package/package.json +0 -46
- package/lib/front_end/third_party/third-party-web/package.json +0 -8
- package/lib/front_end/third_party/third-party-web/rebuild.sh +0 -13
- package/lib/front_end/third_party/third-party-web/third-party-web-tsconfig.json +0 -8
- package/lib/front_end/third_party/third-party-web/third-party-web.ts +0 -3
- package/lib/front_end/ui/legacy/theme_support/ThemeSupport.ts +0 -222
- package/lib/front_end/ui/legacy/theme_support/theme_support.ts +0 -5
- package/patches/chrome-devtools-frontend+1.0.1533544.patch +0 -1716
|
@@ -1,139 +0,0 @@
|
|
|
1
|
-
// Copyright 2023 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 * as Helpers from '../helpers/helpers.js';
|
|
6
|
-
import type * as Types from '../types/types.js';
|
|
7
|
-
|
|
8
|
-
import type {AuctionWorkletsData} from './AuctionWorkletsHandler.js';
|
|
9
|
-
import type * as Renderer from './RendererHandler.js';
|
|
10
|
-
import type {HandlerData} from './types.js';
|
|
11
|
-
|
|
12
|
-
export interface ThreadData {
|
|
13
|
-
pid: Types.Events.ProcessID;
|
|
14
|
-
tid: Types.Events.ThreadID;
|
|
15
|
-
entries: readonly Types.Events.Event[];
|
|
16
|
-
processIsOnMainFrame: boolean;
|
|
17
|
-
tree: Helpers.TreeHelpers.TraceEntryTree;
|
|
18
|
-
type: ThreadType;
|
|
19
|
-
name: string|null;
|
|
20
|
-
entryToNode: Map<Types.Events.Event, Helpers.TreeHelpers.TraceEntryNode>;
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
export const enum ThreadType {
|
|
24
|
-
MAIN_THREAD = 'MAIN_THREAD',
|
|
25
|
-
WORKER = 'WORKER',
|
|
26
|
-
RASTERIZER = 'RASTERIZER',
|
|
27
|
-
AUCTION_WORKLET = 'AUCTION_WORKLET',
|
|
28
|
-
OTHER = 'OTHER',
|
|
29
|
-
CPU_PROFILE = 'CPU_PROFILE',
|
|
30
|
-
THREAD_POOL = 'THREAD_POOL',
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
function getThreadTypeForRendererThread(
|
|
34
|
-
pid: Types.Events.ProcessID, thread: Renderer.RendererThread,
|
|
35
|
-
auctionWorkletsData: AuctionWorkletsData): ThreadType {
|
|
36
|
-
let threadType = ThreadType.OTHER;
|
|
37
|
-
if (thread.name === 'CrRendererMain') {
|
|
38
|
-
threadType = ThreadType.MAIN_THREAD;
|
|
39
|
-
} else if (thread.name === 'DedicatedWorker thread') {
|
|
40
|
-
threadType = ThreadType.WORKER;
|
|
41
|
-
} else if (thread.name?.startsWith('CompositorTileWorker')) {
|
|
42
|
-
threadType = ThreadType.RASTERIZER;
|
|
43
|
-
} else if (auctionWorkletsData.worklets.has(pid)) {
|
|
44
|
-
threadType = ThreadType.AUCTION_WORKLET;
|
|
45
|
-
} else if (thread.name?.startsWith('ThreadPool')) {
|
|
46
|
-
// TODO(paulirish): perhaps exclude ThreadPoolServiceThread entirely
|
|
47
|
-
threadType = ThreadType.THREAD_POOL;
|
|
48
|
-
}
|
|
49
|
-
return threadType;
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
export function threadsInRenderer(
|
|
53
|
-
rendererData: Renderer.RendererHandlerData, auctionWorkletsData: AuctionWorkletsData): readonly ThreadData[] {
|
|
54
|
-
const foundThreads: ThreadData[] = [];
|
|
55
|
-
// If we have Renderer threads, we prefer to use those. In the event that a
|
|
56
|
-
// trace is a CPU Profile trace, we will never have Renderer threads, so we
|
|
57
|
-
// know if there are no Renderer threads that we can fallback to using the
|
|
58
|
-
// data from the SamplesHandler.
|
|
59
|
-
if (rendererData.processes.size) {
|
|
60
|
-
for (const [pid, process] of rendererData.processes) {
|
|
61
|
-
for (const [tid, thread] of process.threads) {
|
|
62
|
-
if (!thread.tree) {
|
|
63
|
-
// Drop threads where we could not create the tree; this indicates
|
|
64
|
-
// unexpected data and we won't be able to support all the UI
|
|
65
|
-
// filtering we need.
|
|
66
|
-
continue;
|
|
67
|
-
}
|
|
68
|
-
const threadType = getThreadTypeForRendererThread(pid, thread, auctionWorkletsData);
|
|
69
|
-
foundThreads.push({
|
|
70
|
-
name: thread.name,
|
|
71
|
-
pid,
|
|
72
|
-
tid,
|
|
73
|
-
processIsOnMainFrame: process.isOnMainFrame,
|
|
74
|
-
entries: thread.entries,
|
|
75
|
-
tree: thread.tree,
|
|
76
|
-
type: threadType,
|
|
77
|
-
entryToNode: rendererData.entryToNode,
|
|
78
|
-
});
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
return foundThreads;
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
const threadsInHandlerDataCache = new WeakMap<HandlerData, readonly ThreadData[]>();
|
|
86
|
-
|
|
87
|
-
/**
|
|
88
|
-
* Given trace parsed data, this helper will return a high level array of
|
|
89
|
-
* ThreadData. This is useful because it allows you to get a list of threads
|
|
90
|
-
* regardless of if the trace is a CPU Profile or a Tracing profile. Thus you
|
|
91
|
-
* can use this helper to iterate over threads in confidence that it will work
|
|
92
|
-
* for both trace types.
|
|
93
|
-
* The resulting data is cached per-trace, so you can safely call this multiple times.
|
|
94
|
-
*/
|
|
95
|
-
export function threadsInTrace(handlerData: HandlerData): readonly ThreadData[] {
|
|
96
|
-
const cached = threadsInHandlerDataCache.get(handlerData);
|
|
97
|
-
if (cached) {
|
|
98
|
-
return cached;
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
// If we have Renderer threads, we prefer to use those.
|
|
102
|
-
const threadsFromRenderer = threadsInRenderer(handlerData.Renderer, handlerData.AuctionWorklets);
|
|
103
|
-
if (threadsFromRenderer.length) {
|
|
104
|
-
threadsInHandlerDataCache.set(handlerData, threadsFromRenderer);
|
|
105
|
-
return threadsFromRenderer;
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
// If it's a CPU Profile trace, there will be no Renderer threads.
|
|
109
|
-
// We can fallback to using the data from the SamplesHandler.
|
|
110
|
-
const foundThreads: ThreadData[] = [];
|
|
111
|
-
if (handlerData.Samples.profilesInProcess.size) {
|
|
112
|
-
for (const [pid, process] of handlerData.Samples.profilesInProcess) {
|
|
113
|
-
for (const [tid, thread] of process) {
|
|
114
|
-
if (!thread.profileTree) {
|
|
115
|
-
// Drop threads where we could not create the tree; this indicates
|
|
116
|
-
// unexpected data and we won't be able to support all the UI
|
|
117
|
-
// filtering we need.
|
|
118
|
-
continue;
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
foundThreads.push({
|
|
122
|
-
pid,
|
|
123
|
-
tid,
|
|
124
|
-
// CPU Profile threads do not have a name.
|
|
125
|
-
name: null,
|
|
126
|
-
entries: thread.profileCalls,
|
|
127
|
-
// There is no concept of a "Main Frame" in a CPU profile.
|
|
128
|
-
processIsOnMainFrame: false,
|
|
129
|
-
tree: thread.profileTree,
|
|
130
|
-
type: ThreadType.CPU_PROFILE,
|
|
131
|
-
entryToNode: handlerData.Samples.entryToNode,
|
|
132
|
-
});
|
|
133
|
-
}
|
|
134
|
-
}
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
threadsInHandlerDataCache.set(handlerData, foundThreads);
|
|
138
|
-
return foundThreads;
|
|
139
|
-
}
|
|
@@ -1,400 +0,0 @@
|
|
|
1
|
-
// Copyright 2022 The Chromium Authors
|
|
2
|
-
// Use of this source code is governed by a BSD-style license that can be
|
|
3
|
-
// found in the LICENSE file.
|
|
4
|
-
|
|
5
|
-
import * as Platform from '../../../core/platform/platform.js';
|
|
6
|
-
import * as Helpers from '../helpers/helpers.js';
|
|
7
|
-
import * as Types from '../types/types.js';
|
|
8
|
-
|
|
9
|
-
import {data as metaHandlerData} from './MetaHandler.js';
|
|
10
|
-
import {ScoreClassification} from './PageLoadMetricsHandler.js';
|
|
11
|
-
import type {HandlerName} from './types.js';
|
|
12
|
-
|
|
13
|
-
// This handler gathers EventTimings into Interactions, which we use to show
|
|
14
|
-
// interactions and highlight long interactions to the user, along with INP.
|
|
15
|
-
|
|
16
|
-
let beginCommitCompositorFrameEvents: Types.Events.BeginCommitCompositorFrame[] = [];
|
|
17
|
-
let parseMetaViewportEvents: Types.Events.ParseMetaViewport[] = [];
|
|
18
|
-
|
|
19
|
-
export const LONG_INTERACTION_THRESHOLD = Helpers.Timing.milliToMicro(Types.Timing.Milli(200));
|
|
20
|
-
|
|
21
|
-
const INP_GOOD_TIMING = LONG_INTERACTION_THRESHOLD;
|
|
22
|
-
const INP_MEDIUM_TIMING = Helpers.Timing.milliToMicro(Types.Timing.Milli(500));
|
|
23
|
-
|
|
24
|
-
export interface UserInteractionsData {
|
|
25
|
-
/** All the BeginCommitCompositorFrame events we found in the trace */
|
|
26
|
-
beginCommitCompositorFrameEvents: readonly Types.Events.BeginCommitCompositorFrame[];
|
|
27
|
-
/** All the ParseMetaViewport events we found in the trace */
|
|
28
|
-
parseMetaViewportEvents: readonly Types.Events.ParseMetaViewport[];
|
|
29
|
-
/**
|
|
30
|
-
* All the interaction events we found in the trace that had an
|
|
31
|
-
* interactionId and a duration > 0
|
|
32
|
-
**/
|
|
33
|
-
interactionEvents: readonly Types.Events.SyntheticInteractionPair[];
|
|
34
|
-
/**
|
|
35
|
-
* If the user rapidly generates interaction events (think typing into a
|
|
36
|
-
* text box), in the UI we only really want to show the user the longest
|
|
37
|
-
* interaction in that set.
|
|
38
|
-
* For example picture interactions like this:
|
|
39
|
-
* ===[interaction A]==========
|
|
40
|
-
* =[interaction B]======
|
|
41
|
-
* =[interaction C]=
|
|
42
|
-
*
|
|
43
|
-
* These events all end at the same time, and so in this instance we only want
|
|
44
|
-
* to show the first interaction A on the timeline, as that is the longest one
|
|
45
|
-
* and the one the developer should be focusing on. So this array of events is
|
|
46
|
-
* all the interaction events filtered down, removing any nested interactions
|
|
47
|
-
* entirely.
|
|
48
|
-
**/
|
|
49
|
-
interactionEventsWithNoNesting: readonly Types.Events.SyntheticInteractionPair[];
|
|
50
|
-
// The longest duration interaction event. Can be null if the trace has no interaction events.
|
|
51
|
-
longestInteractionEvent: Readonly<Types.Events.SyntheticInteractionPair>|null;
|
|
52
|
-
// All interactions that went over the interaction threshold (200ms, see https://web.dev/inp/)
|
|
53
|
-
interactionsOverThreshold: Readonly<Set<Types.Events.SyntheticInteractionPair>>;
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
let longestInteractionEvent: Types.Events.SyntheticInteractionPair|null = null;
|
|
57
|
-
|
|
58
|
-
let interactionEvents: Types.Events.SyntheticInteractionPair[] = [];
|
|
59
|
-
let interactionEventsWithNoNesting: Types.Events.SyntheticInteractionPair[] = [];
|
|
60
|
-
let eventTimingStartEventsForInteractions: Types.Events.EventTimingBegin[] = [];
|
|
61
|
-
let eventTimingEndEventsForInteractions: Types.Events.EventTimingEnd[] = [];
|
|
62
|
-
|
|
63
|
-
export function reset(): void {
|
|
64
|
-
beginCommitCompositorFrameEvents = [];
|
|
65
|
-
parseMetaViewportEvents = [];
|
|
66
|
-
interactionEvents = [];
|
|
67
|
-
eventTimingStartEventsForInteractions = [];
|
|
68
|
-
eventTimingEndEventsForInteractions = [];
|
|
69
|
-
interactionEventsWithNoNesting = [];
|
|
70
|
-
longestInteractionEvent = null;
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
export function handleEvent(event: Types.Events.Event): void {
|
|
74
|
-
if (Types.Events.isBeginCommitCompositorFrame(event)) {
|
|
75
|
-
beginCommitCompositorFrameEvents.push(event);
|
|
76
|
-
return;
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
if (Types.Events.isParseMetaViewport(event)) {
|
|
80
|
-
parseMetaViewportEvents.push(event);
|
|
81
|
-
return;
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
if (!Types.Events.isEventTiming(event)) {
|
|
85
|
-
return;
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
if (Types.Events.isEventTimingEnd(event)) {
|
|
89
|
-
// Store the end event; for each start event that is an interaction, we need the matching end event to calculate the duration correctly.
|
|
90
|
-
eventTimingEndEventsForInteractions.push(event);
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
// From this point on we want to find events that represent interactions.
|
|
94
|
-
// These events are always start events - those are the ones that contain all
|
|
95
|
-
// the metadata about the interaction.
|
|
96
|
-
if (!event.args.data || !Types.Events.isEventTimingStart(event)) {
|
|
97
|
-
return;
|
|
98
|
-
}
|
|
99
|
-
const {duration, interactionId} = event.args.data;
|
|
100
|
-
// We exclude events for the sake of interactions if:
|
|
101
|
-
// 1. They have no duration.
|
|
102
|
-
// 2. They have no interactionId
|
|
103
|
-
// 3. They have an interactionId of 0: this indicates that it's not an
|
|
104
|
-
// interaction that we care about because it hasn't had its own interactionId
|
|
105
|
-
// set (0 is the default on the backend).
|
|
106
|
-
// See: https://source.chromium.org/chromium/chromium/src/+/main:third_party/blink/renderer/core/timing/responsiveness_metrics.cc;l=133;drc=40c209a9c365ebb9f16fb99dfe78c7fe768b9594
|
|
107
|
-
|
|
108
|
-
if (duration < 1 || interactionId === undefined || interactionId === 0) {
|
|
109
|
-
return;
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
// Store the start event. In the finalize() function we will pair this with
|
|
113
|
-
// its end event and create the synthetic interaction event.
|
|
114
|
-
eventTimingStartEventsForInteractions.push(event);
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
/**
|
|
118
|
-
* See https://web.dev/better-responsiveness-metric/#interaction-types for the
|
|
119
|
-
* table that defines these sets.
|
|
120
|
-
**/
|
|
121
|
-
const pointerEventTypes = new Set([
|
|
122
|
-
'pointerdown',
|
|
123
|
-
'touchstart',
|
|
124
|
-
'pointerup',
|
|
125
|
-
'touchend',
|
|
126
|
-
'mousedown',
|
|
127
|
-
'mouseup',
|
|
128
|
-
'click',
|
|
129
|
-
]);
|
|
130
|
-
|
|
131
|
-
const keyboardEventTypes = new Set([
|
|
132
|
-
'keydown',
|
|
133
|
-
'keypress',
|
|
134
|
-
'keyup',
|
|
135
|
-
]);
|
|
136
|
-
|
|
137
|
-
export type InteractionCategory = 'KEYBOARD'|'POINTER'|'OTHER';
|
|
138
|
-
export function categoryOfInteraction(interaction: Types.Events.SyntheticInteractionPair): InteractionCategory {
|
|
139
|
-
if (pointerEventTypes.has(interaction.type)) {
|
|
140
|
-
return 'POINTER';
|
|
141
|
-
}
|
|
142
|
-
if (keyboardEventTypes.has(interaction.type)) {
|
|
143
|
-
return 'KEYBOARD';
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
return 'OTHER';
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
/**
|
|
150
|
-
* We define a set of interactions as nested where:
|
|
151
|
-
* 1. Their end times align.
|
|
152
|
-
* 2. The longest interaction's start time is earlier than all other
|
|
153
|
-
* interactions with the same end time.
|
|
154
|
-
* 3. The interactions are of the same category [each interaction is either
|
|
155
|
-
* categorised as keyboard, or pointer.]
|
|
156
|
-
*
|
|
157
|
-
* =============A=[pointerup]=
|
|
158
|
-
* ====B=[pointerdown]=
|
|
159
|
-
* ===C=[pointerdown]==
|
|
160
|
-
* ===D=[pointerup]===
|
|
161
|
-
*
|
|
162
|
-
* In this example, B, C and D are all nested and therefore should not be
|
|
163
|
-
* returned from this function.
|
|
164
|
-
*
|
|
165
|
-
* However, in this example we would only consider B nested (under A) and D
|
|
166
|
-
* nested (under C). A and C both stay because they are of different types.
|
|
167
|
-
* ========A=[keydown]====
|
|
168
|
-
* =======B=[keyup]=====
|
|
169
|
-
* ====C=[pointerdown]=
|
|
170
|
-
* =D=[pointerup]=
|
|
171
|
-
*
|
|
172
|
-
* Additionally, this method will also maximise the processing duration of the
|
|
173
|
-
* events that we keep as non-nested. We want to make sure we give an accurate
|
|
174
|
-
* representation of main thread activity, so if we keep an event + hide its
|
|
175
|
-
* nested children, we set the top level event's processing start &
|
|
176
|
-
* processing end to be the earliest processing start & the latest processing
|
|
177
|
-
* end of its children. This ensures we report a more accurate main thread
|
|
178
|
-
* activity time which is important as we want developers to focus on fixing
|
|
179
|
-
* this.
|
|
180
|
-
**/
|
|
181
|
-
export function removeNestedInteractionsAndSetProcessingTime(
|
|
182
|
-
interactions: readonly Types.Events.SyntheticInteractionPair[]): readonly Types.Events.SyntheticInteractionPair[] {
|
|
183
|
-
/**
|
|
184
|
-
* Because we nest events only that are in the same category, we store the
|
|
185
|
-
* longest event for a given end time by category.
|
|
186
|
-
**/
|
|
187
|
-
const earliestEventForEndTimePerCategory:
|
|
188
|
-
Record<InteractionCategory, Map<Types.Timing.Micro, Types.Events.SyntheticInteractionPair>> = {
|
|
189
|
-
POINTER: new Map(),
|
|
190
|
-
KEYBOARD: new Map(),
|
|
191
|
-
OTHER: new Map(),
|
|
192
|
-
};
|
|
193
|
-
|
|
194
|
-
function storeEventIfEarliestForCategoryAndEndTime(interaction: Types.Events.SyntheticInteractionPair): void {
|
|
195
|
-
const category = categoryOfInteraction(interaction);
|
|
196
|
-
const earliestEventForEndTime = earliestEventForEndTimePerCategory[category];
|
|
197
|
-
const endTime = Types.Timing.Micro(interaction.ts + interaction.dur);
|
|
198
|
-
|
|
199
|
-
const earliestCurrentEvent = earliestEventForEndTime.get(endTime);
|
|
200
|
-
if (!earliestCurrentEvent) {
|
|
201
|
-
earliestEventForEndTime.set(endTime, interaction);
|
|
202
|
-
return;
|
|
203
|
-
}
|
|
204
|
-
if (interaction.ts < earliestCurrentEvent.ts) {
|
|
205
|
-
earliestEventForEndTime.set(endTime, interaction);
|
|
206
|
-
} else if (
|
|
207
|
-
interaction.ts === earliestCurrentEvent.ts &&
|
|
208
|
-
interaction.interactionId === earliestCurrentEvent.interactionId) {
|
|
209
|
-
// We have seen in traces that the same interaction can have multiple
|
|
210
|
-
// events (e.g. a 'click' and a 'pointerdown'). Often only one of these
|
|
211
|
-
// events will have an event handler bound to it which caused delay on
|
|
212
|
-
// the main thread, and the others will not. This leads to a situation
|
|
213
|
-
// where if we pick one of the events that had no event handler, its
|
|
214
|
-
// processing duration (processingEnd - processingStart) will be 0, but if we
|
|
215
|
-
// had picked the event that had the slow event handler, we would show
|
|
216
|
-
// correctly the main thread delay due to the event handler.
|
|
217
|
-
// So, if we find events with the same interactionId and the same
|
|
218
|
-
// begin/end times, we pick the one with the largest (processingEnd -
|
|
219
|
-
// processingStart) time in order to make sure we find the event with the
|
|
220
|
-
// worst main thread delay, as that is the one the user should care
|
|
221
|
-
// about.
|
|
222
|
-
const currentProcessingDuration = earliestCurrentEvent.processingEnd - earliestCurrentEvent.processingStart;
|
|
223
|
-
const newProcessingDuration = interaction.processingEnd - interaction.processingStart;
|
|
224
|
-
|
|
225
|
-
// Use the new interaction if it has a longer processing duration than the existing one.
|
|
226
|
-
if (newProcessingDuration > currentProcessingDuration) {
|
|
227
|
-
earliestEventForEndTime.set(endTime, interaction);
|
|
228
|
-
}
|
|
229
|
-
}
|
|
230
|
-
|
|
231
|
-
// Maximize the processing duration based on the "children" interactions.
|
|
232
|
-
// We pick the earliest start processing duration, and the latest end
|
|
233
|
-
// processing duration to avoid under-reporting.
|
|
234
|
-
if (interaction.processingStart < earliestCurrentEvent.processingStart) {
|
|
235
|
-
earliestCurrentEvent.processingStart = interaction.processingStart;
|
|
236
|
-
writeSyntheticTimespans(earliestCurrentEvent);
|
|
237
|
-
}
|
|
238
|
-
if (interaction.processingEnd > earliestCurrentEvent.processingEnd) {
|
|
239
|
-
earliestCurrentEvent.processingEnd = interaction.processingEnd;
|
|
240
|
-
writeSyntheticTimespans(earliestCurrentEvent);
|
|
241
|
-
}
|
|
242
|
-
}
|
|
243
|
-
|
|
244
|
-
for (const interaction of interactions) {
|
|
245
|
-
storeEventIfEarliestForCategoryAndEndTime(interaction);
|
|
246
|
-
}
|
|
247
|
-
|
|
248
|
-
// Combine all the events that we have kept from all the per-category event
|
|
249
|
-
// maps back into an array and sort them by timestamp.
|
|
250
|
-
const keptEvents = Object.values(earliestEventForEndTimePerCategory)
|
|
251
|
-
.flatMap(eventsByEndTime => Array.from(eventsByEndTime.values()));
|
|
252
|
-
keptEvents.sort((eventA, eventB) => {
|
|
253
|
-
return eventA.ts - eventB.ts;
|
|
254
|
-
});
|
|
255
|
-
return keptEvents;
|
|
256
|
-
}
|
|
257
|
-
|
|
258
|
-
function writeSyntheticTimespans(event: Types.Events.SyntheticInteractionPair): void {
|
|
259
|
-
const startEvent = event.args.data.beginEvent;
|
|
260
|
-
const endEvent = event.args.data.endEvent;
|
|
261
|
-
|
|
262
|
-
event.inputDelay = Types.Timing.Micro(event.processingStart - startEvent.ts);
|
|
263
|
-
event.mainThreadHandling = Types.Timing.Micro(event.processingEnd - event.processingStart);
|
|
264
|
-
event.presentationDelay = Types.Timing.Micro(endEvent.ts - event.processingEnd);
|
|
265
|
-
}
|
|
266
|
-
|
|
267
|
-
export async function finalize(): Promise<void> {
|
|
268
|
-
const {navigationsByFrameId} = metaHandlerData();
|
|
269
|
-
|
|
270
|
-
const beginAndEndEvents = Platform.ArrayUtilities.mergeOrdered(
|
|
271
|
-
eventTimingStartEventsForInteractions, eventTimingEndEventsForInteractions,
|
|
272
|
-
Helpers.Trace.eventTimeComparator) as Types.Events.EventTimingBeginOrEnd[];
|
|
273
|
-
|
|
274
|
-
// Pair up the begin & end events and create synthetic user timing events.
|
|
275
|
-
const beginEventById = new Map<string, Types.Events.EventTimingBegin[]>();
|
|
276
|
-
for (const event of beginAndEndEvents) {
|
|
277
|
-
if (Types.Events.isEventTimingStart(event)) {
|
|
278
|
-
const forId = beginEventById.get(event.id) ?? [];
|
|
279
|
-
forId.push(event);
|
|
280
|
-
beginEventById.set(event.id, forId);
|
|
281
|
-
} else if (Types.Events.isEventTimingEnd(event)) {
|
|
282
|
-
const beginEvents = beginEventById.get(event.id) ?? [];
|
|
283
|
-
const beginEvent = beginEvents.pop();
|
|
284
|
-
if (!beginEvent) {
|
|
285
|
-
continue;
|
|
286
|
-
}
|
|
287
|
-
const {type, interactionId, timeStamp, processingStart, processingEnd} = beginEvent.args.data;
|
|
288
|
-
if (!type || !interactionId || !timeStamp || !processingStart || !processingEnd) {
|
|
289
|
-
// A valid interaction event that we care about has to have a type (e.g. pointerdown, keyup).
|
|
290
|
-
// We also need to ensure it has an interactionId and various timings. There are edge cases where these aren't included in the trace event.
|
|
291
|
-
continue;
|
|
292
|
-
}
|
|
293
|
-
// In the future we will add microsecond timestamps to the trace events…
|
|
294
|
-
// (See https://source.chromium.org/chromium/chromium/src/+/main:third_party/blink/renderer/core/timing/window_performance.cc;l=900-901;drc=b503c262e425eae59ced4a80d59d176ed07152c7 )
|
|
295
|
-
// …but until then we can use the millisecond precision values that are in
|
|
296
|
-
// the trace event. To adjust them to be relative to the event.ts and the
|
|
297
|
-
// trace timestamps, for both processingStart and processingEnd we subtract
|
|
298
|
-
// the event timestamp (NOT event.ts, but the timeStamp millisecond value
|
|
299
|
-
// emitted in args.data), and then add that value to the event.ts. This
|
|
300
|
-
// will give us a processingStart and processingEnd time in microseconds
|
|
301
|
-
// that is relative to event.ts, and can be used when drawing boxes.
|
|
302
|
-
// There is some inaccuracy here as we are converting milliseconds to
|
|
303
|
-
// microseconds, but it is good enough until the backend emits more
|
|
304
|
-
// accurate numbers.
|
|
305
|
-
const processingStartRelativeToTraceTime = Types.Timing.Micro(
|
|
306
|
-
Helpers.Timing.milliToMicro(processingStart) - Helpers.Timing.milliToMicro(timeStamp) + beginEvent.ts,
|
|
307
|
-
);
|
|
308
|
-
|
|
309
|
-
const processingEndRelativeToTraceTime = Types.Timing.Micro(
|
|
310
|
-
(Helpers.Timing.milliToMicro(processingEnd) - Helpers.Timing.milliToMicro(timeStamp)) + beginEvent.ts);
|
|
311
|
-
|
|
312
|
-
// Ultimate frameId fallback only needed for TSC, see comments in the type.
|
|
313
|
-
const frameId = beginEvent.args.frame ?? beginEvent.args.data.frame ?? '';
|
|
314
|
-
const navigation = Helpers.Trace.getNavigationForTraceEvent(beginEvent, frameId, navigationsByFrameId);
|
|
315
|
-
const navigationId = navigation?.args.data?.navigationId;
|
|
316
|
-
const interactionEvent =
|
|
317
|
-
Helpers.SyntheticEvents.SyntheticEventsManager.registerSyntheticEvent<Types.Events.SyntheticInteractionPair>({
|
|
318
|
-
// Use the start event to define the common fields.
|
|
319
|
-
rawSourceEvent: beginEvent,
|
|
320
|
-
cat: beginEvent.cat,
|
|
321
|
-
name: beginEvent.name,
|
|
322
|
-
pid: beginEvent.pid,
|
|
323
|
-
tid: beginEvent.tid,
|
|
324
|
-
ph: beginEvent.ph,
|
|
325
|
-
processingStart: processingStartRelativeToTraceTime,
|
|
326
|
-
processingEnd: processingEndRelativeToTraceTime,
|
|
327
|
-
// These will be set in writeSyntheticTimespans()
|
|
328
|
-
inputDelay: Types.Timing.Micro(-1),
|
|
329
|
-
mainThreadHandling: Types.Timing.Micro(-1),
|
|
330
|
-
presentationDelay: Types.Timing.Micro(-1),
|
|
331
|
-
args: {
|
|
332
|
-
data: {
|
|
333
|
-
beginEvent,
|
|
334
|
-
endEvent: event,
|
|
335
|
-
frame: frameId,
|
|
336
|
-
navigationId,
|
|
337
|
-
},
|
|
338
|
-
},
|
|
339
|
-
ts: beginEvent.ts,
|
|
340
|
-
dur: Types.Timing.Micro(event.ts - beginEvent.ts),
|
|
341
|
-
type: beginEvent.args.data.type,
|
|
342
|
-
interactionId: beginEvent.args.data.interactionId,
|
|
343
|
-
});
|
|
344
|
-
writeSyntheticTimespans(interactionEvent);
|
|
345
|
-
interactionEvents.push(interactionEvent);
|
|
346
|
-
}
|
|
347
|
-
}
|
|
348
|
-
|
|
349
|
-
// Once we gather up all the interactions, we want to remove nested
|
|
350
|
-
// interactions. Interactions can be nested because one user action (e.g. a
|
|
351
|
-
// click) will cause a pointerdown, pointerup and click. But we don't want to
|
|
352
|
-
// fill the interactions track with lots of noise. To fix this, we go through
|
|
353
|
-
// all the events and remove any nested ones so on the timeline we focus the
|
|
354
|
-
// user on the most important events, which we define as the longest one. But
|
|
355
|
-
// this algorithm assumes the events are in ASC order, so we first sort the
|
|
356
|
-
// set of interactions.
|
|
357
|
-
Helpers.Trace.sortTraceEventsInPlace(interactionEvents);
|
|
358
|
-
interactionEventsWithNoNesting.push(...removeNestedInteractionsAndSetProcessingTime(interactionEvents));
|
|
359
|
-
|
|
360
|
-
// Pick the longest interactions from the set that were not nested, as we
|
|
361
|
-
// know those are the set of the largest interactions.
|
|
362
|
-
for (const interactionEvent of interactionEventsWithNoNesting) {
|
|
363
|
-
if (!longestInteractionEvent || longestInteractionEvent.dur < interactionEvent.dur) {
|
|
364
|
-
longestInteractionEvent = interactionEvent;
|
|
365
|
-
}
|
|
366
|
-
}
|
|
367
|
-
}
|
|
368
|
-
|
|
369
|
-
export function data(): UserInteractionsData {
|
|
370
|
-
return {
|
|
371
|
-
beginCommitCompositorFrameEvents,
|
|
372
|
-
parseMetaViewportEvents,
|
|
373
|
-
interactionEvents,
|
|
374
|
-
interactionEventsWithNoNesting,
|
|
375
|
-
longestInteractionEvent,
|
|
376
|
-
interactionsOverThreshold: new Set(interactionEvents.filter(event => {
|
|
377
|
-
return event.dur > LONG_INTERACTION_THRESHOLD;
|
|
378
|
-
})),
|
|
379
|
-
};
|
|
380
|
-
}
|
|
381
|
-
|
|
382
|
-
export function deps(): HandlerName[] {
|
|
383
|
-
return ['Meta'];
|
|
384
|
-
}
|
|
385
|
-
|
|
386
|
-
/**
|
|
387
|
-
* Classifications sourced from
|
|
388
|
-
* https://web.dev/articles/inp#good-score
|
|
389
|
-
*/
|
|
390
|
-
export function scoreClassificationForInteractionToNextPaint(timing: Types.Timing.Micro): ScoreClassification {
|
|
391
|
-
if (timing <= INP_GOOD_TIMING) {
|
|
392
|
-
return ScoreClassification.GOOD;
|
|
393
|
-
}
|
|
394
|
-
|
|
395
|
-
if (timing <= INP_MEDIUM_TIMING) {
|
|
396
|
-
return ScoreClassification.OK;
|
|
397
|
-
}
|
|
398
|
-
|
|
399
|
-
return ScoreClassification.BAD;
|
|
400
|
-
}
|