wiki.techinc.nl/includes/languages/LanguageOs.php
Reedy b0b17ce751 Languages: minor cleanup
* Remove unnecessary duplicate documentation
* Code tweaks
* Rename Language::getSerchIndexVariant() to Language::getSearchIndexVariant()

Change-Id: I10d8b9b82e5f781b8c5d9b349827e3b219745083
2023-10-02 13:34:05 +00:00

128 lines
3.8 KiB
PHP
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<?php
/**
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
* http://www.gnu.org/copyleft/gpl.html
*
* @file
* @author Soslan Khubulov
*/
use MediaWiki\MainConfigNames;
use MediaWiki\MediaWikiServices;
/**
* Ossetian (Ирон)
*
* @ingroup Languages
*/
class LanguageOs extends Language {
/**
* Convert from the nominative form of a noun to other cases
* Invoked with {{grammar:case|word}}
*
* Depending on the word, there are four different ways of converting to other cases.
* 1) Words consist of not Cyrillic letters or is an abbreviation.
* Then result word is: word + hyphen + case ending.
*
* 2) Word consist of Cyrillic letters.
* 2.1) Word is in plural.
* Then result word is: word - last letter + case ending. Ending of the allative case here is 'æм'.
*
* 2.2) Word is in singular form.
* 2.2.1) Word ends on consonant.
* Then result word is: word + case ending.
*
* 2.2.2) Word ends on vowel.
* The resultant word is: word + 'й' + case ending for cases != allative or comitative
* and word + case ending for allative or comitative. Ending of the allative case here is 'æ'.
*
* @param string $word
* @param string $case
* @return string
*/
public function convertGrammar( $word, $case ) {
$grammarForms =
MediaWikiServices::getInstance()->getMainConfig()->get( MainConfigNames::GrammarForms );
if ( isset( $grammarForms['os'][$case][$word] ) ) {
return $grammarForms['os'][$case][$word];
}
# Ending for the allative case
$end_allative = 'мæ';
# Variable for 'j' between vowels
$jot = '';
# Variable for "-" for not Ossetic words
$hyphen = '';
# Variable for ending
$ending = '';
# Checking if the $word is in plural form
if ( preg_match( '/тæ$/u', $word ) ) {
$word = mb_substr( $word, 0, -1 );
$end_allative = 'æм';
} elseif ( preg_match( "/[аæеёиоыэюя]$/u", $word ) ) {
# Works if $word is in singular form.
# Checking if $word ends on one of the vowels: е, ё, и, о, ы, э, ю, я.
$jot = 'й';
} elseif ( preg_match( "/у$/u", $word ) ) {
# Checking if $word ends on 'у'. 'У'
# can be either consonant 'W' or vowel 'U' in Cyrillic Ossetic.
# Examples: {{grammar:genitive|аунеу}} = аунеуы, {{grammar:genitive|лæппу}} = лæппуйы.
if ( !preg_match( "/[аæеёиоыэюя]$/u", mb_substr( $word, -2, 1 ) ) ) {
$jot = 'й';
}
} elseif ( !preg_match( "/[бвгджзйклмнопрстфхцчшщьъ]$/u", $word ) ) {
$hyphen = '-';
}
switch ( $case ) {
case 'genitive':
$ending = $hyphen . $jot . 'ы';
break;
case 'dative':
$ending = $hyphen . $jot . 'æн';
break;
case 'allative':
$ending = $hyphen . $end_allative;
break;
case 'ablative':
if ( $jot == 'й' ) {
$ending = $hyphen . $jot . 'æ';
} else {
$ending = $hyphen . $jot . 'æй';
}
break;
case 'inessive':
break;
case 'superessive':
$ending = $hyphen . $jot . 'ыл';
break;
case 'equative':
$ending = $hyphen . $jot . 'ау';
break;
case 'comitative':
$ending = $hyphen . 'имæ';
break;
}
return $word . $ending;
}
}