Skip to content

Commit

Permalink
Фикс склонения слов на -дь: гвоздь, лошадь. fix #95
Browse files Browse the repository at this point in the history
  • Loading branch information
wapmorgan committed Nov 28, 2020
1 parent becd604 commit 9ac1c10
Show file tree
Hide file tree
Showing 3 changed files with 6 additions and 10 deletions.
5 changes: 0 additions & 5 deletions src/Russian/NounDeclension.php
Original file line number Diff line number Diff line change
Expand Up @@ -108,11 +108,6 @@ class NounDeclension extends BaseInflection implements Cases, Gender
'ячмень',
];

/** @var string[] */
protected static $masculineWithSoftAndRunAwayVowels = [
'санузел',
];

/** @var string[] */
public static $runawayVowelsExceptions = [
'глото*к',
Expand Down
8 changes: 4 additions & 4 deletions src/Russian/NounPluralization.php
Original file line number Diff line number Diff line change
Expand Up @@ -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)) {
Expand Down Expand Up @@ -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.'ев';
Expand All @@ -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.'ами');
Expand Down
3 changes: 2 additions & 1 deletion tests/Russian/NounPluralizationTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -118,7 +118,7 @@ public function pluralWordsProvider()
['поле', false, ['поля', 'полей', 'полям', 'поля', 'полями', 'полях']],
['ночь', false, ['ночи', 'ночей', 'ночам', 'ночи', 'ночами', 'ночах']],
['кирпич', false, ['кирпичи', 'кирпичей', 'кирпичам', 'кирпичи', 'кирпичами', 'кирпичах']],
['гвоздь', false, ['гвоздя', 'гвоздей', 'гвоздям', 'гвоздя', 'гвоздями', 'гвоздях']],
['гвоздь', false, ['гвозди', 'гвоздей', 'гвоздям', 'гвозди', 'гвоздями', 'гвоздях']],
['молния', false, ['молния', 'молний', 'молниям', 'молния', 'молниями', 'молниях']],
['тысяча', false, ['тысячи', 'тысяч', 'тысячам', 'тысячи', 'тысячами', 'тысячах']],
['сообщение', false, ['сообщения', 'сообщений', 'сообщениям', 'сообщения', 'сообщениями', 'сообщениях']],
Expand All @@ -128,6 +128,7 @@ public function pluralWordsProvider()
['фабрика', false, ['фабрики', 'фабрик', 'фабрикам', 'фабрики', 'фабриками', 'фабриках']],
['гений', true, ['гения', 'гениев', 'гениям', 'гениев', 'гениями', 'гениях']],
['библиотекарь', true, ['библиотекари', 'библиотекарей', 'библиотекарям', 'библиотекарей', 'библиотекарями', 'библиотекарях']],
['лошадь', false, ['лошади', 'лошадей', 'лошадям', 'лошади', 'лошадями', 'лошадях']],

['копейка', false, ['копейки', 'копеек', 'копейкам', 'копейки', 'копейками', 'копейках']],
['батарейка', false, ['батарейки', 'батареек', 'батарейкам', 'батарейки', 'батарейками', 'батарейках']],
Expand Down

0 comments on commit 9ac1c10

Please sign in to comment.