wiki.techinc.nl/includes/languages/LanguageOs.php
TChin 47adb6d65a Refactor global variables to use MediaWikiServices instead
Automatically refactors wg prefixed globals to use MediaWikiServices config using Rector. Doesn't include files that set globals or files that fail CI.

Rector Gist: https://gist.github.com/tchin25/7cc54f6d23aedef010b22e4dfbead228

* This patch uses a modified source code rector library for our specific use case and the rector will have different effects without it.

A writeup for future reference is here: https://meta.wikimedia.org/wiki/User:TChin_(WMF)/Using_Rector_On_MediaWiki

Change-Id: I1a691f01cd82e60bf41207d32501edb4b9835e37
2022-01-10 13:55:53 -05:00

123 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
/**
* Ossetian (Ирон) specific code.
*
* 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
* @ingroup Language
*/
use MediaWiki\MediaWikiServices;
/**
* Ossetian (Ирон)
*
* @ingroup Language
*/
class LanguageOs extends Language {
/**
* Convert from the nominative form of a noun to other cases
* Invoked with {{grammar:case|word}}
*
* Depending on word there are four different ways of converting to other cases.
* 1) Word 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 allative case here is 'æм'.
*
* 2.2) Word is in singular.
* 2.2.1) Word ends on consonant.
* Then result word is: word + case ending.
*
* 2.2.2) Word ends on vowel.
* Then result word is: word + 'й' + case ending for cases != allative or comitative
* and word + case ending for allative or comitative. Ending of allative case here is 'æ'.
*
* @param string $word
* @param string $case
* @return string
*/
public function convertGrammar( $word, $case ) {
$grammarForms = MediaWikiServices::getInstance()->getMainConfig()->get( 'GrammarForms' );
if ( isset( $grammarForms['os'][$case][$word] ) ) {
return $grammarForms['os'][$case][$word];
}
# Ending for allative case
$end_allative = 'мæ';
# Variable for 'j' beetwen 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;
}
}