summaryrefslogtreecommitdiff
path: root/old-examples/numerals/votic.gf
diff options
context:
space:
mode:
Diffstat (limited to 'old-examples/numerals/votic.gf')
-rw-r--r--old-examples/numerals/votic.gf61
1 files changed, 61 insertions, 0 deletions
diff --git a/old-examples/numerals/votic.gf b/old-examples/numerals/votic.gf
new file mode 100644
index 000000000..362c465a6
--- /dev/null
+++ b/old-examples/numerals/votic.gf
@@ -0,0 +1,61 @@
+include numerals.Abs.gf ;
+
+param DForm = unit | attr | teen | ten | ten2 ;
+param Size = sg | pl ;
+
+oper LinDigit = {s : DForm => Str ; size : Size };
+oper LinS100 = {s : Str ; size : Size} ;
+
+oper bind : Str -> Str -> Str = \a -> \b -> a ++ b ;
+
+lincat Numeral = {s : Str} ;
+lincat Digit = LinDigit ;
+lincat Sub10 = LinDigit ;
+lincat Sub100 = LinS100 ;
+lincat Sub1000 = LinS100 ;
+lincat Sub1000000 = {s : Str} ;
+lin num x0 = {s = x0.s} ; -- TODO
+
+oper mkN2 : Str -> LinDigit = \u ->
+ mkN u u (u + "ts^ümmettä") (u + "ts^ümmet") ;
+
+oper mkN : Str -> Str -> Str -> Str -> LinDigit = \u -> \a -> \t -> \t2 ->
+ {s = table {unit => u ; attr => a + "sata:"; ten => t ; ten2 => t2 ;
+ teen => a + tess} ; size = pl} ;
+
+lin n2 = mkN "kahsi" "kahs"
+ (variants {"kahs^'t's^'ümmettä" ; "kahts^ümmettä"})
+ (variants {"kahs^'t's^'ümmet" ; "kahts^ümmet"});
+lin n3 = mkN "keVLmeV" "keVm" "keVmts^ümmettä" "keVmts^ümmet";
+lin n4 = mkN2 "nellä" ;
+lin n5 = mkN "vi:si" "vi:s" "vi:s^'t's^'ümmettä" "vi:s^'t's^'ümmet";
+lin n6 = mkN "ku:si" "ku:s" "ku:s^'t's^'ümmettä" "ku:s^'t's^'ümmet";
+lin n7 = mkN2 "seitse:" ;
+lin n8 = mkN2 "kaheVsa:" ;
+lin n9 = mkN2 "ühesä:" ;
+
+oper tess : Str = (variants {"teV*s^s^eVmeVtta" ; "teV*is^'t's^'ümmeD"} ) ;
+
+lin pot01 = {s = table {unit => "ühsi" ; attr => "sata" ; _ => "dummy" }; size = sg } ;
+
+oper ss : Str -> LinS100 = \s1 -> {s = s1 ; size = pl } ;
+
+lin pot0 d = d ;
+lin pot110 = ss "ts^ümme:" ;
+lin pot111 = ss ("ühs" + tess) ;
+lin pot1to19 d = ss (d.s ! teen) ;
+lin pot0as1 n = {s = n.s ! unit ; size = n.size } ;
+lin pot1 d = ss (d.s ! ten) ;
+lin pot1plus d e = ss ((d.s ! ten2) ++ (e.s ! unit)) ;
+lin pot1as2 n = n ;
+lin pot2 d = ss (d.s ! attr) ;
+lin pot2plus d e = ss ((d.s ! attr) ++ e.s) ;
+lin pot2as3 n =
+ {s = n.s } ;
+lin pot3 n =
+ {s = selsg (variants {"tuhatta" ; "tuhaD" }) (bind n.s "tuhatta") ! n.size} ;
+lin pot3plus n m =
+ {s = selsg (variants {"tuhatta" ; "tuhaD" }) (bind n.s "tuhatta") ! n.size ++ m.s };
+
+oper selsg : Str -> Str -> Size => Str = \a -> \b ->
+ table {sg => a ; pl => b} ; \ No newline at end of file