summaryrefslogtreecommitdiff
path: root/examples/numerals/kabardian.gf
blob: 9acb469fe139c0e91d0a04c8f2908f9f2efb3ba0 (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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
-- Kabardian

-- W is superscript w (= IPA labialisation)
-- & is schwa upside down e
-- s' 
-- L is lambda
-- L is lambda with dash across
-- x^ is x with ^ ontop
-- G is gamma

include numerals.Abs.gf ;

param DForm = unit | unite | unitra | teen | ten | tenra | hund | thou;

oper LinDigit = {s : DForm => Str };
oper LinS100 = {s : Str; s2 : Str } ;

lincat Numeral =    { s : Str } ;
lincat Digit =      LinDigit ;
lincat Sub10 =      LinDigit ;
lincat Sub100 =     LinS100 ;
lincat Sub1000 =    LinS100 ;
lincat Sub1000000 = { s : Str } ;

oper mkNum : Str -> LinDigit = \dwa -> 
  {s = table {unit => dwa ; unite => dwa + "&" ; unitra => dwa + "&ra" ; 
              ten => dwa + "&s'" ; tenra => dwa + "&s'ra" ;
              teen => "p's''&" + "k'W&" + dwa ; 
              hund => "s'a" + "&y" + dwa ; 
              thou => variants {"m&yn"+"&y"+dwa ; dwa+"a"+"s''a"++"m&yn"}}};

oper mkNum2 : Str -> LinDigit = \dwa -> 
  {s = table {unit => dwa ; unite => dwa + "&" ; unitra => dwa + "&ra" ; 
              ten => dwa + "as'" ; tenra => dwa + "as'ra" ;
              teen => "p's''&"+"k'W&"+"t'" ;
              hund => "s'a" + "&y" + "t'" ; 
              thou => variants {"m&yn"+"&y"+"t'" ; dwa+"a"+"s''a"++"m&yn"}}};

oper mkNum3 : Str -> LinDigit = \dwa -> 
  {s = table {unit => dwa ; unite => dwa + "&" ; unitra => dwa + "&ra" ; 
              ten => dwa + "as'" ; tenra => dwa + "as'ra" ;
              teen => "p's''&"+"k'W&"+dwa ;
              hund => "s'a" + "&y" + dwa ; 
              thou => variants {"m&yn"+"&y"+dwa ; dwa+"a"+"s''a"++"m&yn"}}};

lin num x = {s = x.s } ; -- TODO ;

lin n2 = mkNum2 "t'?W" ;
lin n3 = mkNum3 "s'" ;
lin n4 = mkNum "p'L-'" ;
lin n5 = mkNum "tx^W" ;
lin n6 = mkNum "x^"; 
lin n7 = mkNum "bL" ;
lin n8 = mkNum "y" ;
lin n9 = mkNum "bGW" ;

oper bind : Str -> Str -> Str = \s1 -> \s2 -> s1 ++ s2 ;

lin pot01 = 
  {s = table {unit => "z" ; unite => "z&" ; unitra => "z&" + "ra" ;
              teen => "p's''&"+"k'W&"+"z" ; ten => "dummy" ; tenra => "dummy" ;
              hund => "s'a" ; thou => "m&yn"}};

oper ss : Str -> LinS100 = \f ->
  {s = f ; s2 = variants {("m&yn"+"&y") ++ f ; (bind f "as'a") ++ "m&yn"}};

lin pot0 d = d ;
lin pot110 = 
  {s = "p's''&" ; 
   s2 = variants {"m&yn"+"&y"+"p's''" ; "p's''"+"a"+"s''a"++"m&yn"}};
lin pot111 = ss ("p's''&"+"k'W&"+"z") ;
lin pot1to19 d = ss (d.s ! teen) ;
lin pot0as1 n = {s = n.s ! unite ; s2 = n.s ! thou } ;
lin pot1 d = ss (variants {(d.s ! ten) ; (d.s ! unite) ++ "p's''&wa"}) ; 
  -- extra variant p's''ay = 80
lin pot1plus d e = ss ((d.s ! tenra) ++ (e.s ! unitra)) ;
lin pot1as2 n = n ;
lin pot2 d = ss (d.s ! hund) ; 
lin pot2plus d e = ss ((d.s ! hund) ++ e.s) ; 
lin pot2as3 n = {s = n.s } ;
lin pot3 n = {s = n.s2} ;
lin pot3plus n m = {s = n.s2 ++ m.s} ;