mirror of
https://github.com/GrammaticalFramework/gf-core.git
synced 2026-04-20 10:19:32 -06:00
114 lines
3.3 KiB
Plaintext
114 lines
3.3 KiB
Plaintext
|
|
concrete NumeralAfr of Numeral = CatAfr ** open ResAfr, Prelude in {
|
|
|
|
flags optimize = all_subs ;
|
|
coding=utf8 ;
|
|
|
|
lincat
|
|
Digit = {s : DForm => CardOrd => Str ; en : Str} ;
|
|
Sub10 = {s : DForm => CardOrd => Str ; n : Number ; en : Str ; attr : Str} ;
|
|
Sub100, Sub1000, Sub1000000 =
|
|
{s : CardOrd => Str ; n : Number ; attr : Str} ;
|
|
|
|
lin
|
|
num x = x ;
|
|
|
|
n2 = mkDigit "twee" "twaalf" "twintig" "tweede" ;
|
|
n3 = mkDigit "drie" "dertien" "dertig" "derde" ;
|
|
n4 = mkDigit "vier" "veertien" "veertig" "vierde" ;
|
|
n5 = mkDigit "vyf" "vyftien" "vyftig" "vyfde" ;
|
|
n6 = mkDigit "ses" "sestien" "sestig" "sesde" ;
|
|
n7 = mkDigit "seven" "seventien" "seventig" "sevende" ;
|
|
n8 = mkDigit "agt" "agtien" "tagtig" "agtste" ;
|
|
n9 = mkDigit "nege" "negentien" "negentig" "negende" ;
|
|
|
|
pot01 = {
|
|
s = \\f => table {
|
|
NCard g _ => "een" ; ---- "één" ;
|
|
NOrd af => (regAdjective "eerste").s ! Posit ! af
|
|
} ;
|
|
n = Sg ;
|
|
attr = [] ;
|
|
en = "en"
|
|
} ;
|
|
pot0 d = {s = \\f,g => d.s ! f ! g ; n = Pl ; en = d.en ; attr = d.s ! DUnit ! invNum ++ BIND} ;
|
|
pot110 = {s = cardOrd "tien" "tiende" ; n = Pl ; attr = "tien" ++ BIND} ;
|
|
pot111 = {s = cardOrd "elf" "elfde" ; n = Pl ; attr = "elf" ++ BIND} ;
|
|
pot1to19 d = addAttr {s = d.s ! DTeen ; n = Pl} ;
|
|
pot0as1 n = {s = n.s ! DUnit; n = n.n ; attr = n.attr} ;
|
|
pot1 d = addAttr {s = d.s ! DTen ; n = Pl} ;
|
|
pot1plus d e = addAttr {s = \\g =>
|
|
e.s ! DUnit ! invNum ++ BIND ++ e.en ++ BIND ++ d.s ! DTen ! g ; n = Pl} ;
|
|
pot1as2 n = n ;
|
|
pot2 d =
|
|
addAttr {s = \\g => d.attr ++ cardOrd "honderd" "honderdste" ! g ; n = Pl} ;
|
|
pot2plus d e =
|
|
addAttr {s = \\g => d.attr ++ "honderd" ++ BIND ++ e.s ! g ; n = Pl} ;
|
|
pot2as3 n = n ;
|
|
pot3 n =
|
|
addAttr {s = \\g => n.attr ++ cardOrd "duisend" "duisendste" ! g ; n = Pl} ;
|
|
pot3plus n m =
|
|
addAttr {s = \\g => n.attr ++ "duisend" ++ m.s ! g ; n = Pl} ;
|
|
|
|
|
|
lincat
|
|
Dig = TDigit ;
|
|
|
|
lin
|
|
IDig d = d ;
|
|
|
|
IIDig d i = {
|
|
s = \\o => d.s ! invNum ++ i.s ! o ;
|
|
n = Pl
|
|
} ;
|
|
|
|
D_0 = mkDig "0" ;
|
|
D_1 = mk3Dig "1" "1e" Sg ;
|
|
D_2 = mk2Dig "2" "2e" ;
|
|
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 Pl ;
|
|
mkDig : Str -> TDigit = \c -> mk2Dig c (c + "e") ;
|
|
|
|
mk3Dig : Str -> Str -> Number -> TDigit = \c,o,n -> {
|
|
s = table {NCard _ _ => c ; NOrd _ => o} ;
|
|
n = n
|
|
} ;
|
|
|
|
TDigit = {
|
|
n : Number ;
|
|
s : CardOrd => Str
|
|
} ;
|
|
|
|
LinDigit = {s : DForm => CardOrd => Str ; en : Str} ;
|
|
|
|
cardOrd : Str -> Str -> CardOrd => Str = \drei,dritte ->
|
|
let dritt = init dritte in
|
|
table {
|
|
NCard _ _ => drei ;
|
|
NOrd a => (regAdjective dritt).s ! Posit ! a
|
|
} ;
|
|
|
|
mkDigit : (x1,_,_,x4 : Str) -> LinDigit =
|
|
\drei,dreizehn,dreissig,dritte ->
|
|
{s = table {
|
|
DUnit => cardOrd drei dritte ;
|
|
DTeen => cardOrd dreizehn (dreizehn + "de") ;
|
|
DTen => cardOrd dreissig (dreissig + "ste")
|
|
} ;
|
|
en = case drei of {_ + "e" => "ën" ; _ => "en"}
|
|
} ;
|
|
invNum : CardOrd = NCard Neutr Nom ;
|
|
|
|
addAttr : {s : CardOrd => Str ; n : Number} ->
|
|
{s : CardOrd => Str ; n : Number ; attr : Str} = \n -> n ** {attr = n.s ! invNum ++ BIND} ;
|
|
|
|
}
|