wiki.techinc.nl/maintenance/language/StatOutputs.php
Umherirrender 72d6b46339 Use namespaced classes
Changes to the use statements done automatically via script
Addition of missing use statements and changes to docs done manually

Change-Id: I443aada1c18c8628b02671aa9fd6f441961e5c2e
2023-12-11 16:07:18 +01:00

149 lines
4 KiB
PHP

<?php
/**
* Statistic output classes.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
* http://www.gnu.org/copyleft/gpl.html
*
* @file
* @ingroup MaintenanceLanguage
* @author Ævar Arnfjörð Bjarmason <avarab@gmail.com>
* @author Antoine Musso <hashar at free dot fr>
*/
use MediaWiki\Specials\SpecialVersion;
use Wikimedia\AtEase\AtEase;
/**
* A general output object. Need to be overridden
*/
class StatsOutput {
public function formatPercent( $subset, $total, $revert = false, $accuracy = 2 ) {
AtEase::suppressWarnings();
$return = sprintf( '%.' . $accuracy . 'f%%', 100 * $subset / $total );
AtEase::restoreWarnings();
return $return;
}
public function heading() {
}
public function footer() {
}
public function blockstart() {
}
public function blockend() {
}
public function element( $in, $heading = false ) {
}
}
/** Outputs WikiText */
class WikiStatsOutput extends StatsOutput {
public function heading() {
global $wgDummyLanguageCodes;
$version = SpecialVersion::getVersion( 'nodb' );
echo "'''Statistics are based on:''' <code>" . $version . "</code>\n\n";
echo 'English (en) is excluded because it is the default localization';
if ( is_array( $wgDummyLanguageCodes ) ) {
$dummyCodes = [];
foreach ( $wgDummyLanguageCodes as $dummyCode => $correctCode ) {
$dummyCodes[] = $this->getServiceContainer()
->getLanguageNameUtils()
->getLanguageName( $dummyCode ) . ' (' . $dummyCode . ')';
}
echo ', as well as the following languages that are not intended for ' .
'system message translations, usually because they redirect to other ' .
'language codes: ' . implode( ', ', $dummyCodes );
}
# dot to end sentence
echo ".\n\n";
echo '{| class="sortable wikitable" border="2" style="background-color: #F9F9F9; ' .
'border: 1px #AAAAAA solid; border-collapse: collapse; clear:both; width:100%;"' . "\n";
}
public function footer() {
echo "|}\n";
}
public function blockstart() {
echo "|-\n";
}
public function blockend() {
echo '';
}
public function element( $in, $heading = false ) {
echo ( $heading ? '!' : '|' ) . "$in\n";
}
public function formatPercent( $subset, $total, $revert = false, $accuracy = 2 ) {
AtEase::suppressWarnings();
$v = round( 255 * $subset / $total );
AtEase::restoreWarnings();
if ( $revert ) {
# Weigh reverse with factor 20 so coloring takes effect more quickly as
# this option is used solely for reporting 'bad' percentages.
$v = $v * 20;
if ( $v > 255 ) {
$v = 255;
}
$v = 255 - $v;
}
if ( $v < 128 ) {
# Red to Yellow
$red = 'FF';
$green = sprintf( '%02X', 2 * $v );
} else {
# Yellow to Green
$red = sprintf( '%02X', 2 * ( 255 - $v ) );
$green = 'FF';
}
$blue = '00';
$color = $red . $green . $blue;
$percent = parent::formatPercent( $subset, $total, $revert, $accuracy );
return 'style="background-color:#' . $color . ';"|' . $percent;
}
}
/** Output text. To be used on a terminal for example. */
class TextStatsOutput extends StatsOutput {
public function element( $in, $heading = false ) {
echo $in . "\t";
}
public function blockend() {
echo "\n";
}
}
/** csv output. Some people love excel */
class CsvStatsOutput extends StatsOutput {
public function element( $in, $heading = false ) {
echo $in . ";";
}
public function blockend() {
echo "\n";
}
}