concrete ConjunctionGer of Conjunction = CatGer ** open ResGer, Coordination, Prelude in { flags optimize=all_subs ; lin ConjS conj ss = conjunctDistrTable Order conj ss ; ConjAdv conj ss = conjunctDistrSS conj ss ; ConjNP conj ss = heavyNP ( {s = \\_ => (conjunctDistrTable Case conj ss).s ; a = let n : Number = (conjNumber conj.n (numberAgr ss.a)) ; p : Person = personAgr ss.a ; agr : Agr = case of { => AgPl q ; => AgSgP3 Neutr ; => AgSgP1 ; => AgSgP2 } in (conjAgr agr ss.a) }) ; ConjAP conj ss = conjunctDistrTable AForm conj ss ** { s2 = \\c => [] ; -- comparison np of ap = {s:AForm => Str; s2:Case => Str} HL 1/23 isPre = ss.isPre ; c = ss.c ; ext = ss.ext} ; ConjRS conj ss = conjunctDistrTable RelGenNum conj ss ** { c = ss.c } ; ConjCN conj ss = conjunctDistrTable3 Adjf Number Case conj ss ** { rc = \\_ => [] ; ext = [] ; adv = [] ; g = ss.g } ; -- These fun's are generated from the list cat's. BaseS x y = { -- twoTable Order ; s1 = x.s ; s2 = table {Inv => y.s ! Main ; o => y.s ! o} } ; ConsS x xs = { -- consrTable Order comma ; s1 = \\o => x.s ! Inv ++ comma ++ xs.s1 ! case o of {Inv => Main ; _ => o} ; s2 = xs.s2 } ; BaseAdv = twoSS ; ConsAdv = consrSS comma ; BaseNP x y = { s1 = \\c => x.s ! False ! c ++ bigNP x ; s2 = \\c => y.s ! False ! c ++ bigNP y ; a = conjAgr x.a y.a } ; ConsNP xs x = { s1 = \\c => xs.s ! False ! c ++ bigNP xs ++ comma ++ x.s1 ! c ; s2 = x.s2 ; a = conjAgr xs.a x.a } ; BaseAP x y = lin AP { s1 = bigAP x ; s2 = bigAP y ; isPre = andB x.isPre y.isPre ; c = <[],[]> ; ext = []} ; ConsAP xs x = lin AP { s1 = \\a => (bigAP xs) ! a ++ comma ++ x.s1 ! a ; s2 = x.s2 ; isPre = andB x.isPre xs.isPre ; c = <[],[]> ; ext = []} ; BaseRS x y = twoTable RelGenNum x y ** {c = y.c} ; ConsRS xs x = consrTable RelGenNum comma xs x ** {c = xs.c} ; BaseCN x y = lin CN { s1 = bigCN x ; s2 = bigCN y ; g = x.g ; --- gender of first CN, used e.g. in articles } ; ConsCN x xs = lin CN { s1 = \\a,n,c => bigCN x ! a ! n ! c ++ comma ++ xs.s1 ! a ! n ! c ; s2 = xs.s2 ; g = x.g ; --- gender of first CN, used e.g. in articles } ; lincat [S] = {s1,s2 : Order => Str} ; [Adv] = {s1,s2 : Str} ; [NP] = {s1,s2 : Case => Str ; a : Agr} ; [AP] = {s1,s2 : AForm => Str ; isPre : Bool; c : Str * Str ; ext : Str} ; [RS] = {s1,s2 : RelGenNum => Str ; c : Case} ; [CN] = {s1,s2 : Adjf => Number => Case => Str ; g : Gender} ; oper bigAP : AP -> AForm => Str = \ap -> -- HL 1/23: not always ok: \\a => ap.c.p1 ++ ap.s ! a ++ ap.c.p2 ++ ap.ext ++ ap.s2 ! Nom ; -- comparison np in Nom bigCN : CN -> Adjf => Number => Case => Str = \cn -> \\a,n,c => cn.s ! a ! n ! c ++ cn.adv ++ cn.ext ++ cn.rc ! n ; }