Improvements of Russian Phrasebook that do not rely on Participles and Numerals

This commit is contained in:
Nick Frolov
2011-10-18 15:16:58 +00:00
parent 08bcc07325
commit bdd52b0560
10 changed files with 137 additions and 117 deletions

View File

@@ -6,7 +6,7 @@ concrete PhrasebookRus of Phrasebook =
SyntaxRus, SyntaxRus,
Prelude in { Prelude in {
--lin -- lin
-- PGreeting g = lin Text g ; -- PGreeting g = lin Text g ;
} }

View File

@@ -1,7 +1,15 @@
concrete SentencesRus of Sentences = NumeralRus ** SentencesI - [ concrete SentencesRus of Sentences = NumeralRus ** SentencesI - [
Today, NameNN -- not defined in lib NameNN, SHave, SHaveNo, SHaveNoMass, QDoHave, AHaveCurr
] with ] with
(Syntax = SyntaxRus), (Syntax = SyntaxRus),
-- (Symbolic = SymbolicRus), -- (Symbolic = SymbolicRus),
(Lexicon = LexiconRus) ** open Prelude, SyntaxRus in { (Lexicon = LexiconRus), (Grammar = GrammarRus) ** open Prelude, SyntaxRus in {
lin
SHave p obj = mkS (mkCl (mkVP have_V3 obj p.name)) ;
SHaveNo p obj = mkS (mkCl (mkVP have_not_V3 (mkNP obj) p.name)) ;
SHaveNoMass p obj = mkS (mkCl (mkVP have_not_V3 (mkNP obj) p.name)) ;
QDoHave p obj = mkQS (mkQCl (mkCl (mkVP have_V3 obj p.name))) ;
AHaveCurr p curr = mkCl (mkVP have_V3 (mkNP aPl_Det curr) p.name) ;
} }

View File

