mirror of
https://github.com/GrammaticalFramework/gf-core.git
synced 2026-05-13 05:02:50 -06:00
70 lines
2.2 KiB
Plaintext
70 lines
2.2 KiB
Plaintext
--# -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 = "[..]" ;
|
|
|
|
}
|