summaryrefslogtreecommitdiff
path: root/examples/query/QueryI.gf
diff options
context:
space:
mode:
authoraarne <aarne@chalmers.se>2010-10-20 16:22:23 +0000
committeraarne <aarne@chalmers.se>2010-10-20 16:22:23 +0000
commit8bffe71cd4af103faaa4276df086aa1b7546844e (patch)
tree09547e1b1f082fd1238e2803bc50f00be96d03bb /examples/query/QueryI.gf
parent2991b7acefd84c62eb305f3d13afc34b401b7527 (diff)
functorized Query and added Swe
Diffstat (limited to 'examples/query/QueryI.gf')
-rw-r--r--examples/query/QueryI.gf180
1 files changed, 180 insertions, 0 deletions
diff --git a/examples/query/QueryI.gf b/examples/query/QueryI.gf
new file mode 100644
index 000000000..16c8ba24c
--- /dev/null
+++ b/examples/query/QueryI.gf
@@ -0,0 +1,180 @@
+incomplete concrete QueryI of Query = open
+ Syntax,
+ LexQuery,
+ Lang,
+ Prelude
+in {
+
+lincat
+ Move = Utt ; ---- Text ;
+ Query = Utt ;
+ Answer = Cl ; -- Utt ;
+ Set = NP ;
+ Interrogative = IP ;
+ Function = Fun ; -- = {cn : CN ; prep : Prep} ;
+ Kind = CN ;
+ Property = Prop ; -- = {ap : AP ; vp : VP} ;
+ Relation = Rel ; -- = {ap : AP ; vp : VP ; prep : Prep} ;
+ Individual = NP ;
+ Name = NP ;
+ [Individual] = [NP] ;
+
+lin
+ MQuery q = q ; ---- mkText (mkPhr q) questMarkPunct ;
+ MAnswer a = mkUtt a ; ---- mkText (mkPhr a) fullStopPunct ;
+
+ QSet s =
+ let
+ ss : NP = s
+ | mkNP (mkNP theSg_Det Lang.name_N) (mkAdv namePrep s)
+ | mkNP (mkNP thePl_Det Lang.name_N) (mkAdv namePrep s)
+---- | mkNP (GenNP s) sgNum Lang.name_N
+---- | mkNP (GenNP s) plNum Lang.name_N ;
+ in
+ mkUtt (mkImp (mkVP LexQuery.give_V3 ss (mkNP i_Pron)))
+ | mkUtt (mkQS (mkQCl (Lang.CompIP whatSg_IP) ss))
+ | mkUtt (mkQS (mkQCl (Lang.CompIP (Lang.IdetIP (mkIDet which_IQuant))) ss))
+ | mkUtt ss ;
+
+ QWhere s =
+ mkUtt (mkQS (mkQCl where_IAdv s))
+ | mkUtt (mkQS (mkQCl where_IAdv (mkCl s located_A))) ;
+ QWhat i p = mkUtt (mkQS (mkQCl i p.vp)) ;
+ QRelWhere s p = mkUtt (mkQS (mkQCl where_IAdv (mkCl s p.vp))) ;
+
+ QFun r s =
+ mkUtt
+ (mkImp (mkVP LexQuery.give_V3
+ (mkNP and_Conj s (detSet s r.cn)) (mkNP i_Pron)))
+ | mkUtt (mkQS (mkQCl (mkIP what_IQuant plNum r.cn) s have_V2))
+ | mkUtt (mkQS (mkQCl whatSg_IP
+ (mkClSlash (mkClSlash s have_V2) (mkAdv as_Prep (mkNP aPl_Det r.cn))))) ;
+
+ QFunPair s f =
+ let
+ ss0 : NP = s
+ | mkNP (mkNP thePl_Det Lang.name_N) (mkAdv namePrep s) ;
+ ss : NP = mkNP and_Conj ss0 (mkNP (mkQuant they_Pron) plNum f.cn)
+ | mkNP ss0 (mkAdv with_Prep (mkNP (mkQuant they_Pron) plNum f.cn))
+ in
+ mkUtt (mkImp (mkVP LexQuery.give_V3 ss (mkNP i_Pron)))
+ | mkUtt (mkQS (mkQCl (Lang.CompIP whatPl_IP) ss))
+ | mkUtt (mkQS (mkQCl (Lang.CompIP (Lang.IdetIP (mkIDet which_IQuant))) ss))
+ | mkUtt ss ;
+
+ QInfo s =
+ let
+ info : NP = mkNP (all_NP | (mkNP information_N)) (mkAdv about_Prep s) ;
+ in
+ mkUtt (mkImp (mkVP LexQuery.give_V3 info (mkNP i_Pron)))
+ | mkUtt (mkQCl whatSg_IP
+ (mkClSlash (mkClSlash (mkNP youSg_Pron) know_V2) (mkAdv about_Prep s)))
+ | mkUtt info ;
+
+ QCalled i = mkUtt (mkQS (mkQCl how_IAdv (mkCl i
+ (mkVP (also_AdV | otherwise_AdV) (mkVP called_A))))) ;
+
+ QWhether a = mkUtt (mkQS a) ;
+
+ AInd s i = (mkCl s i) ;
+ AName s n = (mkCl n (mkNP the_Det (mkCN Lang.name_N (mkAdv namePrep s)))) ;
+ AProp s p = (mkCl s p.vp) ;
+
+ 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 ;
+ SDef k = mkNP the_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 ;
+
+ IWhich k =
+ mkIP what_IQuant (sgNum | plNum) k
+ | mkIP which_IQuant (sgNum | plNum) k ;
+
+ IWho = whoSg_IP | whoPl_IP ;
+ IWhat = whatSg_IP | whatPl_IP ;
+
+ KFunSet r s =
+ mkCN r.cn (mkAdv r.prep s) ;
+
+ KFunKind k r s =
+ mkCN k (mkRS (mkRCl which_RP (mkVP (mkNP aPl_Det (mkCN r.cn (mkAdv r.prep s))))))
+ | mkCN k (mkRS (mkRCl that_RP (mkVP (mkNP aPl_Det (mkCN r.cn (mkAdv r.prep s))))))
+ ;
+
+ KFunPair k r = mkCN k (mkAdv with_Prep (mkNP (mkQuant they_Pron) plNum r.cn)) ;
+ KProp p k =
+ participlePropCN p k
+ | mkCN k (mkRS (mkRCl which_RP p.vp))
+ | mkCN k (mkRS (mkRCl that_RP p.vp))
+ ;
+ KFun r = r.cn ;
+
+ IName n = n ;
+
+ PCalled i = propCalled i ;
+ PCalleds is = propCalled (mkNP or_Conj is) ;
+
+ BaseIndividual = mkListNP ;
+ ConsIndividual = mkListNP ;
+
+-- these need new things in resource
+lin
+ KFunsSet r q s =
+ mkCN (ConjCN and_Conj (BaseCN r.cn q.cn)) (mkAdv r.prep s) ;
+ SFun s r = mkNP (GenNP s) plNum r.cn | mkNP (GenNP s) sgNum r.cn ;
+ QWhatWhat i j p = mkUtt (mkQS (QuestQVP i (AdvQVP p.vp (mkIAdv p.prep j)))) ;
+ QWhatWhere i p = mkUtt (mkQS (QuestQVP i (AdvQVP p.vp where_IAdv))) ;
+ PIs i = propVP (mkVP i) ;
+ AKind s k = (mkCl s (Lang.UseComp (Lang.CompCN k))) ;
+
+ PRelation r s = {
+ ap = AdvAP r.ap (mkAdv r.prep s) ;
+ vp = mkVP r.vp (mkAdv r.prep s)
+ } ;
+
+oper
+ namePrep : Prep = possess_Prep ;
+
+ relVP : VP -> Prep -> Rel = \vp,p -> {
+ ap = vpAP vp ;
+ vp = vp ;
+ prep = p
+ } ;
+
+ propVP : VP -> Prop = \vp -> {
+ ap = vpAP vp ;
+ vp = vp
+ } ;
+
+ propAP : AP -> Prop = \ap -> {
+ ap = ap ;
+ vp = mkVP ap
+ } ;
+
+ relAP : AP -> Prep -> Rel = \ap,p -> {
+ ap = ap ;
+ vp = mkVP ap ;
+ prep = p
+ } ;
+
+ propCalled : NP -> Prop = \i ->
+ propAP (mkAP (also_AdA | otherwise_AdA) (mkAP (mkA2 called_A (mkPrep [])) i)) ;
+
+ detSet : NP -> CN -> NP = \s,c ->
+ mkNP (mkQuant they_Pron) plNum c ;
+
+
+-- lexicon
+
+lincat
+ Country = {np : NP ; a : A} ;
+ JobTitle = CN ;
+lin
+ NCountry c = c.np ;
+ PCountry c = propAP (mkAP c.a) ;
+
+}
+