@@ -1,4 +1,4 @@
-- (c) 2009 Aarne Ranta under LGPL -- (C) 2009 Aarne Ranta under LGPL
concrete WordsRus of Words = SentencesRus ** concrete WordsRus of Words = SentencesRus **
open SyntaxRus, (P = ParadigmsRus), (L = LexiconRus), Prelude in { open SyntaxRus, (P = ParadigmsRus), (L = LexiconRus), Prelude in {
@@ -35,39 +35,39 @@ flags coding = utf8 ;
Expensive = P.mkA "дорогой" ; Expensive = P.mkA "дорогой" ;
Fresh = P.mkA "свежий" ; Fresh = P.mkA "свежий" ;
Good = L.good_A ; Good = L.good_A ;
Suspect = P.mkA "подозреваемый" ; Suspect = P.mkA "подозрительный" ;
Warm = L.warm_A ; Warm = L.warm_A ;
-- places -- places
Airport = mkPlace (P.mkN "аэропорт") in_Prep ; Airport = mkPlace "аэропорт" in_Prep ;
-- AmusementPark = ? парк развлечений AmusementPark = mkPlace2 "развлечения" "парк" in_Prep;
Bank = mkPlace (P.mkN "банк") in_Prep ; Bank = mkPlace "банк" in_Prep ;
Bar = mkPlace (P.mkN "бар") in_Prep ; Bar = mkPlace "бар" in_Prep ;
Cafeteria = mkPlace (P.mkN "кафетерий") in_Prep ; Cafeteria = mkPlace "кафетерий" in_Prep ;
Center = mkPlace (P.mkN "центр") in_Prep ; Center = mkPlace "центр" in_Prep ;
Church = mkPlace (P.mkN "церковь") in_Prep ; Church = mkPlace "церковь" in_Prep ;
Cinema = mkPlace (P.mkN "кино") in_Prep ; Cinema = mkPlace "кино" in_Prep ;
Disco = mkPlace (P.mkN "дискотека") on_Prep ; Disco = mkPlace "дискотека" on_Prep ;
Hospital = mkPlace (P.mkN "больница") in_Prep ; Hospital = mkPlace "больница" in_Prep ;
Hotel = mkPlace (P.mkN "отель") in_Prep ; Hotel = mkPlace "отель" in_Prep ;
Museum = mkPlace (P.mkN "музей") in_Prep ; Museum = mkPlace "музей" in_Prep ;
Park = mkPlace (P.mkN "парк") in_Prep ; Park = mkPlace "парк" in_Prep ;
Parking = mkPlace (P.mkN "автостоянка") on_Prep ; Parking = mkPlace "автостоянка" on_Prep ;
Pharmacy = mkPlace (P.mkN "аптека") in_Prep ; Pharmacy = mkPlace "аптека" in_Prep ;
PostOffice = mkPlace (P.mkN "почта") on_Prep ; PostOffice = mkPlace "почта" on_Prep ;
Pub = mkPlace (P.mkN "паб") in_Prep ; Pub = mkPlace "паб" in_Prep ;
Restaurant = mkPlace (P.mkN "ресторан") in_Prep ; Restaurant = mkPlace "ресторан" in_Prep ;
Shop = mkPlace (P.mkN "магазин") in_Prep ; Shop = mkPlace "магазин" in_Prep ;
School = mkPlace (P.mkN "школа") in_Prep ; School = mkPlace "школа" in_Prep ;
Station = mkPlace (P.mkN "станция") on_Prep ; Station = mkPlace "станция" on_Prep ;
Supermarket = mkPlace (P.mkN "супермаркет") in_Prep ; Supermarket = mkPlace "супермаркет" in_Prep ;
Theatre = mkPlace (P.mkN "театр") in_Prep ; Theatre = mkPlace "театр" in_Prep ;
Toilet = mkPlace (P.mkN "туалет") in_Prep ; Toilet = mkPlace "туалет" in_Prep ;
University = mkPlace (P.mkN "университет") in_Prep ; University = mkPlace "университет" in_Prep ;
Zoo = mkPlace (P.mkN "зоопарк") in_Prep ; Zoo = mkPlace "зоопарк" in_Prep ;
CitRestaurant cit = CitRestaurant cit =
@@ -90,23 +90,23 @@ flags coding = utf8 ;
-- Nationalities -- Nationalities
-- Belgian = mkNat "бельгийский" (P.mkN "Бельгия" "Бельгии" "Бельгию" "Бельгию" "Бельгией" "Бельгии" "Бельгии" "Бельгии" "Бельгий" "Бельгиям" "Бельгии" "Бельгиями" "Бельгиях" P.feminine P.animate) ; -- Belgian = mkNat "бельгийский" (P.mkPN "Бельгия" P.feminine P.singular P.inanimate) ;
Bulgarian = mkNat "болгарский" (P.mkN "Болгария" "Болгарии" "Болгарию" "Болгарию" "Болгарией" "Болгарии" "Болгарии" "Болгарии" "Болгарий" "Болгариям" "Болгарии" "Болгариями" "Болгариях" P.feminine P.animate) ; Bulgarian = mkNat "болгарский" (P.mkPN "Болгария" P.feminine P.singular P.inanimate) ;
Catalan = mkNat "каталонский" (P.mkN "Каталония" "Каталонии" "Каталонию" "Каталонию" "Каталонией" "Каталонии" "Каталонии" "Каталонии" "Каталоний" "Каталониям" "Каталонии" "Каталониями" "Каталониях" P.feminine P.animate) ; Catalan = mkNat "каталонский" (P.mkPN "Каталония" P.feminine P.singular P.inanimate) ;
Danish = mkNat "датский" (P.mkN "Дания" "Дании" "Данию" "Данию" "Данией" "Дании" "Дании" "Дании" "Даний" "Даниям" "Дании" "Даниями" "Даниях" P.feminine P.animate) ; Danish = mkNat "датский" (P.mkPN "Дания" P.feminine P.singular P.inanimate) ;
Dutch = mkNat "нидерландский" (P.mkN "Нидерланды" P.animate) ; Dutch = mkNat "нидерландский" (P.mkPN "Нидерланды" P.neuter P.plural P.animate) ;
English = mkNat "английский" (P.mkN "Англия" "Англии" "Англию" "Англию" "Англией" "Англии" "Англии" "Англии" "Англий" "Англиям" "Англии" "Англиями" "Англиях" P.feminine P.animate) ; English = mkNat "английский" (P.mkPN "Англия" P.feminine P.singular P.animate) ;
Finnish = mkNat "финский" (P.mkN "Финляндия" "Финляндии" "Финляндию" "Финляндию" "Финляндией" "Финляндии" "Финляндии" "Финляндии" "Финляндий" "Финляндиям" "Финляндии" "Финляндиями" "Финляндиях" P.feminine P.animate) ; Finnish = mkNat "финский" (P.mkPN "Финляндия" P.feminine P.singular P.animate) ;
-- Flemish = mkNat "фландрийский" (P.mkN "Фландрия" "Фландрии" "Фландрию" "Фландрию" "Фландрией" "Фландрии" "Фландрии" "Фландрии" "Фландрий" "Фландриям" "Фландрии" "Фландриями" "Фландриях" P.feminine P.animate) ; -- Flemish = mkNat "фландрийский" (P.mkPN "Фландрия" P.feminine P.singular P.animate) ;
French = mkNat "французский" (P.mkN "Франция" "Франции" "Францию" "Францию" "Францией" "Франции" "Франции" "Франции" "Франций" "Франциям" "Франции" "Франциями" "Франциях" P.feminine P.animate) ; French = mkNat "французский" (P.mkPN "Франция" P.feminine P.singular P.animate) ;
German = mkNat "немецкий" (P.mkN "Германия" "Германии" "Германию" "Германию" "Германией" "Германии" "Германии" "Германии" "Германий" "Германиям" "Германии" "Германиями" "Германиях" P.feminine P.animate) ; German = mkNat "немецкий" (P.mkPN "Германия" P.feminine P.singular P.animate) ;
Italian = mkNat "итальянский" (P.mkN "Италия" "Италии" "Италию" "Италию" "Италией" "Италии" "Италии" "Италии" "Италий" "Италиям" "Италии" "Италиями" "Италиях" P.feminine P.animate) ; Italian = mkNat "итальянский" (P.mkPN "Италия" P.feminine P.singular P.animate) ;
Norwegian = mkNat "норвежский" (P.mkN "Норвегия" "Норвегии" "Норвегию" "Норвегию" "Норвегией" "Норвегии" "Норвегии" "Норвегии" "Норвегий" "Норвегиям" "Норвегии" "Норвегиями" "Норвегиях" P.feminine P.animate) ; Norwegian = mkNat "норвежский" (P.mkPN "Норвегия" P.feminine P.singular P.animate) ;
Polish = mkNat "польский" (P.mkN "Польша" "Польши" "Польшу" "Польшу" "Польшей" "Польше" "Польше" "Польши" "Польш" "Польшам" "Польши" "Польшами" "Польшах" P.feminine P.animate) ; Polish = mkNat "польский" (P.mkPN "Польша" P.feminine P.singular P.animate) ;
Romanian = mkNat "румынский" (P.mkN "Румыния" "Румынии" "Румынию" "Румынию" "Румынией" "Румынии" "Румынии" "Румынии" "Румыний" "Румыниям" "Румынии" "Румыниями" "Румыниях" P.feminine P.animate) ; Romanian = mkNat "румынский" (P.mkPN "Румыния" P.feminine P.singular P.animate) ;
Russian = mkNat "русский" (P.mkN "Россия" "России" "Россию" "Россию" "Россией" "России" "России" "России" "Россий" "Россиям" "России" "Россиями" "Россиях" P.feminine P.animate) ; Russian = mkNat "русский" (P.mkPN "Россия" P.feminine P.singular P.animate) ;
Spanish = mkNat "испанский" (P.mkN "Испания" "Испании" "Испанию" "Испанию" "Испанией" "Испании" "Испании" "Испании" "Испаний" "Испаниям" "Испании" "Испаниями" "Испаниях" P.feminine P.animate) ; Spanish = mkNat "испанский" (P.mkPN "Испания" P.feminine P.singular P.inanimate) ;
Swedish = mkNat "шведский" (P.mkN "Швеция" "Швеции" "Швецию" "Швецию" "Швецией" "Швеции" "Швеции" "Швеции" "Швеций" "Швециям" "Швеции" "Швециями" "Швециях" P.feminine P.animate) ; Swedish = mkNat "шведский" (P.mkPN "Швеция" P.feminine P.singular P.animate) ;
-- Means of transportation -- Means of transportation
@@ -117,8 +117,8 @@ flags coding = utf8 ;
Car = mkTransport (P.mkN "автомобиль"); Car = mkTransport (P.mkN "автомобиль");
Ferry = mkTransport (P.mkN "паром") ; Ferry = mkTransport (P.mkN "паром") ;
Plane = mkTransport (P.mkN "самолет") ; Plane = mkTransport (P.mkN "самолет") ;
Subway = mkTransport (P.mkN "метро") ; Subway = mkTransport (P.mkIndeclinableNoun "метро" P.neuter P.inanimate) ;
Taxi = mkTransport (P.mkN "такси") ; Taxi = mkTransport (P.mkIndeclinableNoun "такси" P.neuter P.inanimate) ;
Tram = mkTransport (P.mkN "трамвай") ; Tram = mkTransport (P.mkN "трамвай") ;
Train = mkTransport (P.mkN "поезд") ; Train = mkTransport (P.mkN "поезд") ;
@@ -128,7 +128,7 @@ flags coding = utf8 ;
-- actions -- actions
AHasAge p num = mkCl p.name (mkNP num L.year_N) ; AHasAge p num = mkCl p.name (mkNP num L.year_N) ;
-- AHasName p name = ? AHasName p name = mkCl (mkVP (P.mkV3 name_is_V "" "" P.accusative P.nominative) p.name name) ;
AHasChildren p num = mkCl p.name have_V2 (mkNP num L.child_N) ; AHasChildren p num = mkCl p.name have_V2 (mkNP num L.child_N) ;
AHasRoom p num = mkCl p.name have_V2 AHasRoom p num = mkCl p.name have_V2
(mkNP (mkNP a_Det (P.mkN "номер")) (mkNP (mkNP a_Det (P.mkN "номер"))
@@ -136,29 +136,28 @@ flags coding = utf8 ;
AHasTable p num = mkCl p.name have_V2 AHasTable p num = mkCl p.name have_V2
(mkNP (mkNP a_Det (P.mkN "стол")) (mkNP (mkNP a_Det (P.mkN "стол"))
(SyntaxRus.mkAdv for_Prep (mkNP num (P.mkN "человек")))) ; (SyntaxRus.mkAdv for_Prep (mkNP num (P.mkN "человек")))) ;
AHungry p = mkCl p.name (P.mkAdv "голоден") ; AHungry p = mkCl p.name (P.mkAdv "голодный") ;
AIll p = mkCl p.name (P.mkA "болен") ; AIll p = mkCl p.name (P.mkA "больной") ;
AKnow p = mkCl p.name (P.regV P.imperfective P.first "зна" "ю" "знал" "знай" "знать" ) ; AKnow p = mkCl p.name (P.regV P.imperfective P.first "зна" "ю" "знал" "знай" "знать" ) ;
ALike p item = mkCl p.name (P.dirV2 (P.regV P.imperfective P.second "нрав" "лю" "нравил" "нравь" "нравить" )) item ; ALike p item = mkCl p.name (P.dirV2 (P.regV P.imperfective P.second "нрав" "лю" "нравил" "нравь" "нравить" )) item ;
ALive p co = mkCl p.name (mkVP (mkVP (P.regV P.imperfective P.firstE "жив" "у" "жил" "живи" "жить")) (SyntaxRus.mkAdv in_Prep co)) ; ALive p co = mkCl p.name (mkVP (mkVP (P.regV P.imperfective P.firstE "жив" "у" "жил" "живи" "жить")) (SyntaxRus.mkAdv in_Prep co)) ;
ALove p q = mkCl p.name (P.dirV2 (P.regV P.imperfective P.second "люб" "лю" "любил" "люби" "любить" )) q.name ; ALove p q = mkCl p.name (P.dirV2 (P.regV P.imperfective P.second "люб" "лю" "любил" "люби" "любить" )) q.name ;
AMarried p = mkCl p.name (P.mkA "женат") ; AMarried p = mkCl p.name (P.mkA "женатый") ;
AReady p = mkCl p.name (P.mkA "готов") ; AReady p = mkCl p.name (P.mkA "готовый") ;
AScared p = mkCl p.name (P.mkA "боюсь") ; AScared p = mkCl p.name (P.mkA "испуганный") ;
ASpeak p lang = mkCl p.name (P.mkV2 (P.regV P.imperfective P.secondA "говор" "ю" "говорил" "говори" "говорить") ASpeak p lang = mkCl p.name (P.mkV2 (P.regV P.imperfective P.secondA "говор" "ю" "говорил" "говори" "говорить") "на" P.prepositional) lang ;
"на" P.prepositional) lang ; AThirsty p = mkCl p.name (P.mkA "жаждущий") ;
AThirsty p = mkCl p.name (P.mkA "жажду") ; ATired p = mkCl p.name (P.mkA "уставший") ;
ATired p = mkCl p.name (P.mkA "устал") ;
AUnderstand p = mkCl p.name (P.regV P.imperfective P.first "понима" "ю" "понимал" "понимай" "понимать") ; AUnderstand p = mkCl p.name (P.regV P.imperfective P.first "понима" "ю" "понимал" "понимай" "понимать") ;
AWant p obj = mkCl p.name want_VV (mkVP have_V2 obj) ; 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 L.go_V) place.to) ;
-- miscellaneous -- miscellaneous
-- QWhatName p = ? QWhatName p = mkQS (mkQCl how_IAdv (mkCl (mkVP (P.mkV2 name_is_V "" P.accusative) p.name))) ;
-- QWhatAge p = ? QWhatAge p = mkQS (mkQCl (mkIP how8many_IDet L.year_N) p.name);
-- HowMuchCost item = ? HowMuchCost item = mkQS (mkQCl how8much_IAdv (mkCl item cost_V)) ;
-- ItCost item price = ? ItCost item price = mkCl item (P.mkV2 cost_V "" P.accusative) price ;
PropOpen p = mkCl p.name open_A ; PropOpen p = mkCl p.name open_A ;
PropClosed p = mkCl p.name closed_A ; PropClosed p = mkCl p.name closed_A ;
@@ -167,12 +166,13 @@ flags coding = utf8 ;
PropOpenDay p d = mkCl p.name (mkVP (mkVP open_A) d.habitual) ; PropOpenDay p d = mkCl p.name (mkVP (mkVP open_A) d.habitual) ;
PropClosedDay p d = mkCl p.name (mkVP (mkVP closed_A) d.habitual) ; PropClosedDay p d = mkCl p.name (mkVP (mkVP closed_A) d.habitual) ;
-- Building phrases from strings is complicated: the solution is to use -- Building phrases from strings is complicated: the solution is to use
-- mkText : Text -> Text -> Text ; -- mkText : Text -> Text -> Text ;
PSeeYouDate d = mkText (lin Text (ss ("увидимся"))) (mkPhrase (mkUtt d)) ; PSeeYouDate d = mkText (lin Text (ss ("увидимся"))) (mkPhrase (mkUtt d)) ;
PSeeYouPlace p = PSeeYouPlace p =
mkText (lin Text (ss ("Вы видите"))) (mkPhrase (mkUtt p.at)) ; mkText (lin Text (ss ("увидимся"))) (mkPhrase (mkUtt p.at)) ;
PSeeYouPlaceDate p d = PSeeYouPlaceDate p d =
mkText (lin Text (ss ("увидимся"))) mkText (lin Text (ss ("увидимся")))
(mkText (mkPhrase (mkUtt d)) (mkPhrase (mkUtt p.at))) ; (mkText (mkPhrase (mkUtt d)) (mkPhrase (mkUtt p.at))) ;
@@ -184,7 +184,7 @@ flags coding = utf8 ;
Wife = xOf sing (P.mkN "жена") ; Wife = xOf sing (P.mkN "жена") ;
Husband = xOf sing (P.mkN "муж") ; Husband = xOf sing (P.mkN "муж") ;
Son = xOf sing (P.mkN "сын") ; Son = xOf sing (P.mkN "сын") ;
Daughter = xOf sing (P.mkN "дочь") ; Daughter = xOf sing (P.mkN "дочь" "дочери" "дочери" "дочь" "дочерью" "дочери" "дочь" "дочери" "дочерей" "дочерям" "дочерей" "дочерьми" "дочерях" P.feminine P.animate) ;
Children = xOf plur L.child_N ; Children = xOf plur L.child_N ;
@@ -203,11 +203,11 @@ flags coding = utf8 ;
-- modifiers of places -- modifiers of places
TheBest = mkSuperl L.good_A ; TheBest = mkSuperl L.good_A ;
--TheClosest = mkSuperl ? ; TheClosest = mkSuperl L.near_A ;
TheCheapest = mkSuperl (P.mkA "дешевый") ; TheCheapest = mkSuperl (P.mkA "дешевый") ;
TheMostExpensive = mkSuperl (P.mkA "duur") ; TheMostExpensive = mkSuperl (P.mkA "дорогой") ;
TheMostPopular = mkSuperl (P.mkA "популярный") ; TheMostPopular = mkSuperl (P.mkA "популярный") ;
TheWorst = mkSuperl (P.mkA "плохой") ; TheWorst = mkSuperl L.bad_A ;
SuperlPlace sup p = placeNP sup p ; SuperlPlace sup p = placeNP sup p ;
@@ -229,29 +229,35 @@ flags coding = utf8 ;
oper oper
mkNat : Str -> N -> NPNationality = \la,co -> mkNat : Str -> PN -> NPNationality = \la,co ->
mkNPNationality (mkNP (P.mkPN la P.masculine P.animate)) (mkNP co) (P.mkA la) ; mkNPNationality (mkNP (P.mkPN la P.masculine P.singular P.animate)) (mkNP co) (P.mkA la) ;
mkDay : Str -> P.Gender -> {name : NP ; point : Adv ; habitual : Adv} = \d,g -> mkDay : Str -> P.Gender -> {name : NP ; point : Adv ; habitual : Adv} =
mkNPDay (mkNP (P.mkPN d g P.inanimate)) (mkAdv (P.mkPrep [] P.nominative) (mkNP (P.mkPN d g P.inanimate))) \d,g -> mkNPDay (mkNP (P.mkPN d g P.singular P.inanimate)) (mkAdv (P.mkPrep "в" P.accusative) (mkNP (P.mkPN d g P.singular P.inanimate)))
---- (mkAdv on_Prep (mkNP (P.mkPN d))) ---- (mkAdv on_Prep (mkNP (P.mkPN d)))
(mkAdv on_Prep (mkNP a_Quant plNum (mkCN (P.mkN d)))) ; (mkAdv (P.mkPrep "по" P.dative) (mkNP a_Quant plNum (mkCN (P.mkN d)))) ;
-- mkPlace : N -> Str -> {name : CN ; at : Prep ; to : Prep} = \p,i -> -- mkPlace : N -> Str -> {name : CN ; at : Prep ; to : Prep} = \p,i ->
-- mkCNPlace (mkCN p) (P.mkPrep i P.prepositional) to_Prep ; -- mkCNPlace (mkCN p) (P.mkPrep i P.prepositional) to_Prep ;
mkPlace : N -> Prep -> {name : CN ; at : Prep ; to : Prep ; isPl : Bool} = \p,i -> mkPlace : Str -> Prep -> {name : CN ; at : Prep ; to : Prep ; isPl : Bool} = \p,i ->
mkCNPlace (mkCN p) i to_Prep; mkCNPlace (mkCN (P.mkN p)) i to_Prep;
mkPlace2 : Str -> Str -> Prep -> {name : CN ; at : Prep ; to : Prep ; isPl : Bool} = \p,p2,i ->
mkCNPlace (mkCN (P.mkN2 (P.mkN p2)) (mkNP (P.mkN p))) i to_Prep;
open_A = P.mkA "открыт" ; open_A = P.mkA "открытый";
closed_A = P.mkA "закрыт" ; closed_A = P.mkA "закрытый";
cost_V = P.regV P.imperfective P.secondA "сто" "ю" "стоил" "стой" "стоить" ;
name_is_V = P.regV P.imperfective P.first "зов" "у" "звал" "зови" "звать" ;
xOf : GNumber -> N -> NPPerson -> NPPerson = \n,x,p -> xOf : GNumber -> N -> NPPerson -> NPPerson = \n,x,p ->
relativePerson n (mkCN x) (\a,b,c -> mkNP (mkNP the_Quant a c) (SyntaxRus.mkAdv possess_Prep b)) p ; relativePerson n (mkCN x) (\a,b,c -> mkNP (mkNP the_Quant a c) (SyntaxRus.mkAdv possess_Prep b)) p ;
mkTransport : N -> {name : CN ; by : Adv} = \n -> { mkTransport : N -> {name : CN ; by : Adv} = \n -> {
name = mkCN n ; name = mkCN n ;
by = SyntaxRus.mkAdv with_Prep (mkNP the_Det n) by = SyntaxRus.mkAdv on_Prep (mkNP the_Det n)
} ; } ;
far_IAdv = ss "как далеко" ** {lock_IAdv = <>} ; far_IAdv = ss "как далеко" ** {lock_IAdv = <>} ;

View File

@@ -122,6 +122,8 @@ abstract Structural = Cat ** {
as_CAdv : CAdv ; as_CAdv : CAdv ;
have_V2 : V2 ; have_V2 : V2 ;
have_V3 : V3 ;
have_not_V3 : V3;
fun language_title_Utt : Utt ; fun language_title_Utt : Utt ;

View File

@@ -157,7 +157,7 @@ lin
important_A = mkA "важный" ; important_A = mkA "важный" ;
industry_N = mkN "промышленность" ; industry_N = mkN "промышленность" ;
iron_N = mkN "железо" ; iron_N = mkN "железо" ;
john_PN = mkPN "Иван" Masc Animate ; john_PN = mkPN "Иван" Masc Sg Animate ;
jump_V = regV imperfective first "прыга" "ю" "прыгал" "прыгай" "прыгать" ; jump_V = regV imperfective first "прыга" "ю" "прыгал" "прыгай" "прыгать" ;
kill_V2 = dirV2 (regV imperfective first "убива" "ю" "убивал" "убивай" "убивать" ) ; kill_V2 = dirV2 (regV imperfective first "убива" "ю" "убивал" "убивай" "убивать" ) ;
king_N = mkN "король" "короля" "королю" "короля" "королем" "короле" "короле" "короли" "королей" "королям" "королей" "королями" "королях" masculine animate ; king_N = mkN "король" "короля" "королю" "короля" "королем" "короле" "короле" "короли" "королей" "королям" "королей" "королями" "королях" masculine animate ;
@@ -211,7 +211,7 @@ lin
paint_V2A = dirV2 (regV imperfective first "рису" "ю" "рисовал" "рисуй" "рисовать" ) ; paint_V2A = dirV2 (regV imperfective first "рису" "ю" "рисовал" "рисуй" "рисовать" ) ;
--- palace_N = nDvorec "двор" ; -- +++ MG_UR: added +++ --- palace_N = nDvorec "двор" ; -- +++ MG_UR: added +++
paper_N = mkN "бумага" ; paper_N = mkN "бумага" ;
paris_PN = mkPN "Париж" Masc Inanimate ; paris_PN = mkPN "Париж" Masc Sg Inanimate ;
peace_N = mkN "мир" ; peace_N = mkN "мир" ;
pen_N = mkN "ручка" ; pen_N = mkN "ручка" ;
person_N = mkN "лицo" animate ; -- irregular person_N = mkN "лицo" animate ; -- irregular
@@ -317,7 +317,7 @@ lin
think_V = regV imperfective first "дума" "ю" "думал" "думай" "думать" ; think_V = regV imperfective first "дума" "ю" "думал" "думай" "думать" ;
throw_V2 = dirV2 (regV imperfective first "броса" "ю" "бросал" "бросай" "бросать" ) ; throw_V2 = dirV2 (regV imperfective first "броса" "ю" "бросал" "бросай" "бросать" ) ;
tie_V2 = dirV2 (regV imperfective first "вяж" "у" "вязал" "вяжи" "вязать") ; tie_V2 = dirV2 (regV imperfective first "вяж" "у" "вязал" "вяжи" "вязать") ;
-- today_Adv = ; today_Adv = mkAdv "сегодня" ;
tongue_N = mkN "язык" ; tongue_N = mkN "язык" ;
tooth_N = mkN "зуб" ; tooth_N = mkN "зуб" ;
train_N = mkN "поезд" ; train_N = mkN "поезд" ;
@@ -353,7 +353,7 @@ lin
wood_N = mkN "дерево" ; wood_N = mkN "дерево" ;
worm_N = mkN "черв" ; worm_N = mkN "черв" ;
write_V2 = dirV2 (regV imperfective first "пиш" "у" "писал" "пиши" "писать" ); write_V2 = dirV2 (regV imperfective first "пиш" "у" "писал" "пиши" "писать" );
year_N = mkN "годь" ; year_N = mkN "год" ;
yellow_A = mkA "жёлтый" ; yellow_A = mkA "жёлтый" ;
young_A = mkA "молодой" "моложе"; young_A = mkA "молодой" "моложе";
} }

View File

@@ -34,7 +34,7 @@ oper pronTu : Pronoun =
Prepos _ => "тебе" } } Prepos _ => "тебе" } }
in pronYaTu nonPoss "тво" P2 ; in pronYaTu nonPoss "тво" P2 ;
-- Pronouns ya, tu, svoj -- Pronouns ya, ty, svoj
oper pronYaTu : { s : Case => Str } -> Str -> Person -> Pronoun = oper pronYaTu : { s : Case => Str } -> Str -> Person -> Pronoun =
\nonPoss, mo, pers -> \nonPoss, mo, pers ->
{ s = table { { s = table {
@@ -1313,4 +1313,15 @@ oper ProperName : Type = {s : Case => Str ; g : Gender ; anim : Animacy} ;
(Prepos _) => masha + "е" }; (Prepos _) => masha + "е" };
g = Fem ; anim = anim }; g = Fem ; anim = anim };
-- Люберцы, Нидерланды
mkProperNamePl : Str -> Animacy -> ProperName = \lubercy, anim ->
let a : Str = case lubercy of {_+("ч"|"щ"|"ш"|"ж") => "а"; _ => "о" } in
{ s = table { Nom => lubercy + "ы";
Gen => lubercy + a + "в";
Dat => lubercy + "ам";
Acc => lubercy + "ы";
Inst => lubercy + "ей";
(Prepos _) => lubercy + "ах" };
g = Neut ; anim = anim };
}; };

