summaryrefslogtreecommitdiff
path: root/examples/query/QueryEng.gf
diff options
context:
space:
mode:
authoraarne <aarne@chalmers.se>2010-06-16 20:00:46 +0000
committeraarne <aarne@chalmers.se>2010-06-16 20:00:46 +0000
commitd8284f61bf033fed293bbdeeed9c09a379a86100 (patch)
treef09c02c01d58f1051434e84acaaf8388f2dbf5fb /examples/query/QueryEng.gf
parent74811193edec2c935b4a152a5d3fc363fabca39b (diff)
starting query language for MOLTO
Diffstat (limited to 'examples/query/QueryEng.gf')
-rw-r--r--examples/query/QueryEng.gf165
1 files changed, 165 insertions, 0 deletions
diff --git a/examples/query/QueryEng.gf b/examples/query/QueryEng.gf
new file mode 100644
index 000000000..51f1afd7f
--- /dev/null
+++ b/examples/query/QueryEng.gf
@@ -0,0 +1,165 @@
+--# -path=.:present
+
+concrete QueryEng of Query = open
+ ParadigmsEng,
+ IrregEng,
+ SyntaxEng,
+ ExtraEng,
+ (L = LangEng),
+ Prelude
+in {
+
+lincat
+ Move = Utt ; ---- Text ;
+ Query = Utt ;
+ Answer = Utt ;
+ Set = NP ;
+ Relation = {cn : CN ; prep : Prep} ;
+ Kind = CN ;
+ Property = AP ; ---- {vp : VP ; typ : PropTyp} ;
+ Individual = NP ;
+ Activity = VP ;
+ Name = NP ;
+ [Individual] = [NP] ;
+
+lin
+ MQuery q = q ; ---- mkText (mkPhr q) questMarkPunct ;
+ MAnswer a = a ; ---- mkText (mkPhr a) fullStopPunct ;
+
+ QSet s =
+ let
+ ss : NP = s
+ | mkNP (mkNP thePl_Det L.name_N) (mkAdv possess_Prep s)
+ ---- s's names
+ in
+ mkUtt (mkImp (mkVP give_V3 ss (mkNP i_Pron)))
+ | mkUtt (mkQS (mkQCl (L.CompIP whatSg_IP) ss))
+ | mkUtt (mkQS (mkQCl (L.CompIP (L.IdetIP (mkIDet which_IQuant))) ss))
+ | mkUtt ss ;
+
+ QWhere s = mkUtt (mkQS (mkQCl where_IAdv s)) ;
+ QInfo s =
+ let
+ info : NP = mkNP (all_NP | (mkNP information_N)) (mkAdv about_Prep s) ;
+ in
+ mkUtt (mkImp (mkVP give_V3 info (mkNP i_Pron)))
+ | mkUtt info ;
+
+ QCalled i = mkUtt (mkQS (mkQCl how_IAdv (mkCl i (mkVP also_AdV (mkVP called_A))))) ;
+
+ AKind s k = mkUtt (mkCl s (mkNP aPl_Det k)) ; ---- a, fun of s
+ AProp s p = mkUtt (mkCl s p) ;
+ AAct s p = mkUtt (mkCl s p) ;
+
+ SAll k = mkNP all_Predet (mkNP aPl_Det k) | mkNP thePl_Det k ;
+ SOne k = mkNP n1_Numeral k ;
+ SIndef k = mkNP a_Det k ;
+ SPlural k = mkNP aPl_Det k ;
+ SOther k = mkNP aPl_Det (mkCN other_A k) ;
+ SInd i = i ;
+ SInds is = mkNP and_Conj is ;
+
+ KRelSet r s =
+ mkCN r.cn (mkAdv r.prep s) ;
+ ---- | S's R
+
+---- KRelsSet r q s =
+---- mkCN r.cn (mkAdv r.prep s) ;
+
+ KRelKind k r s =
+ mkCN k (mkRS (mkRCl that_RP (mkVP (mkNP aPl_Det (mkCN r.cn (mkAdv r.prep s)))))) ;
+
+ KRelPair k r = mkCN k (mkAdv with_Prep (mkNP (mkQuant they_Pron) plNum r.cn)) ;
+ KProp p k =
+ mkCN p k
+ | mkCN k (mkRS (mkRCl that_RP (mkVP p))) ;
+ KAct p k =
+ mkCN k (mkRS (mkRCl that_RP p)) ;
+ KRel r = r.cn ;
+
+ IName n = n ;
+
+ ACalled is = mkVP also_AdV (mkVP (mkAP (mkA2 called_A []) (mkNP or_Conj is))) ;
+
+ BaseIndividual = mkListNP ;
+ ConsIndividual = mkListNP ;
+
+oper
+-- structural words
+ about_Prep = mkPrep "about" ;
+ all_NP = mkNP (mkPN "all") ; ---
+ also_AdV = mkAdV "also" | mkAdV "otherwise" ;
+ as_Prep = mkPrep "as" ;
+ at_Prep = mkPrep "at" ;
+ called_A = mkA "called" | mkA "named" ;
+ give_V3 = mkV3 give_V ;
+ information_N = mkN "information" ;
+ other_A = mkA "other" ;
+
+-- lexical constructors
+ mkName : Str -> NP =
+ \s -> mkNP (mkPN s) ;
+ mkRelation : Str -> {cn : CN ; prep : Prep} =
+ \s -> {cn = mkCN (mkN s) ; prep = possess_Prep} ;
+
+-- lexicon
+
+lincat
+ Country = {np : NP ; a : A} ;
+ JobTitle = CN ;
+lin
+ NCountry c = c.np ;
+ PCountry c = mkAP c.a ;
+
+ Located i =
+ mkAP (mkA2 (mkA "located") in_Prep) i
+ | mkAP (mkA2 (mkA "situated") in_Prep) i ;
+
+ Employed i =
+ mkAP (mkA2 (mkA "employed") by8agent_Prep) i
+ | mkAP (mkA2 (mkA "paid") by8agent_Prep) i
+ | mkAP (mkA2 (mkA "active") at_Prep) i
+ | mkAP (mkA2 (mkA "professionally active") at_Prep) i ;
+
+ Work i =
+ mkVP (mkV2 (mkV "work") at_Prep) i
+ | mkVP (mkV2 (mkV "collaborate") in_Prep) i ;
+
+ HaveTitle t i =
+ mkVP (mkVP (mkAP (mkA2 (mkA "employed") as_Prep) (mkNP t))) (mkAdv at_Prep i)
+ | mkVP (mkVP (mkV2 (mkV "work") as_Prep) (mkNP t)) (mkAdv at_Prep i)
+ | mkVP (mkVP have_V2 (mkNP the_Det (mkCN (mkN2 (mkN "title")) (mkNP t)))) (mkAdv at_Prep i) ;
+
+ Organization = mkCN (mkN "organization") ;
+ Place = mkCN (mkN "place") ;
+ Person =
+ mkCN (mkN "person" "people")
+ | mkCN (mkN "person") ;
+
+ Location = mkRelation "location" ;
+ Region = mkRelation "region" ;
+ Subregion = mkRelation "subregion" ;
+ RName = mkRelation "name" ;
+ RNickname = mkRelation "nickname" ;
+
+ USA = mkCountry "USA" "American" ;
+ Bulgaria = mkCountry "Bulgaria" "Bulgarian" ;
+ California = mkCountry "California" "Californian" ;
+ OblastSofiya = mkName "Oblast Sofiya" ;
+
+ CEO = mkCN (mkN "CEO") ;
+
+ Microsoft = mkName "Microsoft" ;
+ Google = mkName "Google" ;
+
+ SergeyBrin = mkName "Sergey Brin" ;
+ LarryPage = mkName "Larry Page" ;
+ EricSchmidt = mkName "Eric Schmidt" ;
+ MarissaMayer = mkName "Marissa Mayer" ;
+ UdiManber = mkName "Udi Manber" ;
+
+oper
+ mkCountry : Str -> Str -> {np : NP ; a : A} =
+ \n,a -> {np = mkNP (mkPN n) ; a = mkA a} ;
+
+}