@paulirish/trace_engine 0.0.9 → 0.0.11
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/analyze-trace.mjs +1 -1
- package/core/platform/DevToolsPath.d.ts +23 -0
- package/core/platform/DevToolsPath.js +7 -0
- package/core/platform/DevToolsPath.js.map +1 -0
- package/core/platform/MimeType.d.ts +27 -0
- package/core/platform/MimeType.js +137 -0
- package/core/platform/MimeType.js.map +1 -0
- package/core/platform/Timing.d.ts +7 -0
- package/core/platform/Timing.js +13 -0
- package/core/platform/Timing.js.map +1 -0
- package/core/platform/UIString.d.ts +3 -0
- package/core/platform/UIString.js +5 -0
- package/core/platform/UIString.js.map +1 -0
- package/core/platform/UserVisibleError.d.ts +12 -0
- package/core/platform/UserVisibleError.js +23 -0
- package/core/platform/UserVisibleError.js.map +1 -0
- package/core/platform/array-utilities.d.ts +66 -0
- package/core/platform/array-utilities.js +199 -0
- package/core/platform/array-utilities.js.map +1 -0
- package/core/platform/brand.d.ts +14 -0
- package/core/platform/brand.js +5 -0
- package/core/platform/brand.js.map +1 -0
- package/core/platform/bundle-tsconfig.json +1 -0
- package/core/platform/date-utilities.d.ts +2 -0
- package/core/platform/date-utilities.js +14 -0
- package/core/platform/date-utilities.js.map +1 -0
- package/core/platform/dcheck-tsconfig.json +8 -0
- package/core/platform/dcheck.d.ts +4 -0
- package/core/platform/dcheck.js +5 -0
- package/core/platform/devtools_entrypoint-bundle-tsconfig-tsconfig.json +40 -0
- package/core/platform/devtools_entrypoint-bundle-typescript-tsconfig.json +44 -0
- package/core/platform/dom-utilities.d.ts +8 -0
- package/core/platform/dom-utilities.js +109 -0
- package/core/platform/dom-utilities.js.map +1 -0
- package/core/platform/keyboard-utilities.d.ts +17 -0
- package/core/platform/keyboard-utilities.js +22 -0
- package/core/platform/keyboard-utilities.js.map +1 -0
- package/core/platform/map-utilities.d.ts +18 -0
- package/core/platform/map-utilities.js +76 -0
- package/core/platform/map-utilities.js.map +1 -0
- package/core/platform/number-utilities.d.ts +15 -0
- package/core/platform/number-utilities.js +82 -0
- package/core/platform/number-utilities.js.map +1 -0
- package/core/platform/platform-tsconfig.json +59 -0
- package/core/platform/platform.d.ts +19 -0
- package/core/platform/platform.js +54 -0
- package/core/platform/platform.js.compressed +0 -0
- package/core/platform/platform.js.hash +1 -0
- package/core/platform/platform.js.map +1 -0
- package/core/platform/platform.prebundle.d.ts +15 -0
- package/core/platform/platform.prebundle.js +50 -0
- package/core/platform/platform.prebundle.js.map +1 -0
- package/core/platform/platform.prebundle.ts +64 -0
- package/core/platform/promise-utilities.d.ts +10 -0
- package/core/platform/promise-utilities.js +18 -0
- package/core/platform/promise-utilities.js.map +1 -0
- package/core/platform/set-utilities.d.ts +2 -0
- package/core/platform/set-utilities.js +23 -0
- package/core/platform/set-utilities.js.map +1 -0
- package/core/platform/string-utilities.d.ts +71 -0
- package/core/platform/string-utilities.js +513 -0
- package/core/platform/string-utilities.js.map +1 -0
- package/core/platform/typescript-utilities.d.ts +56 -0
- package/core/platform/typescript-utilities.js +25 -0
- package/core/platform/typescript-utilities.js.map +1 -0
- package/generated/protocol.d.ts +17923 -0
- package/generated/protocol.js +5 -0
- package/models/cpu_profile/CPUProfileDataModel.d.ts +77 -0
- package/models/cpu_profile/CPUProfileDataModel.js +508 -0
- package/models/cpu_profile/CPUProfileDataModel.js.map +1 -0
- package/models/cpu_profile/ProfileTreeModel.d.ts +29 -0
- package/models/cpu_profile/ProfileTreeModel.js +95 -0
- package/models/cpu_profile/ProfileTreeModel.js.map +1 -0
- package/models/cpu_profile/bundle-tsconfig.json +1 -0
- package/models/cpu_profile/cpu_profile-tsconfig.json +51 -0
- package/models/cpu_profile/cpu_profile.d.ts +3 -0
- package/models/cpu_profile/cpu_profile.js +7 -0
- package/models/cpu_profile/cpu_profile.js.map +1 -0
- package/models/cpu_profile/devtools_entrypoint-bundle-typescript-tsconfig.json +44 -0
- package/models/trace/EntriesFilter.d.ts +55 -0
- package/models/trace/EntriesFilter.js +243 -0
- package/models/trace/EntriesFilter.js.map +1 -0
- package/models/trace/LegacyTracingModel.d.ts +1 -0
- package/models/trace/LegacyTracingModel.js +1 -0
- package/models/trace/LegacyTracingModel.js.map +1 -0
- package/models/trace/ModelImpl.d.ts +110 -0
- package/models/trace/ModelImpl.js +175 -0
- package/models/trace/ModelImpl.js.map +1 -0
- package/models/trace/Processor.d.ts +36 -0
- package/models/trace/Processor.js +213 -0
- package/models/trace/Processor.js.map +1 -0
- package/models/trace/SDKServices.js +104 -0
- package/models/trace/SDKServices.js.map +7 -0
- package/models/trace/TraceProcessor.js +133 -0
- package/models/trace/TraceProcessor.js.map +7 -0
- package/models/trace/TracingManager.d.ts +1 -0
- package/models/trace/TracingManager.js +1 -0
- package/models/trace/TracingManager.js.map +1 -0
- package/models/trace/TreeManipulator.js +85 -0
- package/models/trace/TreeManipulator.js.map +7 -0
- package/models/trace/bundle-tsconfig.json +1 -0
- package/models/trace/devtools_entrypoint-bundle-typescript-tsconfig.json +44 -0
- package/models/trace/devtools_entrypoint-legacy-typescript-tsconfig.json +43 -0
- package/models/trace/extras/FetchNodes.d.ts +46 -0
- package/models/trace/extras/FetchNodes.js +145 -0
- package/models/trace/extras/FetchNodes.js.map +1 -0
- package/models/trace/extras/FilmStrip.d.ts +19 -0
- package/models/trace/extras/FilmStrip.js +44 -0
- package/models/trace/extras/FilmStrip.js.map +1 -0
- package/models/trace/extras/MainThreadActivity.d.ts +2 -0
- package/models/trace/extras/MainThreadActivity.js +77 -0
- package/models/trace/extras/MainThreadActivity.js.map +1 -0
- package/models/trace/extras/Metadata.d.ts +2 -0
- package/models/trace/extras/Metadata.js +44 -0
- package/models/trace/extras/Metadata.js.map +1 -0
- package/models/trace/extras/bundle-tsconfig.json +1 -0
- package/models/trace/extras/devtools_entrypoint-bundle-typescript-tsconfig.json +44 -0
- package/models/trace/extras/extras-tsconfig.json +59 -0
- package/models/trace/extras/extras.d.ts +1 -0
- package/models/trace/extras/extras.js +1 -0
- package/models/trace/extras/extras.js.map +1 -0
- package/models/trace/frames/TimelineFrameModel.js +392 -0
- package/models/trace/frames/TimelineFrameModel.js.map +7 -0
- package/models/trace/frames/bundle-tsconfig.json +1 -0
- package/models/trace/frames/devtools_entrypoint-bundle-typescript-tsconfig.json +43 -0
- package/models/trace/frames/frames-tsconfig.json +58 -0
- package/models/trace/frames/frames.js +5 -0
- package/models/trace/frames/frames.js.map +7 -0
- package/models/trace/handlers/AnimationHandler.d.ts +8 -0
- package/models/trace/handlers/AnimationHandler.js +32 -0
- package/models/trace/handlers/AnimationHandler.js.map +1 -0
- package/models/trace/handlers/AuctionWorkletsHandler.d.ts +8 -0
- package/models/trace/handlers/AuctionWorkletsHandler.js +160 -0
- package/models/trace/handlers/AuctionWorkletsHandler.js.map +1 -0
- package/models/trace/handlers/FramesHandler.d.ts +76 -0
- package/models/trace/handlers/FramesHandler.js +457 -0
- package/models/trace/handlers/FramesHandler.js.map +1 -0
- package/models/trace/handlers/GPUHandler.d.ts +11 -0
- package/models/trace/handlers/GPUHandler.js +54 -0
- package/models/trace/handlers/GPUHandler.js.map +1 -0
- package/models/trace/handlers/InitiatorsHandler.d.ts +10 -0
- package/models/trace/handlers/InitiatorsHandler.js +184 -0
- package/models/trace/handlers/InitiatorsHandler.js.map +1 -0
- package/models/trace/handlers/InvalidationsHandler.d.ts +10 -0
- package/models/trace/handlers/InvalidationsHandler.js +120 -0
- package/models/trace/handlers/InvalidationsHandler.js.map +1 -0
- package/models/trace/handlers/LargestImagePaintHandler.d.ts +5 -0
- package/models/trace/handlers/LargestImagePaintHandler.js +38 -0
- package/models/trace/handlers/LargestImagePaintHandler.js.map +1 -0
- package/models/trace/handlers/LargestTextPaintHandler.d.ts +5 -0
- package/models/trace/handlers/LargestTextPaintHandler.js +26 -0
- package/models/trace/handlers/LargestTextPaintHandler.js.map +1 -0
- package/models/trace/handlers/LayerTreeHandler.d.ts +13 -0
- package/models/trace/handlers/LayerTreeHandler.js +116 -0
- package/models/trace/handlers/LayerTreeHandler.js.map +1 -0
- package/models/trace/handlers/LayoutShiftsHandler.d.ts +44 -0
- package/models/trace/handlers/LayoutShiftsHandler.js +347 -0
- package/models/trace/handlers/LayoutShiftsHandler.js.map +1 -0
- package/models/trace/handlers/MemoryHandler.d.ts +7 -0
- package/models/trace/handlers/MemoryHandler.js +20 -0
- package/models/trace/handlers/MemoryHandler.js.map +1 -0
- package/models/trace/handlers/MetaHandler.d.ts +37 -0
- package/models/trace/handlers/MetaHandler.js +338 -0
- package/models/trace/handlers/MetaHandler.js.map +1 -0
- package/models/trace/handlers/Migration.js +27 -0
- package/models/trace/handlers/Migration.js.map +7 -0
- package/models/trace/handlers/ModelHandlers.d.ts +21 -0
- package/models/trace/handlers/ModelHandlers.js +25 -0
- package/models/trace/handlers/ModelHandlers.js.map +1 -0
- package/models/trace/handlers/NetworkRequestsHandler.d.ts +17 -0
- package/models/trace/handlers/NetworkRequestsHandler.js +361 -0
- package/models/trace/handlers/NetworkRequestsHandler.js.map +1 -0
- package/models/trace/handlers/PageLoadMetricsHandler.d.ts +67 -0
- package/models/trace/handlers/PageLoadMetricsHandler.js +407 -0
- package/models/trace/handlers/PageLoadMetricsHandler.js.map +1 -0
- package/models/trace/handlers/RendererHandler.d.ts +101 -0
- package/models/trace/handlers/RendererHandler.js +325 -0
- package/models/trace/handlers/RendererHandler.js.map +1 -0
- package/models/trace/handlers/SamplesHandler.d.ts +46 -0
- package/models/trace/handlers/SamplesHandler.js +215 -0
- package/models/trace/handlers/SamplesHandler.js.map +1 -0
- package/models/trace/handlers/ScreenshotsHandler.d.ts +7 -0
- package/models/trace/handlers/ScreenshotsHandler.js +79 -0
- package/models/trace/handlers/ScreenshotsHandler.js.map +1 -0
- package/models/trace/handlers/Threads.d.ts +33 -0
- package/models/trace/handlers/Threads.js +95 -0
- package/models/trace/handlers/Threads.js.map +1 -0
- package/models/trace/handlers/UberFramesHandler.js +293 -0
- package/models/trace/handlers/UberFramesHandler.js.map +7 -0
- package/models/trace/handlers/UserInteractionsHandler.d.ts +57 -0
- package/models/trace/handlers/UserInteractionsHandler.js +267 -0
- package/models/trace/handlers/UserInteractionsHandler.js.map +1 -0
- package/models/trace/handlers/UserTimingsHandler.d.ts +28 -0
- package/models/trace/handlers/UserTimingsHandler.js +108 -0
- package/models/trace/handlers/UserTimingsHandler.js.map +1 -0
- package/models/trace/handlers/WarningsHandler.d.ts +14 -0
- package/models/trace/handlers/WarningsHandler.js +125 -0
- package/models/trace/handlers/WarningsHandler.js.map +1 -0
- package/models/trace/handlers/WorkersHandler.d.ts +11 -0
- package/models/trace/handlers/WorkersHandler.js +52 -0
- package/models/trace/handlers/WorkersHandler.js.map +1 -0
- package/models/trace/handlers/bundle-tsconfig.json +1 -0
- package/models/trace/handlers/devtools_entrypoint-bundle-typescript-tsconfig.json +44 -0
- package/models/trace/handlers/handlers-tsconfig.json +79 -0
- package/models/trace/handlers/handlers.d.ts +3 -0
- package/models/trace/handlers/handlers.js +7 -0
- package/models/trace/handlers/handlers.js.map +1 -0
- package/models/trace/handlers/types.d.ts +45 -0
- package/models/trace/handlers/types.js +18 -0
- package/models/trace/handlers/types.js.map +1 -0
- package/models/trace/helpers/SamplesIntegrator.d.ts +49 -0
- package/models/trace/helpers/SamplesIntegrator.js +397 -0
- package/models/trace/helpers/SamplesIntegrator.js.map +1 -0
- package/models/trace/helpers/Timing.d.ts +26 -0
- package/models/trace/helpers/Timing.js +162 -0
- package/models/trace/helpers/Timing.js.map +1 -0
- package/models/trace/helpers/Trace.d.ts +37 -0
- package/models/trace/helpers/Trace.js +230 -0
- package/models/trace/helpers/Trace.js.map +1 -0
- package/models/trace/helpers/TreeHelpers.d.ts +90 -0
- package/models/trace/helpers/TreeHelpers.js +222 -0
- package/models/trace/helpers/TreeHelpers.js.map +1 -0
- package/models/trace/helpers/bundle-tsconfig.json +1 -0
- package/models/trace/helpers/devtools_entrypoint-bundle-typescript-tsconfig.json +44 -0
- package/models/trace/helpers/helpers-tsconfig.json +59 -0
- package/models/trace/helpers/helpers.d.ts +4 -0
- package/models/trace/helpers/helpers.js +8 -0
- package/models/trace/helpers/helpers.js.map +1 -0
- package/models/trace/legacy-tsconfig.json +1 -0
- package/models/trace/root-causes/LayoutShift.d.ts +119 -0
- package/models/trace/root-causes/LayoutShift.js +517 -0
- package/models/trace/root-causes/LayoutShift.js.map +1 -0
- package/models/trace/root-causes/RootCauses.d.ts +14 -0
- package/models/trace/root-causes/RootCauses.js +11 -0
- package/models/trace/root-causes/RootCauses.js.map +1 -0
- package/models/trace/root-causes/bundle-tsconfig.json +1 -0
- package/models/trace/root-causes/devtools_entrypoint-bundle-typescript-tsconfig.json +44 -0
- package/models/trace/root-causes/root-causes-tsconfig.json +57 -0
- package/models/trace/root-causes/root-causes.d.ts +1 -0
- package/models/trace/root-causes/root-causes.js +5 -0
- package/models/trace/root-causes/root-causes.js.map +1 -0
- package/models/trace/sdk_services/DOMNodeLookup.js +41 -0
- package/models/trace/sdk_services/DOMNodeLookup.js.map +7 -0
- package/models/trace/sdk_services/LayoutShifts.js +68 -0
- package/models/trace/sdk_services/LayoutShifts.js.map +7 -0
- package/models/trace/sdk_services/bundle-tsconfig.json +1 -0
- package/models/trace/sdk_services/devtools_entrypoint-bundle-typescript-tsconfig.json +41 -0
- package/models/trace/sdk_services/sdk_services-tsconfig.json +57 -0
- package/models/trace/sdk_services/sdk_services.js +7 -0
- package/models/trace/sdk_services/sdk_services.js.map +7 -0
- package/models/trace/trace-legacy.js +16 -0
- package/models/trace/trace-legacy.js.map +7 -0
- package/models/trace/trace-tsconfig.json +69 -0
- package/models/trace/trace.d.ts +11 -0
- package/models/trace/trace.js +17 -0
- package/models/trace/trace.js.map +1 -0
- package/models/trace/types/Configuration.d.ts +33 -0
- package/models/trace/types/Configuration.js +29 -0
- package/models/trace/types/Configuration.js.map +1 -0
- package/models/trace/types/File.d.ts +23 -0
- package/models/trace/types/File.js +5 -0
- package/models/trace/types/File.js.map +1 -0
- package/models/trace/types/Timing.d.ts +25 -0
- package/models/trace/types/Timing.js +16 -0
- package/models/trace/types/Timing.js.map +1 -0
- package/models/trace/types/TraceEvents.d.ts +1571 -0
- package/models/trace/types/TraceEvents.js +388 -0
- package/models/trace/types/TraceEvents.js.map +1 -0
- package/models/trace/types/bundle-tsconfig.json +1 -0
- package/models/trace/types/devtools_entrypoint-bundle-typescript-tsconfig.json +44 -0
- package/models/trace/types/types-tsconfig.json +47 -0
- package/models/trace/types/types.d.ts +4 -0
- package/models/trace/types/types.js +8 -0
- package/models/trace/types/types.js.map +1 -0
- package/models/trace/worker/Processor.js +143 -0
- package/models/trace/worker/Processor.js.map +7 -0
- package/models/trace/worker/Types.js +1 -0
- package/models/trace/worker/Types.js.map +7 -0
- package/models/trace/worker/bundle-tsconfig.json +1 -0
- package/models/trace/worker/devtools_entrypoint-bundle-typescript-tsconfig.json +41 -0
- package/models/trace/worker/devtools_entrypoint-worker_entrypoint-typescript-tsconfig.json +41 -0
- package/models/trace/worker/processor-tsconfig.json +45 -0
- package/models/trace/worker/worker.js +7 -0
- package/models/trace/worker/worker.js.map +7 -0
- package/models/trace/worker/worker_entrypoint-tsconfig.json +1 -0
- package/models/trace/worker/worker_entrypoint.js +36 -0
- package/models/trace/worker/worker_entrypoint.js.map +7 -0
- package/package.json +2 -2
- package/TracingManager.js +0 -0
- package/extras/extras.js +0 -0
- package/trace.mjs +0 -6980
- package/trace.mjs.map +0 -8
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Timing.js","sourceRoot":"","sources":["../../../../../../../front_end/models/trace/helpers/Timing.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright 2022 The Chromium Authors. All rights reserved.\n// Use of this source code is governed by a BSD-style license that can be\n// found in the LICENSE file.\n\nimport * as Platform from '../../../core/platform/platform.js';\nimport * as Types from '../types/types.js';\n\nimport {getNavigationForTraceEvent} from './Trace.js';\n\nexport const millisecondsToMicroseconds = (value: Types.Timing.MilliSeconds): Types.Timing.MicroSeconds =>\n Types.Timing.MicroSeconds(value * 1000);\n\nexport const secondsToMilliseconds = (value: Types.Timing.Seconds): Types.Timing.MilliSeconds =>\n Types.Timing.MilliSeconds(value * 1000);\n\nexport const secondsToMicroseconds = (value: Types.Timing.Seconds): Types.Timing.MicroSeconds =>\n millisecondsToMicroseconds(secondsToMilliseconds(value));\n\nexport const microSecondsToMilliseconds = (value: Types.Timing.MicroSeconds): Types.Timing.MilliSeconds =>\n Types.Timing.MilliSeconds(value / 1000);\n\nexport const microSecondsToSeconds = (value: Types.Timing.MicroSeconds): Types.Timing.Seconds =>\n Types.Timing.Seconds(value / 1000 / 1000);\n\nexport function detectBestTimeUnit(timeInMicroseconds: Types.Timing.MicroSeconds): Types.Timing.TimeUnit {\n if (timeInMicroseconds < 1000) {\n return Types.Timing.TimeUnit.MICROSECONDS;\n }\n\n const timeInMilliseconds = timeInMicroseconds / 1000;\n if (timeInMilliseconds < 1000) {\n return Types.Timing.TimeUnit.MILLISECONDS;\n }\n\n const timeInSeconds = timeInMilliseconds / 1000;\n if (timeInSeconds < 60) {\n return Types.Timing.TimeUnit.SECONDS;\n }\n\n return Types.Timing.TimeUnit.MINUTES;\n}\n\ninterface FormatOptions extends Intl.NumberFormatOptions {\n format?: Types.Timing.TimeUnit;\n}\n\nconst defaultFormatOptions = {\n style: 'unit',\n unit: 'millisecond',\n unitDisplay: 'narrow',\n};\n\n// Create a bunch of common formatters up front, so that we're not creating\n// them repeatedly during rendering.\nconst serialize = (value: {}): string => JSON.stringify(value);\nconst formatterFactory = (key: string|undefined): Intl.NumberFormat => {\n // If we pass undefined as the locale, that achieves two things:\n // 1. Avoids us referencing window.navigatior to fetch the locale, which is\n // useful given long term we would like this engine to run in NodeJS\n // environments.\n // 2. Will cause the formatter to fallback to the locale of the system, which\n // is likely going to be the most accurate one to use anyway.\n return new Intl.NumberFormat(undefined, key ? JSON.parse(key) : {});\n};\nconst formatters = new Map<string, Intl.NumberFormat>();\n\n// Microsecond Formatter.\nPlatform.MapUtilities.getWithDefault(formatters, serialize({style: 'decimal'}), formatterFactory);\n\n// Millisecond Formatter\nPlatform.MapUtilities.getWithDefault(formatters, serialize(defaultFormatOptions), formatterFactory);\n\n// Second Formatter\nPlatform.MapUtilities.getWithDefault(\n formatters, serialize({...defaultFormatOptions, unit: 'second'}), formatterFactory);\n\n// Minute Formatter\nPlatform.MapUtilities.getWithDefault(\n formatters, serialize({...defaultFormatOptions, unit: 'minute'}), formatterFactory);\n\nexport function formatMicrosecondsTime(\n timeInMicroseconds: Types.Timing.MicroSeconds, opts: FormatOptions = {}): string {\n if (!opts.format) {\n opts.format = detectBestTimeUnit(timeInMicroseconds);\n }\n\n const timeInMilliseconds = timeInMicroseconds / 1000;\n const timeInSeconds = timeInMilliseconds / 1000;\n const formatterOpts = {...defaultFormatOptions, ...opts};\n\n switch (opts.format) {\n case Types.Timing.TimeUnit.MICROSECONDS: {\n const formatter =\n Platform.MapUtilities.getWithDefault(formatters, serialize({style: 'decimal'}), formatterFactory);\n return `${formatter.format(timeInMicroseconds)}μs`;\n }\n\n case Types.Timing.TimeUnit.MILLISECONDS: {\n const formatter = Platform.MapUtilities.getWithDefault(formatters, serialize(formatterOpts), formatterFactory);\n return formatter.format(timeInMilliseconds);\n }\n\n case Types.Timing.TimeUnit.SECONDS: {\n const formatter = Platform.MapUtilities.getWithDefault(\n formatters, serialize({...formatterOpts, unit: 'second'}), formatterFactory);\n return formatter.format(timeInSeconds);\n }\n\n default: {\n // Switch to mins & seconds.\n const minuteFormatter = Platform.MapUtilities.getWithDefault(\n formatters, serialize({...formatterOpts, unit: 'minute'}), formatterFactory);\n const secondFormatter = Platform.MapUtilities.getWithDefault(\n formatters, serialize({...formatterOpts, unit: 'second'}), formatterFactory);\n const timeInMinutes = timeInSeconds / 60;\n const [mins, divider, fraction] = minuteFormatter.formatToParts(timeInMinutes);\n\n let seconds = 0;\n if (divider && fraction) {\n // Convert the fraction value (a string) to the nearest second.\n seconds = Math.round(Number(`0.${fraction.value}`) * 60);\n }\n return `${minuteFormatter.format(Number(mins.value))} ${secondFormatter.format(seconds)}`;\n }\n }\n}\n\nexport function timeStampForEventAdjustedByClosestNavigation(\n event: Types.TraceEvents.TraceEventData,\n traceBounds: Types.Timing.TraceWindowMicroSeconds,\n navigationsByNavigationId: Map<string, Types.TraceEvents.TraceEventNavigationStart>,\n navigationsByFrameId: Map<string, Types.TraceEvents.TraceEventNavigationStart[]>,\n ): Types.Timing.MicroSeconds {\n let eventTimeStamp = event.ts - traceBounds.min;\n if (event.args?.data?.navigationId) {\n const navigationForEvent = navigationsByNavigationId.get(event.args.data.navigationId);\n if (navigationForEvent) {\n eventTimeStamp = event.ts - navigationForEvent.ts;\n }\n } else if (event.args?.data?.frame) {\n const navigationForEvent = getNavigationForTraceEvent(event, event.args.data.frame, navigationsByFrameId);\n if (navigationForEvent) {\n eventTimeStamp = event.ts - navigationForEvent.ts;\n }\n }\n return Types.Timing.MicroSeconds(eventTimeStamp);\n}\n\nexport interface EventTimingsData<\n ValueType extends Types.Timing.MicroSeconds|Types.Timing.MilliSeconds|Types.Timing.Seconds,\n> {\n startTime: ValueType;\n endTime: ValueType;\n duration: ValueType;\n selfTime: ValueType;\n}\n\nexport function eventTimingsMicroSeconds(event: Types.TraceEvents.TraceEventData):\n EventTimingsData<Types.Timing.MicroSeconds> {\n return {\n startTime: event.ts,\n endTime: Types.Timing.MicroSeconds(event.ts + (event.dur || Types.Timing.MicroSeconds(0))),\n duration: Types.Timing.MicroSeconds(event.dur || 0),\n // TODO(crbug.com/1434599): Implement selfTime calculation for events\n // from the new engine.\n selfTime: Types.TraceEvents.isSyntheticTraceEntry(event) ? Types.Timing.MicroSeconds(event.selfTime || 0) :\n Types.Timing.MicroSeconds(event.dur || 0),\n };\n}\nexport function eventTimingsMilliSeconds(event: Types.TraceEvents.TraceEventData):\n EventTimingsData<Types.Timing.MilliSeconds> {\n const microTimes = eventTimingsMicroSeconds(event);\n return {\n startTime: microSecondsToMilliseconds(microTimes.startTime),\n endTime: microSecondsToMilliseconds(microTimes.endTime),\n duration: microSecondsToMilliseconds(microTimes.duration),\n selfTime: microSecondsToMilliseconds(microTimes.selfTime),\n };\n}\nexport function eventTimingsSeconds(event: Types.TraceEvents.TraceEventData): EventTimingsData<Types.Timing.Seconds> {\n const microTimes = eventTimingsMicroSeconds(event);\n return {\n startTime: microSecondsToSeconds(microTimes.startTime),\n endTime: microSecondsToSeconds(microTimes.endTime),\n duration: microSecondsToSeconds(microTimes.duration),\n selfTime: microSecondsToSeconds(microTimes.selfTime),\n };\n}\n\nexport function traceWindowMilliSeconds(bounds: Types.Timing.TraceWindowMicroSeconds):\n Types.Timing.TraceWindowMilliSeconds {\n return {\n min: microSecondsToMilliseconds(bounds.min),\n max: microSecondsToMilliseconds(bounds.max),\n range: microSecondsToMilliseconds(bounds.range),\n };\n}\n\nexport function traceWindowMillisecondsToMicroSeconds(bounds: Types.Timing.TraceWindowMilliSeconds):\n Types.Timing.TraceWindowMicroSeconds {\n return {\n min: millisecondsToMicroseconds(bounds.min),\n max: millisecondsToMicroseconds(bounds.max),\n range: millisecondsToMicroseconds(bounds.range),\n };\n}\n\nexport function traceWindowFromMilliSeconds(\n min: Types.Timing.MilliSeconds, max: Types.Timing.MilliSeconds): Types.Timing.TraceWindowMicroSeconds {\n const traceWindow: Types.Timing.TraceWindowMicroSeconds = {\n min: millisecondsToMicroseconds(min),\n max: millisecondsToMicroseconds(max),\n range: Types.Timing.MicroSeconds(millisecondsToMicroseconds(max) - millisecondsToMicroseconds(min)),\n };\n return traceWindow;\n}\n\nexport function traceWindowFromMicroSeconds(\n min: Types.Timing.MicroSeconds, max: Types.Timing.MicroSeconds): Types.Timing.TraceWindowMicroSeconds {\n const traceWindow: Types.Timing.TraceWindowMicroSeconds = {\n min,\n max,\n range: Types.Timing.MicroSeconds(max - min),\n };\n return traceWindow;\n}\n"]}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import type * as CPUProfile from '../../cpu_profile/cpu_profile.js';
|
|
2
|
+
import * as Types from '../types/types.js';
|
|
3
|
+
type MatchedPairType<T extends Types.TraceEvents.TraceEventPairableAsync> = Types.TraceEvents.SyntheticEventPair<T>;
|
|
4
|
+
export declare function stackTraceForEvent(event: Types.TraceEvents.TraceEventData): Types.TraceEvents.TraceEventCallFrame[] | null;
|
|
5
|
+
export declare function extractOriginFromTrace(firstNavigationURL: string): string | null;
|
|
6
|
+
export type EventsInThread<T extends Types.TraceEvents.TraceEventData> = Map<Types.TraceEvents.ThreadID, T[]>;
|
|
7
|
+
export declare function addEventToProcessThread<T extends Types.TraceEvents.TraceEventData>(event: T, eventsInProcessThread: Map<Types.TraceEvents.ProcessID, EventsInThread<T>>): void;
|
|
8
|
+
/**
|
|
9
|
+
* Sorts all the events in place, in order, by their start time. If they have
|
|
10
|
+
* the same start time, orders them by longest first.
|
|
11
|
+
*/
|
|
12
|
+
export declare function sortTraceEventsInPlace(events: {
|
|
13
|
+
ts: Types.Timing.MicroSeconds;
|
|
14
|
+
dur?: Types.Timing.MicroSeconds;
|
|
15
|
+
}[]): void;
|
|
16
|
+
/**
|
|
17
|
+
* Returns an array of ordered events that results after merging the two
|
|
18
|
+
* ordered input arrays.
|
|
19
|
+
*/
|
|
20
|
+
export declare function mergeEventsInOrder<T1 extends Types.TraceEvents.TraceEventData, T2 extends Types.TraceEvents.TraceEventData>(eventsArray1: T1[], eventsArray2: T2[]): (T1 | T2)[];
|
|
21
|
+
export declare function getNavigationForTraceEvent(event: Types.TraceEvents.TraceEventData, eventFrameId: string, navigationsByFrameId: Map<string, Types.TraceEvents.TraceEventNavigationStart[]>): Types.TraceEvents.TraceEventNavigationStart | null;
|
|
22
|
+
export declare function extractId(event: Types.TraceEvents.TraceEventPairableAsync | MatchedPairType<Types.TraceEvents.TraceEventPairableAsync>): string | undefined;
|
|
23
|
+
export declare function activeURLForFrameAtTime(frameId: string, time: Types.Timing.MicroSeconds, rendererProcessesByFrame: Map<string, Map<Types.TraceEvents.ProcessID, {
|
|
24
|
+
frame: Types.TraceEvents.TraceFrame;
|
|
25
|
+
window: Types.Timing.TraceWindowMicroSeconds;
|
|
26
|
+
}[]>>): string | null;
|
|
27
|
+
export declare function makeProfileCall(node: CPUProfile.ProfileTreeModel.ProfileNode, ts: Types.Timing.MicroSeconds, pid: Types.TraceEvents.ProcessID, tid: Types.TraceEvents.ThreadID): Types.TraceEvents.SyntheticProfileCall;
|
|
28
|
+
export declare function matchBeginningAndEndEvents(unpairedEvents: Types.TraceEvents.TraceEventPairableAsync[]): Map<string, {
|
|
29
|
+
begin: Types.TraceEvents.TraceEventPairableAsyncBegin | null;
|
|
30
|
+
end: Types.TraceEvents.TraceEventPairableAsyncEnd | null;
|
|
31
|
+
}>;
|
|
32
|
+
export declare function createSortedSyntheticEvents<T extends Types.TraceEvents.TraceEventPairableAsync>(matchedPairs: Map<string, {
|
|
33
|
+
begin: Types.TraceEvents.TraceEventPairableAsyncBegin | null;
|
|
34
|
+
end: Types.TraceEvents.TraceEventPairableAsyncEnd | null;
|
|
35
|
+
}>): MatchedPairType<T>[];
|
|
36
|
+
export declare function createMatchedSortedSyntheticEvents<T extends Types.TraceEvents.TraceEventPairableAsync>(unpairedAsyncEvents: T[]): MatchedPairType<T>[];
|
|
37
|
+
export {};
|
|
@@ -0,0 +1,230 @@
|
|
|
1
|
+
// Copyright 2022 The Chromium Authors. All rights reserved.
|
|
2
|
+
// Use of this source code is governed by a BSD-style license that can be
|
|
3
|
+
// found in the LICENSE file.
|
|
4
|
+
import * as Platform from '../../../core/platform/platform.js';
|
|
5
|
+
import * as Types from '../types/types.js';
|
|
6
|
+
export function stackTraceForEvent(event) {
|
|
7
|
+
if (Types.TraceEvents.isSyntheticInvalidation(event)) {
|
|
8
|
+
return event.stackTrace || null;
|
|
9
|
+
}
|
|
10
|
+
if (event.args?.data?.stackTrace) {
|
|
11
|
+
return event.args.data.stackTrace;
|
|
12
|
+
}
|
|
13
|
+
if (Types.TraceEvents.isTraceEventUpdateLayoutTree(event)) {
|
|
14
|
+
return event.args.beginData?.stackTrace || null;
|
|
15
|
+
}
|
|
16
|
+
return null;
|
|
17
|
+
}
|
|
18
|
+
export function extractOriginFromTrace(firstNavigationURL) {
|
|
19
|
+
const url = new URL(firstNavigationURL);
|
|
20
|
+
if (url) {
|
|
21
|
+
// We do this to save some space in the toolbar - seeing the `www` is less
|
|
22
|
+
// useful than seeing `foo.com` if it's truncated at narrow widths
|
|
23
|
+
if (url.host.startsWith('www.')) {
|
|
24
|
+
return url.host.slice(4);
|
|
25
|
+
}
|
|
26
|
+
return url.host;
|
|
27
|
+
}
|
|
28
|
+
return null;
|
|
29
|
+
}
|
|
30
|
+
// Each thread contains events. Events indicate the thread and process IDs, which are
|
|
31
|
+
// used to store the event in the correct process thread entry below.
|
|
32
|
+
export function addEventToProcessThread(event, eventsInProcessThread) {
|
|
33
|
+
const { tid, pid } = event;
|
|
34
|
+
let eventsInThread = eventsInProcessThread.get(pid);
|
|
35
|
+
if (!eventsInThread) {
|
|
36
|
+
eventsInThread = new Map();
|
|
37
|
+
}
|
|
38
|
+
let events = eventsInThread.get(tid);
|
|
39
|
+
if (!events) {
|
|
40
|
+
events = [];
|
|
41
|
+
}
|
|
42
|
+
events.push(event);
|
|
43
|
+
eventsInThread.set(event.tid, events);
|
|
44
|
+
eventsInProcessThread.set(event.pid, eventsInThread);
|
|
45
|
+
}
|
|
46
|
+
function eventTimeComparator(a, b) {
|
|
47
|
+
const aBeginTime = a.ts;
|
|
48
|
+
const bBeginTime = b.ts;
|
|
49
|
+
if (aBeginTime < bBeginTime) {
|
|
50
|
+
return -1;
|
|
51
|
+
}
|
|
52
|
+
if (aBeginTime > bBeginTime) {
|
|
53
|
+
return 1;
|
|
54
|
+
}
|
|
55
|
+
const aDuration = a.dur ?? 0;
|
|
56
|
+
const bDuration = b.dur ?? 0;
|
|
57
|
+
const aEndTime = aBeginTime + aDuration;
|
|
58
|
+
const bEndTime = bBeginTime + bDuration;
|
|
59
|
+
if (aEndTime > bEndTime) {
|
|
60
|
+
return -1;
|
|
61
|
+
}
|
|
62
|
+
if (aEndTime < bEndTime) {
|
|
63
|
+
return 1;
|
|
64
|
+
}
|
|
65
|
+
return 0;
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Sorts all the events in place, in order, by their start time. If they have
|
|
69
|
+
* the same start time, orders them by longest first.
|
|
70
|
+
*/
|
|
71
|
+
export function sortTraceEventsInPlace(events) {
|
|
72
|
+
events.sort(eventTimeComparator);
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* Returns an array of ordered events that results after merging the two
|
|
76
|
+
* ordered input arrays.
|
|
77
|
+
*/
|
|
78
|
+
export function mergeEventsInOrder(eventsArray1, eventsArray2) {
|
|
79
|
+
const result = [];
|
|
80
|
+
let i = 0;
|
|
81
|
+
let j = 0;
|
|
82
|
+
while (i < eventsArray1.length && j < eventsArray2.length) {
|
|
83
|
+
const event1 = eventsArray1[i];
|
|
84
|
+
const event2 = eventsArray2[j];
|
|
85
|
+
const compareValue = eventTimeComparator(event1, event2);
|
|
86
|
+
if (compareValue <= 0) {
|
|
87
|
+
result.push(event1);
|
|
88
|
+
i++;
|
|
89
|
+
}
|
|
90
|
+
if (compareValue === 1) {
|
|
91
|
+
result.push(event2);
|
|
92
|
+
j++;
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
while (i < eventsArray1.length) {
|
|
96
|
+
result.push(eventsArray1[i++]);
|
|
97
|
+
}
|
|
98
|
+
while (j < eventsArray2.length) {
|
|
99
|
+
result.push(eventsArray2[j++]);
|
|
100
|
+
}
|
|
101
|
+
return result;
|
|
102
|
+
}
|
|
103
|
+
export function getNavigationForTraceEvent(event, eventFrameId, navigationsByFrameId) {
|
|
104
|
+
const navigations = navigationsByFrameId.get(eventFrameId);
|
|
105
|
+
if (!navigations || eventFrameId === '') {
|
|
106
|
+
// This event's navigation has been filtered out by the meta handler as a noise event
|
|
107
|
+
// or contains an empty frameId.
|
|
108
|
+
return null;
|
|
109
|
+
}
|
|
110
|
+
const eventNavigationIndex = Platform.ArrayUtilities.nearestIndexFromEnd(navigations, navigation => navigation.ts <= event.ts);
|
|
111
|
+
if (eventNavigationIndex === null) {
|
|
112
|
+
// This event's navigation has been filtered out by the meta handler as a noise event.
|
|
113
|
+
return null;
|
|
114
|
+
}
|
|
115
|
+
return navigations[eventNavigationIndex];
|
|
116
|
+
}
|
|
117
|
+
export function extractId(event) {
|
|
118
|
+
return event.id ?? event.id2?.global ?? event.id2?.local;
|
|
119
|
+
}
|
|
120
|
+
export function activeURLForFrameAtTime(frameId, time, rendererProcessesByFrame) {
|
|
121
|
+
const processData = rendererProcessesByFrame.get(frameId);
|
|
122
|
+
if (!processData) {
|
|
123
|
+
return null;
|
|
124
|
+
}
|
|
125
|
+
for (const processes of processData.values()) {
|
|
126
|
+
for (const processInfo of processes) {
|
|
127
|
+
if (processInfo.window.min > time || processInfo.window.max < time) {
|
|
128
|
+
continue;
|
|
129
|
+
}
|
|
130
|
+
return processInfo.frame.url;
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
return null;
|
|
134
|
+
}
|
|
135
|
+
export function makeProfileCall(node, ts, pid, tid) {
|
|
136
|
+
return {
|
|
137
|
+
cat: '',
|
|
138
|
+
name: 'ProfileCall',
|
|
139
|
+
nodeId: node.id,
|
|
140
|
+
args: {},
|
|
141
|
+
ph: "X" /* Types.TraceEvents.Phase.COMPLETE */,
|
|
142
|
+
pid,
|
|
143
|
+
tid,
|
|
144
|
+
ts,
|
|
145
|
+
dur: Types.Timing.MicroSeconds(0),
|
|
146
|
+
selfTime: Types.Timing.MicroSeconds(0),
|
|
147
|
+
callFrame: node.callFrame,
|
|
148
|
+
};
|
|
149
|
+
}
|
|
150
|
+
export function matchBeginningAndEndEvents(unpairedEvents) {
|
|
151
|
+
// map to store begin and end of the event
|
|
152
|
+
const matchedPairs = new Map();
|
|
153
|
+
// looking for start and end
|
|
154
|
+
for (const event of unpairedEvents) {
|
|
155
|
+
const syntheticId = getSyntheticId(event);
|
|
156
|
+
if (syntheticId === undefined) {
|
|
157
|
+
continue;
|
|
158
|
+
}
|
|
159
|
+
// Create a synthetic id to prevent collisions across categories.
|
|
160
|
+
// Console timings can be dispatched with the same id, so use the
|
|
161
|
+
// event name as well to generate unique ids.
|
|
162
|
+
const otherEventsWithID = Platform.MapUtilities.getWithDefault(matchedPairs, syntheticId, () => {
|
|
163
|
+
return { begin: null, end: null };
|
|
164
|
+
});
|
|
165
|
+
const isStartEvent = event.ph === "b" /* Types.TraceEvents.Phase.ASYNC_NESTABLE_START */;
|
|
166
|
+
const isEndEvent = event.ph === "e" /* Types.TraceEvents.Phase.ASYNC_NESTABLE_END */;
|
|
167
|
+
if (isStartEvent) {
|
|
168
|
+
otherEventsWithID.begin = event;
|
|
169
|
+
}
|
|
170
|
+
else if (isEndEvent) {
|
|
171
|
+
otherEventsWithID.end = event;
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
return matchedPairs;
|
|
175
|
+
}
|
|
176
|
+
function getSyntheticId(event) {
|
|
177
|
+
const id = extractId(event);
|
|
178
|
+
return id && `${event.cat}:${id}:${event.name}`;
|
|
179
|
+
}
|
|
180
|
+
export function createSortedSyntheticEvents(matchedPairs) {
|
|
181
|
+
const syntheticEvents = [];
|
|
182
|
+
for (const [id, eventsPair] of matchedPairs.entries()) {
|
|
183
|
+
const beginEvent = eventsPair.begin;
|
|
184
|
+
const endEvent = eventsPair.end;
|
|
185
|
+
if (!beginEvent || !endEvent) {
|
|
186
|
+
// This should never happen, the backend only creates the events once it
|
|
187
|
+
// has them both, so we should never get into this state.
|
|
188
|
+
// If we do, something is very wrong, so let's just drop that problematic event.
|
|
189
|
+
continue;
|
|
190
|
+
}
|
|
191
|
+
const pair = { beginEvent, endEvent };
|
|
192
|
+
function eventsArePairable(data) {
|
|
193
|
+
return Boolean(getSyntheticId(data.beginEvent)) &&
|
|
194
|
+
getSyntheticId(data.beginEvent) === getSyntheticId(data.endEvent);
|
|
195
|
+
}
|
|
196
|
+
if (!eventsArePairable(pair)) {
|
|
197
|
+
continue;
|
|
198
|
+
}
|
|
199
|
+
const event = {
|
|
200
|
+
cat: endEvent.cat,
|
|
201
|
+
ph: endEvent.ph,
|
|
202
|
+
pid: endEvent.pid,
|
|
203
|
+
tid: endEvent.tid,
|
|
204
|
+
id,
|
|
205
|
+
// Both events have the same name, so it doesn't matter which we pick to
|
|
206
|
+
// use as the description
|
|
207
|
+
name: beginEvent.name,
|
|
208
|
+
dur: Types.Timing.MicroSeconds(endEvent.ts - beginEvent.ts),
|
|
209
|
+
ts: beginEvent.ts,
|
|
210
|
+
args: {
|
|
211
|
+
data: pair,
|
|
212
|
+
},
|
|
213
|
+
};
|
|
214
|
+
if (event.dur < 0) {
|
|
215
|
+
// We have seen in the backend that sometimes animation events get
|
|
216
|
+
// generated with multiple begin entries, or multiple end entries, and this
|
|
217
|
+
// can cause invalid data on the performance panel, so we drop them.
|
|
218
|
+
// crbug.com/1472375
|
|
219
|
+
continue;
|
|
220
|
+
}
|
|
221
|
+
syntheticEvents.push(event);
|
|
222
|
+
}
|
|
223
|
+
return syntheticEvents.sort((a, b) => a.ts - b.ts);
|
|
224
|
+
}
|
|
225
|
+
export function createMatchedSortedSyntheticEvents(unpairedAsyncEvents) {
|
|
226
|
+
const matchedPairs = matchBeginningAndEndEvents(unpairedAsyncEvents);
|
|
227
|
+
const syntheticEvents = createSortedSyntheticEvents(matchedPairs);
|
|
228
|
+
return syntheticEvents;
|
|
229
|
+
}
|
|
230
|
+
//# sourceMappingURL=Trace.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Trace.js","sourceRoot":"","sources":["../../../../../../../front_end/models/trace/helpers/Trace.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright 2022 The Chromium Authors. All rights reserved.\n// Use of this source code is governed by a BSD-style license that can be\n// found in the LICENSE file.\n\nimport * as Platform from '../../../core/platform/platform.js';\nimport type * as CPUProfile from '../../cpu_profile/cpu_profile.js';\nimport * as Types from '../types/types.js';\n\ntype MatchedPairType<T extends Types.TraceEvents.TraceEventPairableAsync> = Types.TraceEvents.SyntheticEventPair<T>;\nexport function stackTraceForEvent(event: Types.TraceEvents.TraceEventData): Types.TraceEvents.TraceEventCallFrame[]|\n null {\n if (Types.TraceEvents.isSyntheticInvalidation(event)) {\n return event.stackTrace || null;\n }\n if (event.args?.data?.stackTrace) {\n return event.args.data.stackTrace;\n }\n if (Types.TraceEvents.isTraceEventUpdateLayoutTree(event)) {\n return event.args.beginData?.stackTrace || null;\n }\n return null;\n}\n\nexport function extractOriginFromTrace(firstNavigationURL: string): string|null {\n const url = new URL(firstNavigationURL);\n if (url) {\n // We do this to save some space in the toolbar - seeing the `www` is less\n // useful than seeing `foo.com` if it's truncated at narrow widths\n if (url.host.startsWith('www.')) {\n return url.host.slice(4);\n }\n return url.host;\n }\n return null;\n}\n\nexport type EventsInThread<T extends Types.TraceEvents.TraceEventData> = Map<Types.TraceEvents.ThreadID, T[]>;\n// Each thread contains events. Events indicate the thread and process IDs, which are\n// used to store the event in the correct process thread entry below.\nexport function addEventToProcessThread<T extends Types.TraceEvents.TraceEventData>(\n event: T,\n eventsInProcessThread: Map<Types.TraceEvents.ProcessID, EventsInThread<T>>,\n ): void {\n const {tid, pid} = event;\n let eventsInThread = eventsInProcessThread.get(pid);\n if (!eventsInThread) {\n eventsInThread = new Map<Types.TraceEvents.ThreadID, T[]>();\n }\n\n let events = eventsInThread.get(tid);\n if (!events) {\n events = [];\n }\n\n events.push(event);\n eventsInThread.set(event.tid, events);\n eventsInProcessThread.set(event.pid, eventsInThread);\n}\n\ntype TimeSpan = {\n ts: Types.Timing.MicroSeconds,\n dur?: Types.Timing.MicroSeconds,\n};\nfunction eventTimeComparator(a: TimeSpan, b: TimeSpan): -1|0|1 {\n const aBeginTime = a.ts;\n const bBeginTime = b.ts;\n if (aBeginTime < bBeginTime) {\n return -1;\n }\n if (aBeginTime > bBeginTime) {\n return 1;\n }\n const aDuration = a.dur ?? 0;\n const bDuration = b.dur ?? 0;\n const aEndTime = aBeginTime + aDuration;\n const bEndTime = bBeginTime + bDuration;\n if (aEndTime > bEndTime) {\n return -1;\n }\n if (aEndTime < bEndTime) {\n return 1;\n }\n return 0;\n}\n/**\n * Sorts all the events in place, in order, by their start time. If they have\n * the same start time, orders them by longest first.\n */\nexport function sortTraceEventsInPlace(events: {ts: Types.Timing.MicroSeconds, dur?: Types.Timing.MicroSeconds}[]):\n void {\n events.sort(eventTimeComparator);\n}\n\n/**\n * Returns an array of ordered events that results after merging the two\n * ordered input arrays.\n */\nexport function\nmergeEventsInOrder<T1 extends Types.TraceEvents.TraceEventData, T2 extends Types.TraceEvents.TraceEventData>(\n eventsArray1: T1[], eventsArray2: T2[]): (T1|T2)[] {\n const result = [];\n let i = 0;\n let j = 0;\n while (i < eventsArray1.length && j < eventsArray2.length) {\n const event1 = eventsArray1[i];\n const event2 = eventsArray2[j];\n const compareValue = eventTimeComparator(event1, event2);\n if (compareValue <= 0) {\n result.push(event1);\n i++;\n }\n if (compareValue === 1) {\n result.push(event2);\n j++;\n }\n }\n while (i < eventsArray1.length) {\n result.push(eventsArray1[i++]);\n }\n while (j < eventsArray2.length) {\n result.push(eventsArray2[j++]);\n }\n return result;\n}\n\nexport function getNavigationForTraceEvent(\n event: Types.TraceEvents.TraceEventData,\n eventFrameId: string,\n navigationsByFrameId: Map<string, Types.TraceEvents.TraceEventNavigationStart[]>,\n ): Types.TraceEvents.TraceEventNavigationStart|null {\n const navigations = navigationsByFrameId.get(eventFrameId);\n if (!navigations || eventFrameId === '') {\n // This event's navigation has been filtered out by the meta handler as a noise event\n // or contains an empty frameId.\n return null;\n }\n\n const eventNavigationIndex =\n Platform.ArrayUtilities.nearestIndexFromEnd(navigations, navigation => navigation.ts <= event.ts);\n\n if (eventNavigationIndex === null) {\n // This event's navigation has been filtered out by the meta handler as a noise event.\n return null;\n }\n return navigations[eventNavigationIndex];\n}\n\nexport function extractId(event: Types.TraceEvents.TraceEventPairableAsync|\n MatchedPairType<Types.TraceEvents.TraceEventPairableAsync>): string|undefined {\n return event.id ?? event.id2?.global ?? event.id2?.local;\n}\n\nexport function activeURLForFrameAtTime(\n frameId: string, time: Types.Timing.MicroSeconds,\n rendererProcessesByFrame:\n Map<string,\n Map<Types.TraceEvents.ProcessID,\n {frame: Types.TraceEvents.TraceFrame, window: Types.Timing.TraceWindowMicroSeconds}[]>>): string|null {\n const processData = rendererProcessesByFrame.get(frameId);\n if (!processData) {\n return null;\n }\n for (const processes of processData.values()) {\n for (const processInfo of processes) {\n if (processInfo.window.min > time || processInfo.window.max < time) {\n continue;\n }\n return processInfo.frame.url;\n }\n }\n return null;\n}\n\nexport function makeProfileCall(\n node: CPUProfile.ProfileTreeModel.ProfileNode, ts: Types.Timing.MicroSeconds, pid: Types.TraceEvents.ProcessID,\n tid: Types.TraceEvents.ThreadID): Types.TraceEvents.SyntheticProfileCall {\n return {\n cat: '',\n name: 'ProfileCall',\n nodeId: node.id,\n args: {},\n ph: Types.TraceEvents.Phase.COMPLETE,\n pid,\n tid,\n ts,\n dur: Types.Timing.MicroSeconds(0),\n selfTime: Types.Timing.MicroSeconds(0),\n callFrame: node.callFrame,\n };\n}\n\nexport function matchBeginningAndEndEvents(unpairedEvents: Types.TraceEvents.TraceEventPairableAsync[]): Map<string, {\n begin: Types.TraceEvents.TraceEventPairableAsyncBegin | null,\n end: Types.TraceEvents.TraceEventPairableAsyncEnd | null,\n}> {\n // map to store begin and end of the event\n const matchedPairs: Map<string, {\n begin: Types.TraceEvents.TraceEventPairableAsyncBegin | null,\n end: Types.TraceEvents.TraceEventPairableAsyncEnd | null,\n }> = new Map();\n\n // looking for start and end\n for (const event of unpairedEvents) {\n const syntheticId = getSyntheticId(event);\n if (syntheticId === undefined) {\n continue;\n }\n // Create a synthetic id to prevent collisions across categories.\n // Console timings can be dispatched with the same id, so use the\n // event name as well to generate unique ids.\n const otherEventsWithID = Platform.MapUtilities.getWithDefault(matchedPairs, syntheticId, () => {\n return {begin: null, end: null};\n });\n\n const isStartEvent = event.ph === Types.TraceEvents.Phase.ASYNC_NESTABLE_START;\n const isEndEvent = event.ph === Types.TraceEvents.Phase.ASYNC_NESTABLE_END;\n\n if (isStartEvent) {\n otherEventsWithID.begin = event as Types.TraceEvents.TraceEventPairableAsyncBegin;\n } else if (isEndEvent) {\n otherEventsWithID.end = event as Types.TraceEvents.TraceEventPairableAsyncEnd;\n }\n }\n\n return matchedPairs;\n}\n\nfunction getSyntheticId(event: Types.TraceEvents.TraceEventPairableAsync): string|undefined {\n const id = extractId(event);\n return id && `${event.cat}:${id}:${event.name}`;\n}\n\nexport function createSortedSyntheticEvents<T extends Types.TraceEvents.TraceEventPairableAsync>(\n matchedPairs: Map<string, {\n begin: Types.TraceEvents.TraceEventPairableAsyncBegin | null,\n end: Types.TraceEvents.TraceEventPairableAsyncEnd | null,\n }>): MatchedPairType<T>[] {\n const syntheticEvents: MatchedPairType<T>[] = [];\n for (const [id, eventsPair] of matchedPairs.entries()) {\n const beginEvent = eventsPair.begin;\n const endEvent = eventsPair.end;\n if (!beginEvent || !endEvent) {\n // This should never happen, the backend only creates the events once it\n // has them both, so we should never get into this state.\n // If we do, something is very wrong, so let's just drop that problematic event.\n continue;\n }\n const pair = {beginEvent, endEvent};\n function eventsArePairable(data: {\n beginEvent: Types.TraceEvents.TraceEventPairableAsyncBegin,\n endEvent: Types.TraceEvents.TraceEventPairableAsyncEnd,\n }): data is MatchedPairType<T>['args']['data'] {\n return Boolean(getSyntheticId(data.beginEvent)) &&\n getSyntheticId(data.beginEvent) === getSyntheticId(data.endEvent);\n }\n if (!eventsArePairable(pair)) {\n continue;\n }\n const event: MatchedPairType<T> = {\n cat: endEvent.cat,\n ph: endEvent.ph,\n pid: endEvent.pid,\n tid: endEvent.tid,\n id,\n // Both events have the same name, so it doesn't matter which we pick to\n // use as the description\n name: beginEvent.name,\n dur: Types.Timing.MicroSeconds(endEvent.ts - beginEvent.ts),\n ts: beginEvent.ts,\n args: {\n data: pair,\n },\n };\n\n if (event.dur < 0) {\n // We have seen in the backend that sometimes animation events get\n // generated with multiple begin entries, or multiple end entries, and this\n // can cause invalid data on the performance panel, so we drop them.\n // crbug.com/1472375\n continue;\n }\n syntheticEvents.push(event);\n }\n return syntheticEvents.sort((a, b) => a.ts - b.ts);\n}\n\nexport function createMatchedSortedSyntheticEvents<T extends Types.TraceEvents.TraceEventPairableAsync>(\n unpairedAsyncEvents: T[]): MatchedPairType<T>[] {\n const matchedPairs = matchBeginningAndEndEvents(unpairedAsyncEvents);\n const syntheticEvents = createSortedSyntheticEvents<T>(matchedPairs);\n return syntheticEvents;\n}\n"]}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import * as Types from '../types/types.js';
|
|
2
|
+
export declare const makeTraceEntryNodeId: () => TraceEntryNodeId;
|
|
3
|
+
export declare const makeEmptyTraceEntryTree: () => TraceEntryTree;
|
|
4
|
+
export declare const makeEmptyTraceEntryNode: (entry: Types.TraceEvents.SyntheticTraceEntry, id: TraceEntryNodeId) => TraceEntryNode;
|
|
5
|
+
export interface TraceEntryTree {
|
|
6
|
+
roots: Set<TraceEntryNode>;
|
|
7
|
+
maxDepth: number;
|
|
8
|
+
}
|
|
9
|
+
export interface TraceEntryNode {
|
|
10
|
+
entry: Types.TraceEvents.SyntheticTraceEntry;
|
|
11
|
+
depth: number;
|
|
12
|
+
id: TraceEntryNodeId;
|
|
13
|
+
parent: TraceEntryNode | null;
|
|
14
|
+
children: TraceEntryNode[];
|
|
15
|
+
}
|
|
16
|
+
declare class TraceEntryNodeIdTag {
|
|
17
|
+
#private;
|
|
18
|
+
}
|
|
19
|
+
export type TraceEntryNodeId = number & TraceEntryNodeIdTag;
|
|
20
|
+
/**
|
|
21
|
+
* Builds a hierarchy of the entries (trace events and profile calls) in
|
|
22
|
+
* a particular thread of a particular process, assuming that they're
|
|
23
|
+
* sorted, by iterating through all of the events in order.
|
|
24
|
+
*
|
|
25
|
+
* The approach is analogous to how a parser would be implemented. A
|
|
26
|
+
* stack maintains local context. A scanner peeks and pops from the data
|
|
27
|
+
* stream. Various "tokens" (events) are treated as "whitespace"
|
|
28
|
+
* (ignored).
|
|
29
|
+
*
|
|
30
|
+
* The tree starts out empty and is populated as the hierarchy is built.
|
|
31
|
+
* The nodes are also assumed to be created empty, with no known parent
|
|
32
|
+
* or children.
|
|
33
|
+
*
|
|
34
|
+
* Complexity: O(n), where n = number of events
|
|
35
|
+
*/
|
|
36
|
+
export declare function treify(entries: Types.TraceEvents.SyntheticTraceEntry[], options?: {
|
|
37
|
+
filter: {
|
|
38
|
+
has: (name: Types.TraceEvents.KnownEventName) => boolean;
|
|
39
|
+
};
|
|
40
|
+
}): {
|
|
41
|
+
tree: TraceEntryTree;
|
|
42
|
+
entryToNode: Map<Types.TraceEvents.SyntheticTraceEntry, TraceEntryNode>;
|
|
43
|
+
};
|
|
44
|
+
/**
|
|
45
|
+
* Iterates events in a tree hierarchically, from top to bottom,
|
|
46
|
+
* calling back on every event's start and end in the order
|
|
47
|
+
* as it traverses down and then up the tree.
|
|
48
|
+
*
|
|
49
|
+
* For example, given this tree, the following callbacks
|
|
50
|
+
* are expected to be made in the following order
|
|
51
|
+
* |---------------A---------------|
|
|
52
|
+
* |------B------||-------D------|
|
|
53
|
+
* |---C---|
|
|
54
|
+
*
|
|
55
|
+
* 1. Start A
|
|
56
|
+
* 3. Start B
|
|
57
|
+
* 4. Start C
|
|
58
|
+
* 5. End C
|
|
59
|
+
* 6. End B
|
|
60
|
+
* 7. Start D
|
|
61
|
+
* 8. End D
|
|
62
|
+
* 9. End A
|
|
63
|
+
*
|
|
64
|
+
*/
|
|
65
|
+
export declare function walkTreeFromEntry(entryToNode: Map<Types.TraceEvents.SyntheticTraceEntry, TraceEntryNode>, rootEntry: Types.TraceEvents.SyntheticTraceEntry, onEntryStart: (entry: Types.TraceEvents.SyntheticTraceEntry) => void, onEntryEnd: (entry: Types.TraceEvents.SyntheticTraceEntry) => void): void;
|
|
66
|
+
/**
|
|
67
|
+
* Given a Helpers.TreeHelpers.RendererTree, this will iterates events in hierarchically, visiting
|
|
68
|
+
* each root node and working from top to bottom, calling back on every event's
|
|
69
|
+
* start and end in the order as it traverses down and then up the tree.
|
|
70
|
+
*
|
|
71
|
+
* For example, given this tree, the following callbacks
|
|
72
|
+
* are expected to be made in the following order
|
|
73
|
+
* |------------- Task A -------------||-- Task E --|
|
|
74
|
+
* |-- Task B --||-- Task D --|
|
|
75
|
+
* |- Task C -|
|
|
76
|
+
*
|
|
77
|
+
* 1. Start A
|
|
78
|
+
* 3. Start B
|
|
79
|
+
* 4. Start C
|
|
80
|
+
* 5. End C
|
|
81
|
+
* 6. End B
|
|
82
|
+
* 7. Start D
|
|
83
|
+
* 8. End D
|
|
84
|
+
* 9. End A
|
|
85
|
+
* 10. Start E
|
|
86
|
+
* 11. End E
|
|
87
|
+
*
|
|
88
|
+
*/
|
|
89
|
+
export declare function walkEntireTree(entryToNode: Map<Types.TraceEvents.SyntheticTraceEntry, TraceEntryNode>, tree: TraceEntryTree, onEntryStart: (entry: Types.TraceEvents.SyntheticTraceEntry) => void, onEntryEnd: (entry: Types.TraceEvents.SyntheticTraceEntry) => void, traceWindowToInclude?: Types.Timing.TraceWindowMicroSeconds, minDuration?: Types.Timing.MicroSeconds): void;
|
|
90
|
+
export {};
|
|
@@ -0,0 +1,222 @@
|
|
|
1
|
+
// Copyright 2023 The Chromium Authors. All rights reserved.
|
|
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 Types from '../types/types.js';
|
|
5
|
+
let nodeIdCount = 0;
|
|
6
|
+
export const makeTraceEntryNodeId = () => (++nodeIdCount);
|
|
7
|
+
export const makeEmptyTraceEntryTree = () => ({
|
|
8
|
+
roots: new Set(),
|
|
9
|
+
maxDepth: 0,
|
|
10
|
+
});
|
|
11
|
+
export const makeEmptyTraceEntryNode = (entry, id) => ({
|
|
12
|
+
entry,
|
|
13
|
+
id,
|
|
14
|
+
parent: null,
|
|
15
|
+
children: [],
|
|
16
|
+
depth: 0,
|
|
17
|
+
});
|
|
18
|
+
class TraceEntryNodeIdTag {
|
|
19
|
+
/* eslint-disable-next-line no-unused-private-class-members */
|
|
20
|
+
#tag;
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Builds a hierarchy of the entries (trace events and profile calls) in
|
|
24
|
+
* a particular thread of a particular process, assuming that they're
|
|
25
|
+
* sorted, by iterating through all of the events in order.
|
|
26
|
+
*
|
|
27
|
+
* The approach is analogous to how a parser would be implemented. A
|
|
28
|
+
* stack maintains local context. A scanner peeks and pops from the data
|
|
29
|
+
* stream. Various "tokens" (events) are treated as "whitespace"
|
|
30
|
+
* (ignored).
|
|
31
|
+
*
|
|
32
|
+
* The tree starts out empty and is populated as the hierarchy is built.
|
|
33
|
+
* The nodes are also assumed to be created empty, with no known parent
|
|
34
|
+
* or children.
|
|
35
|
+
*
|
|
36
|
+
* Complexity: O(n), where n = number of events
|
|
37
|
+
*/
|
|
38
|
+
export function treify(entries, options) {
|
|
39
|
+
// As we construct the tree, store a map of each entry to its node. This
|
|
40
|
+
// means if you are iterating over a list of RendererEntry events you can
|
|
41
|
+
// easily look up that node in the tree.
|
|
42
|
+
const entryToNode = new Map();
|
|
43
|
+
const stack = [];
|
|
44
|
+
// Reset the node id counter for every new renderer.
|
|
45
|
+
nodeIdCount = -1;
|
|
46
|
+
const tree = makeEmptyTraceEntryTree();
|
|
47
|
+
for (let i = 0; i < entries.length; i++) {
|
|
48
|
+
const event = entries[i];
|
|
49
|
+
// If the current event should not be part of the tree, then simply proceed
|
|
50
|
+
// with the next event.
|
|
51
|
+
if (options && !options.filter.has(event.name)) {
|
|
52
|
+
continue;
|
|
53
|
+
}
|
|
54
|
+
const duration = event.dur || 0;
|
|
55
|
+
const nodeId = makeTraceEntryNodeId();
|
|
56
|
+
const node = makeEmptyTraceEntryNode(event, nodeId);
|
|
57
|
+
// If the parent stack is empty, then the current event is a root. Create a
|
|
58
|
+
// node for it, mark it as a root, then proceed with the next event.
|
|
59
|
+
if (stack.length === 0) {
|
|
60
|
+
tree.roots.add(node);
|
|
61
|
+
event.selfTime = Types.Timing.MicroSeconds(duration);
|
|
62
|
+
stack.push(node);
|
|
63
|
+
tree.maxDepth = Math.max(tree.maxDepth, stack.length);
|
|
64
|
+
entryToNode.set(event, node);
|
|
65
|
+
continue;
|
|
66
|
+
}
|
|
67
|
+
const parentNode = stack.at(-1);
|
|
68
|
+
if (parentNode === undefined) {
|
|
69
|
+
throw new Error('Impossible: no parent node found in the stack');
|
|
70
|
+
}
|
|
71
|
+
const parentEvent = parentNode.entry;
|
|
72
|
+
const begin = event.ts;
|
|
73
|
+
const parentBegin = parentEvent.ts;
|
|
74
|
+
const parentDuration = parentEvent.dur || 0;
|
|
75
|
+
const end = begin + duration;
|
|
76
|
+
const parentEnd = parentBegin + parentDuration;
|
|
77
|
+
// Check the relationship between the parent event at the top of the stack,
|
|
78
|
+
// and the current event being processed. There are only 4 distinct
|
|
79
|
+
// possiblities, only 2 of them actually valid, given the assumed sorting:
|
|
80
|
+
// 1. Current event starts before the parent event, ends whenever. (invalid)
|
|
81
|
+
// 2. Current event starts after the parent event, ends whenever. (valid)
|
|
82
|
+
// 3. Current event starts during the parent event, ends after. (invalid)
|
|
83
|
+
// 4. Current event starts and ends during the parent event. (valid)
|
|
84
|
+
// 1. If the current event starts before the parent event, then the data is
|
|
85
|
+
// not sorted properly, messed up some way, or this logic is incomplete.
|
|
86
|
+
const startsBeforeParent = begin < parentBegin;
|
|
87
|
+
if (startsBeforeParent) {
|
|
88
|
+
throw new Error('Impossible: current event starts before the parent event');
|
|
89
|
+
}
|
|
90
|
+
// 2. If the current event starts after the parent event, then it's a new
|
|
91
|
+
// parent. Pop, then handle current event again.
|
|
92
|
+
const startsAfterParent = begin >= parentEnd;
|
|
93
|
+
if (startsAfterParent) {
|
|
94
|
+
stack.pop();
|
|
95
|
+
i--;
|
|
96
|
+
// The last created node has been discarded, so discard this id.
|
|
97
|
+
nodeIdCount--;
|
|
98
|
+
continue;
|
|
99
|
+
}
|
|
100
|
+
// 3. If the current event starts during the parent event, but ends
|
|
101
|
+
// after it, then the data is messed up some way, for example a
|
|
102
|
+
// profile call was sampled too late after its start, ignore the
|
|
103
|
+
// problematic event.
|
|
104
|
+
const endsAfterParent = end > parentEnd;
|
|
105
|
+
if (endsAfterParent) {
|
|
106
|
+
continue;
|
|
107
|
+
}
|
|
108
|
+
// 4. The only remaining case is the common case, where the current event is
|
|
109
|
+
// contained within the parent event. Create a node for the current
|
|
110
|
+
// event, establish the parent/child relationship, then proceed with the
|
|
111
|
+
// next event.
|
|
112
|
+
node.depth = stack.length;
|
|
113
|
+
node.parent = parentNode;
|
|
114
|
+
parentNode.children.push(node);
|
|
115
|
+
event.selfTime = Types.Timing.MicroSeconds(duration);
|
|
116
|
+
if (parentEvent.selfTime !== undefined) {
|
|
117
|
+
parentEvent.selfTime = Types.Timing.MicroSeconds(parentEvent.selfTime - (event.dur || 0));
|
|
118
|
+
}
|
|
119
|
+
stack.push(node);
|
|
120
|
+
tree.maxDepth = Math.max(tree.maxDepth, stack.length);
|
|
121
|
+
entryToNode.set(event, node);
|
|
122
|
+
}
|
|
123
|
+
return { tree, entryToNode };
|
|
124
|
+
}
|
|
125
|
+
/**
|
|
126
|
+
* Iterates events in a tree hierarchically, from top to bottom,
|
|
127
|
+
* calling back on every event's start and end in the order
|
|
128
|
+
* as it traverses down and then up the tree.
|
|
129
|
+
*
|
|
130
|
+
* For example, given this tree, the following callbacks
|
|
131
|
+
* are expected to be made in the following order
|
|
132
|
+
* |---------------A---------------|
|
|
133
|
+
* |------B------||-------D------|
|
|
134
|
+
* |---C---|
|
|
135
|
+
*
|
|
136
|
+
* 1. Start A
|
|
137
|
+
* 3. Start B
|
|
138
|
+
* 4. Start C
|
|
139
|
+
* 5. End C
|
|
140
|
+
* 6. End B
|
|
141
|
+
* 7. Start D
|
|
142
|
+
* 8. End D
|
|
143
|
+
* 9. End A
|
|
144
|
+
*
|
|
145
|
+
*/
|
|
146
|
+
export function walkTreeFromEntry(entryToNode, rootEntry, onEntryStart, onEntryEnd) {
|
|
147
|
+
const startNode = entryToNode.get(rootEntry);
|
|
148
|
+
if (!startNode) {
|
|
149
|
+
return;
|
|
150
|
+
}
|
|
151
|
+
walkTreeByNode(entryToNode, startNode, onEntryStart, onEntryEnd);
|
|
152
|
+
}
|
|
153
|
+
/**
|
|
154
|
+
* Given a Helpers.TreeHelpers.RendererTree, this will iterates events in hierarchically, visiting
|
|
155
|
+
* each root node and working from top to bottom, calling back on every event's
|
|
156
|
+
* start and end in the order as it traverses down and then up the tree.
|
|
157
|
+
*
|
|
158
|
+
* For example, given this tree, the following callbacks
|
|
159
|
+
* are expected to be made in the following order
|
|
160
|
+
* |------------- Task A -------------||-- Task E --|
|
|
161
|
+
* |-- Task B --||-- Task D --|
|
|
162
|
+
* |- Task C -|
|
|
163
|
+
*
|
|
164
|
+
* 1. Start A
|
|
165
|
+
* 3. Start B
|
|
166
|
+
* 4. Start C
|
|
167
|
+
* 5. End C
|
|
168
|
+
* 6. End B
|
|
169
|
+
* 7. Start D
|
|
170
|
+
* 8. End D
|
|
171
|
+
* 9. End A
|
|
172
|
+
* 10. Start E
|
|
173
|
+
* 11. End E
|
|
174
|
+
*
|
|
175
|
+
*/
|
|
176
|
+
export function walkEntireTree(entryToNode, tree, onEntryStart, onEntryEnd, traceWindowToInclude, minDuration) {
|
|
177
|
+
for (const rootNode of tree.roots) {
|
|
178
|
+
walkTreeByNode(entryToNode, rootNode, onEntryStart, onEntryEnd, traceWindowToInclude, minDuration);
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
function walkTreeByNode(entryToNode, rootNode, onEntryStart, onEntryEnd, traceWindowToInclude, minDuration) {
|
|
182
|
+
if (traceWindowToInclude && !treeNodeIsInWindow(rootNode, traceWindowToInclude)) {
|
|
183
|
+
// If this node is not within the provided window, we can skip it. We also
|
|
184
|
+
// can skip all its children too, as we know they won't be in the window if
|
|
185
|
+
// their parent is not.
|
|
186
|
+
return;
|
|
187
|
+
}
|
|
188
|
+
if (typeof minDuration !== 'undefined') {
|
|
189
|
+
const duration = Types.Timing.MicroSeconds(rootNode.entry.ts + Types.Timing.MicroSeconds(rootNode.entry.dur || 0));
|
|
190
|
+
if (duration < minDuration) {
|
|
191
|
+
return;
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
onEntryStart(rootNode.entry);
|
|
195
|
+
for (const child of rootNode.children) {
|
|
196
|
+
walkTreeByNode(entryToNode, child, onEntryStart, onEntryEnd, traceWindowToInclude, minDuration);
|
|
197
|
+
}
|
|
198
|
+
onEntryEnd(rootNode.entry);
|
|
199
|
+
}
|
|
200
|
+
/**
|
|
201
|
+
* Returns true if the provided node is partially or fully within the trace
|
|
202
|
+
* window. The entire node does not have to fit inside the window, but it does
|
|
203
|
+
* have to partially intersect it.
|
|
204
|
+
*/
|
|
205
|
+
function treeNodeIsInWindow(node, traceWindow) {
|
|
206
|
+
const startTime = node.entry.ts;
|
|
207
|
+
const endTime = node.entry.ts + (node.entry.dur || 0);
|
|
208
|
+
// Min ======= startTime ========= Max => node is within window
|
|
209
|
+
if (startTime >= traceWindow.min && startTime < traceWindow.max) {
|
|
210
|
+
return true;
|
|
211
|
+
}
|
|
212
|
+
// Min ======= endTime ========= Max => node is within window
|
|
213
|
+
if (endTime > traceWindow.min && endTime <= traceWindow.max) {
|
|
214
|
+
return true;
|
|
215
|
+
}
|
|
216
|
+
// startTime ==== Min ======== Max === endTime => node spans greater than the window so is in it.
|
|
217
|
+
if (startTime <= traceWindow.min && endTime >= traceWindow.max) {
|
|
218
|
+
return true;
|
|
219
|
+
}
|
|
220
|
+
return false;
|
|
221
|
+
}
|
|
222
|
+
//# sourceMappingURL=TreeHelpers.js.map
|