View File

@@ -101,7 +101,7 @@ oper
-- Proper names. -- Proper names.
mkPN : Str -> Gender -> Animacy -> PN ; -- "Иван", "Маша" mkPN : Str -> Gender -> Number -> Animacy -> PN ; -- "Иван", "Маша"
nounPN : N -> PN ; nounPN : N -> PN ;
@@ -130,6 +130,7 @@ oper
-- Adjectives with irregular comparative. -- Adjectives with irregular comparative.
mkA : (positive, comparative : Str) -> A ; mkA : (positive, comparative : Str) -> A ;
} ; } ;
-- Two-place adjectives need a preposition and a case as extra arguments. -- Two-place adjectives need a preposition and a case as extra arguments.
@@ -361,10 +362,13 @@ foreign = Foreign; -- +++ MG_UR: added +++
mkN3 f p2 p3 = (UseN f) ** {c2 = p2; c3 = p3; lock_N3 = <>} ; mkN3 f p2 p3 = (UseN f) ** {c2 = p2; c3 = p3; lock_N3 = <>} ;
mkPN = \ivan, g, anim -> mkPN = \ivan, g, n, anim ->
case g of { case n of {
Masc => mkProperNameMasc ivan anim ; Sg => case g of {
_ => mkProperNameFem ivan anim Masc => mkProperNameMasc ivan anim ;
_ => mkProperNameFem ivan anim
} ;
Pl => mkProperNamePl ivan anim
} ** {lock_PN =<>}; } ** {lock_PN =<>};
nounPN n = {s=\\c => n.s! NF Sg c; anim=n.anim; g=n.g; lock_PN=<>}; nounPN n = {s=\\c => n.s! NF Sg c; anim=n.anim; g=n.g; lock_PN=<>};
@@ -377,7 +381,7 @@ foreign = Foreign; -- +++ MG_UR: added +++
makeCN = UseN; makeCN = UseN;
makeNP = \x,y,z -> UsePN (mkPN x y z) ; makeNP = \x,y,z -> UsePN (mkPN x y singular z) ;
mkA = overload { mkA = overload {
mkA : (positive : Str) -> A = mk1A ; mkA : (positive : Str) -> A = mk1A ;
@@ -397,6 +401,12 @@ foreign = Foreign; -- +++ MG_UR: added +++
stem => mkAdjDeg (adjInvar stem) comparative stem => mkAdjDeg (adjInvar stem) comparative
} ; } ;
-- mkParticiple : VP -> AP = \v, voice ->
-- case voice of {
-- Act => ;
-- Pass => ;
-- } ;
-- khaki, mini, hindi, netto -- khaki, mini, hindi, netto
adjInvar : Str -> Adjective = \stem -> { s = \\_ => stem } ; adjInvar : Str -> Adjective = \stem -> { s = \\_ => stem } ;

