concrete VerbAfr of Verb = CatAfr ** open Prelude, ResAfr in { flags optimize=all_subs ; lin UseV = predV ; ComplVV v vp = let vpi = infVP v.isAux vp in insertExtrapos vpi.p3 ( insertInf vpi.p2 ( insertObj vpi.p1 ( predVGen v.isAux (v2v v)))) ; ---- subtyp ComplVS v s = insertExtrapos (conjThat ++ s.s ! Sub) (predV v) ; ComplVQ v q = insertExtrapos (q.s ! QIndir) (predV v) ; ComplVA v ap = insertObj (\\ _ => ap.s ! APred) (predV v) ; SlashV2a v = predV (v2v v) ** {c2 = v.c2} ; Slash2V3 v np = insertObj (\\_ => appPrep v.c2 np.s) (predVv v) ** {c2 = v.c3} ; Slash3V3 v np = insertObj (\\_ => appPrep v.c3 np.s) (predVv v) ** {c2 = v.c2} ; SlashV2S v s = insertExtrapos (conjThat ++ s.s ! Sub) (predVv v) ** {c2 = v.c2} ; SlashV2Q v q = insertExtrapos (q.s ! QIndir) (predVv v) ** {c2 = v.c2} ; SlashV2V v vp = let vpi = infVP False vp in insertExtrapos vpi.p3 ( insertInf vpi.p2 ( insertObj vpi.p1 ((predVv v)))) ** {c2 = v.c2} ; SlashV2A v ap = insertObj (\\_ => ap.s ! APred) (predVv v) ** {c2 = v.c2} ; ComplSlash vp np = insertObjNP np.isPron (\\_ => appPrep vp.c2 np.s) vp ; SlashVV v vp = let vpi = infVP v.isAux vp in insertExtrapos vpi.p3 ( insertInf vpi.p2 ( insertObj vpi.p1 ( predVGen v.isAux (v2v v)))) ** {c2 = vp.c2} ; SlashV2VNP v np vp = let vpi = infVP False vp in insertExtrapos vpi.p3 ( insertInf vpi.p2 ( insertObj vpi.p1 ( insertObj (\\_ => appPrep v.c2 np.s) ( predVv v)))) ** {c2 = v.c2} ; UseComp comp = insertObj comp.s (predV zijn_V) ; -- agr not used --edited CompCN cn = {s = \\a => case a.n of { Sg => "'n" ++ cn.s ! Strong ! NF a.n Nom ; Pl => cn.s ! Strong ! NF a.n Nom } } ; CompAP ap = {s = \\_ => ap.s ! APred} ; CompNP np = {s = \\_ => np.s ! NPNom} ; CompAdv a = {s = \\_ => a.s} ; AdvVP vp adv = insertAdv adv.s vp ; AdVVP adv vp = insertAdV adv.s vp ; ReflVP vp = insertObj (\\a => appPrep vp.c2 (\\_ => reflPron ! a )) vp ; PassV2 v = insertInf (v.s ! VPerf) (predV word_V) ; ---- workaround for a subtyping bug oper v2v : VVerb -> VVerb = \v -> {s = v.s ; aux = v.aux ; prefix = v.prefix ; vtype = v.vtype} ; predVv : VVerb -> ResAfr.VP = \v -> predV (v2v v) ; }