diff options
| author | aarne <aarne@chalmers.se> | 2009-06-22 15:39:08 +0000 |
|---|---|---|
| committer | aarne <aarne@chalmers.se> | 2009-06-22 15:39:08 +0000 |
| commit | e89fdae2fa1626348d8025824a7469252fa85e42 (patch) | |
| tree | c7d46bbd0494043b4bd6f917a25a7687517d0547 /next-lib/src/finnish/NumeralFin.gf | |
| parent | 3049b59b35b25381a7c6787444165c200d66e08b (diff) | |
next-lib renamed to lib, lib to old-lib
Diffstat (limited to 'next-lib/src/finnish/NumeralFin.gf')
| -rw-r--r-- | next-lib/src/finnish/NumeralFin.gf | 179 |
1 files changed, 0 insertions, 179 deletions
diff --git a/next-lib/src/finnish/NumeralFin.gf b/next-lib/src/finnish/NumeralFin.gf deleted file mode 100644 index 2103788ac..000000000 --- a/next-lib/src/finnish/NumeralFin.gf +++ /dev/null @@ -1,179 +0,0 @@ -concrete NumeralFin of Numeral = CatFin ** open Prelude, ParadigmsFin, MorphoFin in { - --- Notice: possessive forms are not used. They get wrong, since every --- part is made to agree in them. - -flags optimize = all_subs ; - -lincat - Sub1000000 = {s : CardOrd => Str ; n : MorphoFin.Number} ; - Digit = {s : CardOrd => Str} ; - Sub10, Sub100, Sub1000 = {s : NumPlace => CardOrd => Str ; n : MorphoFin.Number} ; - -lin - num x = x ; - n2 = co - (nhn (mkSubst "a" "kaksi" "kahde" "kahte" "kahta" "kahteen" "kaksi" "kaksi" - "kaksien" "kaksia" "kaksiin")) - (ordN "a" "kahdes") ; --- toinen - n3 = co - (nhn (mkSubst "a" "kolme" "kolme" "kolme" "kolmea" "kolmeen" "kolmi" "kolmi" - "kolmien" "kolmia" "kolmiin")) - (ordN "a" "kolmas") ; - n4 = co (mkN "neljä") (ordN "ä" "neljäs") ; - n5 = co (mkN "viisi" "viiden" "viisiä") (ordN "ä" "viides") ; - n6 = co (mkN "kuusi" "kuuden" "kuusia") (ordN "a" "kuudes") ; - n7 = co - (nhn (mkSubst "ä" "seitsemän" "seitsemä" "seitsemä" "seitsemää" - "seitsemään" "seitsemi" "seitsemi" "seitsemien" "seitsemiä" - "seitsemiin")) - (ordN "ä" "seitsemäs") ; - n8 = co - (nhn (mkSubst "a" "kahdeksan" "kahdeksa" "kahdeksa" "kahdeksaa" - "kahdeksaan" "kahdeksi" "kahdeksi" "kahdeksien" "kahdeksia" - "kahdeksiin")) - (ordN "a" "kahdeksas") ; - n9 = co - (nhn (mkSubst "ä" "yhdeksän" "yhdeksä" "yhdeksä" "yhdeksää" - "yhdeksään" "yhdeksi" "yhdeksi" "yhdeksien" "yhdeksiä" "yhdeksiin")) - (ordN "ä" "yhdeksäs") ; - - pot01 = - {s = table { - NumAttr => \\_ => [] ; - NumIndep => yksiN.s - } ; - n = Sg - } ; - pot0 d = {n = Pl ; s = \\_ => d.s} ; - pot110 = - {s = \\_ => kymmenenN.s ; - n = Pl - } ; - - pot111 = {n = Pl ; s = \\_,c => yksiN.s ! c ++"toista"} ; ---- yhdes - pot1to19 d = {n = Pl ; s = \\_,c => d.s ! c ++"toista"} ; - pot0as1 n = n ; - - pot1 d = {n = Pl ; s = \\_,c => d.s ! c ++ kymmentaN.s ! c} ; - pot1plus d e = { - n = Pl ; - s = \\_,c => d.s ! c ++ kymmentaN.s ! c ++ e.s ! NumIndep ! c - } ; - pot1as2 n = n ; - pot2 d = {n = Pl ; s = \\_,c => d.s ! NumAttr ! c ++ sataaN.s ! d.n ! c} ; ---- - pot2plus d e = { - n = Pl ; - s = \\_,c => d.s ! NumAttr ! c ++ sataaN.s ! d.n ! c ++ e.s ! NumIndep ! c - } ; - pot2as3 n = {n = n.n ; s = n.s ! NumIndep} ; - pot3 d = {n = Pl ; s = \\c => d.s ! NumAttr ! c ++ tuhattaN.s ! d.n ! c} ; ---- - pot3plus d e = { - n = Pl ; - s = \\c => d.s ! NumAttr ! c ++ tuhattaN.s ! d.n ! c ++ e.s ! NumIndep ! c - } ; - -oper - co : (c,o : {s : NForm => Str}) -> {s : CardOrd => Str} = \c,o -> { - s = table { - NCard nf => c.s ! nf ; - NOrd nf => o.s ! nf - } - } ; - --- Too much trouble to infer vowel, cf. "kuudes" vs. "viides". - - ordN : Str -> Str -> {s : NForm => Str} = \a,sadas -> - let - sada = init sadas - in - mkN - sadas (sada + "nnen") (sada + "nten" + a) (sada + "tt" + a) (sada + "nteen") - (sada + "nsin" + a) (sada + "nsiss" + a) (sada + "nsien") - (sada + "nsi" + a) (sada + "nsiin") ; - -param - NumPlace = NumIndep | NumAttr ; - -oper - yksiN = co - (nhn (mkSubst "ä" "yksi" "yhde" "yhte" "yhtä" "yhteen" "yksi" "yksi" - "yksien" "yksiä" "yksiin")) - (ordN "ä" "yhdes") ; ---- ensimmäinen - kymmenenN = co - (nhn (mkSubst "ä" "kymmenen" "kymmene" "kymmene" "kymmentä" - "kymmeneen" "kymmeni" "kymmeni" "kymmenien" "kymmeniä" "kymmeniin")) - (ordN "ä" "kymmenes") ; - sataN = co - (mkN "sata") - (ordN "a" "sadas") ; - - tuhatN = co - (mkN "tuhat" "tuhannen" "tuhatta" "ruhantena" "tuhanteen" - "tuhansien" "tuhansia" "tuhansina" "tuhansissa" "tuhansiin") - (ordN "a" "tuhannes") ; - - kymmentaN = - {s = table { - NCard (NCase Sg Nom) => "kymmentä" ; - k => kymmenenN.s ! k - } - } ; - - sataaN : {s : MorphoFin.Number => CardOrd => Str} = {s = table { - Sg => sataN.s ; - Pl => table { - NCard (NCase Sg Nom) => "sataa" ; - k => sataN.s ! k - } - } - } ; - - tuhattaN = {s = table { - Sg => tuhatN.s ; - Pl => table { - NCard (NCase Sg Nom) => "tuhatta" ; - k => tuhatN.s ! k - } - } - } ; - - - lincat - Dig = TDigit ; - - lin - IDig d = d ; - - IIDig d i = { - s = \\o => d.s ! NCard (NCase Sg Nom) ++ i.s ! o ; - n = Pl - } ; - - D_0 = mkDig "0" ; - D_1 = mk3Dig "1" "1." MorphoFin.Sg ; - D_2 = mkDig "2" ; - D_3 = mkDig "3" ; - D_4 = mkDig "4" ; - D_5 = mkDig "5" ; - D_6 = mkDig "6" ; - D_7 = mkDig "7" ; - D_8 = mkDig "8" ; - D_9 = mkDig "9" ; - - oper - mk2Dig : Str -> Str -> TDigit = \c,o -> mk3Dig c o MorphoFin.Pl ; - mkDig : Str -> TDigit = \c -> mk2Dig c (c + ".") ; - - mk3Dig : Str -> Str -> MorphoFin.Number -> TDigit = \c,o,n -> { - s = table {NCard _ => c ; NOrd _ => o} ; - n = n - } ; - - TDigit = { - n : MorphoFin.Number ; - s : CardOrd => Str - } ; - -} - |
