return $wgGrammarForms['uk'][$case][$word];
}
- # These rules are not perfect, but they are currently only used for site names so it doesn't
- # matter if they are wrong sometimes. Just add a special case for your site name if necessary.
+ # These rules don't cover the whole language.
+ # They are used only for site names.
# join and array_slice instead mb_substr
$ar = array();
if ( !preg_match( "/[a-zA-Z_]/us", $word ) ) {
switch ( $case ) {
case 'genitive': # родовий відмінок
- if ( ( join( '', array_slice( $ar[0], -4 ) ) == 'вікі' )
- || ( join( '', array_slice( $ar[0], -4 ) ) == 'Вікі' )
- ) {
- } elseif ( join( '', array_slice( $ar[0], -1 ) ) == 'ь' ) {
- $word = join( '', array_slice( $ar[0], 0, -1 ) ) . 'я';
- } elseif ( join( '', array_slice( $ar[0], -2 ) ) == 'ія' ) {
+ if ( join( '', array_slice( $ar[0], -2 ) ) === 'ія' ) {
$word = join( '', array_slice( $ar[0], 0, -2 ) ) . 'ії';
- } elseif ( join( '', array_slice( $ar[0], -2 ) ) == 'ка' ) {
- $word = join( '', array_slice( $ar[0], 0, -2 ) ) . 'ки';
- } elseif ( join( '', array_slice( $ar[0], -2 ) ) == 'ти' ) {
- $word = join( '', array_slice( $ar[0], 0, -2 ) ) . 'тей';
- } elseif ( join( '', array_slice( $ar[0], -2 ) ) == 'ди' ) {
+ } elseif ( join( '', array_slice( $ar[0], -2 ) ) === 'ти' ) {
+ $word = join( '', array_slice( $ar[0], 0, -2 ) ) . 'т';
+ } elseif ( join( '', array_slice( $ar[0], -2 ) ) === 'ди' ) {
$word = join( '', array_slice( $ar[0], 0, -2 ) ) . 'дів';
- } elseif ( join( '', array_slice( $ar[0], -3 ) ) == 'ник' ) {
+ } elseif ( join( '', array_slice( $ar[0], -3 ) ) === 'ник' ) {
$word = join( '', array_slice( $ar[0], 0, -3 ) ) . 'ника';
}
break;
- case 'dative': # давальний відмінок
- # stub
- break;
case 'accusative': # знахідний відмінок
- if ( ( join( '', array_slice( $ar[0], -4 ) ) == 'вікі' )
- || ( join( '', array_slice( $ar[0], -4 ) ) == 'Вікі' )
- ) {
- } elseif ( join( '', array_slice( $ar[0], -2 ) ) == 'ія' ) {
+ if ( join( '', array_slice( $ar[0], -2 ) ) === 'ія' ) {
$word = join( '', array_slice( $ar[0], 0, -2 ) ) . 'ію';
}
break;
- case 'instrumental': # орудний відмінок
- # stub
- break;
- case 'prepositional': # місцевий відмінок
- # stub
- break;
}
}
return $word;
*/
function commafy( $_ ) {
if ( !preg_match( '/^\-?\d{1,4}(\.\d+)?$/', $_ ) ) {
- return strrev( (string)preg_replace( '/(\d{3})(?=\d)(?!\d*\.)/', '$1,', strrev( $_ ) ) );
+ return strrev( (string)preg_replace(
+ '/(\d{3})(?=\d)(?!\d*\.)/',
+ '$1,',
+ strrev( $_ )
+ ) );
} else {
return $_;
}
switch ( form ) {
case 'genitive': // родовий відмінок
if ( word.slice( -4 ) !== 'вікі' && word.slice( -4 ) !== 'Вікі' ) {
- if ( word.slice( -1 ) === 'ь' ) {
- word = word.slice( 0, -1 ) + 'я';
- } else if ( word.slice( -2 ) === 'ія' ) {
+ if ( word.slice( -2 ) === 'ія' ) {
word = word.slice( 0, -2 ) + 'ії';
} else if ( word.slice( -2 ) === 'ка' ) {
word = word.slice( 0, -2 ) + 'ки';
} else if ( word.slice( -2 ) === 'ти' ) {
- word = word.slice( 0, -2 ) + 'тей';
+ word = word.slice( 0, -2 ) + 'т';
} else if ( word.slice( -2 ) === 'ди' ) {
word = word.slice( 0, -2 ) + 'дів';
} else if ( word.slice( -3 ) === 'ник' ) {
],
uk: [
- {
- word: 'тесть',
- grammarForm: 'genitive',
- expected: 'тестя',
- description: 'Grammar test for genitive case'
- },
{
word: 'Вікіпедія',
grammarForm: 'genitive',
description: 'Grammar test for genitive case'
},
{
- word: 'установка',
- grammarForm: 'genitive',
- expected: 'установки',
- description: 'Grammar test for genitive case'
- },
- {
- word: 'похоти',
+ word: 'Віківиди',
grammarForm: 'genitive',
- expected: 'поÑ\85оÑ\82ей',
+ expected: 'Ð\92Ñ\96кÑ\96видÑ\96в',
description: 'Grammar test for genitive case'
},
{
- word: 'Віківиди',
+ word: 'Вікіцитати',
grammarForm: 'genitive',
- expected: 'Віківидів',
+ expected: 'Вікіцитат',
description: 'Grammar test for genitive case'
},
{
- word: 'пеÑ\81Ñ\87аник',
+ word: 'Ð\92Ñ\96кÑ\96пÑ\96дÑ\80Ñ\83Ñ\87ник',
grammarForm: 'genitive',
- expected: 'пеÑ\81Ñ\87аника',
+ expected: 'Ð\92Ñ\96кÑ\96пÑ\96дÑ\80Ñ\83Ñ\87ника',
description: 'Grammar test for genitive case'
},
{