Merge "Reduced some master queries by adding flags to Revision functions."
[lhc/web/wiklou.git] / languages / classes / LanguageHe.php
1 <?php
2 /**
3 * Hebrew (עברית) 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 * @author Rotem Liss
22 * @ingroup Language
23 */
24
25 /**
26 * Hebrew (עברית)
27 *
28 * @ingroup Language
29 */
30 class LanguageHe extends Language {
31
32 /**
33 * Convert grammar forms of words.
34 *
35 * Available cases:
36 * "prefixed" (or "תחילית") - when the word has a prefix
37 *
38 * @param $word String: the word to convert
39 * @param $case String: the case
40 *
41 * @return string
42 */
43 public function convertGrammar( $word, $case ) {
44 global $wgGrammarForms;
45 if ( isset( $wgGrammarForms['he'][$case][$word] ) ) {
46 return $wgGrammarForms['he'][$case][$word];
47 }
48
49 switch ( $case ) {
50 case 'prefixed':
51 case 'תחילית':
52 # Duplicate the "Waw" if prefixed
53 if ( substr( $word, 0, 2 ) == "ו" && substr( $word, 0, 4 ) != "וו" ) {
54 $word = "ו" . $word;
55 }
56
57 # Remove the "He" if prefixed
58 if ( substr( $word, 0, 2 ) == "ה" ) {
59 $word = substr( $word, 2 );
60 }
61
62 # Add a hyphen (maqaf) if non-Hebrew letters
63 if ( substr( $word, 0, 2 ) < "א" || substr( $word, 0, 2 ) > "ת" ) {
64 $word = "־" . $word;
65 }
66 }
67
68 return $word;
69 }
70
71 /**
72 * Gets a number and uses the suited form of the word.
73 *
74 * @param $count Integer: the number of items
75 * @param $forms Array with 3 items: the three plural forms
76 * @return String: the suited form of word
77 */
78 function convertPlural( $count, $forms ) {
79 if ( !count( $forms ) ) { return ''; }
80 $forms = $this->preConvertPlural( $forms, 3 );
81
82 if ( $count == 1 ) {
83 return $forms[0]; // Singular
84 } elseif ( $count == 2 ) {
85 return $forms[2]; // Dual or plural if dual is not provided (filled in preConvertPlural)
86 } else {
87 return $forms[1]; // Plural
88 }
89 }
90 }