xref: /aosp_15_r20/external/perfetto/ui/src/plugins/dev.perfetto.Debug/index.ts (revision 6dbdd20afdafa5e3ca9b8809fa73465d530080dc)
1*6dbdd20aSAndroid Build Coastguard Worker// Copyright (C) 2023 The Android Open Source Project
2*6dbdd20aSAndroid Build Coastguard Worker//
3*6dbdd20aSAndroid Build Coastguard Worker// Licensed under the Apache License, Version 2.0 (the "License");
4*6dbdd20aSAndroid Build Coastguard Worker// you may not use this file except in compliance with the License.
5*6dbdd20aSAndroid Build Coastguard Worker// You may obtain a copy of the License at
6*6dbdd20aSAndroid Build Coastguard Worker//
7*6dbdd20aSAndroid Build Coastguard Worker//      http://www.apache.org/licenses/LICENSE-2.0
8*6dbdd20aSAndroid Build Coastguard Worker//
9*6dbdd20aSAndroid Build Coastguard Worker// Unless required by applicable law or agreed to in writing, software
10*6dbdd20aSAndroid Build Coastguard Worker// distributed under the License is distributed on an "AS IS" BASIS,
11*6dbdd20aSAndroid Build Coastguard Worker// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12*6dbdd20aSAndroid Build Coastguard Worker// See the License for the specific language governing permissions and
13*6dbdd20aSAndroid Build Coastguard Worker// limitations under the License.
14*6dbdd20aSAndroid Build Coastguard Worker
15*6dbdd20aSAndroid Build Coastguard Workerimport {
16*6dbdd20aSAndroid Build Coastguard Worker  addDebugCounterTrack,
17*6dbdd20aSAndroid Build Coastguard Worker  addDebugSliceTrack,
18*6dbdd20aSAndroid Build Coastguard Worker} from '../../components/tracks/debug_tracks';
19*6dbdd20aSAndroid Build Coastguard Workerimport {Trace} from '../../public/trace';
20*6dbdd20aSAndroid Build Coastguard Workerimport {PerfettoPlugin} from '../../public/plugin';
21*6dbdd20aSAndroid Build Coastguard Workerimport {exists} from '../../base/utils';
22*6dbdd20aSAndroid Build Coastguard Worker
23*6dbdd20aSAndroid Build Coastguard Workerexport default class implements PerfettoPlugin {
24*6dbdd20aSAndroid Build Coastguard Worker  static readonly id = 'dev.perfetto.DebugTracks';
25*6dbdd20aSAndroid Build Coastguard Worker  async onTraceLoad(ctx: Trace): Promise<void> {
26*6dbdd20aSAndroid Build Coastguard Worker    ctx.commands.registerCommand({
27*6dbdd20aSAndroid Build Coastguard Worker      id: 'perfetto.DebugTracks#addDebugSliceTrack',
28*6dbdd20aSAndroid Build Coastguard Worker      name: 'Add debug slice track',
29*6dbdd20aSAndroid Build Coastguard Worker      callback: async (arg: unknown) => {
30*6dbdd20aSAndroid Build Coastguard Worker        // This command takes a query and creates a debug track out of it The
31*6dbdd20aSAndroid Build Coastguard Worker        // query can be passed in using the first arg, or if this is not defined
32*6dbdd20aSAndroid Build Coastguard Worker        // or is the wrong type, we prompt the user for it.
33*6dbdd20aSAndroid Build Coastguard Worker        const query = await getStringFromArgOrPrompt(ctx, arg);
34*6dbdd20aSAndroid Build Coastguard Worker        if (exists(query)) {
35*6dbdd20aSAndroid Build Coastguard Worker          await addDebugSliceTrack({
36*6dbdd20aSAndroid Build Coastguard Worker            trace: ctx,
37*6dbdd20aSAndroid Build Coastguard Worker            data: {
38*6dbdd20aSAndroid Build Coastguard Worker              sqlSource: query,
39*6dbdd20aSAndroid Build Coastguard Worker            },
40*6dbdd20aSAndroid Build Coastguard Worker            title: 'Debug slice track',
41*6dbdd20aSAndroid Build Coastguard Worker          });
42*6dbdd20aSAndroid Build Coastguard Worker        }
43*6dbdd20aSAndroid Build Coastguard Worker      },
44*6dbdd20aSAndroid Build Coastguard Worker    });
45*6dbdd20aSAndroid Build Coastguard Worker
46*6dbdd20aSAndroid Build Coastguard Worker    ctx.commands.registerCommand({
47*6dbdd20aSAndroid Build Coastguard Worker      id: 'perfetto.DebugTracks#addDebugCounterTrack',
48*6dbdd20aSAndroid Build Coastguard Worker      name: 'Add debug counter track',
49*6dbdd20aSAndroid Build Coastguard Worker      callback: async (arg: unknown) => {
50*6dbdd20aSAndroid Build Coastguard Worker        const query = await getStringFromArgOrPrompt(ctx, arg);
51*6dbdd20aSAndroid Build Coastguard Worker        if (exists(query)) {
52*6dbdd20aSAndroid Build Coastguard Worker          await addDebugCounterTrack({
53*6dbdd20aSAndroid Build Coastguard Worker            trace: ctx,
54*6dbdd20aSAndroid Build Coastguard Worker            data: {
55*6dbdd20aSAndroid Build Coastguard Worker              sqlSource: query,
56*6dbdd20aSAndroid Build Coastguard Worker            },
57*6dbdd20aSAndroid Build Coastguard Worker            title: 'Debug slice track',
58*6dbdd20aSAndroid Build Coastguard Worker          });
59*6dbdd20aSAndroid Build Coastguard Worker        }
60*6dbdd20aSAndroid Build Coastguard Worker      },
61*6dbdd20aSAndroid Build Coastguard Worker    });
62*6dbdd20aSAndroid Build Coastguard Worker  }
63*6dbdd20aSAndroid Build Coastguard Worker}
64*6dbdd20aSAndroid Build Coastguard Worker
65*6dbdd20aSAndroid Build Coastguard Worker// If arg is a string, return it, otherwise prompt the user for a string. An
66*6dbdd20aSAndroid Build Coastguard Worker// exception is thrown if the prompt is cancelled, so this function handles this
67*6dbdd20aSAndroid Build Coastguard Worker// and returns undefined in this case.
68*6dbdd20aSAndroid Build Coastguard Workerasync function getStringFromArgOrPrompt(
69*6dbdd20aSAndroid Build Coastguard Worker  ctx: Trace,
70*6dbdd20aSAndroid Build Coastguard Worker  arg: unknown,
71*6dbdd20aSAndroid Build Coastguard Worker): Promise<string | undefined> {
72*6dbdd20aSAndroid Build Coastguard Worker  if (typeof arg === 'string') {
73*6dbdd20aSAndroid Build Coastguard Worker    return arg;
74*6dbdd20aSAndroid Build Coastguard Worker  } else {
75*6dbdd20aSAndroid Build Coastguard Worker    return await ctx.omnibox.prompt('Enter a query...');
76*6dbdd20aSAndroid Build Coastguard Worker  }
77*6dbdd20aSAndroid Build Coastguard Worker}
78