diff options
author | Pierre Schmitz <pierre@archlinux.de> | 2006-10-11 18:12:39 +0000 |
---|---|---|
committer | Pierre Schmitz <pierre@archlinux.de> | 2006-10-11 18:12:39 +0000 |
commit | 183851b06bd6c52f3cae5375f433da720d410447 (patch) | |
tree | a477257decbf3360127f6739c2f9d0ec57a03d39 /languages/LanguageTyv.php |
MediaWiki 1.7.1 wiederhergestellt
Diffstat (limited to 'languages/LanguageTyv.php')
-rw-r--r-- | languages/LanguageTyv.php | 312 |
1 files changed, 312 insertions, 0 deletions
diff --git a/languages/LanguageTyv.php b/languages/LanguageTyv.php new file mode 100644 index 00000000..1c7abe0b --- /dev/null +++ b/languages/LanguageTyv.php @@ -0,0 +1,312 @@ +<?php +/** Tyvan localization (Тыва дыл) + * @package MediaWiki + * @subpackage Language + */ + +# From friends at tyvawiki.org +# Originally based upon LanguageRu.php + +require_once( 'LanguageUtf8.php' ); + +#-------------------------------------------------------------------------- +# Language-specific text +#-------------------------------------------------------------------------- + +/* private */ $wgNamespaceNamesTyv = array( + NS_MEDIA => 'Медиа', //Media + NS_SPECIAL => 'Тускай', //Special + NS_MAIN => '', + NS_TALK => 'Чугаа', //Talk + NS_USER => 'Aжыглакчы', //User + NS_USER_TALK => 'Aжыглакчы_чугаа', //User_talk + NS_PROJECT => $wgMetaNamespace, + NS_PROJECT_TALK => $wgMetaNamespace . '_чугаа', //_talk + NS_IMAGE => 'Чурук', //Image + NS_IMAGE_TALK => 'Чурук_чугаа', //Image_talk + NS_MEDIAWIKI => 'МедиаВики', //MediaWiki + NS_MEDIAWIKI_TALK => 'МедиаВики_чугаа', //MediaWiki_talk + NS_TEMPLATE => 'Хээ', //Template + NS_TEMPLATE_TALK => 'Хээ_чугаа', //Template_talk + NS_HELP => 'Дуза', //Help + NS_HELP_TALK => 'Дуза_чугаа', //Help_talk + NS_CATEGORY => 'Бөлүк', //Category + NS_CATEGORY_TALK => 'Бөлүк_чугаа', //Category_talk +) + $wgNamespaceNamesEn; + +/* private */ $wgSkinNamesTyv = array( + 'standard' => 'Classic', //Classic + 'nostalgia' => 'Nostalgia', //Nostalgia + 'cologneblue' => 'Cologne Blue', //Cologne Blue + 'davinci' => 'ДаВинчи', //DaVinci + 'mono' => 'Моно', //Mono + 'monobook' => 'Моно-Ном', //MonoBook + 'myskin' => 'MySkin', //MySkin + 'chick' => 'Chick' //Chick +) + $wgSkinNamesEn; + +/* private */ $wgBookstoreListTyv = array( + 'ОЗОН' => 'http://www.ozon.ru/?context=advsearch_book&isbn=$1', + 'Books.Ru' => 'http://www.books.ru/shop/search/advanced?as%5Btype%5D=books&as%5Bname%5D=&as%5Bisbn%5D=$1&as%5Bauthor%5D=&as%5Bmaker%5D=&as%5Bcontents%5D=&as%5Binfo%5D=&as%5Bdate_after%5D=&as%5Bdate_before%5D=&as%5Bprice_less%5D=&as%5Bprice_more%5D=&as%5Bstrict%5D=%E4%E0&as%5Bsub%5D=%E8%F1%EA%E0%F2%FC&x=22&y=8', + 'Яндекс.Маркет' => 'http://market.yandex.ru/search.xml?text=$1', + 'Amazon.com' => 'http://www.amazon.com/exec/obidos/ISBN=$1', + 'AddALL' => 'http://www.addall.com/New/Partner.cgi?query=$1&type=ISBN', + 'PriceSCAN' => 'http://www.pricescan.com/books/bookDetail.asp?isbn=$1', + 'Barnes & Noble' => 'http://shop.barnesandnoble.com/bookSearch/isbnInquiry.asp?isbn=$1' +); + +if (!$wgCachedMessageArrays) { + require_once('MessagesTyv.php'); +} + + +#-------------------------------------------------------------------------- +# Internationalisation code +#-------------------------------------------------------------------------- + +class LanguageTyv extends LanguageUtf8 { + function __construct() { + global $wgNamespaceNamesTyv, $wgMetaNamespace; + parent::__construct(); + $wgNamespaceNamesTyv[NS_PROJECT_TALK] = $wgMetaNamespace . '_чугаа'; + } + + function getNamespaces() { + global $wgNamespaceNamesTyv; + return $wgNamespaceNamesTyv; + } + + function getSkinNames() { + global $wgSkinNamesTyv; + return $wgSkinNamesTyv; + } + + function getMessage( $key ) { + global $wgAllMessagesTyv; + return isset($wgAllMessagesTyv[$key]) ? $wgAllMessagesTyv[$key] : parent::getMessage($key); + } + + function fallback8bitEncoding() { + return "windows-1251"; + } + + /** + * Grammatical transformations, needed for inflected languages + * Invoked by putting {{grammar:case|word}} in a message + * + * @param string $word + * @param string $case + * @return string + */ + function convertGrammar( $word, $case ) { + global $wgGrammarForms; + if ( isset($wgGrammarForms['tyv'][$case][$word]) ) { + return $wgGrammarForms['tyv'][$case][$word]; + } + + + // Set up some constants... + $allVowels = array("е", "и", "э", "ө", "ү", "а", "ё", "о", "у", "ы", "ю", "я", "a", "e", "i", "o", "ö", "u", "ü", "y"); + $frontVowels = array("е", "и", "э", "ө", "ү", "e", "i", "ö", "ü"); + $backVowels = array("а", "ё", "о", "у", "ы", "ю", "я", "a", "o", "u", "y"); + $unroundFrontVowels = array("е", "и", "э", "e", "i"); + $roundFrontVowels = array("ө", "ү", "ö", "ü"); + $unroundBackVowels = array("а", "ы", "я", "a", "y"); + $roundBackVowels = array("ё", "о", "у", "ю", "o", "u"); + $voicedPhonemes = array("д", "б", "з", "ж", "г", "d", "b", "z", "g"); + $unvoicedPhonemes = array("т", "п", "с", "ш", "к", "ч", "х", "t", "p", "s", "k", "x"); + $directiveUnvoicedStems = array("т", "п", "с", "ш", "к", "ч", "х", "л", "м", "н", "ң", "t", "p", "s", "k", "x", "l", "m", "n", "ŋ"); + $directiveVoicedStems = array("д", "б", "з", "ж", "г", "р", "й", "d", "b", "z", "g", "r", "j"); + +// $allSonants = array("л", "м", "н", "ң", "р", "й"); +// $allNasals = array("м", "н", "ң"); + + // Put the word in a form we can play with since we're using UTF-8 + preg_match_all( '/./us', $word, $ar ); + + $wordEnding = $ar[0][count($ar[0]) - 1]; //Here's the last letter in the word + $wordReversed = array_reverse($ar[0]); //Here's an array with the order of the letters in the word reversed so we can find a match quicker *shrug* + + // Find the last vowel in the word + $wordLastVowel = NULL; + foreach ( $wordReversed as $xvalue ) { + foreach ( $allVowels as $yvalue ) { + if ( strcmp($xvalue, $yvalue) == 0 ) { + $wordLastVowel = $xvalue; + break; + } else { + continue; + } + } + if ( $wordLastVowel !== NULL ) { + break; + } else { + continue; + } + } + + // Now convert the word + switch ( $case ) { + case "genitive": + if ( in_array($wordEnding, $unvoicedPhonemes) ) { + if ( in_array($wordLastVowel, $roundFrontVowels) ) { + $word = implode("",$ar[0]) . "түң"; + } elseif ( in_array($wordLastVowel, $unroundFrontVowels) ) { + $word = implode("",$ar[0]) . "тиң"; + } elseif ( in_array($wordLastVowel, $roundBackVowels) ) { + $word = implode("",$ar[0]) . "туң"; + } elseif ( in_array($wordLastVowel, $unroundBackVowels) ) { + $word = implode("",$ar[0]) . "тың"; + } else { + } + } elseif ( $wordEnding === "л" || $wordEnding === "l") { + if ( in_array($wordLastVowel, $roundFrontVowels) ) { + $word = implode("",$ar[0]) . "дүң"; + } elseif ( in_array($wordLastVowel, $unroundFrontVowels) ) { + $word = implode("",$ar[0]) . "диң"; + } elseif ( in_array($wordLastVowel, $roundBackVowels) ) { + $word = implode("",$ar[0]) . "дуң"; + } elseif ( in_array($wordLastVowel, $unroundBackVowels) ) { + $word = implode("",$ar[0]) . "дың"; + } else { + } + } else { + if ( in_array($wordLastVowel, $roundFrontVowels) ) { + $word = implode("",$ar[0]) . "нүң"; + } elseif ( in_array($wordLastVowel, $unroundFrontVowels) ) { + $word = implode("",$ar[0]) . "ниң"; + } elseif ( in_array($wordLastVowel, $roundBackVowels) ) { + $word = implode("",$ar[0]) . "нуң"; + } elseif ( in_array($wordLastVowel, $unroundBackVowels) ) { + $word = implode("",$ar[0]) . "ның"; + } else { + } + } + break; + case "dative": + if ( in_array($wordEnding, $unvoicedPhonemes) ) { + if ( in_array($wordLastVowel, $frontVowels) ) { + $word = implode("",$ar[0]) . "ке"; + } elseif ( in_array($wordLastVowel, $backVowels) ) { + $word = implode("",$ar[0]) . "ка"; + } else { + } + } else { + if ( in_array($wordLastVowel, $frontVowels) ) { + $word = implode("",$ar[0]) . "ге"; + } elseif ( in_array($wordLastVowel, $backVowels) ) { + $word = implode("",$ar[0]) . "га"; + } else { + } + } + break; + case "accusative": + if ( in_array($wordEnding, $unvoicedPhonemes) ) { + if ( in_array($wordLastVowel, $roundFrontVowels) ) { + $word = implode("",$ar[0]) . "тү"; + } elseif ( in_array($wordLastVowel, $unroundFrontVowels) ) { + $word = implode("",$ar[0]) . "ти"; + } elseif ( in_array($wordLastVowel, $roundBackVowels) ) { + $word = implode("",$ar[0]) . "ту"; + } elseif ( in_array($wordLastVowel, $unroundBackVowels) ) { + $word = implode("",$ar[0]) . "ты"; + } else { + } + } elseif ( $wordEnding === "л" || $wordEnding === "l") { + if ( in_array($wordLastVowel, $roundFrontVowels) ) { + $word = implode("",$ar[0]) . "дү"; + } elseif ( in_array($wordLastVowel, $unroundFrontVowels) ) { + $word = implode("",$ar[0]) . "ди"; + } elseif ( in_array($wordLastVowel, $roundBackVowels) ) { + $word = implode("",$ar[0]) . "ду"; + } elseif ( in_array($wordLastVowel, $unroundBackVowels) ) { + $word = implode("",$ar[0]) . "ды"; + } else { + } + } else { + if ( in_array($wordLastVowel, $roundFrontVowels) ) { + $word = implode("",$ar[0]) . "нү"; + } elseif ( in_array($wordLastVowel, $unroundFrontVowels) ) { + $word = implode("",$ar[0]) . "ни"; + } elseif ( in_array($wordLastVowel, $roundBackVowels) ) { + $word = implode("",$ar[0]) . "ну"; + } elseif ( in_array($wordLastVowel, $unroundBackVowels) ) { + $word = implode("",$ar[0]) . "ны"; + } else { + } + } + break; + case "locative": + if ( in_array($wordEnding, $unvoicedPhonemes) ) { + if ( in_array($wordLastVowel, $frontVowels) ) { + $word = implode("",$ar[0]) . "те"; + } elseif ( in_array($wordLastVowel, $backVowels) ) { + $word = implode("",$ar[0]) . "та"; + } else { + } + } else { + if ( in_array($wordLastVowel, $frontVowels) ) { + $word = implode("",$ar[0]) . "де"; + } elseif ( in_array($wordLastVowel, $backVowels) ) { + $word = implode("",$ar[0]) . "да"; + } else { + } + } + break; + case "ablative": + if ( in_array($wordEnding, $unvoicedPhonemes) ) { + if ( in_array($wordLastVowel, $frontVowels) ) { + $word = implode("",$ar[0]) . "тен"; + } elseif ( in_array($wordLastVowel, $backVowels) ) { + $word = implode("",$ar[0]) . "тан"; + } else { + } + } else { + if ( in_array($wordLastVowel, $frontVowels) ) { + $word = implode("",$ar[0]) . "ден"; + } elseif ( in_array($wordLastVowel, $backVowels) ) { + $word = implode("",$ar[0]) . "дан"; + } else { + } + } + break; + case "directive1": + if ( in_array($wordEnding, $directiveVoicedStems) ) { + $word = implode("",$ar[0]) . "же"; + } elseif ( in_array($wordEnding, $directiveUnvoicedStems) ) { + $word = implode("",$ar[0]) . "че"; + } else { + } + break; + case "directive2": + if ( in_array($wordEnding, $unvoicedPhonemes) ) { + if ( in_array($wordLastVowel, $roundFrontVowels) ) { + $word = implode("",$ar[0]) . "түве"; + } elseif ( in_array($wordLastVowel, $unroundFrontVowels) ) { + $word = implode("",$ar[0]) . "тиве"; + } elseif ( in_array($wordLastVowel, $roundBackVowels) ) { + $word = implode("",$ar[0]) . "туве"; + } elseif ( in_array($wordLastVowel, $unroundBackVowels) ) { + $word = implode("",$ar[0]) . "тыве"; + } else { + } + } else { + if ( in_array($wordLastVowel, $roundFrontVowels) ) { + $word = implode("",$ar[0]) . "дүве"; + } elseif ( in_array($wordLastVowel, $unroundFrontVowels) ) { + $word = implode("",$ar[0]) . "диве"; + } elseif ( in_array($wordLastVowel, $roundBackVowels) ) { + $word = implode("",$ar[0]) . "дуве"; + } elseif ( in_array($wordLastVowel, $unroundBackVowels) ) { + $word = implode("",$ar[0]) . "дыве"; + } else { + } + } + break; + default: + break; + } + return $word; + } +} +?>
\ No newline at end of file |