View File

@@ -47,6 +47,7 @@ lin
here7from_Adv = ss "отсюда" ; here7from_Adv = ss "отсюда" ;
how_IAdv = ss "как" ; how_IAdv = ss "как" ;
how8many_IDet = skolkoSgDet ** {n = Pl; g = (PGen Neut); c= Gen}; how8many_IDet = skolkoSgDet ** {n = Pl; g = (PGen Neut); c= Gen};
how8much_IAdv = ss "сколько" ;
i_Pron = pronYa ; i_Pron = pronYa ;
if_Subj = ss "если" ; if_Subj = ss "если" ;
in8front_Prep = { s = "перед" ; c = Inst}; in8front_Prep = { s = "перед" ; c = Inst};
@@ -114,6 +115,9 @@ lin
youPol_Pron = pronVu; youPol_Pron = pronVu;
have_V2= P.dirV2 (P.regV P.imperfective P.first "име" "ю" "имел" "имей" "иметь" ); have_V2= P.dirV2 (P.regV P.imperfective P.first "име" "ю" "имел" "имей" "иметь" );
have_V3 = P.mkV3 (P.mkV P.imperfective "есть" "есть" "есть" "есть" "есть" "есть" "был" "будь" "есть") "" "у" Nom Gen;
have_not_V3 = P.mkV3 (P.mkV P.imperfective "нет" "нет" "нет" "нет" "нет" "нет" "не было" "не будь" "нет") "" "у" Gen Gen;
--- NoDet = nikakojDet ** {n = Sg; g = PNoGen; c= Nom} ; --- NoDet = nikakojDet ** {n = Sg; g = PNoGen; c= Nom} ;
--- AnyDet = lubojDet ** {n = Sg; g = PNoGen; c= Nom} ; --- AnyDet = lubojDet ** {n = Sg; g = PNoGen; c= Nom} ;

