mediawiki-extensions-Cite/src/ReferenceMessageLocalizer.php
libraryupgrader 0af1a039b0 build: Updating mediawiki/mediawiki-codesniffer to 37.0.0
Change-Id: Ia399fafc5280aab1c0cfc129529a822e8d8f8382
2021-07-22 12:34:32 +00:00

68 lines
1.5 KiB
PHP

<?php
namespace Cite;
use Language;
use Message;
use MessageLocalizer;
use MessageSpecifier;
/**
* Interface abstracts everything a Cite needs to do with languages.
*/
class ReferenceMessageLocalizer implements MessageLocalizer {
/**
* @var Language
*/
private $language;
/**
* @param Language $language
*/
public function __construct( Language $language ) {
$this->language = $language;
}
/**
* @param string $number
*
* @return string
*/
public function localizeSeparators( string $number ): string {
// Filter to make sure characters are never removed
return strtr( $number, array_filter( $this->language->separatorTransformTable() ?: [] ) );
}
/**
* Transliterate numerals, without adding or changing separators.
*
* @param string $number
*
* @return string
*/
public function localizeDigits( string $number ): string {
return $this->language->formatNumNoSeparators( $number );
}
/**
* This is the method for getting translated interface messages.
*
* Note that it returns messages coerced to a specific language, the content language
* rather than the UI language.
*
* @see https://www.mediawiki.org/wiki/Manual:Messages_API
* @see Message::__construct
*
* @param string|string[]|MessageSpecifier $key Message key, or array of keys,
* or a MessageSpecifier.
* @param mixed ...$params Normal message parameters
*
* @return Message
*/
public function msg( $key, ...$params ): Message {
return wfMessage( $key, ...$params )->inLanguage( $this->language );
}
}