wiki.techinc.nl/languages/classes/LanguageHe.php

71 lines
1.5 KiB
PHP
Raw Normal View History

<?php
/**
2006-06-16 18:47:15 +00:00
* Hebrew (עברית)
*
* @ingroup Language
2006-06-16 18:47:15 +00:00
*
2006-08-13 21:03:56 +00:00
* @author Rotem Liss
2006-06-16 18:47:15 +00:00
*/
Merged localisation-work branch: * Made lines from initialiseMessages() appear as list items during installation * Moved the bulk of the localisation data from the Language*.php files to the Messages*.php files. Deleted most of the Languages*.php files. * Introduced "stub global" framework to provide deferred initialisation of core modules. * Removed placeholder values for $wgTitle and $wgArticle, these variables will now be null during the initialisation process, until they are set by index.php or another entry point. * Added DBA cache type, for BDB-style caches. * Removed custom date format functions, replacing them with a format string in the style of PHP's date(). Used string identifiers instead of integer identifiers, in both the language files and user preferences. Migration should be transparent in most cases. * Simplified the initialisation API for LoadBalancer objects. * Removed the broken altencoding feature. * Moved default user options and toggles from Language to User. Language objects are still able to define default preference overrides and extra user toggles, via a slightly different interface. * Don't include the date option in the parser cache rendering hash unless $wgUseDynamicDates is enabled. * Merged LanguageUtf8 with Language. Removed LanguageUtf8.php. * Removed inclusion of language files from the bottom of Language.php. This is now consistently done from Language::factory(). * Add the name of the executing maintenance script to the debug log. Start the profiler during maintenance scripts. * Added "serialized" directory, for storing precompiled data in serialized form.
2006-07-26 07:15:39 +00:00
class LanguageHe extends Language {
2010-06-05 19:15:50 +00:00
/**
* Convert grammar forms of words.
2006-06-16 18:47:15 +00:00
*
* Available cases:
* "prefixed" (or "תחילית") - when the word has a prefix
*
2010-06-05 19:15:50 +00:00
* @param $word String: the word to convert
* @param $case String: the case
2011-05-29 15:03:33 +00:00
*
* @return string
*/
public function convertGrammar( $word, $case ) {
global $wgGrammarForms;
if ( isset( $wgGrammarForms['he'][$case][$word] ) ) {
return $wgGrammarForms['he'][$case][$word];
}
2010-06-05 19:15:50 +00:00
switch ( $case ) {
case 'prefixed':
case 'תחילית':
# Duplicate the "Waw" if prefixed
if ( substr( $word, 0, 2 ) == "ו" && substr( $word, 0, 4 ) != "וו" ) {
$word = "ו" . $word;
}
2010-06-05 19:15:50 +00:00
# Remove the "He" if prefixed
if ( substr( $word, 0, 2 ) == "ה" ) {
$word = substr( $word, 2 );
}
2010-06-05 19:15:50 +00:00
# Add a hyphen if non-Hebrew letters
if ( substr( $word, 0, 2 ) < "א" || substr( $word, 0, 2 ) > "ת" ) {
$word = "־" . $word;
}
}
2010-06-05 19:15:50 +00:00
return $word;
}
2010-06-05 19:15:50 +00:00
/**
* Gets a number and uses the suited form of the word.
*
2010-06-05 19:15:50 +00:00
* @param $count Integer: the number of items
* @param $forms Array with 3 items: the three plural forms
* @return String: the suited form of word
*/
function convertPlural( $count, $forms ) {
if ( !count( $forms ) ) { return ''; }
$forms = $this->preConvertPlural( $forms, 3 );
if ( $count == '1' ) {
return $forms[0];
} elseif ( $count == '2' && isset( $forms[2] ) ) {
return $forms[2];
} else {
return $forms[1];
}
}
}