concrete ConjunctionEst of Conjunction = CatEst ** open ResEst, Coordination, Prelude in { flags optimize=all_subs ; coding=utf8; lin ConjS = conjunctDistrSS ; ConjAdv = conjunctDistrSS ; ConjNP conj ss = conjunctDistrTable NPForm conj ss ** { a = conjAgr (Ag conj.n P3) ss.a ; -- P3 is the maximum isPron = False } ; -- ConjAP conj ss = conjunctDistrTable2 Bool NForm conj ss ** { ConjAP conj ss = conjunctDistrTableAdj conj ss ** { infl = ss.s2.infl ; ---- was: True, which is of wrong type. AR 1/2/2014 lock_AP = <> } ; ConjRS conj ss = conjunctDistrTable Agr conj ss ** { c = ss.c } ; -- These fun's are generated from the list cat's. BaseS = twoSS ; ConsS = consrSS comma ; BaseAdv = twoSS ; ConsAdv = consrSS comma ; BaseNP x y = twoTable NPForm x y ** {a = conjAgr x.a y.a} ; ConsNP xs x = consrTable NPForm comma xs x ** {a = conjAgr xs.a x.a} ; BaseAP x y = twoTableAdj x y ; ConsAP xs x = consrTableAdj comma x xs ; -- BaseAP x y = twoTable2 Bool NForm x y ; -- ConsAP xs x = consrTable2 Bool NForm comma xs x ; BaseRS x y = twoTable Agr x y ** {c = y.c} ; ConsRS xs x = consrTable Agr comma xs x ** {c = xs.c} ; lincat [S] = {s1,s2 : Str} ; [Adv] = {s1,s2 : Str} ; [NP] = {s1,s2 : NPForm => Str ; a : Agr} ; [AP] = {s1,s2 : {s : Bool => NForm => Str ; infl : Infl }} ; [RS] = {s1,s2 : Agr => Str ; c : NPForm} ; oper --Modified from prelude/Coordination.gf generic functions twoTableAdj : (_,_ : AP) -> [AP] = \x,y -> lin ListAP { s1 = x ; s2 = y ; lock_ListAP = <> } ; consrTableAdj : Str -> [AP] -> {s : Bool => NForm => Str ; infl : Infl} -> [AP] = \c,xs,x -> let ap1 = xs.s1 ; ap2 = xs.s2 in lin ListAP {s1 = {s = \\isMod,nf => case isMod of { True => case of { <(Participle|Invariable),(Participle|Invariable)> => ap1.s ! isMod ! (NCase Sg Nom) ++ c ++ ap2.s ! isMod ! (NCase Sg Nom) ; --valmis ja täis kassid <(Participle|Invariable),Regular> => ap1.s ! isMod ! (NCase Sg Nom) ++ c++ ap2.s ! isMod ! nf ; --valmis ja suured kassid => ap1.s ! isMod ! nf ++ c ++ ap2.s ! isMod ! (NCase Sg Nom) ; --suured ja valmis kassid _ => ap1.s ! isMod ! nf ++ c ++ ap2.s ! isMod ! nf --suured ja mustad kassid } ; False => ap1.s ! isMod ! nf ++ c ++ ap2.s ! isMod ! nf --kassid on valmid ja suured } ; infl = Regular ; lock_AP = <> } ; s2 = x ; lock_ListAP = <> } ; conjunctDistrTableAdj : ConjunctionDistr -> [AP] -> AP = \or,xs -> let ap1 = xs.s1 ; ap2 = xs.s2 ; in lin AP {s = \\isMod,nf => case isMod of { True => case of { <(Participle|Invariable),(Participle|Invariable)> => or.s1 ++ ap1.s ! isMod ! (NCase Sg Nom) ++ or.s2 ++ ap2.s ! isMod ! (NCase Sg Nom) ; <(Participle|Invariable),Regular> => or.s1 ++ ap1.s ! isMod ! (NCase Sg Nom) ++ or.s2 ++ ap2.s ! isMod ! nf ; => or.s1 ++ ap1.s ! isMod ! nf ++ or.s2 ++ ap2.s ! isMod ! (NCase Sg Nom) ; _ => or.s1 ++ ap1.s ! isMod ! nf ++ or.s2 ++ ap2.s ! isMod ! nf } ; False => or.s1 ++ ap1.s ! isMod ! nf ++ or.s2 ++ ap2.s ! isMod ! nf } ; infl = Regular ; lock_AP = <> } ; }