Files
gf-rgl/src/zulu/ConstructionZul.gf
Laurette Marais 8b05843585 zulu inclusion
2022-04-28 08:53:37 +02:00

223 lines
8.3 KiB
Plaintext
Executable File

--# -path=.:../abstract
concrete ConstructionZul of Construction = CatZul **
open SyntaxZul, SymbolicZul, ParadigmsZul, (L = LexiconZul), (E = ExtendZul), (G = GrammarZul), (R = ResZul), (Sy = SyntaxZul), (S = StructuralZul), Prelude in {
-- lin
-- hungry_VP = mkVP (mkA "hungry") ;
-- thirsty_VP = mkVP (mkA "thirsty") ;
-- tired_VP = mkVP (mkA "tired") ;
-- scared_VP = mkVP (mkA "scared") ;
-- ill_VP = mkVP (mkA "ill") ;
-- ready_VP = mkVP (mkA "ready") ;
--
-- has_age_VP card = mkVP (mkAP (lin AdA (mkUtt (mkNP <lin Card card : Card> 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 (ParadigmsZul.mkA "right") ;
-- is_wrong_VP = mkVP (ParadigmsZul.mkA "wrong") ;
--
-- n_units_AP card cn a = mkAP (lin AdA (mkUtt (mkNP <lin Card card : Card> (lin CN cn)))) (lin A a) ;
-- ---- n_units_of_NP card cn a = mkAP (lin AdA (mkUtt (mkNP <lin Card card : Card> (lin CN cn)))) (lin A a) ;
-- n_unit_CN card unit cn = mkCN (invarA ((mkUtt card).s ++ (mkUtt unit).s)) cn ;
--
-- 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 ;
-- Hour = {s : Str ; am : Bool} ;
-- 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 Sy.mkAdv for_Prep n_hours_NP | mkAdv (n_hours_NP.s ! R.npNom) ;
--
-- timeunitRange l u time = {s = l.s ! True ! R.Nom ++ to_Prep.s ++ u.s ! True ! R.Nom ++ time.s ! R.Pl ! R.Nom} ;
--
-- oneHour = mkHour "1" True ;
-- twoHour = mkHour "2" True ;
-- threeHour = mkHour "3" True ;
-- fourHour = mkHour "4" True ;
-- fiveHour = mkHour "5" True ;
-- sixHour = mkHour "6" True ;
-- sevenHour = mkHour "7" True ;
-- eightHour = mkHour "8" True ;
-- nineHour = mkHour "9" True ;
-- tenHour = mkHour "10" True ;
-- elevenHour = mkHour "11" True ;
-- twelveHour = mkHour "12" False ;
-- thirteenHour = mkHour "1" False ;
-- fourteenHour = mkHour "2" False ;
-- fifteenHour = mkHour "3" False ;
-- sixteenHour = mkHour "4" False ;
-- seventeenHour = mkHour "5" False ;
-- eighteenHour = mkHour "6" False ;
-- nineteenHour = mkHour "7" False ;
-- twentyHour = mkHour "8" False ;
-- twentyOneHour = mkHour "9" False ;
-- twentyTwoHour = mkHour "10" False ;
-- twentyThreeHour = mkHour "11" False ;
-- twentyFourHour = mkHour "12" True ;
--
-- timeHour h = Sy.mkAdv at_Prep (symb (h.s ++ ampm ! h.am)) ;
-- timeHourMinute h m = let
-- min = m.s ! True ! R.Nom
-- in
-- Sy.mkAdv at_Prep (symb (h.s ++ min ++ ampm ! h.am)) ;
--
-- oper
-- mkHour : Str -> Bool -> {s : Str ; am : Bool} ;
-- mkHour n am = Sy.mkUtt (Sy.mkCard n) ** {am = am} ;
--
-- at_Prep : Prep ;
-- at_Prep = mkPrep "at" ;
--
-- ampm : Bool => Str ;
-- ampm = table {True => "a.m." ; False => "p.m."} ;
--
-- lin
-- weekdayPunctualAdv w = SyntaxZul.mkAdv on_Prep (mkNP w) ; -- on Sunday
-- weekdayHabitualAdv w = SyntaxZul.mkAdv on_Prep (mkNP aPl_Det w) ; -- on Sundays
-- weekdayNextAdv w = SyntaxZul.mkAdv (mkPrep "next") (mkNP w) ; -- next Sunday
-- weekdayLastAdv w = SyntaxZul.mkAdv (mkPrep "last") (mkNP w) ; -- last Sunday
--
-- monthAdv m = SyntaxZul.mkAdv in_Prep (mkNP m) ;
-- yearAdv y = SyntaxZul.mkAdv in_Prep y ;
-- dayMonthAdv d m = ParadigmsZul.mkAdv ("on" ++ d.s ! R.NPAcc ++ m.s ! R.Sg ! R.Nom) ; -- on 17 May
-- monthYearAdv m y = SyntaxZul.mkAdv in_Prep (mkNP (mkCN m y)) ; -- in May 2012
-- dayMonthYearAdv d m y = ParadigmsZul.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 = SyntaxZul.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" ;
}