--# -path=.:../abstract concrete ConstructionEng of Construction = CatEng ** open SyntaxEng, SymbolicEng, ParadigmsEng, (L = LexiconEng), (E = ExtraEng), (G = GrammarEng), (R = ResEng), (S = StructuralEng), Prelude in { lin hungry_VP = mkVP (mkA "hungry") ; thirsty_VP = mkVP (mkA "thirsty") ; has_age_VP card = mkVP (mkAP (lin AdA (mkUtt (mkNP L.year_N))) L.old_A) ; have_name_Cl x y = mkCl (mkNP (E.GenNP x) L.name_N) (lin NP y) ; married_Cl x y = mkCl (lin NP x) L.married_A2 (lin NP y) | mkCl (mkNP and_Conj (lin NP x) (lin NP y)) (mkA "married") ; what_name_QCl x = mkQCl (mkIComp whatSg_IP) (mkNP (E.GenNP x) L.name_N) ; how_old_QCl x = mkQCl (E.ICompAP (mkAP L.old_A)) (lin NP x) ; how_far_QCl x = mkQCl (E.IAdvAdv (ss "far")) (lin NP x) ; -- some more things weather_adjCl ap = mkCl (mkVP (lin AP ap)) ; is_right_VP = mkVP (ParadigmsEng.mkA "right") ; is_wrong_VP = mkVP (ParadigmsEng.mkA "wrong") ; n_units_AP card cn a = mkAP (lin AdA (mkUtt (mkNP (lin CN cn)))) (lin A a) ; bottle_of_CN np = mkCN (lin N2 (mkN2 "bottle")) (lin NP np) ; cup_of_CN np = mkCN (lin N2 (mkN2 "cup")) (lin NP np) ; glass_of_CN np = mkCN (lin N2 (mkN2 "glass")) (lin NP np) ; few_X_short_of_Y np x y = let xs : Str = x.s ! R.Pl ! R.Nom ; a_y : Str = (mkNP a_Det y).s ! R.NCase R.Nom ; in mkS (mkCl np (mkAdv ("a few" ++ xs ++ "short of" ++ a_y))) ; {- -- spatial deixis and motion verbs where_go_QCl np = mkQCl where_IAdv (mkCl np (mkVP L.go_V)) ; where_come_from_QCl np = mkQCl from_where_IAdv (mkCl np (mkVP L.go_V)) ; go_here_VP = mkVP (mkVP L.go_V) S.here_Adv ; come_here_VP = mkVP (mkVP L.come_V) S.here_Adv ; come_from_here_VP = mkVP (mkVP L.come_V) (mkAdv "from here") ; go_there_VP = mkVP (mkVP L.go_V) S.there_Adv ; come_there_VP = mkVP (mkVP L.come_V) S.there_Adv ; come_from_there_VP = mkVP (mkVP L.come_V) (mkAdv "from there") ; --TODO "where did X come from" instead of "from where did X come" oper from_where_IAdv : IAdv = lin IAdv (ss "from where") ; -} lincat Timeunit = N ; Weekday = N ; Monthday = NP ; Month = N ; Year = NP ; lin timeunitAdv n time = let n_card : Card = n ; n_hours_NP : NP = mkNP n_card time ; in SyntaxEng.mkAdv for_Prep n_hours_NP | mkAdv (n_hours_NP.s ! R.npNom) ; weekdayPunctualAdv w = SyntaxEng.mkAdv on_Prep (mkNP w) ; -- on Sunday weekdayHabitualAdv w = SyntaxEng.mkAdv on_Prep (mkNP aPl_Det w) ; -- on Sundays weekdayNextAdv w = SyntaxEng.mkAdv (mkPrep "next") (mkNP w) ; -- next Sunday weekdayLastAdv w = SyntaxEng.mkAdv (mkPrep "last") (mkNP w) ; -- last Sunday monthAdv m = SyntaxEng.mkAdv in_Prep (mkNP m) ; yearAdv y = SyntaxEng.mkAdv in_Prep y ; dayMonthAdv d m = ParadigmsEng.mkAdv ("on" ++ d.s ! R.NPAcc ++ m.s ! R.Sg ! R.Nom) ; -- on 17 May monthYearAdv m y = SyntaxEng.mkAdv in_Prep (mkNP (mkCN m y)) ; -- in May 2012 dayMonthYearAdv d m y = ParadigmsEng.mkAdv ("on" ++ d.s ! R.NPAcc ++ m.s ! R.Sg ! R.Nom ++ y.s ! R.NPAcc) ; -- on 17 May 2013 intYear = symb ; intMonthday = symb ; lincat Language = N ; lin InLanguage l = SyntaxEng.mkAdv in_Prep (mkNP l) ; lin weekdayN w = w ; monthN m = m ; weekdayPN w = mkPN w ; monthPN m = mkPN m ; languageCN l = mkCN l ; languageNP l = mkNP l ; oper mkLanguage : Str -> N = \s -> mkN s ; ---------------------------------------------- ---- lexicon of special names lin second_Timeunit = mkN "second" ; lin minute_Timeunit = mkN "minute" ; lin hour_Timeunit = mkN "hour" ; lin day_Timeunit = mkN "day" ; lin week_Timeunit = mkN "week" ; lin month_Timeunit = mkN "month" ; lin year_Timeunit = mkN "year" ; lin monday_Weekday = mkN "Monday" ; lin tuesday_Weekday = mkN "Tuesday" ; lin wednesday_Weekday = mkN "Wednesday" ; lin thursday_Weekday = mkN "Thursday" ; lin friday_Weekday = mkN "Friday" ; lin saturday_Weekday = mkN "Saturday" ; lin sunday_Weekday = mkN "Sunday" ; lin january_Month = mkN "January" ; lin february_Month = mkN "February" ; lin march_Month = mkN "March" ; lin april_Month = mkN "April" ; lin may_Month = mkN "May" ; lin june_Month = mkN "June" ; lin july_Month = mkN "July" ; lin august_Month = mkN "August" ; lin september_Month = mkN "September" ; lin october_Month = mkN "October" ; lin november_Month = mkN "November" ; lin december_Month = mkN "December" ; lin afrikaans_Language = mkLanguage "Afrikaans" ; lin amharic_Language = mkLanguage "Amharic" ; lin arabic_Language = mkLanguage "Arabic" ; lin bulgarian_Language = mkLanguage "Bulgarian" ; lin catalan_Language = mkLanguage "Catalan" ; lin chinese_Language = mkLanguage "Chinese" ; lin danish_Language = mkLanguage "Danish" ; lin dutch_Language = mkLanguage "Dutch" ; lin english_Language = mkLanguage "English" ; lin estonian_Language = mkLanguage "Estonian" ; lin finnish_Language = mkLanguage "Finnish" ; lin french_Language = mkLanguage "French" ; lin german_Language = mkLanguage "German" ; lin greek_Language = mkLanguage "Greek" ; lin hebrew_Language = mkLanguage "Hebrew" ; lin hindi_Language = mkLanguage "Hindi" ; lin japanese_Language = mkLanguage "Japanese" ; lin italian_Language = mkLanguage "Italian" ; lin latin_Language = mkLanguage "Latin" ; lin latvian_Language = mkLanguage "Latvian" ; lin maltese_Language = mkLanguage "Maltese" ; lin nepali_Language = mkLanguage "Nepali" ; lin norwegian_Language = mkLanguage "Norwegian" ; lin persian_Language = mkLanguage "Persian" ; lin polish_Language = mkLanguage "Polish" ; lin punjabi_Language = mkLanguage "Punjabi" ; lin romanian_Language = mkLanguage "Romanian" ; lin russian_Language = mkLanguage "Russian" ; lin sindhi_Language = mkLanguage "Sindhi" ; lin spanish_Language = mkLanguage "Spanish" ; lin swahili_Language = mkLanguage "Swahili" ; lin swedish_Language = mkLanguage "Swedish" ; lin thai_Language = mkLanguage "Thai" ; lin turkish_Language = mkLanguage "Turkish" ; lin urdu_Language = mkLanguage "Urdu" ; }