summaryrefslogtreecommitdiff
path: root/examples/fracas/src/FraCaSSwe.gf
blob: 733384d1ae78d4c3e8c05ac6e8e5285550515e20 (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
--# -path=.:alltenses

concrete FraCaSSwe of FraCaS = GrammarSwe, AdditionsSwe, FraCaSLexSwe ** open
  Prelude,
  (G=GrammarSwe),
  (A=AdditionsSwe),
  (I=IrregSwe),
  (M=MorphoSwe),
  (P=ParadigmsSwe),
  (X=ParamX),
  (C=Coordination)
  in {

-- language independent functions

lin
  ComparAsAs x0 x1 = (G.CAdvAP (G.as_CAdv) (G.PositA x0) x1);

lin
  Adverbial x0 = (PAdverbial (G.NoPConj) x0);
  PAdverbial x0 x1 = (G.PhrUtt x0 (G.UttAdv x1) (G.NoVoc));
  Nounphrase x0 = (PNounphrase (G.NoPConj) x0);
  PNounphrase x0 x1 = (G.PhrUtt x0 (G.UttNP x1) (G.NoVoc));
  Question x0 = (PQuestion (G.NoPConj) x0);
  PQuestion x0 x1 = (G.PhrUtt x0 (G.UttQS x1) (G.NoVoc));
  Sentence x0 = (PSentence (G.NoPConj) x0);
  PSentence x0 x1 = (G.PhrUtt x0 (G.UttS x1) (G.NoVoc));

lin
  Past = (G.TTAnt (G.TPast) (G.ASimul));
  PastPerfect = (G.TTAnt (G.TPast) (G.AAnter));
  Present = (G.TTAnt (G.TPres) (G.ASimul));
  PresentPerfect = (G.TTAnt (G.TPres) (G.AAnter));
  Future = (G.TTAnt (G.TFut) (G.ASimul));
  FuturePerfect = (G.TTAnt (G.TFut) (G.AAnter));
  Conditional = (G.TTAnt (G.TCond) (G.ASimul));

lin
  ConjCN2 c n1 n2 = (G.ConjCN c (G.BaseCN n1 n2));
  ConjNP2 c n1 n2 = (G.ConjNP c (G.BaseNP n1 n2));
  ConjNP3 c n1 n2 n3 = (G.ConjNP c (G.ConsNP n1 (G.BaseNP n2 n3)));
  ConjQS2 c q1 q2 = (A.ConjQS c (A.BaseQS q1 q2));
  ConjS2 c s1 s2 = (G.ConjS c (G.BaseS s1 s2));
  ConjVPI2 c v1 v2 = (A.ConjVPI c (A.BaseVPI (A.MkVPI v1) (A.MkVPI v2)));
  ConjVPS2 c t1 p1 v1 t2 p2 v2 = (A.ConjVPS c (A.BaseVPS (A.MkVPS t1 p1 v1) (A.MkVPS t2 p2 v2)));

-- language dependent functions

lin
  UncNeg = G.PNeg ;

lin
  ComplVSa = G.ComplVS ;
  ProgrVPa vp = vp ;

lin
  elliptic_V = {s = \\_ => ellipsis; part = ""; vtype = M.VAct};
  elliptic_NP_Sg = {s = \\_ => ellipsis; a = M.agrP3 M.utrum M.Sg} ;
  elliptic_NP_Pl = {s = \\_ => ellipsis; a = M.agrP3 M.utrum M.Pl} ;
  elliptic_VP = G.UseV elliptic_V ;
  elliptic_Cl = {s = \\_,_,_,_ => ellipsis} ;
  elliptic_VPSlash = G.UseV elliptic_V ** {c2 = {s=ellipsis; hasPrep=False}; n3 = \\_ => ellipsis};
  elliptic_V2V = elliptic_V ** {c2,c3 = M.mkComplement ""} ;
  elliptic_CN = {s = \\_,_,_ => ellipsis; g = M.utrum; isMod = False} ;

oper
  ellipsis : Str = "[..]" ;

}