summaryrefslogtreecommitdiff
path: root/examples/numerals/maale.gf
blob: 5b8d309a0f806561120b716f849c48ae13ceff29 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
include numerals.Abs.gf ;

param Size = sg | pl ;
param DForm = unit | ten ;

oper LinDigit = {s : DForm => Str ; size : Size } ;
oper Form = {s : Str ; size : Size } ;

lincat Numeral = {s : Str} ;
lincat Digit = LinDigit ;
lincat Sub10 = LinDigit ;
lincat Sub100 = Form ;
lincat Sub1000 = {s : Str} ;
lincat Sub1000000 = {s : Str} ;
lin num x0 =
  {s = x0.s} ; -- TODO: Encoding

oper mkNum : Str -> Str -> LinDigit = \mbili -> \lama ->
  {s = table {unit => mbili ; ten => lama + "-támmi" }; size = pl };

-- b> is b with right bend
-- ? without dot
-- $ IPA [sh]

-- lin n1 = mkNum "pétte" ; 
lin n2 = mkNum "lam?ó" "lamá";
lin n3 = mkNum "haitsó" "haytsí" ;
lin n4 = mkNum "?oidó" "?oydí";
lin n5 = mkNum "dóngo" "dóngi";
lin n6 = mkNum "láhhó" "láhhi";
lin n7 = mkNum "lánkayi" "lánkayi";
lin n8 = mkNum "sálli" "sálli" ;
lin n9 = mkNum "tásub>a" "tázub>i";

oper ss : Str -> Form = \s1 -> {s = s1 ; size = pl} ;

lin pot01  =
  {s = table {f => "pétte" }; size = sg };
lin pot0 d = d ;
lin pot110 = ss "táb>b>ó" ; 
lin pot111 = ss ("táb>b>ó" ++ "pétte") ; 
lin pot1to19 d = ss ("táb>b>ó" ++ (d.s ! unit)) ;
lin pot0as1 n = {s = n.s ! unit ; size = n.size } ;
lin pot1 d = ss (d.s ! ten) ;
lin pot1plus d e = ss (d.s ! ten ++ e.s ! unit) ; 
lin pot1as2 n = n ;
lin pot2 d = {s = mkseeta d.size (d.s ! unit) };
lin pot2plus d e = {s = (mkseeta d.size (d.s ! unit)) ++ e.s} ;
lin pot2as3 n = {s = n.s } ;
lin pot3 n = {s = n.s ++ "$íya"} ;
lin pot3plus n m = {s = n.s ++ "$íya" ++ m.s} ;

oper mkseeta : Size -> Str -> Str = \sz -> \attr -> 
  table {pl => attr ++ "s'ééta" ; 
         sg => "s'ééta" } ! sz ;