summaryrefslogtreecommitdiff
path: root/examples/discourse/DiscourseFin.gf
diff options
context:
space:
mode:
Diffstat (limited to 'examples/discourse/DiscourseFin.gf')
-rw-r--r--examples/discourse/DiscourseFin.gf52
1 files changed, 16 insertions, 36 deletions
diff --git a/examples/discourse/DiscourseFin.gf b/examples/discourse/DiscourseFin.gf
index 4fa1062b6..c9fc0c6d2 100644
--- a/examples/discourse/DiscourseFin.gf
+++ b/examples/discourse/DiscourseFin.gf
@@ -2,49 +2,29 @@
concrete DiscourseFin of Discourse =
LexiconFin,
- NounFin, VerbFin - [SlashV2VNP,SlashVV],
+ NounFin, VerbFin - [SlashV2VNP,SlashVV, Slash2V3, Slash3V3],
AdjectiveFin, AdverbFin,
StructuralFin - [nobody_NP,nothing_NP],
TenseX
** open SyntaxFin, (P = ParadigmsFin), (R = ParamX), (E = ExtraFin), Prelude in {
lincat
- Clause = {subj : NP ; vp : VP} ;
- OClause = {subj : NP ; v : V2 ; obj : NP} ;
- Part = Adv ;
+ Marker = E.Part ;
lin
- ClauseS part temp pol cl =
- mkS temp pol (mkCl (mkNP cl.subj part) cl.vp) ;
- SubjKinS part temp pol cl =
- mkS temp pol (mkCl (mkNP (mkNP cl.subj (kin.s ! pol.p)) part) cl.vp) ;
- VerbKinS part temp pol cl =
- mkS temp pol (mkCl (mkNP cl.subj part) (mkVP cl.vp (kin.s ! pol.p))) ;
- AdvKinS part temp pol adv cl =
- mkS temp pol (mkCl (mkNP cl.subj part) (mkVP (mkVP cl.vp adv) (kin.s ! pol.p))) ;
-
- PreAdvS part temp pol adv cl =
- mkS adv (mkS part (mkS temp pol (mkCl cl.subj cl.vp))) ;
- PreAdvKinS part temp pol adv cl =
- mkS adv (mkS part (mkS (kin.s ! pol.p) (mkS temp pol (mkCl cl.subj cl.vp)))) ;
- PreAdvSubjKinS part temp pol adv cl =
- mkS adv (mkS part (mkS temp pol (mkCl (mkNP cl.subj (kin.s ! pol.p)) cl.vp))) ;
- PreAdvVerbKinS part temp pol adv cl =
- mkS adv (mkS part (mkS temp pol (mkCl cl.subj (mkVP cl.vp (kin.s ! pol.p))))) ;
-
- PredClause subj v = {subj = subj ; vp = v} ;
- PredOClause subj v obj = {subj = subj ; v = v ; obj = obj} ;
- UseOClause oc = {subj = oc.subj ; vp = mkVP oc.v oc.obj} ;
-
- noPart = P.mkAdv [] ;
- han_Part = P.mkAdv (glueTok "han") ;
- pa_Part = P.mkAdv (glueTok "pa") ;
- pas_Part = P.mkAdv (glueTok "pas") ;
-
-oper
- kin : {s : R.Polarity => Adv} =
- {s = table {R.Pos => P.mkAdv (glueTok "kin") ; R.Neg => P.mkAdv (glueTok "kaan")}} ;
-
- glueTok : Str -> Str = \s -> "&+" ++ s ;
+ ClauseS marker temp pol np vp =
+ E.S_SVO marker temp pol (E.PredClPlus np vp) ;
+ FocSubjS marker temp pol np vp =
+ E.S_SVO marker temp pol (E.PredClPlusFocSubj np vp) ;
+ FocVerbS marker temp pol np vp =
+ E.S_SVO marker temp pol (E.PredClPlusFocVerb np vp) ;
+ FocObjS marker temp pol np vp obj =
+ E.S_SVO marker temp pol (E.PredClPlusFocObj np vp obj) ;
+ FocAdvS marker temp pol np vp adv =
+ E.S_SVO marker temp pol (E.PredClPlusFocAdv np vp adv) ;
+
+ neutralMarker = E.noPart ;
+ remindMarker = E.han_Part ;
+ contrastMarker = E.pas_Part ;
}