X-Git-Url: https://git.heureux-cyclage.org/?a=blobdiff_plain;f=maintenance%2Flanguage%2Flanguages.inc;h=9c9b7ff07c4094f7a70ab6c1b2f4da6169477548;hb=f506a05aaa035b96537b33244b0f18b093048e97;hp=6e5b29d86dbc1fc09af498f64623a5b09dd59d6b;hpb=5a77286a1e32f4fd784b5c2985f149fe39b45073;p=lhc%2Fweb%2Fwiklou.git diff --git a/maintenance/language/languages.inc b/maintenance/language/languages.inc index 6e5b29d86d..c6a5c68299 100644 --- a/maintenance/language/languages.inc +++ b/maintenance/language/languages.inc @@ -55,23 +55,16 @@ class Languages { /** @var array Magic words */ protected $mMagicWords; - /** @var array Special page aliases */ + /** @var array Special page aliases */ protected $mSpecialPageAliases; /** * Load the list of languages: all the Messages*.php * files in the languages directory. - * - * @param bool $exif Treat the Exif messages? */ - function __construct( $exif = true ) { - require __DIR__ . '/messageTypes.inc'; - $this->mIgnoredMessages = $wgIgnoredMessages; - if ( $exif ) { - $this->mOptionalMessages = array_merge( $wgOptionalMessages ); - } else { - $this->mOptionalMessages = array_merge( $wgOptionalMessages, $wgEXIFMessages ); - } + function __construct() { + Hooks::run( 'LocalisationIgnoredOptionalMessages', + [ &$this->mIgnoredMessages, &$this->mOptionalMessages ] ); $this->mLanguages = array_keys( Language::fetchLanguageNames( null, 'mwfile' ) ); sort( $this->mLanguages ); @@ -119,12 +112,12 @@ class Languages { ) { return; } - $this->mRawMessages[$code] = array(); + $this->mRawMessages[$code] = []; $this->mFallback[$code] = ''; - $this->mNamespaceNames[$code] = array(); - $this->mNamespaceAliases[$code] = array(); - $this->mMagicWords[$code] = array(); - $this->mSpecialPageAliases[$code] = array(); + $this->mNamespaceNames[$code] = []; + $this->mNamespaceAliases[$code] = []; + $this->mMagicWords[$code] = []; + $this->mSpecialPageAliases[$code] = []; $jsonfilename = Language::getJsonMessagesFileName( $code ); if ( file_exists( $jsonfilename ) ) { @@ -174,10 +167,10 @@ class Languages { $this->loadFile( $code ); $this->loadGeneralMessages(); $this->mMessages[$code]['all'] = $this->mRawMessages[$code]; - $this->mMessages[$code]['required'] = array(); - $this->mMessages[$code]['optional'] = array(); - $this->mMessages[$code]['obsolete'] = array(); - $this->mMessages[$code]['translated'] = array(); + $this->mMessages[$code]['required'] = []; + $this->mMessages[$code]['optional'] = []; + $this->mMessages[$code]['obsolete'] = []; + $this->mMessages[$code]['translated'] = []; foreach ( $this->mMessages[$code]['all'] as $key => $value ) { if ( isset( $this->mGeneralMessages['required'][$key] ) ) { $this->mMessages[$code]['required'][$key] = $value; @@ -208,10 +201,10 @@ class Languages { } $this->loadFile( 'en' ); $this->mGeneralMessages['all'] = $this->mRawMessages['en']; - $this->mGeneralMessages['required'] = array(); - $this->mGeneralMessages['optional'] = array(); - $this->mGeneralMessages['ignored'] = array(); - $this->mGeneralMessages['translatable'] = array(); + $this->mGeneralMessages['required'] = []; + $this->mGeneralMessages['optional'] = []; + $this->mGeneralMessages['ignored'] = []; + $this->mGeneralMessages['translatable'] = []; foreach ( $this->mGeneralMessages['all'] as $key => $value ) { if ( in_array( $key, $this->mIgnoredMessages ) ) { $this->mGeneralMessages['ignored'][$key] = $value; @@ -355,7 +348,7 @@ class Languages { public function getDuplicateMessages( $code ) { $this->loadGeneralMessages(); $this->loadMessages( $code ); - $duplicateMessages = array(); + $duplicateMessages = []; foreach ( $this->mMessages[$code]['translated'] as $key => $value ) { if ( $this->mGeneralMessages['translatable'][$key] == $value ) { $duplicateMessages[$key] = $value; @@ -389,8 +382,8 @@ class Languages { public function getMessagesWithMismatchVariables( $code ) { $this->loadGeneralMessages(); $this->loadMessages( $code ); - $variables = array( '\$1', '\$2', '\$3', '\$4', '\$5', '\$6', '\$7', '\$8', '\$9' ); - $mismatchMessages = array(); + $variables = [ '\$1', '\$2', '\$3', '\$4', '\$5', '\$6', '\$7', '\$8', '\$9' ]; + $mismatchMessages = []; foreach ( $this->mMessages[$code]['translated'] as $key => $value ) { $missing = false; foreach ( $variables as $var ) { @@ -423,7 +416,7 @@ class Languages { public function getMessagesWithoutPlural( $code ) { $this->loadGeneralMessages(); $this->loadMessages( $code ); - $messagesWithoutPlural = array(); + $messagesWithoutPlural = []; foreach ( $this->mMessages[$code]['translated'] as $key => $value ) { if ( stripos( $this->mGeneralMessages['translatable'][$key], '{{plural:' ) !== false && stripos( $value, '{{plural:' ) === false @@ -445,7 +438,7 @@ class Languages { public function getEmptyMessages( $code ) { $this->loadGeneralMessages(); $this->loadMessages( $code ); - $emptyMessages = array(); + $emptyMessages = []; foreach ( $this->mMessages[$code]['translated'] as $key => $value ) { if ( $value === '' || $value === '-' ) { $emptyMessages[$key] = $value; @@ -465,7 +458,7 @@ class Languages { public function getMessagesWithWhitespace( $code ) { $this->loadGeneralMessages(); $this->loadMessages( $code ); - $messagesWithWhitespace = array(); + $messagesWithWhitespace = []; foreach ( $this->mMessages[$code]['translated'] as $key => $value ) { if ( $this->mGeneralMessages['translatable'][$key] !== '' && $value !== rtrim( $value ) ) { $messagesWithWhitespace[$key] = $value; @@ -485,16 +478,16 @@ class Languages { public function getNonXHTMLMessages( $code ) { $this->loadGeneralMessages(); $this->loadMessages( $code ); - $wrongPhrases = array( + $wrongPhrases = [ '
', '
', '
', '
', '
', '
', - ); + ]; $wrongPhrases = '~(' . implode( '|', $wrongPhrases ) . ')~sDu'; - $nonXHTMLMessages = array(); + $nonXHTMLMessages = []; foreach ( $this->mMessages[$code]['translated'] as $key => $value ) { if ( preg_match( $wrongPhrases, $value ) ) { $nonXHTMLMessages[$key] = $value; @@ -514,22 +507,22 @@ class Languages { public function getMessagesWithWrongChars( $code ) { $this->loadGeneralMessages(); $this->loadMessages( $code ); - $wrongChars = array( - '[LRM]' => "\xE2\x80\x8E", - '[RLM]' => "\xE2\x80\x8F", - '[LRE]' => "\xE2\x80\xAA", - '[RLE]' => "\xE2\x80\xAB", - '[POP]' => "\xE2\x80\xAC", - '[LRO]' => "\xE2\x80\xAD", - '[RLO]' => "\xE2\x80\xAB", - '[ZWSP]' => "\xE2\x80\x8B", - '[NBSP]' => "\xC2\xA0", - '[WJ]' => "\xE2\x81\xA0", - '[BOM]' => "\xEF\xBB\xBF", - '[FFFD]' => "\xEF\xBF\xBD", - ); + $wrongChars = [ + '[LRM]' => "\u{200E}", + '[RLM]' => "\u{200F}", + '[LRE]' => "\u{202A}", + '[RLE]' => "\u{202B}", + '[POP]' => "\u{202C}", + '[LRO]' => "\u{202D}", + '[RLO]' => "\u{202B}", + '[ZWSP]' => "\u{200B}", + '[NBSP]' => "\u{00A0}", + '[WJ]' => "\u{2060}", + '[BOM]' => "\u{FEFF}", + '[FFFD]' => "\u{FFFD}", + ]; $wrongRegExp = '/(' . implode( '|', array_values( $wrongChars ) ) . ')/sDu'; - $wrongCharsMessages = array(); + $wrongCharsMessages = []; foreach ( $this->mMessages[$code]['translated'] as $key => $value ) { if ( preg_match( $wrongRegExp, $value ) ) { foreach ( $wrongChars as $viewableChar => $hiddenChar ) { @@ -553,9 +546,9 @@ class Languages { $this->loadGeneralMessages(); $this->loadMessages( $code ); $tc = Title::legalChars() . '#%{}'; - $messages = array(); + $messages = []; foreach ( $this->mMessages[$code]['translated'] as $key => $value ) { - $matches = array(); + $matches = []; preg_match_all( "/\[\[([{$tc}]+)(?:\\|(.+?))?]]/sDu", $value, $matches ); $numMatches = count( $matches[0] ); for ( $i = 0; $i < $numMatches; $i++ ) { @@ -565,7 +558,7 @@ class Languages { } if ( isset( $messages[$key] ) ) { - $messages[$key] = implode( $messages[$key], ", " ); + $messages[$key] = implode( ", ", $messages[$key] ); } } @@ -582,7 +575,7 @@ class Languages { public function getMessagesWithUnbalanced( $code ) { $this->loadGeneralMessages(); $this->loadMessages( $code ); - $messages = array(); + $messages = []; foreach ( $this->mMessages[$code]['translated'] as $key => $value ) { $a = $b = $c = $d = 0; foreach ( preg_split( '//', $value ) as $char ) { @@ -637,7 +630,7 @@ class Languages { */ public function getProblematicProjectTalks( $code ) { $this->loadFile( $code ); - $namespaces = array(); + $namespaces = []; # Check default namespace name if ( isset( $this->mNamespaceNames[$code][NS_PROJECT_TALK] ) ) { @@ -667,7 +660,7 @@ class Languages { public function getUntranslatedMagicWords( $code ) { $this->loadFile( 'en' ); $this->loadFile( $code ); - $magicWords = array(); + $magicWords = []; foreach ( $this->mMagicWords['en'] as $key => $value ) { if ( !isset( $this->mMagicWords[$code][$key] ) ) { $magicWords[$key] = $value[1]; @@ -687,7 +680,7 @@ class Languages { public function getObsoleteMagicWords( $code ) { $this->loadFile( 'en' ); $this->loadFile( $code ); - $magicWords = array(); + $magicWords = []; foreach ( $this->mMagicWords[$code] as $key => $value ) { if ( !isset( $this->mMagicWords['en'][$key] ) ) { $magicWords[$key] = $value[1]; @@ -707,7 +700,7 @@ class Languages { public function getOverridingMagicWords( $code ) { $this->loadFile( 'en' ); $this->loadFile( $code ); - $magicWords = array(); + $magicWords = []; foreach ( $this->mMagicWords[$code] as $key => $local ) { if ( !isset( $this->mMagicWords['en'][$key] ) ) { # Unrecognized magic word @@ -737,7 +730,7 @@ class Languages { public function getCaseMismatchMagicWords( $code ) { $this->loadFile( 'en' ); $this->loadFile( $code ); - $magicWords = array(); + $magicWords = []; foreach ( $this->mMagicWords[$code] as $key => $local ) { if ( !isset( $this->mMagicWords['en'][$key] ) ) { # Unrecognized magic word @@ -761,7 +754,7 @@ class Languages { public function getUntraslatedSpecialPages( $code ) { $this->loadFile( 'en' ); $this->loadFile( $code ); - $specialPageAliases = array(); + $specialPageAliases = []; foreach ( $this->mSpecialPageAliases['en'] as $key => $value ) { if ( !isset( $this->mSpecialPageAliases[$code][$key] ) ) { $specialPageAliases[$key] = $value[0]; @@ -781,7 +774,7 @@ class Languages { public function getObsoleteSpecialPages( $code ) { $this->loadFile( 'en' ); $this->loadFile( $code ); - $specialPageAliases = array(); + $specialPageAliases = []; foreach ( $this->mSpecialPageAliases[$code] as $key => $value ) { if ( !isset( $this->mSpecialPageAliases['en'][$key] ) ) { $specialPageAliases[$key] = $value[0]; @@ -827,7 +820,7 @@ class ExtensionLanguages extends Languages { if ( !isset( $this->mRawMessages[$code] ) ) { $this->mRawMessages[$code] = $this->mMessageGroup->load( $code ); if ( empty( $this->mRawMessages[$code] ) ) { - $this->mRawMessages[$code] = array(); + $this->mRawMessages[$code] = []; } } }