[ Index ]

PHP Cross Reference of MediaWiki-1.24.0

title

Body

[close]

/languages/classes/ -> LanguageKaa.php (source)

   1  <?php
   2  /**
   3   * Karakalpak (Qaraqalpaqsha) specific code.
   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 Language
  22   */
  23  
  24  /**
  25   * Karakalpak (Qaraqalpaqsha)
  26   *
  27   * @ingroup Language
  28   */
  29  class LanguageKaa extends Language {
  30  
  31      # Convert from the nominative form of a noun to some other case
  32      # Invoked with {{GRAMMAR:case|word}}
  33      /**
  34       * Cases: genitive, dative, accusative, locative, ablative, comitative + possessive forms
  35       *
  36       * @param string $word
  37       * @param string $case
  38       *
  39       * @return string
  40       */
  41  	function convertGrammar( $word, $case ) {
  42          global $wgGrammarForms;
  43          if ( isset( $wgGrammarForms['kaa'][$case][$word] ) ) {
  44              return $wgGrammarForms['kaa'][$case][$word];
  45          }
  46          /* Full code of function convertGrammar() is in development. Updates coming soon. */
  47          return $word;
  48      }
  49  
  50      /**
  51       * It fixes issue with ucfirst for transforming 'i' to 'İ'
  52       *
  53       * @param string $string
  54       *
  55       * @return string
  56       */
  57  	function ucfirst( $string ) {
  58          if ( substr( $string, 0, 1 ) === 'i' ) {
  59              return 'İ' . substr( $string, 1 );
  60          } else {
  61              return parent::ucfirst( $string );
  62          }
  63      }
  64  
  65      /**
  66       * It fixes issue with lcfirst for transforming 'I' to 'ı'
  67       *
  68       * @param string $string
  69       *
  70       * @return mixed|string
  71       */
  72  	function lcfirst( $string ) {
  73          if ( substr( $string, 0, 1 ) === 'I' ) {
  74              return 'ı' . substr( $string, 1 );
  75          } else {
  76              return parent::lcfirst( $string );
  77          }
  78      }
  79  
  80      /**
  81       * Avoid grouping whole numbers between 0 to 9999
  82       *
  83       * @param string $_
  84       *
  85       * @return string
  86       */
  87  	function commafy( $_ ) {
  88          if ( !preg_match( '/^\d{1,4}$/', $_ ) ) {
  89              return strrev( (string)preg_replace( '/(\d{3})(?=\d)(?!\d*\.)/', '$1,', strrev( $_ ) ) );
  90          } else {
  91              return $_;
  92          }
  93      }
  94  
  95  }


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