Use $lang->hasVariants() instead of count( $lang->getVariants() ) > 1
authorFomafix <fomafix@googlemail.com>
Tue, 3 Jul 2018 20:14:06 +0000 (22:14 +0200)
committerUmherirrender <umherirrender_de.wp@web.de>
Wed, 11 Jul 2018 16:13:17 +0000 (16:13 +0000)
Change-Id: I23668c69a8d8cc886168cbbd4f94cf13b597b5a6

includes/MediaWiki.php
includes/api/ApiPageSet.php
includes/preferences/DefaultPreferencesFactory.php
includes/skins/SkinTemplate.php
maintenance/language/listVariants.php

index b11239a..a67cb9b 100644 (file)
@@ -90,7 +90,7 @@ class MediaWiki {
                        }
                        // Check variant links so that interwiki links don't have to worry
                        // about the possible different language variants
-                       if ( count( $wgContLang->getVariants() ) > 1
+                       if ( $wgContLang->hasVariants()
                                && !is_null( $ret ) && $ret->getArticleID() == 0
                        ) {
                                $wgContLang->findVariantLink( $title, $ret );
index a32b288..ea2a85f 100644 (file)
@@ -1200,7 +1200,7 @@ class ApiPageSet extends ApiBase {
                                // Variants checking
                                global $wgContLang;
                                if ( $this->mConvertTitles &&
-                                       count( $wgContLang->getVariants() ) > 1 &&
+                                       $wgContLang->hasVariants() &&
                                        !$titleObj->exists()
                                ) {
                                        // Language::findVariantLink will modify titleText and titleObj into
index bcd15b3..8c113f4 100644 (file)
@@ -444,12 +444,11 @@ class DefaultPreferencesFactory implements PreferencesFactory {
                if ( !$this->config->get( 'DisableLangConversion' ) ) {
                        foreach ( LanguageConverter::$languagesWithVariants as $langCode ) {
                                if ( $langCode == $this->contLang->getCode() ) {
-                                       $variants = $this->contLang->getVariants();
-
-                                       if ( count( $variants ) <= 1 ) {
+                                       if ( !$this->contLang->hasVariants() ) {
                                                continue;
                                        }
 
+                                       $variants = $this->contLang->getVariants();
                                        $variantArray = [];
                                        foreach ( $variants as $v ) {
                                                $v = str_replace( '_', '-', strtolower( $v ) );
index 7fc0c3a..7b2d79e 100644 (file)
@@ -1116,11 +1116,11 @@ class SkinTemplate extends Skin {
 
                        if ( $userCanRead && !$wgDisableLangConversion ) {
                                $pageLang = $title->getPageLanguage();
-                               // Gets list of language variants
-                               $variants = $pageLang->getVariants();
                                // Checks that language conversion is enabled and variants exist
                                // And if it is not in the special namespace
-                               if ( count( $variants ) > 1 ) {
+                               if ( $pageLang->hasVariants() ) {
+                                       // Gets list of language variants
+                                       $variants = $pageLang->getVariants();
                                        // Gets preferred variant (note that user preference is
                                        // only possible for wiki content language variant)
                                        $preferred = $pageLang->getPreferredVariant();
index 4098e0c..264ef5b 100644 (file)
@@ -42,7 +42,7 @@ class ListVariants extends Maintenance {
                $variants = [];
                foreach ( LanguageConverter::$languagesWithVariants as $langCode ) {
                        $lang = Language::factory( $langCode );
-                       if ( count( $lang->getVariants() ) > 1 ) {
+                       if ( $lang->hasVariants() ) {
                                $variants += array_flip( $lang->getVariants() );
                                $variantLangs[$langCode] = $lang->getVariants();
                        }