diff options
Diffstat (limited to 'old-examples/numerals/nenets.gf')
| -rw-r--r-- | old-examples/numerals/nenets.gf | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/old-examples/numerals/nenets.gf b/old-examples/numerals/nenets.gf new file mode 100644 index 000000000..6ab6cb44b --- /dev/null +++ b/old-examples/numerals/nenets.gf @@ -0,0 +1,67 @@ +include numerals.Abs.gf ; + +-- #n- +-- #t- +-- #l- +-- #s' with , ontop of s +-- #N for n with a thing on the right leg i.e IPA [ng] +-- #|~ a vertical tilde in thge top right corner + +param DForm = unit | teen ; +param Size = sg | nine | pl ; + +oper LinDigit = {s : DForm => Str ; size : Size } ; +oper LinS100 = {s : Str ; size : Size} ; + +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 Encoding + +oper mkNum : Str -> Str -> LinDigit = + \u -> \t -> {s = table {unit => u ; teen => t } ; size = pl} ; + +lin n2 = mkNum (variants {"side"; "sidea"}) "sidejaNan-â|~" ; +lin n3 = mkNum (variants {"n-ahar" ; "nâr"}) "n-aharaNan-â|~" ; +lin n4 = mkNum (variants {"t-êt" ; "t-iet" ; "tiet"}) "t-êtaNan-â|~" ; +lin n5 = mkNum (variants {"saml-aN" ; "sambl-aN" ; "sambel-ank" }) + "saml-an-aNan-â|~"; +lin n6 = mkNum "mat'" "mat-aNan-â|~"; +lin n7 = mkNum (variants {"siu" ; "s'eu"}) "siujaNan-â|~" ; +lin n8 = mkNum "sidend-êt" "sidend-êtaNan-â|~" ; +lin n9 = {s = table {unit => variants {"hâsawaju'" ; "habeiju'"} ; + teen => "hâsawajujaNan-â|~" } ; + size = nine} ; + +oper ss : Str -> LinS100 = \s1 -> {s = s1 ; size = pl} ; + +lin pot01 = + {s = table {unit => variants {"~ob" ; "~opoi" } ; _ => "dummy" }; size = sg}; +lin pot0 d = d ; +lin pot110 = ss (variants {"ju'" ; "lûcaju'" ; "lûsaju'" }) ; +lin pot111 = ss (variants {"~objaNan-â|~"; "~objaNn-â" ; "~objaNa"}) ; +lin pot1to19 d = ss (d.s ! teen) ; +lin pot0as1 n = {s = n.s ! unit ; size = n.size} ; +lin pot1 d = ss (ifnine d.size (d.s ! unit)) ; +lin pot1plus d e = ss ((ifnine d.size (d.s ! unit)) ++ (e.s ! unit)) ; +lin pot1as2 n = n ; +lin pot2 d = ss (mkjur d.size (d.s ! unit)) ; +lin pot2plus d e = ss ((mkjur d.size (d.s ! unit)) ++ e.s) ; +lin pot2as3 n = {s = n.s } ; +lin pot3 n = {s = mkjuonar n.size n.s } ; +lin pot3plus n m = {s = (mkjuonar n.size n.s) ++ m.s } ; + +oper mkjuonar : Size -> Str -> Str = \sz -> \attr -> + table {nine => attr ++ "juonar" ; + sg => variants {"juonar" ; "jônar" ; "ju" ++ "jur"} ; + pl => attr ++ "juonar" } ! sz ; + +oper mkjur : Size -> Str -> Str = \sz -> \attr -> + table {sg => "jur" ; _ => attr ++ "jur" } ! sz ; + +oper ifnine : Size -> Str -> Str = \sz -> \attr -> + table {nine => "hâsawajur" ; _ => attr ++ "ju'" } ! sz ;
\ No newline at end of file |
