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, ['батарейки', 'батареек', 'батарейкам', 'батарейки', 'батарейками', 'батарейках']],