mirror of
https://github.com/GrammaticalFramework/gf-rgl.git
synced 2026-06-12 08:30:12 -06:00
106 lines
3.5 KiB
Plaintext
106 lines
3.5 KiB
Plaintext
--# -path=.:../common:../abstract
|
|
|
|
concrete ExtendMay of Extend = CatMay
|
|
** ExtendFunctor - [
|
|
VPS -- finite VP's with tense and polarity
|
|
, ListVPS
|
|
, VPI
|
|
, ListVPI -- infinitive VP's (TODO: with anteriority and polarity)
|
|
, MkVPS
|
|
, PredVPS
|
|
|
|
-- excluded because RGL funs needed for them not implemented yet
|
|
, SlashBareV2S
|
|
, PredAPVP
|
|
, ComplBareVS
|
|
|
|
|
|
,PresPartAP, PastPartAP
|
|
,GenModNP, GenNP, GenRP
|
|
,CompoundN
|
|
,GerundNP
|
|
|
|
|
|
-- VPS2 ; -- have loved (binary version of VPS)
|
|
-- [VPS2] {2} ; -- has loved, hates"
|
|
-- VPI2 ; -- to love (binary version of VPI)
|
|
-- [VPI2] {2} ; -- to love, to hate
|
|
|
|
]
|
|
with (Grammar=GrammarMay)
|
|
** open Prelude, Coordination, ResMay, NounMay in {
|
|
lincat
|
|
VPS, VPI = SS ;
|
|
ListVPS, ListVPI = ListX ;
|
|
lin
|
|
-- MkVPS : Temp -> Pol -> VP -> VPS ; -- hasn't slept
|
|
MkVPS t p vp = {
|
|
s = t.s ++ p.s ++ vp.s ! Active ! p.p;
|
|
} ;
|
|
|
|
-- BaseVPS : VPS -> VPS -> ListVPS ;
|
|
BaseVPS vps vps2 = twoSS vps vps2 ;
|
|
-- ConsVPS : VPS -> ListVPS -> ListVPS ;
|
|
ConsVPS str listvps vps = consSS "," listvps vps ;
|
|
-- ConjVPS : Conj -> [VPS] -> VPS ; -- has walked and won't sleep
|
|
ConjVPS conj listvps = conjunctX conj listvps ;
|
|
-- PredVPS : NP -> VPS -> S ; -- she [has walked and won't sleep]
|
|
PredVPS np vps = {
|
|
s = np.s ! Bare ++ vps.s ;
|
|
} ;
|
|
-- SQuestVPS : NP -> VPS -> QS ; -- has she walked
|
|
-- QuestVPS : IP -> VPS -> QS ; -- who has walked
|
|
-- RelVPS : RP -> VPS -> RS ; -- which won't sleep
|
|
|
|
-- MkVPI : VP -> VPI ; -- to sleep (TODO: Ant and Pol)
|
|
MkVPI vp = {s = linVP vp} ;
|
|
|
|
|
|
-- BaseVPI : VPI -> VPI -> ListVPI ;
|
|
BaseVPI vpi vpi2 = twoSS vpi vpi2 ;
|
|
-- ConsVPI : VPI -> ListVPI -> ListVPI ;
|
|
ConsVPI str listvpi vpi = consSS "," listvpi vpi ;
|
|
|
|
-- ConjVPI : Conj -> [VPI] -> VPI ; -- to sleep and to walk
|
|
-- ComplVPIVV : VV -> VPI -> VP ; -- must sleep and walk
|
|
ComplVPIVV vv vpi = useV {
|
|
s = \\vf => vv.s ++ vpi.s
|
|
} ;
|
|
|
|
-- PresPartAP : VP -> AP ; -- (the man) looking at Mary
|
|
PresPartAP vp = {
|
|
s = linVP vp
|
|
} ;
|
|
|
|
PastPartAP vp = {
|
|
s = linVP vp
|
|
} ;
|
|
-- GenModNP : Num -> NP -> CN -> NP ; -- this man's car(s)
|
|
GenModNP n np cn = variants {};
|
|
|
|
-- GenNP : NP -> Quant ; -- this man's
|
|
GenNP np = variants {};
|
|
-- GenRP : Num -> CN -> RP ; -- whose car
|
|
GenRP n cn = variants {};
|
|
|
|
-- CompoundN : N -> N -> N ; -- control system / controls system / control-system
|
|
CompoundN n1 n2 = n2 ** {
|
|
s = \\nf => n1.s ! NF Sg Bare ++ n2.s ! nf
|
|
} ;
|
|
-- GerundNP : VP -> NP ; -- publishing the document (by nature definite)
|
|
GerundNP vp = emptyNP ** {
|
|
s = \\_ => linVP vp
|
|
} ;
|
|
|
|
|
|
-- MkVPS2 : Temp -> Pol -> VPSlash -> VPS2 ; -- has loved
|
|
-- ConjVPS2 : Conj -> [VPS2] -> VPS2 ; -- has loved and now hates
|
|
-- ComplVPS2 : VPS2 -> NP -> VPS ; -- has loved and now hates that person
|
|
-- ReflVPS2 : VPS2 -> RNP -> VPS ; -- have loved and now hate myself and my car
|
|
|
|
-- MkVPI2 : VPSlash -> VPI2 ; -- to love
|
|
-- ConjVPI2 : Conj -> [VPI2] -> VPI2 ; -- to love and hate
|
|
-- ComplVPI2 : VPI2 -> NP -> VPI ; -- to love and hate that person
|
|
|
|
} ;
|