From b08309f236df7a7ad0eb388164281ce799458eb8 Mon Sep 17 00:00:00 2001 From: aarne Date: Tue, 20 Sep 2011 08:54:35 +0000 Subject: [PATCH] QueryIta added --- examples/query/small/QueryFin.gf | 2 +- examples/query/small/QueryIta.gf | 150 +++++++++++++++++++++++++++++++ 2 files changed, 151 insertions(+), 1 deletion(-) create mode 100644 examples/query/small/QueryIta.gf diff --git a/examples/query/small/QueryFin.gf b/examples/query/small/QueryFin.gf index 552810bc1..b7b5c7b4d 100644 --- a/examples/query/small/QueryFin.gf +++ b/examples/query/small/QueryFin.gf @@ -31,7 +31,7 @@ lin MQuery q = q ; MAnswer a = a ; - QSet s = mkUtt (mkImp (mkV2 (mkV "luetella")) s) ; + QSet s = mkUtt (mkImp (mkV2 (mkV "näyttää")) s) ; QWhere s = mkUtt (mkQS (ICompExistNP (mkIComp where_IAdv) s)) ; QInfo s = mkUtt (mkImp (mkVP (mkV2 (mkV "antaa")) diff --git a/examples/query/small/QueryIta.gf b/examples/query/small/QueryIta.gf new file mode 100644 index 000000000..dd5cd14b5 --- /dev/null +++ b/examples/query/small/QueryIta.gf @@ -0,0 +1,150 @@ +--# -path=.:alltenses + +concrete QueryIta of Query = open + ParadigmsIta, + SyntaxIta, + ExtraIta, + (G = GrammarIta), + SymbolicIta, + Prelude +in { + +flags coding = utf8 ; + +-- for a baseline: just change these lexical entries +oper + about_Prep = on_Prep ; + also_AdV = lin AdV (ss "anche") ; + as_Prep = mkPrep "come" ; + at_Prep = mkPrep "presso" ; + called_A = mkA "chiamato" ; + give_V = mkV "mostrare" ; + information_N = mkN "informazione" feminine ; + other_A = prefixA (mkA "altro") ; + name_N = mkN "nome" ; + nickname_N = mkN "soprannome" ; + located_A = mkA "situato" ; + employed_A = mkA "impiegato" ; + work_V = mkV "lavorare" ; + position_N = mkN "posto" ; + organization_N = mkN "organizzazione" feminine ; + place_N = mkN "luogo" ; + person_N = mkN "persona" ; + location_N = mkN "posizione" feminine ; + region_N = mkN "regione" feminine ; + subregion_N = mkN "sottoregione" feminine ; + +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 ; + Loc = NP ; + Org = NP ; + Pers = NP ; + [Individual] = [NP] ; + +lin + MQuery q = q ; + MAnswer a = a ; + + QSet s = mkUtt (mkVP (mkV2 give_V) s) ; + + QWhere s = mkUtt (mkQS (mkQCl where_IAdv s)) ; + QInfo s = mkUtt (mkVP (mkV2 give_V) + (mkNP all_Predet (mkNP thePl_Det (mkCN information_N (mkAdv on_Prep s))))) ; + + QCalled i = mkUtt (mkQS (mkQCl (mkIP whichSg_IDet (mkCN other_A name_N)) i have_V2)) ; + + AKind s k = mkUtt (mkCl s (mkNP aPl_Det k)) ; + AProp s p = mkUtt (mkCl s p) ; + AAct s p = mkUtt (mkCl s p) ; + + SAll k = mkNP all_Predet (mkNP thePl_Det k) ; + SOne k = mkNP a_Det k ; + SIndef k = mkNP someSg_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) ; + KRelKind k r s = mkCN k (mkRS (mkRCl which_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 ; + KAct p k = mkCN k (mkRS (mkRCl which_RP p)) ; + KRel r = r.cn ; + + IName n = n ; + NLoc n = n ; + NOrg n = n ; + NPers n = n; + + ACalled is = mkVP also_AdV (mkVP (mkAP (mkA2 called_A (mkPrep "")) (mkNP or_Conj is))) ; + + BaseIndividual = mkListNP ; + ConsIndividual = mkListNP ; + +oper + +-- lexical constructors + mkName : Str -> NP = + \s -> mkNP (mkPN s) ; + mkRelation : N -> {cn : CN ; prep : Prep} = + \s -> {cn = mkCN s ; prep = possess_Prep} ; + +-- lexicon + +lincat + JobTitle = CN ; +lin + Located i = mkAP (mkA2 located_A in_Prep) i ; + Employed i = mkAP (mkA2 employed_A at_Prep) i ; + Work i = mkVP (mkV2 work_V at_Prep) i ; + + HaveTitle t = mkVP have_V2 (mkNP the_Det (mkCN position_N (mkAdv possess_Prep (mkNP t)))) ; + HaveTitleOrg t i = mkVP (mkVP have_V2 (mkNP the_Det (mkCN position_N (mkAdv possess_Prep (mkNP t))))) (mkAdv in_Prep i) ; + + Organization = mkCN organization_N ; + Place = mkCN place_N ; + Person = mkCN person_N ; + + Location = mkRelation location_N ; + Region = mkRelation region_N ; + Subregion = mkRelation subregion_N ; + RName = mkRelation name_N ; + RNickname = mkRelation nickname_N ; + +-- JobTitles + JobTitle1 = mkCN (mkN "'JobTitle1") ; + JobTitle2 = mkCN (mkN "'JobTitle2") ; + JobTitle3 = mkCN (mkN "'JobTitle3") ; + JobTitle4 = mkCN (mkN "'JobTitle4") ; + +-- Locations + Location1 = mkName "'Location1" ; + Location2 = mkName "'Location2" ; + Location3 = mkName "'Location3" ; + Location4 = mkName "'Location4" ; + +-- Organizations + Organization1 = mkName "'Organization1" ; + Organization2 = mkName "'Organization2" ; + Organization3 = mkName "'Organization3" ; + Organization4 = mkName "'Organization4" ; + +-- Persons + Person1 = mkName "'Person1" ; + Person2 = mkName "'Person2" ; + Person3 = mkName "'Person3" ; + Person4 = mkName "'Person4" ; + + +}