mediawiki-extensions-Templa.../includes/TemplateDataNormalizer.php
thiemowmde 8f81812242 Enable and enforce a few extra PHPCS sniffs
This is not really anything new. Most code already followed these
sniffs. This patch just fixes the remaining exceptions. Also:
* Remove PHPDoc blocks that don't add anything but just repeat the
  strict types.
* Remove @file comments in favor of class-level comments.
* Add strict types where possible, most notably some `void`.

Change-Id: Iff6872dff68170b0fc4e82ac2ba3cad385e8773e
2023-09-06 18:15:22 +02:00

97 lines
2.5 KiB
PHP

<?php
namespace MediaWiki\Extension\TemplateData;
use stdClass;
/**
* @license GPL-2.0-or-later
*/
class TemplateDataNormalizer {
public const DEPRECATED_PARAMETER_TYPES = [
'string/line' => 'line',
'string/wiki-page-name' => 'wiki-page-name',
'string/wiki-user-name' => 'wiki-user-name',
'string/wiki-file-name' => 'wiki-file-name',
];
private string $contentLanguageCode;
public function __construct( string $contentLanguageCode ) {
$this->contentLanguageCode = $contentLanguageCode;
}
/**
* @param stdClass $data Expected to be valid according to the {@see TemplateDataValidator}
*/
public function normalize( stdClass $data ): void {
$data->description ??= null;
$data->sets ??= [];
$data->maps ??= (object)[];
$data->format ??= null;
$this->normaliseInterfaceText( $data->description );
foreach ( $data->sets as $setObj ) {
$this->normaliseInterfaceText( $setObj->label );
}
if ( isset( $data->params ) ) {
foreach ( $data->params as $param ) {
if ( isset( $param->inherits ) && isset( $data->params->{ $param->inherits } ) ) {
$parent = $data->params->{ $param->inherits };
foreach ( $parent as $key => $value ) {
if ( !isset( $param->$key ) ) {
$param->$key = is_object( $parent->$key ) ?
clone $parent->$key :
$parent->$key;
}
}
unset( $param->inherits );
}
$this->normalizeParameter( $param );
}
}
}
private function normalizeParameter( stdClass $paramObj ): void {
$paramObj->label ??= null;
$paramObj->description ??= null;
$paramObj->required ??= false;
$paramObj->suggested ??= false;
$paramObj->deprecated ??= false;
$paramObj->aliases ??= [];
$paramObj->type ??= 'unknown';
$paramObj->autovalue ??= null;
$paramObj->default ??= null;
$paramObj->suggestedvalues ??= [];
$paramObj->example ??= null;
$this->normaliseInterfaceText( $paramObj->label );
$this->normaliseInterfaceText( $paramObj->description );
$this->normaliseInterfaceText( $paramObj->default );
$this->normaliseInterfaceText( $paramObj->example );
foreach ( $paramObj->aliases as &$alias ) {
if ( is_int( $alias ) ) {
$alias = (string)$alias;
}
}
// Map deprecated types to newer versions
if ( isset( self::DEPRECATED_PARAMETER_TYPES[$paramObj->type] ) ) {
$paramObj->type = self::DEPRECATED_PARAMETER_TYPES[$paramObj->type];
}
}
/**
* @param string|stdClass &$text
*/
private function normaliseInterfaceText( &$text ): void {
if ( is_string( $text ) ) {
$text = (object)[ $this->contentLanguageCode => $text ];
}
}
}