concrete RelativeGer of Relative = CatGer ** open ResGer, Prelude in { flags optimize=all_subs ; lin RelCl cl = { --- no comma before derart s = \\m,t,a,b,_ => "derart" ++ Predef.BIND ++ "," ++ conjThat ++ cl.s ! m ! t ! a ! b ! Sub ; c = Nom } ; RelVP rp vp = { s = \\m,t,ant,b,rgn => let gn = case rgn of { RGenNum gf => gf ; RSentence => GSg Neutr } ; agr = case rp.a of { RNoAg => agrP3 (numGenNum gn) ; RAg Sg p => AgSgP3 Neutr ; RAg Pl p => AgPl p } ; -- subject may be non-nom, e.g. an dem gezweifelt wird cl = mkClause (appPrep vp.c1 (rp.s ! rgn)) agr vp in cl.s ! m ! t ! ant ! b ! Sub ; c = Nom } ; RelSlash rp slash = { s = \\m,t,a,p,gn => appPrep slash.c2 (rp.s ! gn) ++ slash.s ! m ! t ! a ! p ! Sub ; c = slash.c2.c } ; FunRP p np rp = { s = \\gn,c => np.s ! False ! c ++ appPrep p (rp.s ! gn) ; a = RAg (numberAgr np.a) (personAgr np.a) } ; IdRP = {s = relPron ; a = RNoAg} ; }