Files
gf-core/examples/numerals/lithuanian.gf

62 lines
1.9 KiB
Plaintext

concrete lithuanian of Numerals = {
-- include numerals.Abs.gf ;
-- y:
-- e:
-- i~
-- s^
-- m~
-- n~
-- ú:
-- u,
param Size = sg | pl ;
param DForm = unit | teen | ten ;
oper LinDigit = {s : DForm => Str ; size : Size };
oper LinSub100 = {s : Str ; size : Size } ;
lincat Numeral = { s : Str } ;
lincat Digit = LinDigit ;
lincat Sub10 = LinDigit ;
lincat Sub100 = LinSub100 ;
lincat Sub1000 = LinSub100 ;
lincat Sub1000000 = { s : Str } ;
oper mkNum : Str -> Str -> Str -> LinDigit = \tri -> \dvylika -> \tribase ->
{ s = table {unit => tri ; teen => dvylika ; ten => tribase + "des^imt" } ; size = pl};
lin num x = {s = x.s} ; -- TODO ;
lin n2 = mkNum "dù" "dvýlika" "dvì" ;
lin n3 = mkNum "try:s" "trýlika" "trìs" ;
lin n4 = mkNum "keturì" "keturiólika" "ke:turias" ;
lin n5 = mkNum "penkì" "penkiólika" "pen~kias" ;
lin n6 = mkNum "s^es^ì" "s^es^iólika" "s^e:s^ias" ;
lin n7 = mkNum "septynì" "septyniólika" "septýnias" ;
lin n8 = mkNum "as^tuonì" "as^tuoniólika" "as^túonias" ;
lin n9 = mkNum "devynì" "devyniólika" "devýnias" ;
oper mkR : Str -> LinSub100 = \n -> {s = n ; size = pl } ;
lin pot01 = { s = table {_ => "víenas" } ; size = sg };
lin pot0 d = d ;
lin pot110 = mkR (variants {"de:s^imt"; "des^imtìs" });
lin pot111 = mkR "vienúolika" ;
lin pot1to19 d = mkR (d.s ! teen) ;
lin pot0as1 n = mkR (n.s ! unit) ;
lin pot1 d = mkR (d.s ! ten) ;
lin pot1plus d e = mkR ((d.s ! ten) ++ (e.s ! unit)) ;
lin pot1as2 n = n ;
lin pot2 d = mkR (selsg d.size "s^im~tas" ((d.s ! unit) ++ "s^imtai~")) ;
lin pot2plus d e = mkR ((selsg d.size "s^im~tas" ((d.s ! unit) ++ "s^imtai~")) ++ e.s) ;
lin pot2as3 n = {s = n.s };
lin pot3 n = {s = selsg n.size "tú:kstantis" (n.s ++ "tú:kstanc^iu,") } ;
lin pot3plus n m = {s = (selsg n.size "tú:kstantis" (n.s ++ "tú:kstanc^iu,")) ++ m.s} ;
oper selsg : Size -> Str -> Str -> Str = \sz -> \s1 -> \s2 ->
table {sg => s1 ; pl => s2} ! sz ;
}