forked from GitHub/gf-core
50 lines
1.2 KiB
Plaintext
50 lines
1.2 KiB
Plaintext
concrete RelativeGer of Relative = CatGer ** open ResGer in {
|
|
|
|
flags optimize=all_subs ;
|
|
|
|
lin
|
|
|
|
RelCl cl = {
|
|
s = \\m,t,a,b,_ => "derart" ++ conjThat ++ cl.s ! m ! t ! a ! b ! Sub ;
|
|
c = Nom
|
|
} ;
|
|
|
|
RelVP rp vp = {
|
|
s = \\m,t,ant,b,gn =>
|
|
let
|
|
agr = case rp.a of {
|
|
RNoAg => agrP3 (numGenNum gn) ;
|
|
RAg n p => Ag Neutr n p
|
|
} ;
|
|
cl = mkClause (rp.s ! gn ! Nom) agr vp
|
|
in
|
|
cl.s ! m ! t ! ant ! b ! Sub ;
|
|
c = Nom
|
|
} ;
|
|
|
|
RelSlash rp slash = {
|
|
s = \\m,t,a,p,gn =>
|
|
appPrep slash.c2 (\\k => usePrepC k (\c -> rp.s ! gn ! c)) ++
|
|
slash.s ! m ! t ! a ! p ! Sub ;
|
|
c = (prepC slash.c2.c).c
|
|
} ;
|
|
|
|
FunRP p np rp = {
|
|
s = \\gn,c => np.s ! NPC c ++ appPrep p (\\k => usePrepC k (\c -> rp.s ! gn ! c)) ;
|
|
a = RAg (numberAgr np.a) (personAgr np.a)
|
|
} ;
|
|
|
|
IdRP = {s = relPron ; a = RNoAg} ;
|
|
|
|
oper
|
|
relPron : GenNum => Case => Str = \\gn,c =>
|
|
case <gn,c> of {
|
|
<GSg Fem,Gen> => "deren" ;
|
|
<GSg g,Gen> => "dessen" ;
|
|
<GPl,Dat> => "denen" ;
|
|
<GPl,Gen> => "deren" ;
|
|
_ => artDef ! gn ! c
|
|
} ;
|
|
|
|
}
|