From 9ac1c108801a5144f43a8d2fc3de4d2c3d0a836c Mon Sep 17 00:00:00 2001 From: wapmorgan <wapmorgan@gmail.com> Date: Sat, 28 Nov 2020 23:05:55 +0300 Subject: [PATCH] =?UTF-8?q?=D0=A4=D0=B8=D0=BA=D1=81=20=D1=81=D0=BA=D0=BB?= =?UTF-8?q?=D0=BE=D0=BD=D0=B5=D0=BD=D0=B8=D1=8F=20=D1=81=D0=BB=D0=BE=D0=B2?= =?UTF-8?q?=20=D0=BD=D0=B0=20-=D0=B4=D1=8C:=20=D0=B3=D0=B2=D0=BE=D0=B7?= =?UTF-8?q?=D0=B4=D1=8C,=20=D0=BB=D0=BE=D1=88=D0=B0=D0=B4=D1=8C.=20fix=20#?= =?UTF-8?q?95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/Russian/NounDeclension.php | 5 ----- src/Russian/NounPluralization.php | 8 ++++---- tests/Russian/NounPluralizationTest.php | 3 ++- 3 files changed, 6 insertions(+), 10 deletions(-) diff --git a/src/Russian/NounDeclension.php b/src/Russian/NounDeclension.php index b0d859b..f1d62ce 100644 --- a/src/Russian/NounDeclension.php +++ b/src/Russian/NounDeclension.php @@ -108,11 +108,6 @@ class NounDeclension extends BaseInflection implements Cases, Gender 'ячмень', ]; - /** @var string[] */ - protected static $masculineWithSoftAndRunAwayVowels = [ - 'санузел', - ]; - /** @var string[] */ public static $runawayVowelsExceptions = [ 'глото*к', diff --git a/src/Russian/NounPluralization.php b/src/Russian/NounPluralization.php index 985bae4..ef1c4b0 100644 --- a/src/Russian/NounPluralization.php +++ b/src/Russian/NounPluralization.php @@ -186,13 +186,13 @@ protected static function declinateSubstative($word, $animateness) } elseif ($declension == NounDeclension::FIRST_DECLENSION) { $soft_last = static::checkLastConsonantSoftness($word); } else { - $soft_last = in_array(S::slice($word, -2), ['чь', 'сь', 'ть', 'нь'], true); + $soft_last = in_array(S::slice($word, -2), ['чь', 'сь', 'ть', 'нь', 'дь'], true); } $forms = []; if (in_array($last, ['ч', 'г'], true) - || in_array(S::slice($word, -2), ['чь', 'сь', 'ть', 'нь', 'рь'], true) + || in_array(S::slice($word, -2), ['чь', 'сь', 'ть', 'нь', 'рь', 'дь'], true) || (static::isVowel($last) && in_array(S::slice($word, -2, -1), ['ч', 'к'], true))) { // before ч, чь, сь, ч+vowel, к+vowel $forms[Cases::IMENIT] = $prefix.'и'; } elseif (in_array($last, ['н', 'ц', 'р', 'т'], true)) { @@ -225,7 +225,7 @@ protected static function declinateSubstative($word, $animateness) $forms[Cases::RODIT] = $prefix; } elseif (in_array($last, ['я'], true)) { // молния $forms[Cases::RODIT] = $prefix.'й'; - } elseif (RussianLanguage::isHissingConsonant($last) || ($soft_last && $last != 'й') || in_array(S::slice($word, -2), ['чь', 'сь', 'ть', 'нь'], true)) { + } elseif (RussianLanguage::isHissingConsonant($last) || ($soft_last && $last != 'й') || in_array(S::slice($word, -2), ['чь', 'сь', 'ть', 'нь', 'дь'], true)) { $forms[Cases::RODIT] = $prefix.'ей'; } elseif ($last == 'й' || S::slice($word, -2) == 'яц') { // месяц $forms[Cases::RODIT] = $prefix.'ев'; @@ -241,7 +241,7 @@ protected static function declinateSubstative($word, $animateness) // TVORIT // my personal rule - if ($last == 'ь' && $declension == NounDeclension::THIRD_DECLENSION && !in_array(S::slice($word, -2), ['чь', 'сь', 'ть', 'нь'], true)) { + if ($last == 'ь' && $declension == NounDeclension::THIRD_DECLENSION && !in_array(S::slice($word, -2), ['чь', 'сь', 'ть', 'нь', 'дь'], true)) { $forms[Cases::TVORIT] = $prefix.'ми'; } else { $forms[Cases::TVORIT] = static::chooseVowelAfterConsonant($last, $soft_last && S::slice($word, -2, -1) != 'ч', $prefix.'ями', $prefix.'ами'); diff --git a/tests/Russian/NounPluralizationTest.php b/tests/Russian/NounPluralizationTest.php index d2822d1..ba08b6f 100644 --- a/tests/Russian/NounPluralizationTest.php +++ b/tests/Russian/NounPluralizationTest.php @@ -118,7 +118,7 @@ public function pluralWordsProvider() ['поле', false, ['поля', 'полей', 'полям', 'поля', 'полями', 'полях']], ['ночь', false, ['ночи', 'ночей', 'ночам', 'ночи', 'ночами', 'ночах']], ['кирпич', false, ['кирпичи', 'кирпичей', 'кирпичам', 'кирпичи', 'кирпичами', 'кирпичах']], - ['гвоздь', false, ['гвоздя', 'гвоздей', 'гвоздям', 'гвоздя', 'гвоздями', 'гвоздях']], + ['гвоздь', false, ['гвозди', 'гвоздей', 'гвоздям', 'гвозди', 'гвоздями', 'гвоздях']], ['молния', false, ['молния', 'молний', 'молниям', 'молния', 'молниями', 'молниях']], ['тысяча', false, ['тысячи', 'тысяч', 'тысячам', 'тысячи', 'тысячами', 'тысячах']], ['сообщение', false, ['сообщения', 'сообщений', 'сообщениям', 'сообщения', 'сообщениями', 'сообщениях']], @@ -128,6 +128,7 @@ public function pluralWordsProvider() ['фабрика', false, ['фабрики', 'фабрик', 'фабрикам', 'фабрики', 'фабриками', 'фабриках']], ['гений', true, ['гения', 'гениев', 'гениям', 'гениев', 'гениями', 'гениях']], ['библиотекарь', true, ['библиотекари', 'библиотекарей', 'библиотекарям', 'библиотекарей', 'библиотекарями', 'библиотекарях']], + ['лошадь', false, ['лошади', 'лошадей', 'лошадям', 'лошади', 'лошадями', 'лошадях']], ['копейка', false, ['копейки', 'копеек', 'копейкам', 'копейки', 'копейками', 'копейках']], ['батарейка', false, ['батарейки', 'батареек', 'батарейкам', 'батарейки', 'батарейками', 'батарейках']],