mirror of
https://github.com/GrammaticalFramework/gf-core.git
synced 2026-04-11 05:49:31 -06:00
66 lines
2.2 KiB
Plaintext
66 lines
2.2 KiB
Plaintext
concrete tuda_daza of Numerals = {
|
|
-- include numerals.Abs.gf ;
|
|
|
|
param DForm = ten | unit ;
|
|
param Size = sg | sub10 | pl | e10;
|
|
|
|
oper LinDigit = {s : DForm => Str ; s2 : Str ; size : Size} ;
|
|
oper LinS100 = {s : Str ; s2 : Str ; size : Size} ;
|
|
|
|
lincat Numeral = { s : Str } ;
|
|
lincat Digit = LinDigit ;
|
|
lincat Sub10 = LinDigit ;
|
|
lincat Sub100 = LinS100 ;
|
|
lincat Sub1000 = LinS100 ;
|
|
lincat Sub1000000 = {s : Str} ;
|
|
|
|
oper mkNum : Str -> LinDigit = \kunun ->
|
|
{s = table {unit => kunun ; ten => "mOrta" ++ kunun } ;
|
|
s2 = "dubu" ++ kunun ;
|
|
size = sub10} ;
|
|
|
|
lin num x0 =
|
|
{s = x0.s} ; -- TODO
|
|
|
|
-- o.
|
|
-- O for IPA o in Eng. Cod
|
|
|
|
lin n2 = {s = table {unit => "cu" ; ten => "digidem" } ; s2 = "dubu" ++ "cu"; size = sub10} ;
|
|
lin n3 = mkNum "ago.zo." ;
|
|
lin n4 = mkNum "tozo" ;
|
|
lin n5 = mkNum "fo";
|
|
lin n6 = mkNum "dissi" ;
|
|
lin n7 = mkNum (variants {"tuduzu" ; "tudusu"}) ;
|
|
lin n8 = mkNum (variants {"osso" ; "yosso"}) ;
|
|
lin n9 = mkNum "issi";
|
|
|
|
oper olufu : Str = variants {"oluou" ; "olufu"} ;
|
|
oper ss : Str -> Str -> LinS100 = \a -> \b -> {s = a ; s2 = b ; size = pl} ;
|
|
oper ss2 : Str -> Str -> LinS100 = \a -> \b -> {s = a ; s2 = b ; size = e10} ;
|
|
|
|
lin pot01 = {s = table {_ => "tro" }; s2 = "dubu" ; size = sg};
|
|
lin pot0 d = d ;
|
|
lin pot110 = ss2 "mOrdOm" [];
|
|
lin pot111 = ss2 ("mOrdOm" ++ "sao" ++ "tro") ("dubu");
|
|
lin pot1to19 d = ss2 ("mOrdOm" ++ "sao" ++ d.s ! unit) ("dubu" ++ d.s ! unit);
|
|
lin pot0as1 n = {s = n.s ! unit ; s2 = n.s2 ; size = n.size} ;
|
|
lin pot1 d = ss (d.s ! ten) (d.s ! unit) ;
|
|
lin pot1plus d e = ss (d.s ! ten ++ "sao" ++ e.s ! unit) (d.s ! unit ++ e.s2) ;
|
|
lin pot1as2 n = {s = n.s ; s2 = ifsub10 n.s2 ! n.size ; size = n.size };
|
|
lin pot2 d = ss (selsg "kidri" ("kidra" ++ d.s ! unit) ! d.size)
|
|
(olufu ++ d.s ! ten) ;
|
|
lin pot2plus d e =
|
|
ss (selsg "kidri" ("kidra" ++ d.s ! unit) ! d.size ++ "sao" ++ e.s)
|
|
(olufu ++ d.s ! ten ++ "sao" ++ ifs10 ! e.size ++ e.s2) ;
|
|
lin pot2as3 n = {s = n.s} ;
|
|
lin pot3 n = {s = n.s2};
|
|
lin pot3plus n m = {s = n.s2 ++ "sao" ++ m.s};
|
|
|
|
oper ifs10 : Size => Str = table {e10 => "tro" ; _ => []} ;
|
|
oper ifsub10 : Str -> Size => Str = \a ->
|
|
table {pl => olufu ++ a; e10 => olufu ++ a ; _ => a } ;
|
|
oper selsg : Str -> Str -> Size => Str = \a -> \b ->
|
|
table {sg => a ; _ => b} ;
|
|
|
|
}
|