1fb726d48Sopenharmony_ci/*
2fb726d48Sopenharmony_ci * Copyright (C) 2024 Shenzhen Kaihong Digital Industry Development Co., Ltd.
3fb726d48Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4fb726d48Sopenharmony_ci * you may not use this file except in compliance with the License.
5fb726d48Sopenharmony_ci * You may obtain a copy of the License at
6fb726d48Sopenharmony_ci *
7fb726d48Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
8fb726d48Sopenharmony_ci *
9fb726d48Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10fb726d48Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11fb726d48Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12fb726d48Sopenharmony_ci * See the License for the specific language governing permissions and
13fb726d48Sopenharmony_ci * limitations under the License.
14fb726d48Sopenharmony_ci */
15fb726d48Sopenharmony_ci
16fb726d48Sopenharmony_ciimport { FlagsConfig } from '../../component/SpFlags';
17fb726d48Sopenharmony_ciimport { query } from '../SqlLite';
18fb726d48Sopenharmony_ciimport { HangStruct } from '../ui-worker/ProcedureWorkerHang';
19fb726d48Sopenharmony_ci
20fb726d48Sopenharmony_cifunction getMinDur(): string {
21fb726d48Sopenharmony_ci  let flagsItemJson = JSON.parse(window.localStorage.getItem(FlagsConfig.FLAGS_CONFIG_KEY)!);
22fb726d48Sopenharmony_ci  let minDur = flagsItemJson.hangValue;
23fb726d48Sopenharmony_ci  return minDur;
24fb726d48Sopenharmony_ci}
25fb726d48Sopenharmony_ci
26fb726d48Sopenharmony_ciexport const queryHangData = (): Promise<Array<{
27fb726d48Sopenharmony_ci  id: number,
28fb726d48Sopenharmony_ci  name: string,
29fb726d48Sopenharmony_ci  num: number
30fb726d48Sopenharmony_ci}>> => query(
31fb726d48Sopenharmony_ci  'queryHangData',
32fb726d48Sopenharmony_ci  `
33fb726d48Sopenharmony_ciSELECT
34fb726d48Sopenharmony_ci  p.pid as id,
35fb726d48Sopenharmony_ci  p.name as name,
36fb726d48Sopenharmony_ci  count(*) as num
37fb726d48Sopenharmony_ciFROM
38fb726d48Sopenharmony_ci  callstack c
39fb726d48Sopenharmony_ciLEFT JOIN thread t ON
40fb726d48Sopenharmony_ci  t.itid = c.callid
41fb726d48Sopenharmony_ciLEFT JOIN process p ON
42fb726d48Sopenharmony_ci  p.ipid = t.ipid
43fb726d48Sopenharmony_ciWHERE
44fb726d48Sopenharmony_ci  c.name LIKE 'H:Et:%'
45fb726d48Sopenharmony_ci  AND t.is_main_thread = 1
46fb726d48Sopenharmony_ci  AND c.dur >= ${getMinDur()}
47fb726d48Sopenharmony_ciGROUP BY
48fb726d48Sopenharmony_ci  p.pid
49fb726d48Sopenharmony_ci`.trim()
50fb726d48Sopenharmony_ci);
51fb726d48Sopenharmony_ci
52fb726d48Sopenharmony_ci
53fb726d48Sopenharmony_ciexport const queryAllHangs = (): Promise<Array<HangStruct>> => query(
54fb726d48Sopenharmony_ci  'queryAllHangs',
55fb726d48Sopenharmony_ci  `
56fb726d48Sopenharmony_ciSELECT
57fb726d48Sopenharmony_ci  c.id as id,
58fb726d48Sopenharmony_ci  c.ts - r.start_ts as startNS,
59fb726d48Sopenharmony_ci  c.dur as dur,
60fb726d48Sopenharmony_ci  t.tid as tid,
61fb726d48Sopenharmony_ci  p.pid as pid,
62fb726d48Sopenharmony_ci  p.name as pname,
63fb726d48Sopenharmony_ci  c.name as content
64fb726d48Sopenharmony_ciFROM
65fb726d48Sopenharmony_ci  callstack c, trace_range r
66fb726d48Sopenharmony_ciLEFT JOIN thread t ON
67fb726d48Sopenharmony_ci  t.itid = c.callid
68fb726d48Sopenharmony_ciLEFT JOIN process p ON
69fb726d48Sopenharmony_ci  p.ipid = t.ipid
70fb726d48Sopenharmony_ciWHERE
71fb726d48Sopenharmony_ci  c.dur >= ${getMinDur()}
72fb726d48Sopenharmony_ci  AND t.is_main_thread = 1
73fb726d48Sopenharmony_ci  AND c.name LIKE 'H:Et:%'
74fb726d48Sopenharmony_ci`.trim()
75fb726d48Sopenharmony_ci);