summaryrefslogtreecommitdiff
path: root/includes/ProfilerSimpleText.php
blob: d3df390832f37761b12eb535a870e5e0a9fc474f (plain)
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
<?php
/**
 * @file
 * @ingroup Profiler
 */

require_once( dirname( __FILE__ ) . '/ProfilerSimple.php' );

/**
 * The least sophisticated profiler output class possible, view your source! :)
 *
 * Put it to StartProfiler.php like this:
 *
 * require_once( dirname( __FILE__ ) . '/includes/ProfilerSimpleText.php' );
 * $wgProfiler = new ProfilerSimpleText;
 * $wgProfiler->visible=true;
 *
 * @ingroup Profiler
 */
class ProfilerSimpleText extends ProfilerSimple {
	public $visible=false; /* Show as <PRE> or <!-- ? */

	function getFunctionReport() {
		global $wgRequest;
		if ( $wgRequest->getVal( 'action' ) == 'raw' ) # bug 20388
			return;

		if ($this->visible) print "<pre>";
			else print "<!--\n";
		uasort($this->mCollated,array('self','sort'));
		array_walk($this->mCollated,array('self','format'));
		if ($this->visible) print "</pre>\n";
			else print "-->\n";
	}

	/* dense is good */
	static function sort($a,$b) { return $a['real']<$b['real']; /* sort descending by time elapsed */ }
	static function format($item,$key) { printf("%3.6f %6d - %s\n",$item['real'],$item['count'], $key); }
}