MediaWiki REL1_31
ProfilerOutputText.php
Go to the documentation of this file.
1<?php
32 protected $thresholdMs;
33
35 parent::__construct( $collector, $params );
36 $this->thresholdMs = isset( $params['thresholdMs'] )
37 ? $params['thresholdMs']
38 : 1.0;
39 }
40 public function log( array $stats ) {
41 if ( $this->collector->getTemplated() ) {
42 $out = '';
43
44 // Filter out really tiny entries
45 $min = $this->thresholdMs;
46 $stats = array_filter( $stats, function ( $a ) use ( $min ) {
47 return $a['real'] > $min;
48 } );
49 // Sort descending by time elapsed
50 usort( $stats, function ( $a, $b ) {
51 return $a['real'] < $b['real'];
52 } );
53
54 array_walk( $stats,
55 function ( $item ) use ( &$out ) {
56 $out .= sprintf( "%6.2f%% %3.3f %6d - %s\n",
57 $item['%real'], $item['real'], $item['calls'], $item['name'] );
58 }
59 );
60
61 $contentType = $this->collector->getContentType();
62 if ( wfIsCLI() ) {
63 print "<!--\n{$out}\n-->\n";
64 } elseif ( $contentType === 'text/html' ) {
65 $visible = isset( $this->params['visible'] ) ?
66 $this->params['visible'] : false;
67 if ( $visible ) {
68 print "<pre>{$out}</pre>";
69 } else {
70 print "<!--\n{$out}\n-->\n";
71 }
72 } elseif ( $contentType === 'text/javascript' || $contentType === 'text/css' ) {
73 print "\n/*\n{$out}*/\n";
74 }
75 }
76 }
77}
wfIsCLI()
Check if we are running from the commandline.
The least sophisticated profiler output class possible, view your source! :)
float $thresholdMs
Min real time display threshold.
log(array $stats)
Log MediaWiki-style profiling data.
__construct(Profiler $collector, array $params)
Base class for profiling output.
array $params
Configuration of $wgProfiler.
Profiler base class that defines the interface and some trivial functionality.
Definition Profiler.php:33
this hook is for auditing only or null if authentication failed before getting that far or null if we can t even determine that probably a stub it is not rendered in wiki pages or galleries in category pages allow injecting custom HTML after the section Any uses of the hook need to handle escaping see BaseTemplate::getToolbox and BaseTemplate::makeListItem for details on the format of individual items inside of this array or by returning and letting standard HTTP rendering take place modifiable or by returning false and taking over the output $out
Definition hooks.txt:864
while(( $__line=Maintenance::readconsole()) !==false) print
Definition eval.php:64