mirror of
https://github.com/GrammaticalFramework/gf-rgl.git
synced 2026-06-12 08:30:12 -06:00
44 lines
1.1 KiB
Plaintext
44 lines
1.1 KiB
Plaintext
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} ;
|
|
|
|
}
|