diff options
| author | aarne <unknown> | 2004-01-29 12:57:32 +0000 |
|---|---|---|
| committer | aarne <unknown> | 2004-01-29 12:57:32 +0000 |
| commit | d09777a9aaeb580d8e793ad5e572296eb4c351d9 (patch) | |
| tree | 8e6d54d1687bdc772cd67d91d643f246ce023776 /examples/numerals/welsh.gf | |
| parent | fdddeca0d08ba68b564b14359ef9b4a697cdb636 (diff) | |
New order among numerals.
Diffstat (limited to 'examples/numerals/welsh.gf')
| -rw-r--r-- | examples/numerals/welsh.gf | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/examples/numerals/welsh.gf b/examples/numerals/welsh.gf new file mode 100644 index 000000000..54a2ca640 --- /dev/null +++ b/examples/numerals/welsh.gf @@ -0,0 +1,71 @@ +include numerals.Abs.gf ;
+
+-- The neo-base-10 system dauddeg, trideg, pedwardeg, pumdeg/hanner cant, chwedeg, saithdeg, wythdeg, nawdeg is
+-- implemented as the second variant as it should be
+
+oper LinDigit = {s : DForm => Str ; even20 : Even20 ; size : Size} ;
+oper LinSub100 = {s : Str ; size : Size} ;
+
+oper mk20Ten : Str -> Str -> Str -> Str -> Size -> LinDigit =
+ \tri -> \trideg -> \fiche -> \triarddeg -> \sz ->
+ { s = table {unit => tri ; twenty => fiche ; teen => triarddeg ; ten => trideg} ; even20 = odd ; size = sz} ;
+
+oper mkEven20 : Str -> Str -> Str -> Str -> Size -> LinDigit =
+ \tri -> \trideg -> \fiche -> \triarddeg -> \sz ->
+ { s = table {unit => tri ; twenty => fiche ; teen => triarddeg ; ten => trideg} ; even20 = even ; size = sz} ;
+
+param Even20 = odd | even ;
+param DForm = unit | ten | twenty | teen ;
+param Size = sg | mutation | am | pl | five | overten;
+
+lincat Numeral = {s : Str} ;
+lincat Digit = LinDigit ;
+lincat Sub10 = LinDigit ;
+lincat Sub100 = LinSub100 ;
+lincat Sub1000 = LinSub100 ;
+lincat Sub1000000 = {s : Str} ;
+lin num x0 =
+ {s = x0.s} ;
+lin n2 = mkEven20 "dau" "dauddeg" "hugain" "deuddeg" mutation ;
+lin n3 = mk20Ten "tri" "trideg" "hugain" ("tri" ++ "ar" ++ "deg") am ;
+lin n4 = mkEven20 "pedwar" "pedwardeg" "deugain" ("pedwar" ++ "ar" ++ "ddeg") pl ;
+lin n5 = mk20Ten ("pum" + p) "pumdeg" "deugain" "pymtheg" five ;
+lin n6 = mkEven20 ("chwe" + ch) "chwedeg" "trigain" ("un" ++ "ar" ++ "bymtheg") am ;
+lin n7 = mk20Ten "saith" "saithdeg" "trigain" ("dau" ++ "ar" ++ "bymtheg") pl ;
+lin n8 = mkEven20 "wyth" "wythdeg" ("pedwar" ++ "ugain") "deunaw" pl ;
+lin n9 = mk20Ten "naw" "nawdeg" ("pedwar" ++ "ugain") ("pedwar" ++ "ar" ++ "bymtheg") pl ;
+oper AR : Str = pre {"ar" ; "a" / strs {"d"} } ;
+oper AG : Str = pre {"a" ; "ag" / strs {"a" ; "u" ; "i" ; "e" ; "o" ; "w"} } ; -- before vowel
+oper ng : Str = pre {"g" ; "ng" / strs {"m"} } ;
+oper t : Str = pre {[] ; "t" / strs {[]}} ;
+oper ch : Str = pre {[] ; "ch" / strs{[]}} ;
+oper p : Str = pre {[] ; "p" / strs{[]}} ;
+
+oper mkR : Str -> LinSub100 = \s1 -> {s = s1 ; size = overten } ;
+oper mkR2 : Str -> Size -> LinSub100 = \s1 -> \sz -> {s = s1 ; size = table {mutation => mutation ; am => am ; _ => overten} ! sz } ;
+
+lin pot01 =
+ {s = table {unit => "un" ; _ => "dummy"} ; even20 = odd ; size = sg};
+lin pot0 d = d ;
+lin pot110 = {s = "de" + ng ; size = pl} ;
+lin pot111 = mkR (variants {"un" ++ "ar" ++ "ddeg" ; "undeg" ++ "un"}) ;
+lin pot1to19 d = mkR (variants {d.s ! teen ; "undeg" ++ d.s ! unit}) ;
+lin pot0as1 n = {s = n.s ! unit ; size = n.size} ;
+lin pot1 d = table {mutation => mkR (variants {"ugain" ; "dauddeg" }) ;
+ five => mkR (variants {"hanner" ++ "cant" ; "deg" ++ "a" + "deugain" ; "pumdeg"}) ;
+ _ => mkR (variants { table {even => d.s ! twenty ; odd => "deg" ++ AR ++ d.s ! twenty} ! d.even20 ; d.s ! ten}) } ! d.size ;
+lin pot1plus d e = mkR2 (variants { table {even => e.s ! unit ++ AR ++ d.s ! twenty ; odd => e.s ! teen ++ AR ++ d.s ! twenty} ! d.even20 ; d.s ! ten}) e.size ; -- hugain
+lin pot1as2 n = n ;
+lin pot2 d = mkR ((CANT (d.s ! unit)) ! d.size) ; +lin pot2plus d e = mkR2 (((CANT (d.s ! unit)) ! d.size) ++ (maybeAG ! e.size) ++ e.s) e.size;
+lin pot2as3 n =
+ {s = n.s } ;
+lin pot3 n =
+ {s = (MIL n.s) ! n.size } ;
+lin pot3plus n m =
+ {s = (MIL n.s) ! n.size ++ m.s } ;
+
+oper maybeAG : Size => Str = (table {overten => [] ; _ => AG} );
+oper CANT : Str -> Size => Str = \s1 -> table {sg => "can" + t ; mutation => s1 ++ "gan" + t; am => s1 ++ "chan" + t ; _ => s1 ++ "can" + t} ;
+oper MIL : Str -> Size => Str = \s1 -> table {sg => "mil" ; mutation => s1 ++ "fil" ; _ => s1 ++ "mil" } ;
+
|
