tweb-i2p/src/lib/pluralPolyfill.ts
2021-04-08 17:52:31 +04:00

377 lines
13 KiB
TypeScript

/*
* https://github.com/morethanwords/tweb
* Copyright (C) 2019-2021 Eduard Kuzmenko
* https://github.com/morethanwords/tweb/blob/master/LICENSE
*/
const NumberPluralizationFormZero: Intl.LDMLPluralRule = 'zero';
const NumberPluralizationFormOne: Intl.LDMLPluralRule = 'one';
const NumberPluralizationFormTwo: Intl.LDMLPluralRule = 'two';
const NumberPluralizationFormFew: Intl.LDMLPluralRule = 'few';
const NumberPluralizationFormMany: Intl.LDMLPluralRule = 'many';
const NumberPluralizationFormOther: Intl.LDMLPluralRule = 'other';
function numberPluralizationForm(lc: number, n: number): Intl.LDMLPluralRule {
switch (lc) {
// set1
case 0x6c74: // lt
if (((n % 10) == 1) && (((n % 100) < 11 || (n % 100) > 19))) // n mod 10 is 1 and n mod 100 not in 11..19
return NumberPluralizationFormOne;
if ((((n % 10) >= 2 && (n % 10) <= 9)) && (((n % 100) < 11 || (n % 100) > 19))) // n mod 10 in 2..9 and n mod 100 not in 11..19
return NumberPluralizationFormFew;
break;
// set2
case 0x6c76: // lv
if (n == 0) // n is 0
return NumberPluralizationFormZero;
if (((n % 10) == 1) && ((n % 100) != 11)) // n mod 10 is 1 and n mod 100 is not 11
return NumberPluralizationFormOne;
break;
// set3
case 0x6379: // cy
if (n == 2) // n is 2
return NumberPluralizationFormTwo;
if (n == 3) // n is 3
return NumberPluralizationFormFew;
if (n == 0) // n is 0
return NumberPluralizationFormZero;
if (n == 1) // n is 1
return NumberPluralizationFormOne;
if (n == 6) // n is 6
return NumberPluralizationFormMany;
break;
// set4
case 0x6265: // be
case 0x6273: // bs
case 0x6872: // hr
case 0x7275: // ru
case 0x7368: // sh
case 0x7372: // sr
case 0x756b: // uk
if (((n % 10) == 1) && ((n % 100) != 11)) // n mod 10 is 1 and n mod 100 is not 11
return NumberPluralizationFormOne;
if ((((n % 10) >= 2 && (n % 10) <= 4)) && (((n % 100) < 12 || (n % 100) > 14))) // n mod 10 in 2..4 and n mod 100 not in 12..14
return NumberPluralizationFormFew;
if (((n % 10) == 0) || (((n % 10) >= 5 && (n % 10) <= 9)) || (((n % 100) >= 11 && (n % 100) <= 14))) // n mod 10 is 0 or n mod 10 in 5..9 or n mod 100 in 11..14
return NumberPluralizationFormMany;
break;
// set5
case 0x6b7368: // ksh
if (n == 0) // n is 0
return NumberPluralizationFormZero;
if (n == 1) // n is 1
return NumberPluralizationFormOne;
break;
// set6
case 0x736869: // shi
if ((n >= 2 && n <= 10)) // n in 2..10
return NumberPluralizationFormFew;
if ((n >= 0 && n <= 1)) // n within 0..1
return NumberPluralizationFormOne;
break;
// set7
case 0x6865: // he
if (n == 2) // n is 2
return NumberPluralizationFormTwo;
if (n == 1) // n is 1
return NumberPluralizationFormOne;
if ((n != 0) && ((n % 10) == 0)) // n is not 0 AND n mod 10 is 0
return NumberPluralizationFormMany;
break;
// set8
case 0x6373: // cs
case 0x736b: // sk
if (n == 1) // n is 1
return NumberPluralizationFormOne;
if ((n >= 2 && n <= 4)) // n in 2..4
return NumberPluralizationFormFew;
break;
// set9
case 0x6272: // br
if ((n != 0) && ((n % 1000000) == 0)) // n is not 0 and n mod 1000000 is 0
return NumberPluralizationFormMany;
if (((n % 10) == 1) && (((n % 100) != 11) && ((n % 100) != 71) && ((n % 100) != 91))) // n mod 10 is 1 and n mod 100 not in 11,71,91
return NumberPluralizationFormOne;
if (((n % 10) == 2) && (((n % 100) != 12) && ((n % 100) != 72) && ((n % 100) != 92))) // n mod 10 is 2 and n mod 100 not in 12,72,92
return NumberPluralizationFormTwo;
if ((((n % 10) >= 3 && (n % 10) <= 4) || ((n % 10) == 9)) && (((n % 100) < 10 || (n % 100) > 19) && ((n % 100) < 70 || (n % 100) > 79) && ((n % 100) < 90 || (n % 100) > 99))) // n mod 10 in 3..4,9 and n mod 100 not in 10..19,70..79,90..99
return NumberPluralizationFormFew;
break;
// set10
case 0x736c: // sl
if ((n % 100) == 2) // n mod 100 is 2
return NumberPluralizationFormTwo;
if ((n % 100) == 1) // n mod 100 is 1
return NumberPluralizationFormOne;
if (((n % 100) >= 3 && (n % 100) <= 4)) // n mod 100 in 3..4
return NumberPluralizationFormFew;
break;
// set11
case 0x6c6167: // lag
if (n == 0) // n is 0
return NumberPluralizationFormZero;
if (((n >= 0 && n <= 2)) && (n != 0) && (n != 2)) // n within 0..2 and n is not 0 and n is not 2
return NumberPluralizationFormOne;
break;
// set12
case 0x706c: // pl
if (n == 1) // n is 1
return NumberPluralizationFormOne;
if ((((n % 10) >= 2 && (n % 10) <= 4)) && (((n % 100) < 12 || (n % 100) > 14))) // n mod 10 in 2..4 and n mod 100 not in 12..14
return NumberPluralizationFormFew;
if (((n != 1) && (((n % 10) >= 0 && (n % 10) <= 1))) || (((n % 10) >= 5 && (n % 10) <= 9)) || (((n % 100) >= 12 && (n % 100) <= 14))) // n is not 1 and n mod 10 in 0..1 or n mod 10 in 5..9 or n mod 100 in 12..14
return NumberPluralizationFormMany;
break;
// set13
case 0x6764: // gd
if ((n == 2) || (n == 12)) // n in 2,12
return NumberPluralizationFormTwo;
if ((n == 1) || (n == 11)) // n in 1,11
return NumberPluralizationFormOne;
if ((n >= 3 && n <= 10) || (n >= 13 && n <= 19)) // n in 3..10,13..19
return NumberPluralizationFormFew;
break;
// set14
case 0x6776: // gv
if ((((n % 10) >= 1 && (n % 10) <= 2)) || ((n % 20) == 0)) // n mod 10 in 1..2 or n mod 20 is 0
return NumberPluralizationFormOne;
break;
// set15
case 0x6d6b: // mk
if (((n % 10) == 1) && (n != 11)) // n mod 10 is 1 and n is not 11
return NumberPluralizationFormOne;
break;
// set16
case 0x6d74: // mt
if (n == 1) // n is 1
return NumberPluralizationFormOne;
if (((n % 100) >= 11 && (n % 100) <= 19)) // n mod 100 in 11..19
return NumberPluralizationFormMany;
if ((n == 0) || (((n % 100) >= 2 && (n % 100) <= 10))) // n is 0 or n mod 100 in 2..10
return NumberPluralizationFormFew;
break;
// set17
case 0x6d6f: // mo
case 0x726f: // ro
if (n == 1) // n is 1
return NumberPluralizationFormOne;
if ((n == 0) || ((n != 1) && (((n % 100) >= 1 && (n % 100) <= 19)))) // n is 0 OR n is not 1 AND n mod 100 in 1..19
return NumberPluralizationFormFew;
break;
// set18
case 0x6761: // ga
if (n == 2) // n is 2
return NumberPluralizationFormTwo;
if (n == 1) // n is 1
return NumberPluralizationFormOne;
if ((n >= 3 && n <= 6)) // n in 3..6
return NumberPluralizationFormFew;
if ((n >= 7 && n <= 10)) // n in 7..10
return NumberPluralizationFormMany;
break;
// set19
case 0x6666: // ff
case 0x6672: // fr
case 0x6b6162: // kab
if (((n >= 0 && n <= 2)) && (n != 2)) // n within 0..2 and n is not 2
return NumberPluralizationFormOne;
break;
// set20
case 0x6975: // iuw
case 0x6b77: // kw
case 0x7365: // se
case 0x6e6171: // naq
case 0x736d61: // sma
case 0x736d69: // smi
case 0x736d6a: // smj
case 0x736d6e: // smn
case 0x736d73: // sms
if (n == 2) // n is 2
return NumberPluralizationFormTwo;
if (n == 1) // n is 1
return NumberPluralizationFormOne;
break;
// set21
case 0x616b: // ak
case 0x616d: // am
case 0x6268: // bh
case 0x6869: // hi
case 0x6c6e: // ln
case 0x6d67: // mg
case 0x7469: // ti
case 0x746c: // tl
case 0x7761: // wa
case 0x66696c: // fil
case 0x677577: // guw
case 0x6e736f: // nso
if ((n >= 0 && n <= 1)) // n in 0..1
return NumberPluralizationFormOne;
break;
// set22
case 0x747a6d: // tzm
if (((n >= 0 && n <= 1)) || ((n >= 11 && n <= 99))) // n in 0..1 or n in 11..99
return NumberPluralizationFormOne;
break;
// set23
case 0x6166: // af
case 0x6267: // bg
case 0x626e: // bn
case 0x6361: // ca
case 0x6461: // da
case 0x6465: // de
case 0x6476: // dv
case 0x6565: // ee
case 0x656c: // el
case 0x656e: // en
case 0x656f: // eo
case 0x6573: // es
case 0x6574: // et
case 0x6575: // eu
case 0x6669: // fi
case 0x666f: // fo
case 0x6679: // fy
case 0x676c: // gl
case 0x6775: // gu
case 0x6861: // ha
case 0x6973: // is
case 0x6974: // it
case 0x6b6b: // kk
case 0x6b6c: // kl
case 0x6b73: // ks
case 0x6b75: // ku
case 0x6b79: // ky
case 0x6c62: // lb
case 0x6c67: // lg
case 0x6d6c: // ml
case 0x6d6e: // mn
case 0x6d72: // mr
case 0x6e62: // nb
case 0x6e64: // nd
case 0x6e65: // ne
case 0x6e6c: // nl
case 0x6e6e: // nn
case 0x6e6f: // no
case 0x6e72: // nr
case 0x6e79: // ny
case 0x6f6d: // om
case 0x6f72: // or
case 0x6f73: // os
case 0x7061: // pa
case 0x7073: // ps
case 0x7074: // pt
case 0x726d: // rm
case 0x736e: // sn
case 0x736f: // so
case 0x7371: // sq
case 0x7373: // ss
case 0x7374: // st
case 0x7376: // sv
case 0x7377: // sw
case 0x7461: // ta
case 0x7465: // te
case 0x746b: // tk
case 0x746e: // tn
case 0x7473: // ts
case 0x7572: // ur
case 0x7665: // ve
case 0x766f: // vo
case 0x7868: // xh
case 0x7a75: // zu
case 0x617361: // asa
case 0x617374: // ast
case 0x62656d: // bem
case 0x62657a: // bez
case 0x627278: // brx
case 0x636767: // cgg
case 0x636872: // chr
case 0x636b62: // ckb
case 0x667572: // fur
case 0x677377: // gsw
case 0x686177: // haw
case 0x6a676f: // jgo
case 0x6a6d63: // jmc
case 0x6b616a: // kaj
case 0x6b6367: // kcg
case 0x6b6b6a: // kkj
case 0x6b7362: // ksb
case 0x6d6173: // mas
case 0x6d676f: // mgo
case 0x6e6168: // nah
case 0x6e6e68: // nnh
case 0x6e796e: // nyn
case 0x706170: // pap
case 0x726f66: // rof
case 0x72776b: // rwk
case 0x736171: // saq
case 0x736568: // seh
case 0x737379: // ssy
case 0x737972: // syr
case 0x74656f: // teo
case 0x746967: // tig
case 0x76756e: // vun
case 0x776165: // wae
case 0x786f67: // xog
if (n == 1) // n is 1
return NumberPluralizationFormOne;
break;
// set24
case 0x6172: // ar
if (n == 2) // n is 2
return NumberPluralizationFormTwo;
if (n == 1) // n is 1
return NumberPluralizationFormOne;
if (n == 0) // n is 0
return NumberPluralizationFormZero;
if (((n % 100) >= 3 && (n % 100) <= 10)) // n mod 100 in 3..10
return NumberPluralizationFormFew;
if (((n % 100) >= 11 && (n % 100) <= 99)) // n mod 100 in 11..99
return NumberPluralizationFormMany;
break;
}
return NumberPluralizationFormOther;
}
function languageCodehash(code: string) {
let lc = 0;
for(let i = 0; i < code.length; ++i) { lc = (lc << 8) + code.charCodeAt(i); }
return lc;
}
const Intl = {
PluralRules: class {
public select: (n: number) => Intl.LDMLPluralRule;
constructor(code: string) {
this.select = numberPluralizationForm.bind(null, languageCodehash(code));
}
}
};
export default Intl;