concrete QuestionUrd of Question = CatUrd ** open ResUrd, Prelude in { flags optimize=all_subs ; lin QuestCl cl = { s = \\t,p,qf => case qf of { QDir => cl.s ! t ! p ! OQuest; QIndir => agr_Str ++ cl.s ! t! p ! ODir } }; QuestVP qp vp = let cl = mkSClause [] (Ag qp.g qp.n Pers3_Near) vp; qp1 = qp.s ! Dir; qp2 = qp.s ! Obl ++ nE_Str in { s = \\t,p,o => case t of { VPImpPast => qp2 ++ cl.s ! t ! p ! ODir; _ => qp1 ++ cl.s ! t ! p ! ODir } }; QuestSlash ip slash = let ip1 = ip.s ! Dir; ip2 = ip.s ! Obl ++ nE_Str in { s = \\t,p,o => case t of { VPImpPast => ip2 ++ slash.s ! t ! p ! ODir; _ => ip1 ++ slash.s ! t ! p ! ODir } }; QuestIAdv iadv cl = { s = \\t,p,_ => iadv.s ++ cl.s ! t ! p ! ODir; }; QuestIComp icomp np = let cl = mkSClause (np.s ! NPC Dir ++ icomp.s) np.a (predAux auxBe); in { s = \\t,p,qf => case qf of { QDir => cl.s ! t ! p ! ODir; QIndir => cl.s ! t! p ! ODir } }; PrepIP p ip = {s = ip.s ! ResUrd. Voc ++ p.s } ; AdvIP ip adv = { s = \\c => adv.s ++ ip.s ! c ; n = ip.n; g = ip.g; } ; IdetCN idet cn = { s = \\c => idet.s ! cn.g ++ cn.s ! idet.n ! c ; g = cn.g; n = idet.n; } ; IdetIP idet = { s = \\_ => idet.s ! Masc ; n = idet.n; g = Masc; } ; IdetQuant iqant num = { s = \\g => iqant.s ! num.n ++ num.s ; n = num.n } ; CompIAdv a = a ; CompIP p = ss (p.s ! Dir) ; }