forked from GitHub/gf-core
Adding coding pragmas
--# -coding=latin1
so that grammars will continue to work when we change the default character
encoding to UTF-8.
261 lines
11 KiB
Plaintext
261 lines
11 KiB
Plaintext
-- (c) 2009 Aarne Ranta under LGPL
|
|
--# -coding=latin1
|
|
|
|
concrete WordsDan of Words = SentencesDan **
|
|
open SyntaxDan, ParadigmsDan, IrregDan, (L = LexiconDan), ExtraDan, StructuralDan, Prelude in {
|
|
|
|
lin
|
|
|
|
-- kinds of food
|
|
|
|
Apple = mkCN L.apple_N ;
|
|
Beer = mkCN L.beer_N ;
|
|
Bread = mkCN L.bread_N ;
|
|
Cheese = mkCN (mkN "ost" "osten" "oste" "ostene") ;
|
|
Chicken = mkCN (mkN "kylling" "kyllingen" "kyllinger" "kyllingerne") ;
|
|
Coffee = mkCN (mkN "kaffe" "kaffen" "kaffe" "kaffe") ; -- den kaffe
|
|
Fish = mkCN L.fish_N ;
|
|
Meat = mkCN (mkN "kød" "kødet" "kød" "kødet") ;
|
|
Milk = mkCN L.milk_N ;
|
|
Pizza = mkCN (mkN "pizza" "pizzaen" "pizzaer" "pizzaerne") ; -- den pizza
|
|
Salt = mkCN L.salt_N ;
|
|
Tea = mkCN (mkN "te" "teen" "teer" "teerne") ; -- den te
|
|
Water = mkCN L.water_N ;
|
|
Wine = mkCN L.wine_N ;
|
|
|
|
-- properties
|
|
|
|
Bad = L.bad_A ;
|
|
Cheap = mkA "billig" ;
|
|
Boring = mkA "kedelig" ;
|
|
Cold = L.cold_A ;
|
|
Delicious = mkA "lækker" ;
|
|
Expensive = mkA "dyr" ; -- or dyrt
|
|
Fresh = mkA "frisk" ;
|
|
Good = L.good_A ;
|
|
Suspect = mkA "mistænkelig" ;
|
|
Warm = L.warm_A ;
|
|
|
|
-- places
|
|
|
|
|
|
Airport = mkPlace (mkN "lufthavnen" "lufthavnen" "lufthavne" "lufthavnene") "i" ;
|
|
AmusementPark = mkPlace (mkN "forlystelsespark" "forlystelsesparken" "forlystelsesparker" "forlystelsesparker") "i" ;
|
|
Bank = mkPlace (mkN "bank" "banken" "banke" "bankene") "i" ;
|
|
Bar = mkPlace (mkN "bar" "baren" "barer" "barerne") "i" ;
|
|
Cafeteria = mkPlace (mkN "cafeteria" "cafeteriet" "cafeterier" "cafeterierne") "i" ;
|
|
Center = mkPlace (mkN "centrum" "centrum" "centrummer" "centrummerne") "i" ; -- all centrum ?
|
|
Cinema = mkPlace (mkN "biograf" "biografen" "biografer" "biograferne") "i" ;
|
|
Church = mkPlace (mkN "kirke" "kirken" "kirker" "kirkerne") "i" ;
|
|
Disco = mkPlace (mkN "diskotek" "diskoteket" "diskoteker" "diskotekerne") "på" ;
|
|
Hospital = mkPlace (mkN "hospital" "hospitalet" "hospitaler" "hospitalerne") "på" ;
|
|
|
|
Hotel = mkPlace (mkN "hotel" "hotellet" "hoteller" "hotellerne") "på" ;
|
|
Museum = mkPlace (mkN "museum" "museet" "museer" "museerne") "på" ;
|
|
Park = mkPlace (mkN "park" "parken" "parker" "parkerne") "i" ;
|
|
Parking = mkPlace (mkN "parkeringsplads" "parkeringspladsen" "parkeringspladser" "parkeringspladserne") "på" ;
|
|
Pharmacy = mkPlace (mkN "apotek" "apoteket" "apoteker" "apotekerne") "på" ;
|
|
PostOffice = mkPlace (mkN "posthus" "posthuset" "posthuse" "posthusene") "på" ;
|
|
Pub = mkPlace (mkN "pub" "pubben" "pubber" "pubber") "på" ;
|
|
Restaurant = mkPlace (mkN "restaurant" "restauranten" "restauranter" "restauranterne") "på" ;
|
|
School = mkPlace (mkN "skole" "skolen" "skoler" "skolerne") "i" ;
|
|
Shop = mkPlace (mkN "butik" "butikken" "butikker" "butikkerne") "i" ;
|
|
Station = mkPlace (mkN "station" "stationen" "stationer" "stationerne") "på" ;
|
|
Supermarket = mkPlace (mkN "supermarked" "supermarkedet" "supermarkeder" "supermarkederne") "i" ;
|
|
Theatre = mkPlace (mkN "teater" "teatret" "teatre" "teatrene") "i" ;
|
|
Toilet = mkPlace (mkN "toilet" "toilettet" "toiletter" "toiletterne") "på" ;
|
|
University = mkPlace (mkN "universitet" "universitetet" "universiteter" "universiteterne") "på" ;
|
|
Zoo = mkCNPlace (mkCN (mkA "zoologisk") (mkN "have")) in_Prep to_Prep ;
|
|
|
|
CitRestaurant cit = mkCNPlace (mkCN cit (mkN "restaurant")) (mkPrep "på") to_Prep ;
|
|
|
|
-- currencies
|
|
|
|
DanishCrown = mkCN (mkA "dansk") (mkN "krone" "kronen" "kroner" "kronerne") | mkCN (mkN "krone" "kronen" "kroner" "kronerne") ;
|
|
Dollar = mkCN (mkN "dollar" "dollaren" "dollar" "dollar") ; -- den dollar
|
|
Euro = mkCN (mkN "euro" "euroen" "euro" "euroerne") ; -- den euro
|
|
Lei = mkCN (mkN "leu" "leu" "lei" "lei") ; -- det leis ?
|
|
Leva = mkCN (mkN "lev" "lev" "leva" "leva") ; -- det leva ?
|
|
NorwegianCrown = mkCN (mkA "norsk") (mkN "krone" "kronen" "kroner" "kronerne") | mkCN (mkN "krone" "kronen" "kroner" "kronerne") ;
|
|
Pound = mkCN (mkN "pund" "pundet" "pund" "pundene") ; -- det pund
|
|
Rouble = mkCN (mkN "rubel" "rublen" "rubler" "rublerne") ; -- den rubel
|
|
SwedishCrown = mkCN (mkA "svensk") (mkN "krone" "kronen" "kroner" "kronerne") | mkCN (mkN "krone" "kronen" "kroner" "kronerne") ;
|
|
Zloty = mkCN (mkN "zloty" "zloty" "zloty" "zloty") ; -- det zloty ?
|
|
|
|
-- nationalities
|
|
|
|
|
|
Belgian = mkA "belgisk" ;
|
|
Belgium = mkNP (mkPN "Belgien") ;
|
|
Bulgarian = mkNat "bulgarsk" "Bulgarien" ;
|
|
Catalan = mkNPNationality (mkNP (mkPN "catalansk")) (mkNP (mkPN "Catalonien")) (mkA "catalonsk") ;
|
|
Danish = mkNat "dansk" "Danmark" ;
|
|
Dutch = mkNat "hollandsk" "Holland" ;
|
|
English = mkNat "engelsk" "England" ;
|
|
Finnish = mkNat "finsk" "Finland" ;
|
|
Flemish = mkNP (mkPN "flamsk") ;
|
|
French = mkNat "fransk" "Frankrig" ;
|
|
German = mkNat "tysk" "Tyskland" ;
|
|
Italian = mkNat "italiensk" "Italien" ;
|
|
Norwegian = mkNat "norsk" "Norge" ;
|
|
Polish = mkNat "polsk" "Polen" ;
|
|
Romanian = mkNat "rumænsk" "Rumænien" ;
|
|
Russian = mkNat "russisk" "Russland" ;
|
|
Spanish = mkNat "spansk" "Spanien" ;
|
|
Swedish = mkNat "svensk" "Sverige" ;
|
|
|
|
|
|
|
|
-- Means of transportation
|
|
|
|
Bike = mkTransport L.bike_N ;
|
|
Bus = mkTransport (mkN "bus" "bussen" "busser" "busserne") ;
|
|
Car = mkTransport L.car_N ;
|
|
Ferry = mkTransport (mkN "færge" "færgen" "færger" "færgerne") ;
|
|
Plane = mkTransport L.airplane_N ;
|
|
Subway = mkTransport (mkN "undergrundsbane" "undergrundsbanen" "undergrundsbaner" "undergrundsbanerne") ;
|
|
Taxi = mkTransport (mkN "taxa") ;
|
|
Train = mkTransport (mkN "tog" "toget" "tog" "togene") ;
|
|
Tram = mkTransport (mkN "sporvogn" "sporvognen" "sporvogne" "sporvognene") ;
|
|
|
|
ByFoot = ParadigmsDan.mkAdv "til fods" ;
|
|
|
|
|
|
|
|
|
|
-- actions
|
|
|
|
AHasAge p num = mkCl p.name (mkNP num L.year_N) ;
|
|
AHasName p name = mkCl p.name (mkV2 (mkV "hedde")) name ;
|
|
AHasChildren p num = mkCl p.name have_V2 (mkNP num L.child_N) ;
|
|
AHasRoom p num = mkCl p.name have_V2
|
|
(mkNP (mkNP a_Det (mkN "værelse" "værelset" "værelser" "værelserne"))
|
|
(SyntaxDan.mkAdv to_Prep (mkNP num (mkN "person" "personen" "personer" "personerne")))) ;
|
|
AHasTable p num = mkCl p.name have_V2
|
|
(mkNP (mkNP a_Det (mkN "bord"))
|
|
(SyntaxDan.mkAdv to_Prep (mkNP num (mkN "person" "personen" "personer" "personerne")))) ;
|
|
AHungry p = mkCl p.name (mkA "sulten" "sultet" "sultne") ;
|
|
AIll p = mkCl p.name (mkA "syg") ;
|
|
AKnow p = mkCl p.name vide_V ;
|
|
ALike p item = mkCl p.name (mkV2 holde_V (mkPrep "af")) item ;
|
|
ALive p co = mkCl p.name (mkVP (mkVP (mkV "bo")) (SyntaxDan.mkAdv in_Prep co)) ;
|
|
ALove p q = mkCl p.name (dirV2 (regV "elske")) q.name ;
|
|
AMarried p = mkCl p.name (mkA "gift") ;
|
|
AReady p = mkCl p.name (mkA "færdig") ;
|
|
AScared p = mkCl p.name (mkA "bange") ;
|
|
ASpeak p lang = mkCl p.name (mkV2 (mkV "tale")) lang ;
|
|
AThirsty p = mkCl p.name (mkA "tørstig") ;
|
|
ATired p = mkCl p.name (mkA "træt") ;
|
|
AUnderstand p = mkCl p.name (irregV "forstå" "forstod" "forstået") ;
|
|
AWant p obj = mkCl p.name want_VV (mkVP have_V2 obj) ;
|
|
-- AWantGo p place = mkCl p.name want_VV (mkVP (mkVP L.go_V) place.to) ;
|
|
AWantGo p place = mkCl p.name want_VV (mkVP (mkVP tage_V) place.to) ;
|
|
|
|
-- miscellaneous
|
|
|
|
QWhatName p = mkQS (mkQCl whatSg_IP p.name (mkV2 hede_V)) ;
|
|
QWhatAge p = mkQS (mkQCl (ICompAP (mkAP L.old_A)) p.name) ;
|
|
HowMuchCost item = mkQS (mkQCl how8much_IAdv (mkCl item (mkV "koste"))) ;
|
|
ItCost item price = mkCl item (mkV2 (mkV "koste")) price ;
|
|
|
|
PropOpen p = mkCl p.name (mkVP (mkVP have_V) open_Adv) ;
|
|
PropClosed p = mkCl p.name (mkVP (mkVP have_V) closed_Adv) ;
|
|
PropOpenDate p d = mkCl p.name (mkVP (mkVP (mkVP have_V) open_Adv) d) ;
|
|
PropClosedDate p d = mkCl p.name (mkVP (mkVP (mkVP have_V) closed_Adv) d) ;
|
|
PropOpenDay p d = mkCl p.name (mkVP (mkVP (mkVP have_V) open_Adv) d.habitual) ;
|
|
PropClosedDay p d = mkCl p.name (mkVP (mkVP (mkVP have_V) closed_Adv) d.habitual) ;
|
|
|
|
-- Building phrases from strings is complicated: the solution is to use
|
|
-- mkText : Text -> Text -> Text ;
|
|
|
|
PSeeYouDate d = mkText (lin Text (ss ("vi ses"))) (mkPhrase (mkUtt d)) ;
|
|
PSeeYouPlace p = mkText (lin Text (ss ("vi ses"))) (mkPhrase (mkUtt p.at)) ;
|
|
PSeeYouPlaceDate p d =
|
|
mkText (lin Text (ss ("vi ses")))
|
|
(mkText (mkPhrase (mkUtt p.at)) (mkPhrase (mkUtt d))) ;
|
|
|
|
-- Relations are expressed as "my wife" or "my son's wife", as defined by $xOf$
|
|
-- below. Languages without productive genitives must use an equivalent of
|
|
-- "the wife of my son" for non-pronouns.
|
|
|
|
Wife = xOf sing (mkN "kone" "konen" "koner" "konerne") ;
|
|
Husband = xOf sing L.man_N ;
|
|
Son = xOf sing (mkN "søn" "sønnen" "sønner" "sønnerne") ;
|
|
Daughter = xOf sing (mkN "datter" "datteren" "døtre" "døtrene") ;
|
|
Children = xOf plur L.child_N ;
|
|
|
|
-- week days
|
|
|
|
Monday = mkDay "mandag" ;
|
|
Tuesday = mkDay "tirsdag" ;
|
|
Wednesday = mkDay "onsdag" ;
|
|
Thursday = mkDay "torsdag" ;
|
|
Friday = mkDay "fredag" ;
|
|
Saturday = mkDay "lørdag" ;
|
|
Sunday = mkDay "søndag" ;
|
|
|
|
Tomorrow = ParadigmsDan.mkAdv "i morgen" ;
|
|
|
|
|
|
-- modifiers of places
|
|
|
|
TheBest = mkSuperl L.good_A ;
|
|
TheClosest = mkSuperl L.near_A ;
|
|
TheCheapest = mkSuperl (mkA "billig") ;
|
|
TheMostExpensive = mkSuperl (mkA "dyr") ;
|
|
TheMostPopular = mkSuperl (mkA "populær") ;
|
|
TheWorst = mkSuperl L.bad_A ;
|
|
|
|
SuperlPlace sup p = placeNP sup p ;
|
|
|
|
|
|
|
|
|
|
-- transports
|
|
|
|
HowFar place =
|
|
mkQS (mkQCl long_IAdv (mkCl (mkVP (SyntaxDan.mkAdv to_Prep place.name)))) ;
|
|
HowFarFrom place x =
|
|
mkQS (mkQCl long_IAdv (mkCl place.name (SyntaxDan.mkAdv from_Prep x.name))) ;
|
|
HowFarFromBy x y t =
|
|
mkQS (mkQCl long_IAdv (mkCl y.name (SyntaxDan.mkAdv from_Prep (mkNP x.name t)))) ;
|
|
HowFarBy y t =
|
|
mkQS (mkQCl long_IAdv (mkCl y.name t)) ;
|
|
-- not sure !
|
|
WhichTranspPlace trans place =
|
|
mkQS (mkQCl (mkIP which_IDet trans.name) (mkVP (mkVP L.go_V) place.to)) ;
|
|
|
|
IsTranspPlace trans place =
|
|
mkQS (mkQCl (mkCl (mkCN trans.name place.to))) ;
|
|
|
|
|
|
oper
|
|
mkNat : Str -> Str -> NPNationality = \nat,co ->
|
|
mkNPNationality (mkNP (mkPN nat)) (mkNP (mkPN co)) (mkA nat) ;
|
|
-- don't add the "a"
|
|
mkDay : Str -> {name : NP ; point : Adv ; habitual : Adv} = \d ->
|
|
let day = mkNP (mkPN d) in
|
|
mkNPDay day (SyntaxDan.mkAdv on_Prep day)
|
|
(SyntaxDan.mkAdv on_Prep (mkNP a_Quant plNum (mkCN (mkN d)))) ;
|
|
|
|
mkPlace : N -> Str -> {name : CN ; at : Prep ; to : Prep; isPl : Bool} = \p,i ->
|
|
mkCNPlace (mkCN p) (mkPrep i) to_Prep ;
|
|
|
|
open_Adv = ParadigmsDan.mkAdv "åbent" ;
|
|
closed_Adv = ParadigmsDan.mkAdv "lukket" ;
|
|
|
|
xOf : GNumber -> N -> NPPerson -> NPPerson = \n,x,p ->
|
|
relativePerson n (mkCN x) (\a,b,c -> mkNP (GenNP b) a c) p ;
|
|
|
|
mkSuperl : A -> Det = \a -> mkDet the_Art (mkOrd a) ;
|
|
|
|
mkTransport : N -> {name : CN ; by : Adv} = \n -> {
|
|
name = mkCN n ;
|
|
by = SyntaxDan.mkAdv by8means_Prep (mkNP n)
|
|
} ;
|
|
|
|
far_IAdv = ExtraDan.IAdvAdv L.far_Adv ;
|
|
long_IAdv : IAdv = ss "hvor langt" ** {lock_IAdv = <>};
|
|
how8much_IAdv : IAdv = ss "hvad" ** {lock_IAdv = <>};
|
|
}
|