]> scripts.mit.edu Git - autoinstalls/mediawiki.git/blob - includes/ProfilerSimpleText.php
MediaWiki 1.16.4
[autoinstalls/mediawiki.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 it to StartProfiler.php like this:
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
23         function getFunctionReport() {
24                 global $wgRequest;
25                 if ( $wgRequest->getVal( 'action' ) == 'raw' ) # bug 20388
26                         return;
27
28                 if ($this->visible) print "<pre>";
29                         else print "<!--\n";
30                 uasort($this->mCollated,array('self','sort'));
31                 array_walk($this->mCollated,array('self','format'));
32                 if ($this->visible) print "</pre>\n";
33                         else print "-->\n";
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) { printf("%3.6f %6d - %s\n",$item['real'],$item['count'], $key); }
39 }