diff options
Diffstat (limited to 'old-examples/numerals/kawaiisu.gf')
| -rw-r--r-- | old-examples/numerals/kawaiisu.gf | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/old-examples/numerals/kawaiisu.gf b/old-examples/numerals/kawaiisu.gf new file mode 100644 index 000000000..5e45a4eb6 --- /dev/null +++ b/old-examples/numerals/kawaiisu.gf @@ -0,0 +1,41 @@ +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 ; |
