PhraseBookRon

This commit is contained in:
ramona.enache
2010-04-10 23:17:58 +00:00
parent 50a2e2ea93
commit ec80e12435

View File

@@ -2,7 +2,8 @@
concrete WordsRon of Words = SentencesRon ** open
SyntaxRon,
ParadigmsRon,
(P = ParadigmsRon),
NounRon,
(L = LexiconRon),
BeschRon in {
@@ -15,70 +16,168 @@ concrete WordsRon of Words = SentencesRon ** open
Apple = mkCN L.apple_N ;
Beer = mkCN L.beer_N ;
Bread = mkCN L.bread_N ;
Cheese = mkCN (mkN "brânză" "brânzeturi" feminine) ;
Cheese = mkCN L.cheese_N ;
Chicken = mkCN (P.mkN "pui" "pui") ;
Coffee = mkCN (P.mkN "cafea") ;
Fish = mkCN L.fish_N ;
Meat = mkCN (P.mkN "carne" "cărnuri" "cărni") ;
Milk = mkCN L.milk_N ;
Pizza = mkCN (mkN "pizza" "pizze" feminine) ;
Pizza = mkCN (P.mkN "pizză") ;
Salt = mkCN L.salt_N ;
Tea = mkCN (P.mkNR "ceai") ;
Water = mkCN L.water_N ;
Wine = mkCN L.wine_N ;
-- qualities
Bad = L.bad_A ;
Boring = mkA "plictisitor" "plictisitoare" "plictisitori" "plictisitoare" ;
Boring = P.mkA "plictisitor" "plictisitoare" "plictisitori" "plictisitoare" ;
Cheap = P.mkA "ieftin" ;
Cold = L.cold_A ;
Delicious = mkA "delicios" "delcioasă" "delicioşi" "delicioase" ;
Expensive = mkA "scump" "scumpă" "scumpi" "scumpe" ;
Fresh = mkA "proaspăt" "proaspătă" "proaspeţi" "proaspete" ;
Delicious = P.mkA "delicios" "delcioasă" "delicioşi" "delicioase" ;
Expensive = P.mkA "scump" "scumpă" "scumpi" "scumpe" ;
Fresh = P.mkA "proaspăt" "proaspătă" "proaspeţi" "proaspete" ;
Good = L.good_A ;
Suspect = P.mkA "suspect" ;
Warm = L.warm_A ;
-- places
Bar = mkPlace (mkNR "bar") in_Prep ;
Restaurant = mkPlace (mkN "restaurant") in_Prep ;
Toilet = mkPlace (mkN "toaleta") in_Prep ;
Airport = mkPlace (P.mkNR "aeroport") in_Prep ;
Bar = mkPlace (P.mkNR "bar") in_Prep ; -- at_Prep which doesn't exist
Church = mkPlace (P.mkN "biserică" "biserici") in_Prep ;
Cinema = mkPlace (P.mkNR "cinema") in_Prep ;
Hospital = mkPlace (P.mkN "spital") in_Prep ;
Hotel = mkPlace (P.mkNR "hotel") in_Prep ; -- at_Prep, plural ending in -e is accepted also
Museum = mkPlace (P.mkN "muzeu" "muzee") in_Prep ;
Park = mkPlace (P.mkNR "parc") in_Prep ;
Restaurant = mkPlace (P.mkN "restaurant") in_Prep ; -- at_Prep
School = mkPlace (P.mkN "şcoală" "şcoli") in_Prep ; -- at_Prep
Shop = mkPlace (P.mkN "magazin") in_Prep ; -- at_Prep
Station = mkPlace (P.mkN "gară" "gări") in_Prep ; -- at_Prep
Theatre = mkPlace (P.mkN "teatru" "teatre") in_Prep; -- at_Prep
Toilet = mkPlace (P.mkN "toaletă") in_Prep ; -- at_Prep
University = mkPlace (P.mkN "universitate") in_Prep ;
-- currencies
Dollar = mkCN (mkN "dolar" masculine) ;
Euro = mkCN (mkN "euro" "euro") ;
Lei = mkCN (mkN "leu" "lei") ;
Dollar = mkCN (P.mkN "dolar" P.masculine) ;
Euro = mkCN (P.mkN "euro" "euro") ;
Lei = mkCN (P.mkN "leu" "lei") ;
DanishCrown = mkCN (P.mkN "coroană") ;
SwedishCrown = mkCN (P.mkN "coroană") ;
-- nationalities
-- English = SyntaxRon.mkNP (mkPN "engleză") ; ---- ?
-- Finnish = mkNP (mkPN "finnois") ;
-- French = mkNP (mkPN "français") ;
-- Italian = mkA "italian" "italiană" "italieni" "italiene" ;
-- Romanian = SyntaxRon.mkNP (mkPN "română") ; ---- ?
-- Swedish = mkNP (mkPN "suédois") ;
Belgian = P.mkA "belgian" ;
Belgium = UsePN (P.mkPN "Belgia") ;
English = mkNat "englez" "Anglia" ;
Finnish = mkNat "finlandez" "Finlanda" ;
-- Flemish = UsePN (P.mkPN "fiammingo") ; -- why NP ?
French = mkNat "francez" "Franţa" ;
Italian = mkNat "italian" "Italia" ;
Romanian = mkNat "român" "România" ;
Swedish = mkNat "suedez" "Suedia" ;
-- actions
AWant p obj = mkCl p.name (dirV2 (lin V want_VV)) obj ;
ALike p item = mkCl p.name (dirV2 (v_besch71 "plăcea")) item ;
ASpeak p lang = mkCl p.name (dirV2 (mkV "vorbi")) lang ;
ALove p q = mkCl p.name (dirV2 (mkV "iubi")) q.name ;
AHasAge p num = mkCl p.name have_V2 (mkNP num L.year_N) ;
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 (P.mkN "cameră")) (SyntaxRon.mkAdv for_Prep (mkNP num (P.mkN "persoană")))) ;
AHasTable p num = mkCl p.name have_V2
(mkNP (mkNP a_Det (P.mkN "masa" "mese")) (SyntaxRon.mkAdv for_Prep (mkNP num (P.mkN "persoană")))) ;
AHasName p name = mkCl p.name (P.dirV2 (mkRVAcc (v_besch119 "numi"))) name ;
--AHungry p = mkCl p.name (E.ComplCN have_V2 (mkCN (mkN "fame" feminine))) ;
AIll p = mkCl p.name (P.mkA "bolnav") ;
AKnow p = mkCl p.name (v_besch122 "şti") ;
ALike p item = mkCl p.name (P.dirV2 (v_besch71 "plăcea")) item ;
ALive p co =
mkCl p.name (mkVP (mkVP (v_besch121 "locui")) (SyntaxRon.mkAdv in_Prep co)) ;
ALove p q = mkCl p.name (P.dirV2 (P.mkV "iubi")) q.name ;
AMarried p = mkCl p.name (P.mkA "căsătorit") ;
AReady p = mkCl p.name (P.mkA "gata" "gata" "gata" "gata") ;
AScared p = mkCl p.name (P.mkA "speriat") ;
ASpeak p lang = mkCl p.name (P.dirV2 (P.mkV "vorbi")) lang ;
--AThirsty p = mkCl p.name (E.ComplCN have_V2 (mkCN (P.mkN "sete" feminine))) ;
ATired p = mkCl p.name (P.mkA "obosit") ;
AUnderstand p = mkCl p.name (v_besch83 "înţelege") ;
-- AHungry p = mkCl p have_V2 (SyntaxRon.mkNP a_Det (mkN "foame")) ;
-- AThirsty p = mkCl p (E.ComplCN have_V2 (mkCN (mkN "sete" feminine))) ;
-- ATired p = mkCl p (mkA "stanco") ;
-- AScared p = mkCl p (E.ComplCN have_V2 (mkCN (mkN "paura" feminine))) ;
AWant p obj = mkCl p.name (P.dirV2 (v_besch74 "vrea")) obj ;
AWantGo p place = mkCl p.name want_VV (mkVP (mkVP L.go_V) place.to) ;
-- miscellaneous
HowMuchCost item = mkQS (mkQCl how8much_IAdv (mkCl item (v_besch18 "costa"))) ;
ItCost item price = mkCl item (dirV2 (v_besch18 "costa")) price ;
QWhatName p = mkQS (mkQCl how_IAdv (mkCl p.name (mkRVAcc (v_besch29 "chema")))) ;
QWhatAge p = mkQS (mkQCl (mkIP how8many_IDet L.year_N) p.name have_V2) ;
PropOpen p = mkCl p.name open_A ;
PropClosed p = mkCl p.name closed_A ;
PropOpenDate p d = mkCl p.name (mkVP (mkVP open_A) d) ;
PropClosedDate p d = mkCl p.name (mkVP (mkVP closed_A) d) ;
PropOpenDay p d = mkCl p.name (mkVP (mkVP open_A) d.habitual) ;
PropClosedDay p d = mkCl p.name (mkVP (mkVP closed_A) d.habitual) ;
HowMuchCost item = mkQS (mkQCl how8much_IAdv (mkCl item (v_besch18 "costa"))) ;
ItCost item price = mkCl item (P.dirV2 (v_besch18 "costa")) price ;
-- Building phrases from strings is complicated: the solution is to use
-- mkText : Text -> Text -> Text ;
PSeeYou d = mkText (lin Text {s = ("pe" ++ "curând")}) (mkPhrase (mkUtt d)) ;
PSeeYouPlace p d =
mkText (lin Text { s = ("ne" ++ "vedem")})
(mkText (mkPhrase (mkUtt p.at)) (mkPhrase (mkUtt d))) ;
-- Relations are expressed as "my wife" or "the wife of my son", as defined by $xOf$
-- below. Languages with productive genitives can use an equivalent of
-- "my son's wife" for non-pronouns, as e.g. in English.
Wife = xOf sing (P.mkN "soţie") ;
Husband = xOf sing (P.mkN "soţ" "soţi") ;
Son = xOf sing (P.mkN "fiu") ;
Daughter = xOf sing (P.mkN "fiică") ;
Children = xOf plur L.child_N ;
-- week days
Monday = mkDay "luni" ;
Tuesday = mkDay "marţi" ;
Wednesday = mkDay "miercuri" ;
Thursday = mkDay "joi" ;
Friday = mkDay "vineri" ;
Saturday = mkDay "sâmbătă" ;
Sunday = mkDay "duminică" ;
Tomorrow = P.mkAdv "mâine" ;
oper
closed_A : A = P.mkA "inchis" ;
open_A : A = P.mkA "deschis" ;
-- auxiliaries
mkNat : Str -> Str -> NPNationality = \nat,co ->
mkNPNationality (UsePN (P.mkPN nat)) (UsePN (P.mkPN co)) (P.mkA nat) ;
mkDay : Str -> {name : NP ; point : Adv ; habitual : Adv} = \d ->
let day = UsePN (P.mkPN d P.Feminine) ;
ad = {s = d} in
mkNPDay day ad ad; ---- difference is enforced by additional constructions
-- mkPlace : N -> Prep -> {name : CN ; at : Prep ; to : Prep} = \p,i ->
-- mkCNPlace (mkCN p) i P.dative ;
xOf : GNumber -> N -> NPPerson -> NPPerson = \n,x,p -> mkRelative n (mkCN x) p ;
-- auxiliaries
oper
mkPlace : N -> Prep -> {name : CN ; at : Prep ; to : Prep} = \p,i -> {
name = mkCN p ;
at = i ;
to = to_Prep ---- ?
to = to_Prep -- in Romanian, most of the time they would be the same
} ;
}