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

45 lines
1.3 KiB
Plaintext

concrete kawaiisu of Numerals = {
-- include numerals.Abs.gf ;
oper bind : Str -> Str -> Str = \a -> \b -> a ++ b ;
oper na : {s : Str } = {s = "N/A" } ;
oper LinDigit = {s : Str ; s2 : Str ; s3 : Str} ;
lincat Numeral = {s : Str} ;
lincat Digit = LinDigit ;
lincat Sub10 = LinDigit ;
lincat Sub100 = {s : Str } ;
lincat Sub1000 = {s : Str } ;
lincat Sub1000000 = {s : Str} ;
lin num x0 =
{s = x0.s} ; -- TODO
oper mkNum : Str -> LinDigit = \s1 -> {s = s1 ; s2 = s1 + "yu" ; s3 = s1 + "suu"} ;
oper mkNum2 : Str -> LinDigit = \s1 -> {s = s1 ; s2 = s1 + "yu" ; s3 = s1 + "cuu"} ;
lin n2 = mkNum "waha" ;
lin n3 = mkNum "pehe" ;
lin n4 = mkNum "wacuu" ;
lin n5 = mkNum2 "mani-gi" ;
lin n6 = mkNum2 "navaha" ;
lin n7 = {s = "no?mi-zi" ; s2 = "no?mi-zi" ; s3 = "no?mi-zicuu" };
lin n8 = {s = "nanawacuu" ; s2 = "nanawacuu"; s3 = "nanawacuucuu" };
lin n9 = mkNum2 "sukumi-su" ;
lin pot01 = mkNum "suu" ;
lin pot0 d = d ;
lin pot110 = {s = "mi-mi-suuyu" } ;
lin pot111 = {s = "mi-mi-susuuyu" } ;
lin pot1to19 d = {s = bind "mi-mi-susuu" d.s2 } ;
lin pot0as1 n = {s = n.s } ;
lin pot1 d = {s = bind d.s3 "yu"} ;
lin pot1plus d e = {s = bind d.s3 e.s2 } ;
lin pot1as2 n = n ;
lin pot2 d = na ;
lin pot2plus d e = na ;
lin pot2as3 n = n ;
lin pot3 n = na ;
lin pot3plus n m = na ;
}