]> scripts.mit.edu Git - autoinstallsdev/mediawiki.git/blob - languages/classes/LanguageKaa.php
MediaWiki 1.30.2
[autoinstallsdev/mediawiki.git] / languages / classes / LanguageKaa.php
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         public function ucfirst( $string ) {
58                 if ( substr( $string, 0, 1 ) === 'i' ) {
59                         return 'İ' . substr( $string, 1 );
60                 }
61                 return parent::ucfirst( $string );
62         }
63
64         /**
65          * It fixes issue with lcfirst for transforming 'I' to 'ı'
66          *
67          * @param string $string
68          *
69          * @return mixed|string
70          */
71         function lcfirst( $string ) {
72                 if ( substr( $string, 0, 1 ) === 'I' ) {
73                         return 'ı' . substr( $string, 1 );
74                 }
75                 return parent::lcfirst( $string );
76         }
77
78         /**
79          * Avoid grouping whole numbers between 0 to 9999
80          *
81          * @param string $_
82          *
83          * @return string
84          */
85         function commafy( $_ ) {
86                 if ( !preg_match( '/^\d{1,4}$/', $_ ) ) {
87                         return strrev( (string)preg_replace( '/(\d{3})(?=\d)(?!\d*\.)/', '$1,', strrev( $_ ) ) );
88                 } else {
89                         return $_;
90                 }
91         }
92
93 }