* (bug 24563) Entries on Special:WhatLinksHere now have a link to their history
[lhc/web/wiklou.git] / includes / ProfilerSimpleText.php
1 <?php
2 /**
3 * @file
4 * @ingroup Profiler
5 */
6
7 require_once( dirname( __FILE__ ) . '/ProfilerSimple.php' );
8
9 /**
10 * The least sophisticated profiler output class possible, view your source! :)
11 *
12 * Put the following 3 lines in StartProfiler.php:
13 *
14 * require_once( dirname( __FILE__ ) . '/includes/ProfilerSimpleText.php' );
15 * $wgProfiler = new ProfilerSimpleText;
16 * $wgProfiler->visible=true;
17 *
18 * @ingroup Profiler
19 */
20 class ProfilerSimpleText extends ProfilerSimple {
21 public $visible=false; /* Show as <PRE> or <!-- ? */
22 static private $out;
23
24 function getFunctionReport() {
25 if($this->mTemplated) {
26 uasort($this->mCollated,array('self','sort'));
27 array_walk($this->mCollated,array('self','format'));
28 if ($this->visible) {
29 print '<pre>'.self::$out.'</pre>';
30 } else {
31 print "<!--\n".self::$out."\n-->\n";
32 }
33 }
34 }
35
36 /* dense is good */
37 static function sort($a,$b) { return $a['real']<$b['real']; /* sort descending by time elapsed */ }
38 static function format($item,$key) { self::$out .= sprintf("%3.6f %6d - %s\n",$item['real'],$item['count'], $key); }
39 }