summaryrefslogtreecommitdiff
path: root/old-examples/numerals/kawaiisu.gf
diff options
context:
space:
mode:
Diffstat (limited to 'old-examples/numerals/kawaiisu.gf')
-rw-r--r--old-examples/numerals/kawaiisu.gf41
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 ;