summaryrefslogtreecommitdiff
path: root/examples/numerals/af_tunni.gf
blob: 600397690f6bd43c542360b6de3f1850a22111e9 (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
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 = Form ;
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 }; size = pl };

-- lin n1 = mkNum "ków" ; 
lin n2 = mkNum "lámma" "labaatón";
lin n3 = mkNum "síddi?" "soddón" ;
lin n4 = mkNum "áfar" "afartón";
lin n5 = mkNum "s^án" "kontón";
lin n6 = mkNum "lí?" "lihdón";
lin n7 = mkNum "toddóbo" "toddobátan";
lin n8 = mkNum "siyéed" "siyyeétan" ;
lin n9 = mkNum "sagáal" "sagaás^an";

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

lin pot01  =
  {s = table {f => "ków" }; size = sg };
lin pot0 d = d ;
lin pot110 = ss "tómon" ; 
lin pot111 = ss ("tómon" ++ "i" ++ "ków") ; 
lin pot1to19 d = ss ("tómon" ++ "i" ++ (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 ++ "i" ++ e.s ! unit) ; 
lin pot1as2 n = n ;
lin pot2 d = ss (selsg d.size (d.s ! unit) ++ "boqól" );
lin pot2plus d e = ss ((selsg d.size (d.s ! unit)) ++ "boqól" ++ e.s) ;
lin pot2as3 n = {s = n.s } ;
lin pot3 n = {s = (selsg n.size n.s) ++ "kún"} ;
lin pot3plus n m = {s = (selsg n.size n.s) ++ "kún" ++ m.s} ;

oper selsg : Size -> Str -> Str = \sz -> \attr -> 
  table {pl => attr ; sg => [] } ! sz ;