diff options
| author | bjorn <bjorn@bringert.net> | 2008-08-15 20:21:12 +0000 |
|---|---|---|
| committer | bjorn <bjorn@bringert.net> | 2008-08-15 20:21:12 +0000 |
| commit | 137133b742f38c76d2354047ecc9d4af88826d42 (patch) | |
| tree | 40b29781c11c6c9effd89c08ce7d6501a1bdedd0 /examples/peacekeeping/PeaceSyntaxI.gf | |
| parent | 66c927937ad8ba4055a30c87c4455186535804dd (diff) | |
Added peacekeeping example back in. Doesn't compile yet.
Diffstat (limited to 'examples/peacekeeping/PeaceSyntaxI.gf')
| -rw-r--r-- | examples/peacekeeping/PeaceSyntaxI.gf | 88 |
1 files changed, 88 insertions, 0 deletions
diff --git a/examples/peacekeeping/PeaceSyntaxI.gf b/examples/peacekeeping/PeaceSyntaxI.gf new file mode 100644 index 000000000..89517d735 --- /dev/null +++ b/examples/peacekeeping/PeaceSyntaxI.gf @@ -0,0 +1,88 @@ +incomplete concrete PeaceSyntaxI of PeaceSyntax = + PeaceCatI ** open Lang,PeaceRes in { + + flags +-- optimize = all_subs ; + optimize = share ; + unlexer = text ; lexer = text ; + + lincat + Sent = {s : SForm => Str} ; + Quest = { s : Str } ; + MassCN = CN ; + + lin + PhrPos sent = stop (sent.s!SPos) ; + PhrNeg sent = stop (sent.s!SNeg) ; + PhrQuest q = quest q.s ; + PhrImp imp = excl (PhrUtt NoPConj (UttImpSg PPos imp) NoVoc).s; + PhrImpNeg imp = excl (PhrUtt NoPConj (UttImpSg PNeg imp) NoVoc).s; + + PhrYes = stop yes_Phr.s ; + PhrNo = stop no_Phr.s ; + + QuestSent sent = { s = sent.s!SQuest } ; + QuestIP_V v ip = mkQuest (QuestVP ip (UseV v)) ; + QuestIP_V2 v ip x = mkQuest (QuestVP ip (ComplV2 v x)) ; + QuestIP_V2Mass v ip x = mkQuest (QuestVP ip (ComplV2 v (massNP x))) ; + QuestIP_V3 v ip x y = mkQuest (QuestVP ip (ComplV3 v x y)) ; + QuestIP_V3Mass v ip x y = mkQuest (QuestVP ip (ComplV3 v (massNP x) y)) ; + QuestIP_A a ip = mkQuest (QuestVP ip (UseComp (CompAP (PositA a)))); + QuestIAdv_NP x ia = mkQuest (QuestIComp (CompIAdv ia) x); + + QuestIAdv_V v x ia = mkQuest (QuestIAdv ia (PredVP x (UseV v))); + QuestIAdv_V2 v x y ia = mkQuest (QuestIAdv ia (PredVP x (ComplV2 v y))); + + SentV v np = mkSent np (UseV v) ; + + SentV2 v x y = mkSent x (ComplV2 v y) ; + SentV2Mass v x y = mkSent x (ComplV2 v (massNP y)) ; + SentV3 v x y z = mkSent x (ComplV3 v y z) ; + SentV3Mass v x y z = mkSent x (ComplV3 v (massNP y) z) ; + SentA a x = mkSent x (UseComp (CompAP (PositA a))) ; + SentNP a x = mkSent x (UseComp (CompNP a)) ; + + SentAdvV v np adv = mkSent np (AdvVP (UseV v) adv) ; + SentAdvV2 v x y adv = mkSent x (AdvVP (ComplV2 v y) adv) ; + + ImpV v = ImpVP (UseV v) ; + ImpV2 v x = ImpVP (ComplV2 v x) ; + ImpV2Mass v x = ImpVP (ComplV2 v (massNP x)) ; + ImpV3 v x y = ImpVP (ComplV3 v x y) ; + ImpV3Mass v x y = ImpVP (ComplV3 v (massNP x) y) ; + + UsePron p = UsePron p ; + PossPronCNSg p n = DetCN (DetSg (SgQuant (PossPron p)) NoOrd) n; + PossPronCNPl p n = DetCN (DetPl (PlQuant (PossPron p)) NoNum NoOrd) n; + DetCN d n = DetCN d n ; + NumCN k cn = DetCN (DetPl (PlQuant IndefArt) k NoOrd) cn ; + + UseN n = UseN n ; + ModCN a cn = AdjCN (PositA a) cn ; + + UseMassN mn = UseN mn ; + ModMass a cn = AdjCN (PositA a) cn ; + + param + SForm = SPos | SNeg | SQuest ; + + oper + mkSent : NP -> VP -> Sent ; + mkSent np vp = + let cl = PredVP np vp + in { + s = table { + SPos => Predef.toStr S (UseCl TPres ASimul PPos cl) ; + SNeg => Predef.toStr S (UseCl TPres ASimul PNeg cl) ; + SQuest => Predef.toStr QS (UseQCl TPres ASimul PPos (QuestCl cl)) + } ; + lock_Sent = <> + } ; + + massNP : CN -> NP = \mcn -> DetCN (DetSg MassDet NoOrd) mcn ; + + mkQuest : QCl -> Quest ; + mkQuest q = { s = Predef.toStr QS (UseQCl TPres ASimul PPos q); + lock_Quest = <> } ; + +} |
