aboutsummaryrefslogtreecommitdiffstats
path: root/includes/languages/LanguageOs.php
diff options
context:
space:
mode:
authorTimo Tijhof <krinklemail@gmail.com>2021-07-31 22:23:21 +0100
committerTimo Tijhof <krinklemail@gmail.com>2021-08-04 23:44:46 +0100
commit7c39f764520f60109dedbcb904fe8327aa5ddedb (patch)
tree9e99e5a055f7a97f4cde265ecb90cb45f0bb3ab4 /includes/languages/LanguageOs.php
parentdef349289f899f9f8e3884cc79dc2751997b09d1 (diff)
downloadmediawikicore-7c39f764520f60109dedbcb904fe8327aa5ddedb.tar.gz
mediawikicore-7c39f764520f60109dedbcb904fe8327aa5ddedb.zip
Move Language subclasses to includes/
Depending on which namespace we want these classes to have after T166010 they could either stay in includes/languages/ (plural) in their own MediaWiki\Languages\-namespace dedicated to Language subclasses, or they could go in into a subdirectory like `includes/language/languages/` if we want to keep them in the same top-level namespace as other Language classes and services, but in a more nested namespace. For now, I've made the smaller change and kept the Language subclasses in their own directory directly under includes/, not nested further. Bug: T225756 Change-Id: I01015424707b442853879fd50c97f00215e5c2fa
Diffstat (limited to 'includes/languages/LanguageOs.php')
-rw-r--r--includes/languages/LanguageOs.php120
1 files changed, 120 insertions, 0 deletions
diff --git a/includes/languages/LanguageOs.php b/includes/languages/LanguageOs.php
new file mode 100644
index 000000000000..16ab0d43777d
--- /dev/null
+++ b/includes/languages/LanguageOs.php
@@ -0,0 +1,120 @@
+<?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
+ */
+
+/**
+ * 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 ) {
+ global $wgGrammarForms;
+ if ( isset( $wgGrammarForms['os'][$case][$word] ) ) {
+ return $wgGrammarForms['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;
+ }
+}