add more time expressions to ConstructionJpn, and fill SymbolJpn (might be wrong though) functions.

This commit is contained in:
Inari Listenmaa
2017-07-04 16:22:37 +02:00
parent d819db35f3
commit bf4313f38e
4 changed files with 113 additions and 65 deletions
+60 -26
View File
@@ -1,5 +1,5 @@
concrete ConstructionJpn of Construction = CatJpn **
open SyntaxJpn, ParadigmsJpn, (R=ResJpn), (L = LexiconJpn) in {
open SyntaxJpn, ParadigmsJpn, (R=ResJpn), (L = LexiconJpn), SymbolicJpn in {
lin
hungry_VP = mkVP (mkV "お腹が空いている" R.Gr1) ;
@@ -11,50 +11,71 @@ lin
lincat
--TODO add rest as soon as I learn that stuff in Duolingo ^^ /IL 2017-07
-- Timeunit ;
Timeunit = N ;
Weekday = N ;
-- Month ;
-- Monthday ;
-- Year ;
Monthday = NP ;
Month = N ;
Year = NP ;
lin
-- : Weekday -> Adv ;
weekdayPunctualAdv w = SyntaxJpn.mkAdv in_Prep (mkNP w) ; -- on Sunday
weekdayHabitualAdv w = SyntaxJpn.mkAdv in_Prep (mkNP w) ; -- on Sundays
weekdayNextAdv w = SyntaxJpn.mkAdv in_Prep (mkNP (mkCN (mkA "次の") w)) ; -- next Sunday
weekdayLastAdv w = SyntaxJpn.mkAdv in_Prep (mkNP (mkCN (mkA "先週の") w)) ; -- last Sunday
{-
monthAdv : Month -> Adv ; -- in June
yearAdv : Year -> Adv ; -- in 1976
dayMonthAdv : Monthday -> Month -> Adv ; -- on 17 May
monthYearAdv : Month -> Year -> Adv ; -- in May 2013
dayMonthYearAdv : Monthday -> Month -> Year -> Adv ; -- on 17 May 2013
intYear : Int -> Year ; -- (year) 1963
intMonthday : Int -> Monthday ; -- 31th (March)
-}
-- : Month -> Adv ; -- in June
monthAdv m = SyntaxJpn.mkAdv in_Prep (mkNP m) ;
-- : Year -> Adv ; -- in 1976
yearAdv y = SyntaxJpn.mkAdv in_Prep y ;
-- : Monthday -> Month -> Adv ; -- on 17 May / 五月十七日に
dayMonthAdv day month =
let futsukaNi : Adv = SyntaxJpn.mkAdv in_Prep day ;
sangatsu : R.Style => Str = month.s ! R.Sg ;
in futsukaNi ** { s = \\style => sangatsu ! style ++ futsukaNi.s ! style } ;
-- : Month -> Year -> Adv ; -- in May 2013
monthYearAdv m y = SyntaxJpn.mkAdv in_Prep (mkNP (mkCN m y)) ;
-- : Monthday -> Month -> Year -> Adv ; -- on 17 May 2013
dayMonthYearAdv d m y =
let futsukaNi : Adv = SyntaxJpn.mkAdv in_Prep d ;
sangatsu2013 : R.Style => Str = \\st => y.s ! st ++ "年" ++ m.s ! R.Sg ! st;
in futsukaNi ** { s = \\style => sangatsu2013 ! style ++ futsukaNi.s ! style } ;
-- : Int -> Year ; -- (year) 1963
intYear = symb ;
-- : Int -> Monthday ; -- 31th (March)
intMonthday i = symb { s = i.s ++ "日" } ;
-- coercions to RGL categories
-- : Weekday -> N ; -- (this) Monday
weekdayN w = w ;
monthN m = m ;
{-
monthN : Month -> N ; -- (this) November
weekdayPN w = mkPN (w.s ! R.Sg ! R.Plain) ;
monthPN m = mkPN (m.s ! R.Sg ! R.Plain) ;
weekdayPN : Weekday -> PN ; -- Monday (is free)
monthPN : Month -> PN ; -- March (is cold)
languageNP : Language -> NP ; -- French (is easy)
languageCN : Language -> CN ; -- (my) French
-}
----------------------------------------------
---- lexicon of special names
-- This is pure guessing /IL 2017-07
-- second_Timeunit = mkN "second" ;
-- minute_Timeunit = mkN "minute" ;
-- hour_Timeunit = mkN "hour" ;
day_Timeunit = mkN "日" ;
week_Timeunit = mkN "週間" ;
month_Timeunit = mkN "箇月" ;
year_Timeunit = mkN "年" ;
monday_Weekday = mkN "月曜日" ; -- "getsuyoubi"
tuesday_Weekday = mkN "火曜日" ; -- "kayoubi"
wednesday_Weekday = mkN "水曜日" ; -- "suiyoubi"
@@ -63,4 +84,17 @@ lin
saturday_Weekday = mkN "土曜日" ; -- "doyoubi"
sunday_Weekday = mkN "日曜日" ; -- "nichiyoubi"
january_Month = mkN "一月" ; -- ichigatsu
february_Month = mkN "二月" ; -- nigatsu
march_Month = mkN "三月" ; -- sangatsu
april_Month = mkN "四月" ; -- shigatsu
may_Month = mkN "五月" ; -- gogatsu
june_Month = mkN "六月" ; -- rokugatsu
july_Month = mkN "七月" ; -- shichigatsu
august_Month = mkN "八月" ; -- hachigatsu
september_Month = mkN "九月" ; -- kugatsu
october_Month = mkN "十月" ; -- jyuugatsu
november_Month = mkN "十一月" ; -- jyuuichigatsu
december_Month = mkN "十二月" ; -- jyuunigatsu
}