1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
<?php declare(strict_types = 1); /** * Database query calling function collector. * * @package query-monitor */
if ( ! defined( 'ABSPATH' ) ) { exit; }
/** * @extends QM_DataCollector<QM_Data_DB_Callers> */ class QM_Collector_DB_Callers extends QM_DataCollector {
public $id = 'db_callers';
public function get_storage(): QM_Data { return new QM_Data_DB_Callers(); }
/** * @return void */ public function process() { /** @var QM_Collector_DB_Queries|null $dbq */ $dbq = QM_Collectors::get( 'db_queries' );
if ( $dbq ) { /** @var QM_Data_DB_Queries $dbq_data */ $dbq_data = $dbq->get_data();
$this->data->times = $dbq_data->times; QM_Util::rsort( $this->data->times, 'ltime' );
$this->data->types = $dbq_data->types; }
}
}
/** * @param array<string, QM_Collector> $collectors * @param QueryMonitor $qm * @return array<string, QM_Collector> */ function register_qm_collector_db_callers( array $collectors, QueryMonitor $qm ) { $collectors['db_callers'] = new QM_Collector_DB_Callers(); return $collectors; }
add_filter( 'qm/collectors', 'register_qm_collector_db_callers', 20, 2 );
|