diff options
author | Pierre Schmitz <pierre@archlinux.de> | 2011-12-03 13:29:22 +0100 |
---|---|---|
committer | Pierre Schmitz <pierre@archlinux.de> | 2011-12-03 13:29:22 +0100 |
commit | ca32f08966f1b51fcb19460f0996bb0c4048e6fe (patch) | |
tree | ec04cc15b867bc21eedca904cea9af0254531a11 /includes/profiler/ProfilerSimpleText.php | |
parent | a22fbfc60f36f5f7ee10d5ae6fe347340c2ee67c (diff) |
Update to MediaWiki 1.18.0
* also update ArchLinux skin to chagnes in MonoBook
* Use only css to hide our menu bar when printing
Diffstat (limited to 'includes/profiler/ProfilerSimpleText.php')
-rw-r--r-- | includes/profiler/ProfilerSimpleText.php | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/includes/profiler/ProfilerSimpleText.php b/includes/profiler/ProfilerSimpleText.php new file mode 100644 index 00000000..ef9049fa --- /dev/null +++ b/includes/profiler/ProfilerSimpleText.php @@ -0,0 +1,54 @@ +<?php +/** + * @file + * @ingroup Profiler + */ + +/** + * The least sophisticated profiler output class possible, view your source! :) + * + * Put the following 2 lines in StartProfiler.php: + * + * $wgProfiler['class'] = 'ProfilerSimpleText'; + * $wgProfiler['visible'] = true; + * + * @ingroup Profiler + */ +class ProfilerSimpleText extends ProfilerSimple { + public $visible = false; /* Show as <PRE> or <!-- ? */ + static private $out; + + public function __construct( $profileConfig ) { + if ( isset( $profileConfig['visible'] ) && $profileConfig['visible'] ) { + $this->visible = true; + } + parent::__construct( $profileConfig ); + } + + public function logData() { + if ( $this->mTemplated ) { + $this->close(); + $totalReal = isset( $this->mCollated['-total'] ) + ? $this->mCollated['-total']['real'] + : 0; // profiling mismatch error? + uasort( $this->mCollated, array('self','sort') ); + array_walk( $this->mCollated, array('self','format'), $totalReal ); + if ( $this->visible ) { + print '<pre>'.self::$out.'</pre>'; + } else { + print "<!--\n".self::$out."\n-->\n"; + } + } + } + + /* dense is good */ + static function sort( $a, $b ) { + return $a['real'] < $b['real']; /* sort descending by time elapsed */ + } + + static function format( $item, $key, $totalReal ) { + $perc = $totalReal ? $item['real']/$totalReal*100 : 0; + self::$out .= sprintf( "%6.2f%% %3.6f %6d - %s\n", + $perc, $item['real'], $item['count'], $key ); + } +} |