mirror of
https://github.com/GrammaticalFramework/gf-core.git
synced 2026-04-12 06:19:33 -06:00
65 lines
1.8 KiB
Plaintext
65 lines
1.8 KiB
Plaintext
concrete SentenceBul of Sentence = CatBul ** open Prelude, ResBul in {
|
|
|
|
flags optimize=all_subs ;
|
|
|
|
lin
|
|
PredVP np vp = mkClause (np.s ! vp.subjRole) np.a vp ;
|
|
|
|
PredSCVP sc vp = mkClause sc.s {gn=GSg Masc; p=P3} vp ;
|
|
|
|
ImpVP vp = {
|
|
s = \\p,gn =>
|
|
let agr = {gn = gn ; p = P2} ;
|
|
verb = vp.imp ! p ! numGenNum gn ! Perf ;
|
|
compl = vp.s2 ! agr
|
|
in
|
|
verb ++ compl
|
|
} ;
|
|
|
|
SlashV2 np v2 =
|
|
mkClause (np.s ! RSubj) np.a (predV v2) ** {c2 = v2.c2} ;
|
|
|
|
SlashVVV2 np vv v2 =
|
|
mkClause (np.s ! RSubj) np.a
|
|
(let vp = predV vv
|
|
in { s = \\t,a,p,agr,q,asp => vp.s ! t ! a ! p ! agr ! q ! asp ++ "äà" ++ v2.s ! Perf ! (VPres (numGenNum agr.gn) agr.p) ;
|
|
imp = vp.imp ;
|
|
ad = vp.ad ;
|
|
s2 = vp.s2 ;
|
|
subjRole = vp.subjRole
|
|
}) **
|
|
{c2 = v2.c2} ;
|
|
|
|
AdvSlash slash adv = {
|
|
s = \\t,a,b,o => slash.s ! t ! a ! b ! o ++ adv.s ;
|
|
c2 = slash.c2
|
|
} ;
|
|
|
|
SlashPrep cl prep = cl ** {c2 = prep} ;
|
|
|
|
SlashVS np vs slash =
|
|
mkClause (np.s ! RSubj) np.a
|
|
(insertObj (\\_ => "֌" ++ slash.s) (predV vs)) **
|
|
{c2 = slash.c2} ;
|
|
|
|
EmbedS s = {s = "," ++ "֌" ++ s.s} ;
|
|
EmbedQS qs = {s = qs.s ! QIndir} ;
|
|
EmbedVP vp = {s = vp.ad ! False ++ "äà" ++ vp.s ! Pres ! Simul ! Pos ! {gn=GSg Masc; p=P1} ! False ! Perf} ;
|
|
|
|
UseCl t a p cl = {
|
|
s = t.s ++ a.s ++ p.s ++ cl.s ! t.t ! a.a ! p.p ! Main
|
|
} ;
|
|
UseQCl t a p cl = {
|
|
s = \\q => t.s ++ a.s ++ p.s ++ cl.s ! t.t ! a.a ! p.p ! q
|
|
} ;
|
|
UseRCl t a p cl = {
|
|
s = \\r => t.s ++ a.s ++ p.s ++ cl.s ! t.t ! a.a ! p.p ! r ;
|
|
role = cl.role
|
|
} ;
|
|
UseSlash t a p cl = {
|
|
s = t.s ++ a.s ++ p.s ++ cl.s ! t.t ! a.a ! p.p ! Main ;
|
|
c2 = cl.c2
|
|
} ;
|
|
|
|
AdvS a s = {s = a.s ++ "," ++ s.s} ;
|
|
} |