View File

@@ -2,30 +2,9 @@
concrete SymbolRus of Symbol = CatRus ** open Prelude, ResRus in { concrete SymbolRus of Symbol = CatRus ** open Prelude, ResRus in {
{- TODO! {- TODO! -}
lin -- lin
SymbPN i = {s = addGenitiveS i.s ; g = Neutr} ; -- SymbPN i = {s = i.s ; g = Neut } ;
IntPN i = {s = addGenitiveS i.s ; g = Neutr} ;
FloatPN i = {s = addGenitiveS i.s ; g = Neutr} ;
NumPN i = {s = i.s ; g = Neutr} ;
CNIntNP cn i = {
s = \\c => cn.s ! Sg ! Nom ++ (addGenitiveS i.s) ! c ;
a = agrgP3 Sg cn.g
} ;
CNSymbNP det cn xs = {
s = \\c => det.s ++ cn.s ! det.n ! Nom ++ (addGenitiveS xs.s) ! c ;
a = agrgP3 det.n cn.g
} ;
CNNumNP cn i = {
s = \\c => cn.s ! Sg ! Nom ++ i.s ! c ;
a = agrgP3 Sg cn.g
} ;
SymbS sy = sy ;
SymbNum sy = { s = addGenitiveS sy.s ; n = Pl ; hasCard = True } ;
SymbOrd sy = { s = \\c => sy.s ++ (regGenitiveS "th")!c} ;
-}
lincat lincat
@@ -37,5 +16,4 @@ lin
-- BaseSymb = infixSS "and" ; -- BaseSymb = infixSS "and" ;
ConsSymb = infixSS "," ; ConsSymb = infixSS "," ;
} }

View File

@@ -53,7 +53,8 @@ concrete VerbRus of Verb = CatRus ** open ResRus, Prelude in {
}; };
-- infinitive does not save GenNum, -- infinitive does not save GenNum,
-- but indicative does for the sake of adjectival predication ! -- but indicative does for the sake of adjectival predication !
ClIndic Present _ => zloj.s ! AF Nom Animate gn ; -- ClIndic Present _ => zloj.s ! AF Nom Animate gn ;
ClIndic Present _ => zloj.s ! AFShort gn ;
ClIndic PastRus _ => case gn of ClIndic PastRus _ => case gn of
{ (GSg Fem) => "была" ++ zloj.s! AF Nom Animate (GSg Fem); { (GSg Fem) => "была" ++ zloj.s! AF Nom Animate (GSg Fem);
(GSg Masc) => "был" ++ zloj.s! AF Nom Animate (GSg Masc); (GSg Masc) => "был" ++ zloj.s! AF Nom Animate (GSg Masc);