concrete SentencesCat of Sentences = NumeralCat ** SentencesI - [ IsMass, IFemale, YouFamFemale, YouPolFemale, IMale, YouFamMale, YouPolMale, WherePlace, WherePerson, ABePlace, Superlative ] with (Syntax = SyntaxCat), (Symbolic = SymbolicCat), (Lexicon = LexiconCat) ** open ParadigmsCat, BeschCat, SyntaxCat, ExtraCat, Prelude in { flags coding = utf8 ; lincat Superlative = OrdSuperlative ; -- {ord: Ord ; isPre: Bool} lin IsMass m q = mkCl (mkNP the_Det m) q ; -- le vin allemand est bon IFemale = {name = mkNP (ProDrop i8fem_Pron) ; isPron = True ; poss = mkQuant i_Pron} ; YouFamFemale = {name = mkNP (ProDrop youSg8fem_Pron) ; isPron = True ; poss = mkQuant youSg_Pron} ; YouPolFemale = {name = mkNP (ProDrop youPol8fem_Pron) ; isPron = True ; poss = mkQuant youPol_Pron}; IMale = {name = mkNP (ProDrop i_Pron) ; isPron = True ; poss = mkQuant i_Pron} ; YouFamMale = {name = mkNP (ProDrop youSg_Pron) ; isPron = True ; poss = mkQuant youSg_Pron} ; YouPolMale = {name = mkNP (ProDrop youPol_Pron) ; isPron = True ; poss = mkQuant youPol_Pron} ; ABePlace p place = mkCl p.name (mkVP (mkVP ser) place.at) ; WherePlace place = mkQS (mkQCl where_IAdv (mkCl place.name ser) ) ; WherePerson person = mkQS (mkQCl where_IAdv (mkCl person.name ser) ) ; oper ser = mkV (ser_52 "ser") ; CNPlace : Type = {name : CN ; at : Prep ; to : Prep } ; mkCNPlace : CN -> Prep -> Prep -> CNPlace = \p,i,t -> { name = p ; at = i ; to = t ; } ; OrdSuperlative : Type = {ord: Ord ; isPre: Bool} ; placeNPSuperl : OrdSuperlative -> CNPlace -> NPPlace = \sup,kind -> case sup.isPre of { True => placeNPDet sup.ord kind ; False => placeNPAdj sup.ord kind } ; placeNPDet : Ord -> CNPlace -> NPPlace = \ord,kind -> let name : NP = mkNP (mkDet the_Art ord) kind.name in { name = name ; at = SyntaxCat.mkAdv kind.at name ; to = SyntaxCat.mkAdv kind.to name ; }; placeNPAdj : Ord -> CNPlace -> NPPlace = \ord,kind -> let name : NP = mkNP the_Art (mkCN kind.name (mkAP ord)) in { name = name ; at = SyntaxCat.mkAdv kind.at name ; to = SyntaxCat.mkAdv kind.to name ; }; }