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

65 lines
2.1 KiB
Plaintext

concrete votic of Numerals = {
-- include numerals.Abs.gf ;
param DForm = unit | attr | teen | ten | ten2 ;
param Size = sg | pl ;
oper LinDigit = {s : DForm => Str ; size : Size };
oper LinS100 = {s : Str ; size : Size} ;
oper bind : Str -> Str -> Str = \a -> \b -> a ++ b ;
lincat Numeral = {s : Str} ;
lincat Digit = LinDigit ;
lincat Sub10 = LinDigit ;
lincat Sub100 = LinS100 ;
lincat Sub1000 = LinS100 ;
lincat Sub1000000 = {s : Str} ;
lin num x0 = {s = x0.s} ; -- TODO
oper mkN2 : Str -> LinDigit = \u ->
mkN u u (u + "ts^ümmettä") (u + "ts^ümmet") ;
oper mkN : Str -> Str -> Str -> Str -> LinDigit = \u -> \a -> \t -> \t2 ->
{s = table {unit => u ; attr => a + "sata:"; ten => t ; ten2 => t2 ;
teen => a + tess} ; size = pl} ;
lin n2 = mkN "kahsi" "kahs"
(variants {"kahs^'t's^'ümmettä" ; "kahts^ümmettä"})
(variants {"kahs^'t's^'ümmet" ; "kahts^ümmet"});
lin n3 = mkN "keVLmeV" "keVm" "keVmts^ümmettä" "keVmts^ümmet";
lin n4 = mkN2 "nellä" ;
lin n5 = mkN "vi:si" "vi:s" "vi:s^'t's^'ümmettä" "vi:s^'t's^'ümmet";
lin n6 = mkN "ku:si" "ku:s" "ku:s^'t's^'ümmettä" "ku:s^'t's^'ümmet";
lin n7 = mkN2 "seitse:" ;
lin n8 = mkN2 "kaheVsa:" ;
lin n9 = mkN2 "ühesä:" ;
oper tess : Str = (variants {"teV*s^s^eVmeVtta" ; "teV*is^'t's^'ümmeD"} ) ;
lin pot01 = {s = table {unit => "ühsi" ; attr => "sata" ; _ => "dummy" }; size = sg } ;
oper ss : Str -> LinS100 = \s1 -> {s = s1 ; size = pl } ;
lin pot0 d = d ;
lin pot110 = ss "ts^ümme:" ;
lin pot111 = ss ("ühs" + tess) ;
lin pot1to19 d = ss (d.s ! teen) ;
lin pot0as1 n = {s = n.s ! unit ; size = n.size } ;
lin pot1 d = ss (d.s ! ten) ;
lin pot1plus d e = ss ((d.s ! ten2) ++ (e.s ! unit)) ;
lin pot1as2 n = n ;
lin pot2 d = ss (d.s ! attr) ;
lin pot2plus d e = ss ((d.s ! attr) ++ e.s) ;
lin pot2as3 n =
{s = n.s } ;
lin pot3 n =
{s = selsg (variants {"tuhatta" ; "tuhaD" }) (bind n.s "tuhatta") ! n.size} ;
lin pot3plus n m =
{s = selsg (variants {"tuhatta" ; "tuhaD" }) (bind n.s "tuhatta") ! n.size ++ m.s };
oper selsg : Str -> Str -> Size => Str = \a -> \b ->
table {sg => a ; pl => b} ;
}