wiki.techinc.nl/includes/language/converters/EnConverter.php
Peter Ovchyn d8f54cae8b Language: Turn public properties into Getters in LanguageConverter based hierarchy
The main goal is to simplify the construction of the LanguageConverter and
avoid using constructors for derived classes.

In order to hard-deprecate removed property, DeprecationHelper::deprecatePublicPropertyFallback
was introduced.

Bug: T253834
Change-Id: Ib167982e4e872cfdf0fbcb78b7ca597f5ac8d60a
2021-02-03 15:17:42 +02:00

97 lines
2.6 KiB
PHP

<?php
/**
* English specific code.
*
* 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 Language
*/
class EnConverter extends LanguageConverter {
/**
* Get Main language code.
* @since 1.36
*
* @return string
*/
public function getMainCode(): string {
return 'en';
}
/**
* Get supported variants of the language.
* @since 1.36
*
* @return array
*/
public function getLanguageVariants(): array {
return [ 'en', 'en-x-piglatin' ];
}
/**
* Get language variants fallbacks.
* @since 1.36
*
* @return array
*/
public function getVariantsFallbacks(): array {
return [];
}
protected function loadDefaultTables() {
$this->mTables = [
'en' => new ReplacementArray(),
'en-x-piglatin' => new ReplacementArray(),
];
}
/**
* Translates text into Pig Latin. This allows developers to test the language variants
* functionality and user interface without having to switch wiki language away from default.
*
* @param string $text
* @param string $toVariant
* @return string
*/
public function translate( $text, $toVariant ) {
if ( $toVariant !== 'en-x-piglatin' ) {
return $text;
}
// Only process words composed of standard English alphabet, leave the rest unchanged.
// This skips some English words like 'naïve' or 'résumé', but we can live with that.
// Ignore single letters and words which aren't lowercase or uppercase-first.
return preg_replace_callback( '/[A-Za-z][a-z\']+/', function ( $matches ) {
$word = $matches[0];
if ( preg_match( '/^[aeiou]/i', $word ) ) {
return $word . 'way';
}
return preg_replace_callback( '/^(s?qu|[^aeiou][^aeiouy]*)(.*)$/i', function ( $m ) {
$ucfirst = strtoupper( $m[1][0] ) === $m[1][0];
if ( $ucfirst ) {
return ucfirst( $m[2] ) . lcfirst( $m[1] ) . 'ay';
}
return $m[2] . $m[1] . 'ay';
}, $word );
}, $text );
}
}