summaryrefslogtreecommitdiff
path: root/examples/peacekeeping/PeaceSyntaxI.gf
blob: 89517d735f90eb36fce6652f4a7b9c8f1dad435e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
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 = <> } ;

}