summaryrefslogtreecommitdiff
path: root/includes/profiler/ProfilerSimpleText.php
diff options
context:
space:
mode:
authorPierre Schmitz <pierre@archlinux.de>2011-12-03 13:29:22 +0100
committerPierre Schmitz <pierre@archlinux.de>2011-12-03 13:29:22 +0100
commitca32f08966f1b51fcb19460f0996bb0c4048e6fe (patch)
treeec04cc15b867bc21eedca904cea9af0254531a11 /includes/profiler/ProfilerSimpleText.php
parenta22fbfc60f36f5f7ee10d5ae6fe347340c2ee67c (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.php54
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 );
+ }
+}