summaryrefslogtreecommitdiff
path: root/examples/numerals/kabardian.gf
diff options
context:
space:
mode:
authoraarne <aarne@cs.chalmers.se>2008-08-04 18:26:48 +0000
committeraarne <aarne@cs.chalmers.se>2008-08-04 18:26:48 +0000
commita9893f45724299e6cc773bbb2fa2cf315fe85206 (patch)
treeb5c6222b2422a3db7bf4dd676aa4872adf22daf4 /examples/numerals/kabardian.gf
parenta401820e3718a936cc926c457d29ec145e189be5 (diff)
ported numerals to GF3 and encoded in UTF8; some problematic ones in todo
Diffstat (limited to 'examples/numerals/kabardian.gf')
-rw-r--r--examples/numerals/kabardian.gf85
1 files changed, 85 insertions, 0 deletions
diff --git a/examples/numerals/kabardian.gf b/examples/numerals/kabardian.gf
new file mode 100644
index 000000000..ade6a75ed
--- /dev/null
+++ b/examples/numerals/kabardian.gf
@@ -0,0 +1,85 @@
+concrete kabardian of Numerals = {
+-- 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} ;
+
+}