[ Index ]

PHP Cross Reference of MediaWiki-1.24.0

title

Body

[close]

/maintenance/language/ -> languages.inc (source)

   1  <?php
   2  /**
   3   * Handle messages in the language files.
   4   *
   5   * This program is free software; you can redistribute it and/or modify
   6   * it under the terms of the GNU General Public License as published by
   7   * the Free Software Foundation; either version 2 of the License, or
   8   * (at your option) any later version.
   9   *
  10   * This program is distributed in the hope that it will be useful,
  11   * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13   * GNU General Public License for more details.
  14   *
  15   * You should have received a copy of the GNU General Public License along
  16   * with this program; if not, write to the Free Software Foundation, Inc.,
  17   * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  18   * http://www.gnu.org/copyleft/gpl.html
  19   *
  20   * @file
  21   * @ingroup MaintenanceLanguage
  22   */
  23  
  24  /**
  25   * @ingroup MaintenanceLanguage
  26   */
  27  class Languages {
  28      /** @var array List of languages */
  29      protected $mLanguages;
  30  
  31      /** @var array Raw list of the messages in each language */
  32      protected $mRawMessages;
  33  
  34      /** @var array Messages in each language (except for English), divided to groups */
  35      protected $mMessages;
  36  
  37      /** @var array Fallback language in each language */
  38      protected $mFallback;
  39  
  40      /** @var array General messages in English, divided to groups */
  41      protected $mGeneralMessages;
  42  
  43      /** @var array All the messages which should be exist only in the English file */
  44      protected $mIgnoredMessages;
  45  
  46      /** @var array All the messages which may be translated or not, depending on the language */
  47      protected $mOptionalMessages;
  48  
  49      /** @var array Namespace names */
  50      protected $mNamespaceNames;
  51  
  52      /** @var array Namespace aliases */
  53      protected $mNamespaceAliases;
  54  
  55      /** @var array Magic words */
  56      protected $mMagicWords;
  57  
  58      /** @var array Special page aliases */
  59      protected $mSpecialPageAliases;
  60  
  61      /**
  62       * Load the list of languages: all the Messages*.php
  63       * files in the languages directory.
  64       */
  65  	function __construct() {
  66          wfRunHooks( 'LocalisationIgnoredOptionalMessages',
  67              array( &$this->mIgnoredMessages, &$this->mOptionalMessages ) );
  68  
  69          $this->mLanguages = array_keys( Language::fetchLanguageNames( null, 'mwfile' ) );
  70          sort( $this->mLanguages );
  71      }
  72  
  73      /**
  74       * Get the language list.
  75       *
  76       * @return array The language list.
  77       */
  78  	public function getLanguages() {
  79          return $this->mLanguages;
  80      }
  81  
  82      /**
  83       * Get the ignored messages list.
  84       *
  85       * @return array The ignored messages list.
  86       */
  87  	public function getIgnoredMessages() {
  88          return $this->mIgnoredMessages;
  89      }
  90  
  91      /**
  92       * Get the optional messages list.
  93       *
  94       * @return array The  optional messages list.
  95       */
  96  	public function getOptionalMessages() {
  97          return $this->mOptionalMessages;
  98      }
  99  
 100      /**
 101       * Load the language file.
 102       *
 103       * @param string $code The language code.
 104       */
 105  	protected function loadFile( $code ) {
 106          if ( isset( $this->mRawMessages[$code] ) &&
 107              isset( $this->mFallback[$code] ) &&
 108              isset( $this->mNamespaceNames[$code] ) &&
 109              isset( $this->mNamespaceAliases[$code] ) &&
 110              isset( $this->mMagicWords[$code] ) &&
 111              isset( $this->mSpecialPageAliases[$code] )
 112          ) {
 113              return;
 114          }
 115          $this->mRawMessages[$code] = array();
 116          $this->mFallback[$code] = '';
 117          $this->mNamespaceNames[$code] = array();
 118          $this->mNamespaceAliases[$code] = array();
 119          $this->mMagicWords[$code] = array();
 120          $this->mSpecialPageAliases[$code] = array();
 121  
 122          $jsonfilename = Language::getJsonMessagesFileName( $code );
 123          if ( file_exists( $jsonfilename ) ) {
 124              $json = Language::getLocalisationCache()->readJSONFile( $jsonfilename );
 125              $this->mRawMessages[$code] = $json['messages'];
 126          }
 127  
 128          $filename = Language::getMessagesFileName( $code );
 129          if ( file_exists( $filename ) ) {
 130              require $filename;
 131              if ( isset( $fallback ) ) {
 132                  $this->mFallback[$code] = $fallback;
 133              }
 134              if ( isset( $namespaceNames ) ) {
 135                  $this->mNamespaceNames[$code] = $namespaceNames;
 136              }
 137              if ( isset( $namespaceAliases ) ) {
 138                  $this->mNamespaceAliases[$code] = $namespaceAliases;
 139              }
 140              if ( isset( $magicWords ) ) {
 141                  $this->mMagicWords[$code] = $magicWords;
 142              }
 143              if ( isset( $specialPageAliases ) ) {
 144                  $this->mSpecialPageAliases[$code] = $specialPageAliases;
 145              }
 146          }
 147      }
 148  
 149      /**
 150       * Load the messages for a specific language (which is not English) and divide them to
 151       * groups:
 152       * all - all the messages.
 153       * required - messages which should be translated in order to get a complete translation.
 154       * optional - messages which can be translated, the fallback translation is used if not
 155       *   translated.
 156       * obsolete - messages which should not be translated, either because they do not exist,
 157       *   or they are ignored messages.
 158       * translated - messages which are either required or optional, but translated from
 159       *   English and needed.
 160       *
 161       * @param string $code The language code.
 162       */
 163  	private function loadMessages( $code ) {
 164          if ( isset( $this->mMessages[$code] ) ) {
 165              return;
 166          }
 167          $this->loadFile( $code );
 168          $this->loadGeneralMessages();
 169          $this->mMessages[$code]['all'] = $this->mRawMessages[$code];
 170          $this->mMessages[$code]['required'] = array();
 171          $this->mMessages[$code]['optional'] = array();
 172          $this->mMessages[$code]['obsolete'] = array();
 173          $this->mMessages[$code]['translated'] = array();
 174          foreach ( $this->mMessages[$code]['all'] as $key => $value ) {
 175              if ( isset( $this->mGeneralMessages['required'][$key] ) ) {
 176                  $this->mMessages[$code]['required'][$key] = $value;
 177                  $this->mMessages[$code]['translated'][$key] = $value;
 178              } elseif ( isset( $this->mGeneralMessages['optional'][$key] ) ) {
 179                  $this->mMessages[$code]['optional'][$key] = $value;
 180                  $this->mMessages[$code]['translated'][$key] = $value;
 181              } else {
 182                  $this->mMessages[$code]['obsolete'][$key] = $value;
 183              }
 184          }
 185      }
 186  
 187      /**
 188       * Load the messages for English and divide them to groups:
 189       * all - all the messages.
 190       * required - messages which should be translated to other languages in order to get a
 191       *   complete translation.
 192       * optional - messages which can be translated to other languages, but it's not required
 193       *   for a complete translation.
 194       * ignored - messages which should not be translated to other languages.
 195       * translatable - messages which are either required or optional, but can be translated
 196       *   from English.
 197       */
 198  	private function loadGeneralMessages() {
 199          if ( isset( $this->mGeneralMessages ) ) {
 200              return;
 201          }
 202          $this->loadFile( 'en' );
 203          $this->mGeneralMessages['all'] = $this->mRawMessages['en'];
 204          $this->mGeneralMessages['required'] = array();
 205          $this->mGeneralMessages['optional'] = array();
 206          $this->mGeneralMessages['ignored'] = array();
 207          $this->mGeneralMessages['translatable'] = array();
 208          foreach ( $this->mGeneralMessages['all'] as $key => $value ) {
 209              if ( in_array( $key, $this->mIgnoredMessages ) ) {
 210                  $this->mGeneralMessages['ignored'][$key] = $value;
 211              } elseif ( in_array( $key, $this->mOptionalMessages ) ) {
 212                  $this->mGeneralMessages['optional'][$key] = $value;
 213                  $this->mGeneralMessages['translatable'][$key] = $value;
 214              } else {
 215                  $this->mGeneralMessages['required'][$key] = $value;
 216                  $this->mGeneralMessages['translatable'][$key] = $value;
 217              }
 218          }
 219      }
 220  
 221      /**
 222       * Get all the messages for a specific language (not English), without the
 223       * fallback language messages, divided to groups:
 224       * all - all the messages.
 225       * required - messages which should be translated in order to get a complete translation.
 226       * optional - messages which can be translated, the fallback translation is used if not
 227       *   translated.
 228       * obsolete - messages which should not be translated, either because they do not exist,
 229       *   or they are ignored messages.
 230       * translated - messages which are either required or optional, but translated from
 231       *   English and needed.
 232       *
 233       * @param string $code The language code.
 234       *
 235       * @return string The messages in this language.
 236       */
 237  	public function getMessages( $code ) {
 238          $this->loadMessages( $code );
 239  
 240          return $this->mMessages[$code];
 241      }
 242  
 243      /**
 244       * Get all the general English messages, divided to groups:
 245       * all - all the messages.
 246       * required - messages which should be translated to other languages in
 247       *   order to get a complete translation.
 248       * optional - messages which can be translated to other languages, but it's
 249       *   not required for a complete translation.
 250       * ignored - messages which should not be translated to other languages.
 251       * translatable - messages which are either required or optional, but can be
 252       *   translated from English.
 253       *
 254       * @return array The general English messages.
 255       */
 256  	public function getGeneralMessages() {
 257          $this->loadGeneralMessages();
 258  
 259          return $this->mGeneralMessages;
 260      }
 261  
 262      /**
 263       * Get fallback language code for a specific language.
 264       *
 265       * @param string $code The language code.
 266       *
 267       * @return string Fallback code.
 268       */
 269  	public function getFallback( $code ) {
 270          $this->loadFile( $code );
 271  
 272          return $this->mFallback[$code];
 273      }
 274  
 275      /**
 276       * Get namespace names for a specific language.
 277       *
 278       * @param string $code The language code.
 279       *
 280       * @return array Namespace names.
 281       */
 282  	public function getNamespaceNames( $code ) {
 283          $this->loadFile( $code );
 284  
 285          return $this->mNamespaceNames[$code];
 286      }
 287  
 288      /**
 289       * Get namespace aliases for a specific language.
 290       *
 291       * @param string $code The language code.
 292       *
 293       * @return array Namespace aliases.
 294       */
 295  	public function getNamespaceAliases( $code ) {
 296          $this->loadFile( $code );
 297  
 298          return $this->mNamespaceAliases[$code];
 299      }
 300  
 301      /**
 302       * Get magic words for a specific language.
 303       *
 304       * @param string $code The language code.
 305       *
 306       * @return array Magic words.
 307       */
 308  	public function getMagicWords( $code ) {
 309          $this->loadFile( $code );
 310  
 311          return $this->mMagicWords[$code];
 312      }
 313  
 314      /**
 315       * Get special page aliases for a specific language.
 316       *
 317       * @param string $code The language code.
 318       *
 319       * @return array Special page aliases.
 320       */
 321  	public function getSpecialPageAliases( $code ) {
 322          $this->loadFile( $code );
 323  
 324          return $this->mSpecialPageAliases[$code];
 325      }
 326  
 327      /**
 328       * Get the untranslated messages for a specific language.
 329       *
 330       * @param string $code The language code.
 331       *
 332       * @return array The untranslated messages for this language.
 333       */
 334  	public function getUntranslatedMessages( $code ) {
 335          $this->loadGeneralMessages();
 336          $this->loadMessages( $code );
 337  
 338          return array_diff_key( $this->mGeneralMessages['required'], $this->mMessages[$code]['required'] );
 339      }
 340  
 341      /**
 342       * Get the duplicate messages for a specific language.
 343       *
 344       * @param string $code The language code.
 345       *
 346       * @return array The duplicate messages for this language.
 347       */
 348  	public function getDuplicateMessages( $code ) {
 349          $this->loadGeneralMessages();
 350          $this->loadMessages( $code );
 351          $duplicateMessages = array();
 352          foreach ( $this->mMessages[$code]['translated'] as $key => $value ) {
 353              if ( $this->mGeneralMessages['translatable'][$key] == $value ) {
 354                  $duplicateMessages[$key] = $value;
 355              }
 356          }
 357  
 358          return $duplicateMessages;
 359      }
 360  
 361      /**
 362       * Get the obsolete messages for a specific language.
 363       *
 364       * @param string $code The language code.
 365       *
 366       * @return array The obsolete messages for this language.
 367       */
 368  	public function getObsoleteMessages( $code ) {
 369          $this->loadGeneralMessages();
 370          $this->loadMessages( $code );
 371  
 372          return $this->mMessages[$code]['obsolete'];
 373      }
 374  
 375      /**
 376       * Get the messages whose variables do not match the original ones.
 377       *
 378       * @param string $code The language code.
 379       *
 380       * @return array The messages whose variables do not match the original ones.
 381       */
 382  	public function getMessagesWithMismatchVariables( $code ) {
 383          $this->loadGeneralMessages();
 384          $this->loadMessages( $code );
 385          $variables = array( '\$1', '\$2', '\$3', '\$4', '\$5', '\$6', '\$7', '\$8', '\$9' );
 386          $mismatchMessages = array();
 387          foreach ( $this->mMessages[$code]['translated'] as $key => $value ) {
 388              $missing = false;
 389              foreach ( $variables as $var ) {
 390                  if ( preg_match( "/$var/sU", $this->mGeneralMessages['translatable'][$key] ) &&
 391                      !preg_match( "/$var/sU", $value )
 392                  ) {
 393                      $missing = true;
 394                  }
 395                  if ( !preg_match( "/$var/sU", $this->mGeneralMessages['translatable'][$key] ) &&
 396                      preg_match( "/$var/sU", $value )
 397                  ) {
 398                      $missing = true;
 399                  }
 400              }
 401              if ( $missing ) {
 402                  $mismatchMessages[$key] = $value;
 403              }
 404          }
 405  
 406          return $mismatchMessages;
 407      }
 408  
 409      /**
 410       * Get the messages which do not use plural.
 411       *
 412       * @param string $code The language code.
 413       *
 414       * @return array The messages which do not use plural in this language.
 415       */
 416  	public function getMessagesWithoutPlural( $code ) {
 417          $this->loadGeneralMessages();
 418          $this->loadMessages( $code );
 419          $messagesWithoutPlural = array();
 420          foreach ( $this->mMessages[$code]['translated'] as $key => $value ) {
 421              if ( stripos( $this->mGeneralMessages['translatable'][$key], '{{plural:' ) !== false &&
 422                  stripos( $value, '{{plural:' ) === false
 423              ) {
 424                  $messagesWithoutPlural[$key] = $value;
 425              }
 426          }
 427  
 428          return $messagesWithoutPlural;
 429      }
 430  
 431      /**
 432       * Get the empty messages.
 433       *
 434       * @param string $code The language code.
 435       *
 436       * @return array The empty messages for this language.
 437       */
 438  	public function getEmptyMessages( $code ) {
 439          $this->loadGeneralMessages();
 440          $this->loadMessages( $code );
 441          $emptyMessages = array();
 442          foreach ( $this->mMessages[$code]['translated'] as $key => $value ) {
 443              if ( $value === '' || $value === '-' ) {
 444                  $emptyMessages[$key] = $value;
 445              }
 446          }
 447  
 448          return $emptyMessages;
 449      }
 450  
 451      /**
 452       * Get the messages with trailing whitespace.
 453       *
 454       * @param string $code The language code.
 455       *
 456       * @return array The messages with trailing whitespace in this language.
 457       */
 458  	public function getMessagesWithWhitespace( $code ) {
 459          $this->loadGeneralMessages();
 460          $this->loadMessages( $code );
 461          $messagesWithWhitespace = array();
 462          foreach ( $this->mMessages[$code]['translated'] as $key => $value ) {
 463              if ( $this->mGeneralMessages['translatable'][$key] !== '' && $value !== rtrim( $value ) ) {
 464                  $messagesWithWhitespace[$key] = $value;
 465              }
 466          }
 467  
 468          return $messagesWithWhitespace;
 469      }
 470  
 471      /**
 472       * Get the non-XHTML messages.
 473       *
 474       * @param string $code The language code.
 475       *
 476       * @return array The non-XHTML messages for this language.
 477       */
 478  	public function getNonXHTMLMessages( $code ) {
 479          $this->loadGeneralMessages();
 480          $this->loadMessages( $code );
 481          $wrongPhrases = array(
 482              '<hr *\\?>',
 483              '<br *\\?>',
 484              '<hr/>',
 485              '<br/>',
 486              '<hr>',
 487              '<br>',
 488          );
 489          $wrongPhrases = '~(' . implode( '|', $wrongPhrases ) . ')~sDu';
 490          $nonXHTMLMessages = array();
 491          foreach ( $this->mMessages[$code]['translated'] as $key => $value ) {
 492              if ( preg_match( $wrongPhrases, $value ) ) {
 493                  $nonXHTMLMessages[$key] = $value;
 494              }
 495          }
 496  
 497          return $nonXHTMLMessages;
 498      }
 499  
 500      /**
 501       * Get the messages which include wrong characters.
 502       *
 503       * @param string $code The language code.
 504       *
 505       * @return array The messages which include wrong characters in this language.
 506       */
 507  	public function getMessagesWithWrongChars( $code ) {
 508          $this->loadGeneralMessages();
 509          $this->loadMessages( $code );
 510          $wrongChars = array(
 511              '[LRM]' => "\xE2\x80\x8E",
 512              '[RLM]' => "\xE2\x80\x8F",
 513              '[LRE]' => "\xE2\x80\xAA",
 514              '[RLE]' => "\xE2\x80\xAB",
 515              '[POP]' => "\xE2\x80\xAC",
 516              '[LRO]' => "\xE2\x80\xAD",
 517              '[RLO]' => "\xE2\x80\xAB",
 518              '[ZWSP]' => "\xE2\x80\x8B",
 519              '[NBSP]' => "\xC2\xA0",
 520              '[WJ]' => "\xE2\x81\xA0",
 521              '[BOM]' => "\xEF\xBB\xBF",
 522              '[FFFD]' => "\xEF\xBF\xBD",
 523          );
 524          $wrongRegExp = '/(' . implode( '|', array_values( $wrongChars ) ) . ')/sDu';
 525          $wrongCharsMessages = array();
 526          foreach ( $this->mMessages[$code]['translated'] as $key => $value ) {
 527              if ( preg_match( $wrongRegExp, $value ) ) {
 528                  foreach ( $wrongChars as $viewableChar => $hiddenChar ) {
 529                      $value = str_replace( $hiddenChar, $viewableChar, $value );
 530                  }
 531                  $wrongCharsMessages[$key] = $value;
 532              }
 533          }
 534  
 535          return $wrongCharsMessages;
 536      }
 537  
 538      /**
 539       * Get the messages which include dubious links.
 540       *
 541       * @param string $code The language code.
 542       *
 543       * @return array The messages which include dubious links in this language.
 544       */
 545  	public function getMessagesWithDubiousLinks( $code ) {
 546          $this->loadGeneralMessages();
 547          $this->loadMessages( $code );
 548          $tc = Title::legalChars() . '#%{}';
 549          $messages = array();
 550          foreach ( $this->mMessages[$code]['translated'] as $key => $value ) {
 551              $matches = array();
 552              preg_match_all( "/\[\[([{$tc}]+)(?:\\|(.+?))?]]/sDu", $value, $matches );
 553              $numMatches = count( $matches[0] );
 554              for ( $i = 0; $i < $numMatches; $i++ ) {
 555                  if ( preg_match( "/.*project.*/isDu", $matches[1][$i] ) ) {
 556                      $messages[$key][] = $matches[0][$i];
 557                  }
 558              }
 559  
 560              if ( isset( $messages[$key] ) ) {
 561                  $messages[$key] = implode( $messages[$key], ", " );
 562              }
 563          }
 564  
 565          return $messages;
 566      }
 567  
 568      /**
 569       * Get the messages which include unbalanced brackets.
 570       *
 571       * @param string $code The language code.
 572       *
 573       * @return array The messages which include unbalanced brackets in this language.
 574       */
 575  	public function getMessagesWithUnbalanced( $code ) {
 576          $this->loadGeneralMessages();
 577          $this->loadMessages( $code );
 578          $messages = array();
 579          foreach ( $this->mMessages[$code]['translated'] as $key => $value ) {
 580              $a = $b = $c = $d = 0;
 581              foreach ( preg_split( '//', $value ) as $char ) {
 582                  switch ( $char ) {
 583                      case '[':
 584                          $a++;
 585                          break;
 586                      case ']':
 587                          $b++;
 588                          break;
 589                      case '{':
 590                          $c++;
 591                          break;
 592                      case '}':
 593                          $d++;
 594                          break;
 595                  }
 596              }
 597  
 598              if ( $a !== $b || $c !== $d ) {
 599                  $messages[$key] = "$a, $b, $c, $d";
 600              }
 601          }
 602  
 603          return $messages;
 604      }
 605  
 606      /**
 607       * Get the untranslated namespace names.
 608       *
 609       * @param string $code The language code.
 610       *
 611       * @return array The untranslated namespace names in this language.
 612       */
 613  	public function getUntranslatedNamespaces( $code ) {
 614          $this->loadFile( 'en' );
 615          $this->loadFile( $code );
 616          $namespacesDiff = array_diff_key( $this->mNamespaceNames['en'], $this->mNamespaceNames[$code] );
 617          if ( isset( $namespacesDiff[NS_MAIN] ) ) {
 618              unset( $namespacesDiff[NS_MAIN] );
 619          }
 620  
 621          return $namespacesDiff;
 622      }
 623  
 624      /**
 625       * Get the project talk namespace names with no $1.
 626       *
 627       * @param string $code The language code.
 628       *
 629       * @return array The problematic project talk namespaces in this language.
 630       */
 631  	public function getProblematicProjectTalks( $code ) {
 632          $this->loadFile( $code );
 633          $namespaces = array();
 634  
 635          # Check default namespace name
 636          if ( isset( $this->mNamespaceNames[$code][NS_PROJECT_TALK] ) ) {
 637              $default = $this->mNamespaceNames[$code][NS_PROJECT_TALK];
 638              if ( strpos( $default, '$1' ) === false ) {
 639                  $namespaces[$default] = 'default';
 640              }
 641          }
 642  
 643          # Check namespace aliases
 644          foreach ( $this->mNamespaceAliases[$code] as $key => $value ) {
 645              if ( $value == NS_PROJECT_TALK && strpos( $key, '$1' ) === false ) {
 646                  $namespaces[$key] = '';
 647              }
 648          }
 649  
 650          return $namespaces;
 651      }
 652  
 653      /**
 654       * Get the untranslated magic words.
 655       *
 656       * @param string $code The language code.
 657       *
 658       * @return array The untranslated magic words in this language.
 659       */
 660  	public function getUntranslatedMagicWords( $code ) {
 661          $this->loadFile( 'en' );
 662          $this->loadFile( $code );
 663          $magicWords = array();
 664          foreach ( $this->mMagicWords['en'] as $key => $value ) {
 665              if ( !isset( $this->mMagicWords[$code][$key] ) ) {
 666                  $magicWords[$key] = $value[1];
 667              }
 668          }
 669  
 670          return $magicWords;
 671      }
 672  
 673      /**
 674       * Get the obsolete magic words.
 675       *
 676       * @param string $code The language code.
 677       *
 678       * @return array The obsolete magic words in this language.
 679       */
 680  	public function getObsoleteMagicWords( $code ) {
 681          $this->loadFile( 'en' );
 682          $this->loadFile( $code );
 683          $magicWords = array();
 684          foreach ( $this->mMagicWords[$code] as $key => $value ) {
 685              if ( !isset( $this->mMagicWords['en'][$key] ) ) {
 686                  $magicWords[$key] = $value[1];
 687              }
 688          }
 689  
 690          return $magicWords;
 691      }
 692  
 693      /**
 694       * Get the magic words that override the original English magic word.
 695       *
 696       * @param string $code The language code.
 697       *
 698       * @return array The overriding magic words in this language.
 699       */
 700  	public function getOverridingMagicWords( $code ) {
 701          $this->loadFile( 'en' );
 702          $this->loadFile( $code );
 703          $magicWords = array();
 704          foreach ( $this->mMagicWords[$code] as $key => $local ) {
 705              if ( !isset( $this->mMagicWords['en'][$key] ) ) {
 706                  # Unrecognized magic word
 707                  continue;
 708              }
 709              $en = $this->mMagicWords['en'][$key];
 710              array_shift( $local );
 711              array_shift( $en );
 712              foreach ( $en as $word ) {
 713                  if ( !in_array( $word, $local ) ) {
 714                      $magicWords[$key] = $word;
 715                      break;
 716                  }
 717              }
 718          }
 719  
 720          return $magicWords;
 721      }
 722  
 723      /**
 724       * Get the magic words which do not match the case-sensitivity of the original words.
 725       *
 726       * @param string $code The language code.
 727       *
 728       * @return array The magic words whose case does not match in this language.
 729       */
 730  	public function getCaseMismatchMagicWords( $code ) {
 731          $this->loadFile( 'en' );
 732          $this->loadFile( $code );
 733          $magicWords = array();
 734          foreach ( $this->mMagicWords[$code] as $key => $local ) {
 735              if ( !isset( $this->mMagicWords['en'][$key] ) ) {
 736                  # Unrecognized magic word
 737                  continue;
 738              }
 739              if ( $local[0] != $this->mMagicWords['en'][$key][0] ) {
 740                  $magicWords[$key] = $local[0];
 741              }
 742          }
 743  
 744          return $magicWords;
 745      }
 746  
 747      /**
 748       * Get the untranslated special page names.
 749       *
 750       * @param string $code The language code.
 751       *
 752       * @return array The untranslated special page names in this language.
 753       */
 754  	public function getUntraslatedSpecialPages( $code ) {
 755          $this->loadFile( 'en' );
 756          $this->loadFile( $code );
 757          $specialPageAliases = array();
 758          foreach ( $this->mSpecialPageAliases['en'] as $key => $value ) {
 759              if ( !isset( $this->mSpecialPageAliases[$code][$key] ) ) {
 760                  $specialPageAliases[$key] = $value[0];
 761              }
 762          }
 763  
 764          return $specialPageAliases;
 765      }
 766  
 767      /**
 768       * Get the obsolete special page names.
 769       *
 770       * @param string $code The language code.
 771       *
 772       * @return array The obsolete special page names in this language.
 773       */
 774  	public function getObsoleteSpecialPages( $code ) {
 775          $this->loadFile( 'en' );
 776          $this->loadFile( $code );
 777          $specialPageAliases = array();
 778          foreach ( $this->mSpecialPageAliases[$code] as $key => $value ) {
 779              if ( !isset( $this->mSpecialPageAliases['en'][$key] ) ) {
 780                  $specialPageAliases[$key] = $value[0];
 781              }
 782          }
 783  
 784          return $specialPageAliases;
 785      }
 786  }
 787  
 788  class ExtensionLanguages extends Languages {
 789      /**
 790       * @var MessageGroup
 791       */
 792      private $mMessageGroup;
 793  
 794      /**
 795       * Load the messages group.
 796       * @param MessageGroup $group The messages group.
 797       */
 798  	function __construct( MessageGroup $group ) {
 799          $this->mMessageGroup = $group;
 800  
 801          $this->mIgnoredMessages = $this->mMessageGroup->getIgnored();
 802          $this->mOptionalMessages = $this->mMessageGroup->getOptional();
 803      }
 804  
 805      /**
 806       * Get the extension name.
 807       *
 808       * @return string The extension name.
 809       */
 810  	public function name() {
 811          return $this->mMessageGroup->getLabel();
 812      }
 813  
 814      /**
 815       * Load the language file.
 816       *
 817       * @param string $code The language code.
 818       */
 819  	protected function loadFile( $code ) {
 820          if ( !isset( $this->mRawMessages[$code] ) ) {
 821              $this->mRawMessages[$code] = $this->mMessageGroup->load( $code );
 822              if ( empty( $this->mRawMessages[$code] ) ) {
 823                  $this->mRawMessages[$code] = array();
 824              }
 825          }
 826      }
 827  }


Generated: Fri Nov 28 14:03:12 2014 Cross-referenced by PHPXref 0.7.1