1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64
|
<?php
use MediaWiki\Config\HashConfig;
use MediaWiki\Config\ServiceOptions;
use MediaWiki\Language\ILanguageConverter;
use MediaWiki\Languages\LanguageConverterFactory;
use MediaWiki\MainConfigNames;
trait LanguageConverterTestTrait {
/** @var string */
private $codeRegex = '/^(.+)ConverterTest$/';
/** @var LanguageConverterFactory */
private $factory;
protected function getCode(): string {
if ( preg_match( $this->codeRegex, get_class( $this ), $m ) ) {
# Normalize language code since classes uses underscores
return mb_strtolower( str_replace( '_', '-', $m[1] ) );
}
return '';
}
protected function getConverterFactory() {
if ( $this->factory ) {
return $this->factory;
}
$code = $this->getCode();
$this->factory = new LanguageConverterFactory(
new ServiceOptions( LanguageConverterFactory::CONSTRUCTOR_OPTIONS, new HashConfig( [
MainConfigNames::UsePigLatinVariant => false,
MainConfigNames::DisableLangConversion => false,
MainConfigNames::DisableTitleConversion => false,
] ) ),
$this->getServiceContainer()->getObjectFactory(),
function () use ( $code ) {
$services = $this->getServiceContainer();
if ( $code ) {
return $services->getLanguageFactory()->getLanguage( $code );
} else {
return $services->getContentLanguage();
}
}
);
return $this->factory;
}
/**
* @param string|null $language Language code or null to use language
* returned by ::getCode(), or the content language if not set either.
* @return ILanguageConverter
*/
protected function getLanguageConverter( $language = null ): ILanguageConverter {
if ( $language ) {
$language = $this->getServiceContainer()->getLanguageFactory()
->getLanguage( $language );
}
return $this->getConverterFactory()->getLanguageConverter( $language );
}
}
|