mirror of
https://github.com/GrammaticalFramework/gf-core.git
synced 2026-05-01 15:22:50 -06:00
English complete (but needs more testing)
This commit is contained in:
1
lib/resource/english/AllResourceEng.gf
Normal file
1
lib/resource/english/AllResourceEng.gf
Normal file
@@ -0,0 +1 @@
|
|||||||
|
concrete AllResourceEng of AllResource = RulesEng, StructuralEng ** {} ;
|
||||||
@@ -50,23 +50,23 @@ lincat
|
|||||||
-- = {s : VForm => Str ; s1 : Particle}
|
-- = {s : VForm => Str ; s1 : Particle}
|
||||||
VG = {s,s2 : Bool => VPForm => Str ; s3 : Number => Str ; isAux : Bool} ;
|
VG = {s,s2 : Bool => VPForm => Str ; s3 : Number => Str ; isAux : Bool} ;
|
||||||
VP = {s,s2 : VPForm => Str ; s3 : Number => Str ; isAux : Bool} ;
|
VP = {s,s2 : VPForm => Str ; s3 : Number => Str ; isAux : Bool} ;
|
||||||
TV = TransVerb ;
|
V2 = TransVerb ;
|
||||||
-- = Verb ** {s3 : Preposition} ;
|
-- = Verb ** {s3 : Preposition} ;
|
||||||
V3 = TransVerb ** {s4 : Preposition} ;
|
V3 = TransVerb ** {s4 : Preposition} ;
|
||||||
VS = Verb ;
|
VS = Verb ;
|
||||||
VV = Verb ** {isAux : Bool} ;
|
VV = Verb ** {isAux : Bool} ;
|
||||||
|
|
||||||
AdV = {s : Str ; p : Bool} ;
|
Adv = {s : Str ; p : Bool} ;
|
||||||
|
|
||||||
S = {s : Str} ;
|
S = {s : Str} ;
|
||||||
Cl = Clause ;
|
Cl = Clause ;
|
||||||
-- = {s : Bool => SForm => Str} ;
|
-- = {s : Bool => SForm => Str} ;
|
||||||
Slash = {s : Bool => Str ; s2 : Preposition} ;
|
Slash = {s : Order => Str ; s2 : Preposition} ;
|
||||||
RP = {s : Gender => Number => NPForm => Str} ;
|
RP = {s : Gender => Number => NPForm => Str} ;
|
||||||
RC = {s : Gender => Number => Str} ;
|
RC = {s : Gender => Number => Str} ;
|
||||||
|
|
||||||
IP = {s : NPForm => Str ; n : Number} ;
|
IP = {s : NPForm => Str ; n : Number} ;
|
||||||
----- Qu = {s : QuestForm => Str} ;
|
Qu = {s : QuestForm => Str} ;
|
||||||
Imp = {s : Number => Str} ;
|
Imp = {s : Number => Str} ;
|
||||||
Phr = {s : Str} ;
|
Phr = {s : Str} ;
|
||||||
Text = {s : Str} ;
|
Text = {s : Str} ;
|
||||||
|
|||||||
@@ -211,5 +211,15 @@ oper
|
|||||||
contractNot : Str -> Str = \is -> variants {is ++ "not" ; is + "n't"} ;
|
contractNot : Str -> Str = \is -> variants {is ++ "not" ; is + "n't"} ;
|
||||||
|
|
||||||
dont = contractNot (verbP3Do.s ! InfImp) ;
|
dont = contractNot (verbP3Do.s ! InfImp) ;
|
||||||
|
|
||||||
|
-- From $numerals$.
|
||||||
|
|
||||||
|
param DForm = unit | teen | ten ;
|
||||||
|
oper mkNum : Str -> Str -> Str -> {s : DForm => Str} =
|
||||||
|
\two -> \twelve -> \twenty ->
|
||||||
|
{s = table {unit => two ; teen => twelve ; ten => twenty}} ;
|
||||||
|
oper regNum : Str -> {s : DForm => Str} =
|
||||||
|
\six -> mkNum six (six + "teen") (six + "ty") ;
|
||||||
|
|
||||||
} ;
|
} ;
|
||||||
|
|
||||||
|
|||||||
31
lib/resource/english/NumeralsEng.gf
Normal file
31
lib/resource/english/NumeralsEng.gf
Normal file
@@ -0,0 +1,31 @@
|
|||||||
|
concrete NumeralsEng of Numerals = open Prelude, MorphoEng in {
|
||||||
|
|
||||||
|
lincat Digit = {s : DForm => Str} ;
|
||||||
|
lincat Sub10 = {s : DForm => Str} ;
|
||||||
|
|
||||||
|
lin num x = x ;
|
||||||
|
lin n2 = mkNum "two" "twelve" "twenty" ;
|
||||||
|
lin n3 = mkNum "three" "thirteen" "thirty" ;
|
||||||
|
lin n4 = mkNum "four" "fourteen" "forty" ;
|
||||||
|
lin n5 = mkNum "five" "fifteen" "fifty" ;
|
||||||
|
lin n6 = regNum "six" ;
|
||||||
|
lin n7 = regNum "seven" ;
|
||||||
|
lin n8 = mkNum "eight" "eighteen" "eighty" ;
|
||||||
|
lin n9 = regNum "nine" ;
|
||||||
|
|
||||||
|
lin pot01 = {s = table {f => "one"}} ;
|
||||||
|
lin pot0 d = {s = table {f => d.s ! f}} ;
|
||||||
|
lin pot110 = ss "ten" ;
|
||||||
|
lin pot111 = ss "eleven" ;
|
||||||
|
lin pot1to19 d = {s = d.s ! teen} ;
|
||||||
|
lin pot0as1 n = {s = n.s ! unit} ;
|
||||||
|
lin pot1 d = {s = d.s ! ten} ;
|
||||||
|
lin pot1plus d e = {s = d.s ! ten ++ "-" ++ e.s ! unit} ;
|
||||||
|
lin pot1as2 n = n ;
|
||||||
|
lin pot2 d = {s = d.s ! unit ++ "hundred"} ;
|
||||||
|
lin pot2plus d e = {s = d.s ! unit ++ "hundred" ++ "and" ++ e.s} ;
|
||||||
|
lin pot2as3 n = n ;
|
||||||
|
lin pot3 n = {s = n.s ++ "thousand"} ;
|
||||||
|
lin pot3plus n m = {s = n.s ++ "thousand" ++ m.s} ;
|
||||||
|
|
||||||
|
}
|
||||||
301
lib/resource/english/ParadigmsEng.gf
Normal file
301
lib/resource/english/ParadigmsEng.gf
Normal file
@@ -0,0 +1,301 @@
|
|||||||
|
--# -path=.:../abstract:../../prelude
|
||||||
|
|
||||||
|
--1 English Lexical Paradigms
|
||||||
|
--
|
||||||
|
-- Aarne Ranta 2003
|
||||||
|
--
|
||||||
|
-- This is an API to the user of the resource grammar
|
||||||
|
-- for adding lexical items. It give shortcuts for forming
|
||||||
|
-- expressions of basic categories: nouns, adjectives, verbs.
|
||||||
|
--
|
||||||
|
-- Closed categories (determiners, pronouns, conjunctions) are
|
||||||
|
-- accessed through the resource syntax API, $Structural.gf$.
|
||||||
|
--
|
||||||
|
-- The main difference with $MorphoEng.gf$ is that the types
|
||||||
|
-- referred to are compiled resource grammar types. We have moreover
|
||||||
|
-- had the design principle of always having existing forms, rather
|
||||||
|
-- than stems, as string
|
||||||
|
-- arguments of the paradigms.
|
||||||
|
--
|
||||||
|
-- The following modules are presupposed:
|
||||||
|
|
||||||
|
resource ParadigmsEng = open (Predef=Predef), Prelude, SyntaxEng, ResourceEng in {
|
||||||
|
|
||||||
|
--2 Parameters
|
||||||
|
--
|
||||||
|
-- To abstract over gender names, we define the following identifiers.
|
||||||
|
|
||||||
|
oper
|
||||||
|
Gender : Type ;
|
||||||
|
|
||||||
|
human : Gender ;
|
||||||
|
nonhuman : Gender ;
|
||||||
|
|
||||||
|
-- To abstract over number names, we define the following.
|
||||||
|
Number : Type ;
|
||||||
|
|
||||||
|
singular : Number ;
|
||||||
|
plural : Number ;
|
||||||
|
|
||||||
|
-- To abstract over case names, we define the following.
|
||||||
|
Case : Type ;
|
||||||
|
|
||||||
|
nominative : Case ;
|
||||||
|
genitive : Case ;
|
||||||
|
|
||||||
|
|
||||||
|
--2 Nouns
|
||||||
|
|
||||||
|
-- Worst case: give all four forms and the semantic gender.
|
||||||
|
-- In practice the worst case is just: give singular and plural nominative.
|
||||||
|
|
||||||
|
oper
|
||||||
|
mkN : (man,men,man's,men's : Str) -> Gender -> N ;
|
||||||
|
nMan : (man,men : Str) -> Gender -> N ;
|
||||||
|
|
||||||
|
-- Regular nouns, nouns ending with "s", "y", or "o", and nouns with the same
|
||||||
|
-- plural form as the singular.
|
||||||
|
|
||||||
|
nReg : Str -> Gender -> N ; -- dog, dogs
|
||||||
|
nKiss : Str -> Gender -> N ; -- kiss, kisses
|
||||||
|
nFly : Str -> Gender -> N ; -- fly, flies
|
||||||
|
nHero : Str -> Gender -> N ; -- hero, heroes (= nKiss !)
|
||||||
|
nSheep : Str -> Gender -> N ; -- sheep, sheep
|
||||||
|
|
||||||
|
-- These use general heuristics, that recognizes the last letter. *N.B* it
|
||||||
|
-- does not get right with "boy", "rush", since it only looks at one letter.
|
||||||
|
|
||||||
|
nHuman : Str -> N ; -- gambler/actress/nanny
|
||||||
|
nNonhuman : Str -> N ; -- dog/kiss/fly
|
||||||
|
|
||||||
|
-- Nouns used as functions need a preposition. The most common is "of".
|
||||||
|
|
||||||
|
mkN2 : N -> Preposition -> N2 ;
|
||||||
|
|
||||||
|
funHuman : Str -> N2 ; -- the father/mistress/daddy of
|
||||||
|
funNonhuman : Str -> N2 ; -- the successor/address/copy of
|
||||||
|
|
||||||
|
-- Proper names, with their regular genitive.
|
||||||
|
|
||||||
|
pnReg : (John : Str) -> PN ; -- John, John's
|
||||||
|
|
||||||
|
-- The most common cases on the higher-level category $CN$ have shortcuts.
|
||||||
|
-- The regular "y"/"s" variation is taken into account.
|
||||||
|
|
||||||
|
cnNonhuman : Str -> CN ;
|
||||||
|
cnHuman : Str -> CN ;
|
||||||
|
npReg : Str -> NP ;
|
||||||
|
|
||||||
|
-- In some cases, you may want to make a complex $CN$ into a function.
|
||||||
|
|
||||||
|
mkN2CN : CN -> Preposition -> N2 ;
|
||||||
|
funOfCN : CN -> N2 ;
|
||||||
|
|
||||||
|
|
||||||
|
--2 Adjectives
|
||||||
|
|
||||||
|
-- Non-comparison one-place adjectives just have one form.
|
||||||
|
|
||||||
|
mkA : (even : Str) -> A ;
|
||||||
|
|
||||||
|
-- Two-place adjectives need a preposition as second argument.
|
||||||
|
|
||||||
|
mkA2 : (divisible, by : Str) -> A2 ;
|
||||||
|
|
||||||
|
-- Comparison adjectives have three forms. The common irregular
|
||||||
|
-- cases are ones ending with "y" and a consonant that is duplicated;
|
||||||
|
-- the "y" ending is recognized by the function $aReg$.
|
||||||
|
|
||||||
|
mkADeg : (good,better,best : Str) -> ADeg ;
|
||||||
|
|
||||||
|
aReg : (long : Str) -> ADeg ; -- long, longer, longest
|
||||||
|
aFat : (fat : Str) -> ADeg ; -- fat, fatter, fattest
|
||||||
|
aRidiculous : (ridiculous : Str) -> ADeg ; -- -/more/most ridiculous
|
||||||
|
|
||||||
|
-- On higher level, there are adjectival phrases. The most common case is
|
||||||
|
-- just to use a one-place adjective.
|
||||||
|
|
||||||
|
apReg : Str -> AP ;
|
||||||
|
|
||||||
|
--2 Adverbs
|
||||||
|
|
||||||
|
-- Adverbs are not inflected. Most lexical ones have position not
|
||||||
|
-- before the verb. Some can be preverbal (e.g. "always").
|
||||||
|
|
||||||
|
mkAdv : Str -> Adv ;
|
||||||
|
mkAdvPre : Str -> Adv ;
|
||||||
|
|
||||||
|
-- Adverbs modifying adjectives and sentences can also be formed.
|
||||||
|
|
||||||
|
mkAdA : Str -> AdA ;
|
||||||
|
mkAdS : Str -> AdS ;
|
||||||
|
|
||||||
|
-- Prepositional phrases are another productive form of adverbials.
|
||||||
|
|
||||||
|
mkPP : Str -> NP -> Adv ;
|
||||||
|
|
||||||
|
--2 Verbs
|
||||||
|
--
|
||||||
|
-- The fragment now has all verb forms, except the gerund/present participle.
|
||||||
|
-- Except for "be", the worst case needs four forms: the infinitive and
|
||||||
|
-- the third person singular present, the past indicative, and the past participle.
|
||||||
|
|
||||||
|
mkV : (go, goes, went, gone : Str) -> V ;
|
||||||
|
|
||||||
|
vReg : (walk : Str) -> V ; -- walk, walks
|
||||||
|
vKiss : (kiss : Str) -> V ; -- kiss, kisses
|
||||||
|
vFly : (fly : Str) -> V ; -- fly, flies
|
||||||
|
vGo : (go : Str) -> V ; -- go, goes (= vKiss !)
|
||||||
|
|
||||||
|
-- This generic function recognizes the special cases where the last
|
||||||
|
-- character is "y", "s", or "z". It is not right for "finish" and "convey".
|
||||||
|
|
||||||
|
vGen : Str -> V ; -- walk/kiss/fly
|
||||||
|
|
||||||
|
-- The verbs "be" and "have" are special.
|
||||||
|
|
||||||
|
vBe : V ;
|
||||||
|
vHave : V ;
|
||||||
|
|
||||||
|
-- Verbs with a particle.
|
||||||
|
|
||||||
|
vPart : (go, goes, went, gone, up : Str) -> V ;
|
||||||
|
vPartReg : (get, up : Str) -> V ;
|
||||||
|
|
||||||
|
-- Two-place verbs, and the special case with direct object.
|
||||||
|
-- Notice that a particle can already be included in $V$.
|
||||||
|
|
||||||
|
mkV2 : V -> Str -> V2 ; -- look for, kill
|
||||||
|
|
||||||
|
tvGen : (look, for : Str) -> V2 ; -- look for, talk about
|
||||||
|
tvDir : V -> V2 ; -- switch off
|
||||||
|
tvGenDir : (kill : Str) -> V2 ; -- kill
|
||||||
|
|
||||||
|
-- Regular two-place verbs with a particle.
|
||||||
|
|
||||||
|
tvPartReg : Str -> Str -> Str -> V2 ; -- get, along, with
|
||||||
|
|
||||||
|
-- Ditransitive verbs.
|
||||||
|
|
||||||
|
mkV3 : V -> Str -> Str -> V3 ; -- speak, with, about
|
||||||
|
v3Dir : V -> Str -> V3 ; -- give,_,to
|
||||||
|
v3DirDir : V -> V3 ; -- give,_,_
|
||||||
|
|
||||||
|
-- The definitions should not bother the user of the API. So they are
|
||||||
|
-- hidden from the document.
|
||||||
|
--.
|
||||||
|
|
||||||
|
Gender = SyntaxEng.Gender ;
|
||||||
|
Number = SyntaxEng.Number ;
|
||||||
|
Case = SyntaxEng.Case ;
|
||||||
|
human = Hum ;
|
||||||
|
nonhuman = NoHum ;
|
||||||
|
singular = Sg ;
|
||||||
|
plural = Pl ;
|
||||||
|
|
||||||
|
nominative = Nom ;
|
||||||
|
genitive = Nom ;
|
||||||
|
|
||||||
|
mkN = \man,men,man's,men's,g ->
|
||||||
|
mkNoun man men man's men's ** {g = g ; lock_N = <>} ;
|
||||||
|
nReg a g = addGenN nounReg a g ;
|
||||||
|
nKiss n g = addGenN nounS n g ;
|
||||||
|
nFly = \fly -> addGenN nounY (Predef.tk 1 fly) ;
|
||||||
|
nMan = \man,men -> mkN man men (man + "'s") (men + "'s") ;
|
||||||
|
nHero = nKiss ;
|
||||||
|
nSheep = \sheep -> nMan sheep sheep ;
|
||||||
|
|
||||||
|
nHuman = \s -> nGen s Hum ;
|
||||||
|
nNonhuman = \s -> nGen s NoHum ;
|
||||||
|
|
||||||
|
nGen : Str -> Gender -> N = \fly,g -> let {
|
||||||
|
fl = Predef.tk 1 fly ;
|
||||||
|
y = Predef.dp 1 fly ;
|
||||||
|
eqy = ifTok (Str -> Gender -> N) y
|
||||||
|
} in
|
||||||
|
eqy "y" nFly (
|
||||||
|
eqy "s" nKiss (
|
||||||
|
eqy "z" nKiss (
|
||||||
|
nReg))) fly g ;
|
||||||
|
|
||||||
|
mkN2 = \n,p -> n ** {lock_N2 = <> ; s2 = p} ;
|
||||||
|
funNonhuman = \s -> mkN2 (nNonhuman s) "of" ;
|
||||||
|
funHuman = \s -> mkN2 (nHuman s) "of" ;
|
||||||
|
|
||||||
|
pnReg n = nameReg n ** {lock_PN = <>} ;
|
||||||
|
|
||||||
|
cnNonhuman = \s -> UseN (nGen s nonhuman) ;
|
||||||
|
cnHuman = \s -> UseN (nGen s human) ;
|
||||||
|
npReg = \s -> UsePN (pnReg s) ;
|
||||||
|
|
||||||
|
mkN2CN = \n,p -> n ** {lock_N2 = <> ; s2 = p} ;
|
||||||
|
funOfCN = \n -> mkN2CN n "of" ;
|
||||||
|
|
||||||
|
addGenN : (Str -> CommonNoun) -> Str -> Gender -> N = \f ->
|
||||||
|
\s,g -> f s ** {g = g ; lock_N = <>} ;
|
||||||
|
|
||||||
|
mkA a = regAdjective a ** {lock_A = <>} ;
|
||||||
|
mkA2 = \s,p -> regAdjective s ** {s2 = p} ** {lock_A2 = <>} ;
|
||||||
|
mkADeg a b c = adjDegrIrreg a b c ** {lock_ADeg = <>} ;
|
||||||
|
aReg a = adjDegrReg a ** {lock_ADeg = <>} ;
|
||||||
|
aFat = \fat -> let {fatt = fat + Predef.dp 1 fat} in
|
||||||
|
mkADeg fat (fatt + "er") (fatt + "est") ;
|
||||||
|
aRidiculous a = adjDegrLong a ** {lock_ADeg = <>} ;
|
||||||
|
apReg = \s -> UseA (mkA s) ;
|
||||||
|
|
||||||
|
aGen : Str -> ADeg = \s -> case last s of {
|
||||||
|
"y" => mkADeg s (init s + "ier") (init s + "iest") ;
|
||||||
|
"e" => mkADeg s (s + "r") (s + "st") ;
|
||||||
|
_ => aReg s
|
||||||
|
} ;
|
||||||
|
|
||||||
|
mkAdv a = advPost a ** {lock_Adv = <>} ;
|
||||||
|
mkAdvPre a = advPre a ** {lock_Adv = <>} ;
|
||||||
|
mkPP x y = prepPhrase x y ** {lock_Adv = <>} ;
|
||||||
|
mkAdA a = ss a ** {lock_AdA = <>} ;
|
||||||
|
mkAdS a = ss a ** {lock_AdS = <>} ;
|
||||||
|
|
||||||
|
mkV = \go,goes,went,gone -> verbNoPart (mkVerbP3 go goes went gone) **
|
||||||
|
{lock_V = <>} ;
|
||||||
|
vReg = \walk -> mkV walk (walk + "s") (walk + "ed") (walk + "ed") ;
|
||||||
|
vKiss = \kiss -> mkV kiss (kiss + "es") (kiss + "ed") (kiss + "ed") ;
|
||||||
|
vFly = \cry -> let {cr = Predef.tk 1 cry} in
|
||||||
|
mkV cry (cr + "ies") (cr + "ied") (cr + "ied") ;
|
||||||
|
vGo = vKiss ;
|
||||||
|
|
||||||
|
vGen = \fly -> let {
|
||||||
|
fl = Predef.tk 1 fly ;
|
||||||
|
y = Predef.dp 1 fly ;
|
||||||
|
eqy = ifTok (Str -> V) y
|
||||||
|
} in
|
||||||
|
eqy "y" vFly (
|
||||||
|
eqy "s" vKiss (
|
||||||
|
eqy "z" vKiss (
|
||||||
|
vReg))) fly ;
|
||||||
|
|
||||||
|
vPart = \go, goes, went, gone, up ->
|
||||||
|
verbPart (mkVerbP3 go goes went gone) up ** {lock_V = <>} ;
|
||||||
|
vPartReg = \get, up ->
|
||||||
|
verbPart (vGen get) up ** {lock_V = <>} ;
|
||||||
|
|
||||||
|
mkV2 = \v,p -> v ** {lock_V2 = <> ; s3 = p} ;
|
||||||
|
tvPartReg = \get, along, to -> mkV2 (vPartReg get along) to ;
|
||||||
|
|
||||||
|
vBe = verbBe ** {s1 = [] ; lock_V = <>} ;
|
||||||
|
vHave = verbP3Have ** {s1 = [] ; lock_V = <>} ;
|
||||||
|
|
||||||
|
tvGen = \s,p -> mkV2 (vGen s) p ;
|
||||||
|
tvDir = \v -> mkV2 v [] ;
|
||||||
|
tvGenDir = \s -> tvDir (vGen s) ;
|
||||||
|
|
||||||
|
mkV3 x y z = mkDitransVerb x y z ** {lock_V3 = <>} ;
|
||||||
|
v3Dir x y = mkV3 x [] y ;
|
||||||
|
v3DirDir x = v3Dir x [] ;
|
||||||
|
|
||||||
|
-- these are used in the generated lexicon
|
||||||
|
noun : Str -> N = nNonhuman ;
|
||||||
|
|
||||||
|
verb2 : Str -> Str -> V2 = \v -> mkV2 (vGen v) ;
|
||||||
|
verb3 : Str -> Str -> Str -> V3 = \v -> mkV3 (vGen v) ;
|
||||||
|
|
||||||
|
} ;
|
||||||
3
lib/resource/english/ResourceEng.gf
Normal file
3
lib/resource/english/ResourceEng.gf
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
--# -path=.:../abstract:../../prelude
|
||||||
|
|
||||||
|
instance ResourceEng of Resource = reuse AllResourceEng ;
|
||||||
@@ -68,25 +68,26 @@ lin
|
|||||||
|
|
||||||
PredV = predVerb ;
|
PredV = predVerb ;
|
||||||
PredAP = predAdjective ;
|
PredAP = predAdjective ;
|
||||||
|
PredSuperl a = predAdjective (superlAdjPhrase a) ;
|
||||||
PredCN = predCommNoun ;
|
PredCN = predCommNoun ;
|
||||||
----- PredV2 = complTransVerb ;
|
PredV2 = complTransVerb ;
|
||||||
PredV3 = complDitransVerb ;
|
PredV3 = complDitransVerb ;
|
||||||
PredPassV = passVerb ;
|
PredPassV = passVerb ;
|
||||||
PredNP = predNounPhrase ;
|
PredNP = predNounPhrase ;
|
||||||
----- PredPP = predAdverb ;
|
PredPP = predAdverb ;
|
||||||
PredVS = complSentVerb ;
|
PredVS = complSentVerb ;
|
||||||
PredVV = complVerbVerb ;
|
PredVV = complVerbVerb ;
|
||||||
----- VTrans = transAsVerb ;
|
VTrans = transAsVerb ;
|
||||||
|
|
||||||
AdjAdv a = advPost (a.s ! AAdv) ;
|
AdjAdv a = advPost (a.s ! AAdv) ;
|
||||||
AdvPP p = p ;
|
AdvPP p = advPost p.s ;
|
||||||
PrepNP p = prepPhrase p.s ; ---
|
PrepNP p = prepPhrase p.s ; ---
|
||||||
----- AdvVP = adVerbPhrase ;
|
AdvVP = adVerbPhrase ;
|
||||||
----- AdvCN = advCommNounPhrase ;
|
AdvCN = advCommNounPhrase ;
|
||||||
AdvAP = advAdjPhrase ;
|
AdvAP = advAdjPhrase ;
|
||||||
} {- -----
|
|
||||||
PosSlashTV = slashTransVerb True ;
|
PosSlashV2 = slashTransVerb True ;
|
||||||
NegSlashTV = slashTransVerb False ;
|
NegSlashV2 = slashTransVerb False ;
|
||||||
OneVP = predVerbPhrase (nameNounPhrase (nameReg "one")) ;
|
OneVP = predVerbPhrase (nameNounPhrase (nameReg "one")) ;
|
||||||
ThereNP = thereIs ;
|
ThereNP = thereIs ;
|
||||||
|
|
||||||
@@ -118,6 +119,7 @@ lin
|
|||||||
ImperOne = imperUtterance singular ;
|
ImperOne = imperUtterance singular ;
|
||||||
ImperMany = imperUtterance plural ;
|
ImperMany = imperUtterance plural ;
|
||||||
|
|
||||||
|
PrepS p = ss (p.s ++ ",") ;
|
||||||
AdvS = advSentence ;
|
AdvS = advSentence ;
|
||||||
|
|
||||||
TwoS = twoSentence ;
|
TwoS = twoSentence ;
|
||||||
@@ -150,4 +152,3 @@ lin
|
|||||||
ConsPhr = cc2 ;
|
ConsPhr = cc2 ;
|
||||||
|
|
||||||
} ;
|
} ;
|
||||||
-}
|
|
||||||
@@ -5,7 +5,7 @@
|
|||||||
-- Aarne Ranta 2002 -- 2003
|
-- Aarne Ranta 2002 -- 2003
|
||||||
--
|
--
|
||||||
concrete StructuralEng of Structural =
|
concrete StructuralEng of Structural =
|
||||||
CategoriesEng ** open Prelude, SyntaxEng in {
|
CategoriesEng, NumeralsEng ** open Prelude, SyntaxEng in {
|
||||||
lin
|
lin
|
||||||
INP = pronI ;
|
INP = pronI ;
|
||||||
ThouNP = pronYouSg ;
|
ThouNP = pronYouSg ;
|
||||||
@@ -16,12 +16,16 @@ concrete StructuralEng of Structural =
|
|||||||
YeNumNP = pronWithNum pronYouPl ;
|
YeNumNP = pronWithNum pronYouPl ;
|
||||||
YouNP = pronYouSg ;
|
YouNP = pronYouSg ;
|
||||||
TheyNP = pronThey ;
|
TheyNP = pronThey ;
|
||||||
|
TheyFemNP = pronThey ;
|
||||||
|
|
||||||
EveryDet = everyDet ;
|
EveryDet = everyDet ;
|
||||||
AllMassDet = mkDeterminer Sg "all" ; --- all the missing
|
AllMassDet = mkDeterminer Sg "all" ; --- all the missing
|
||||||
AllNumDet = mkDeterminerNum Pl "all" ;
|
AllNumDet = mkDeterminerNum Pl "all" ;
|
||||||
WhichDet = whichDet ;
|
WhichDet = whichDet ;
|
||||||
WhichNumDet = mkDeterminerNum Pl "which" ;
|
WhichNumDet = mkDeterminerNum Pl "which" ;
|
||||||
|
|
||||||
|
UseNumeral i = {s = table {Nom => i.s ; Gen => i.s ++ "'s"}} ; ---
|
||||||
|
|
||||||
MostsDet = mostDet ;
|
MostsDet = mostDet ;
|
||||||
MostDet = mkDeterminer Sg "most" ;
|
MostDet = mkDeterminer Sg "most" ;
|
||||||
SomeDet = mkDeterminer Sg "some" ;
|
SomeDet = mkDeterminer Sg "some" ;
|
||||||
@@ -31,6 +35,7 @@ concrete StructuralEng of Structural =
|
|||||||
NoDet = mkDeterminer Sg "no" ;
|
NoDet = mkDeterminer Sg "no" ;
|
||||||
NoNumDet = mkDeterminerNum Pl "no" ;
|
NoNumDet = mkDeterminerNum Pl "no" ;
|
||||||
ManyDet = mkDeterminer Pl "many" ;
|
ManyDet = mkDeterminer Pl "many" ;
|
||||||
|
HowManyDet = mkDeterminer Pl ["how many"] ;
|
||||||
MuchDet = mkDeterminer Sg ["a lot of"] ; ---
|
MuchDet = mkDeterminer Sg ["a lot of"] ; ---
|
||||||
ThisDet = mkDeterminer Sg "this" ;
|
ThisDet = mkDeterminer Sg "this" ;
|
||||||
TheseNumDet = mkDeterminerNum Pl "these" ;
|
TheseNumDet = mkDeterminerNum Pl "these" ;
|
||||||
|
|||||||
@@ -192,6 +192,13 @@ oper
|
|||||||
p = P3
|
p = P3
|
||||||
} ;
|
} ;
|
||||||
|
|
||||||
|
-- Moreover, superlatives can be used alone as adjectival phrases
|
||||||
|
-- ("the youngest" - in free variation).
|
||||||
|
|
||||||
|
superlAdjPhrase : AdjDegr -> AdjPhrase = \big ->
|
||||||
|
{s = \\a => "the" ++ big.s ! Sup ! a ;
|
||||||
|
p = True
|
||||||
|
} ;
|
||||||
|
|
||||||
--3 Two-place adjectives
|
--3 Two-place adjectives
|
||||||
--
|
--
|
||||||
@@ -298,10 +305,12 @@ oper
|
|||||||
|
|
||||||
Tense = Present | Past ;
|
Tense = Present | Past ;
|
||||||
Anteriority = Simul | Anter ;
|
Anteriority = Simul | Anter ;
|
||||||
|
Order = Direct | Indirect ;
|
||||||
VPForm =
|
VPForm =
|
||||||
VIndic Tense Anteriority Number Person
|
VIndic Tense Anteriority Number Person
|
||||||
| VFut Anteriority
|
| VFut Anteriority
|
||||||
| VCondit Anteriority
|
| VCondit Anteriority
|
||||||
|
| VQuest Tense Number Person --- needed for "do" inversions
|
||||||
| VImperat
|
| VImperat
|
||||||
| VInfinit Anteriority
|
| VInfinit Anteriority
|
||||||
;
|
;
|
||||||
@@ -324,6 +333,11 @@ oper
|
|||||||
<Present,_,_> => "have" ;
|
<Present,_,_> => "have" ;
|
||||||
<Past,_,_> => "had"
|
<Past,_,_> => "had"
|
||||||
} ;
|
} ;
|
||||||
|
do : Tense -> Number -> Person -> Str = \t,n,p -> case <t,n,p> of {
|
||||||
|
<Present,Sg,P3> => "does" ;
|
||||||
|
<Present,_,_> => "do" ;
|
||||||
|
<Past,_,_> => "did"
|
||||||
|
} ;
|
||||||
simple : VForm -> {fin,inf : Str} = \v -> {
|
simple : VForm -> {fin,inf : Str} = \v -> {
|
||||||
fin = goes.s ! v ;
|
fin = goes.s ! v ;
|
||||||
inf = []
|
inf = []
|
||||||
@@ -337,6 +351,7 @@ oper
|
|||||||
in case sf of {
|
in case sf of {
|
||||||
VIndic t Simul n p => simple (tense t n p) ;
|
VIndic t Simul n p => simple (tense t n p) ;
|
||||||
VIndic t Anter n p => compound (have t n p) gone ;
|
VIndic t Anter n p => compound (have t n p) gone ;
|
||||||
|
VQuest t n p => compound (do Present n p) go ;
|
||||||
VFut Simul => compound "will" go ;
|
VFut Simul => compound "will" go ;
|
||||||
VFut Anter => compound "will" ("have" ++ gone) ;
|
VFut Anter => compound "will" ("have" ++ gone) ;
|
||||||
VCondit Simul => compound "would" go ;
|
VCondit Simul => compound "would" go ;
|
||||||
@@ -381,11 +396,16 @@ oper
|
|||||||
has : VPForm => Str = \\f => (go f).fin ;
|
has : VPForm => Str = \\f => (go f).fin ;
|
||||||
gone : VPForm => Str = \\f => (go f).inf
|
gone : VPForm => Str = \\f => (go f).inf
|
||||||
in {
|
in {
|
||||||
s = \\_ => has ;
|
s = \\b =>
|
||||||
s2 = table {
|
table {
|
||||||
True => gone ;
|
VQuest t n p => has ! VIndic t Simul n p ; --- undo "do" inversion
|
||||||
False => \\vf => "not" ++ gone ! vf
|
vf => has ! vf
|
||||||
} ;
|
} ;
|
||||||
|
s2 = \\b => let not = if_then_Str b [] "not" in
|
||||||
|
table {
|
||||||
|
VQuest t n p => not ++ gone ! VIndic t Simul n p ;
|
||||||
|
vf => not ++ gone ! vf
|
||||||
|
} ;
|
||||||
s3 = arg ;
|
s3 = arg ;
|
||||||
isAux = True
|
isAux = True
|
||||||
} ;
|
} ;
|
||||||
@@ -452,7 +472,7 @@ oper
|
|||||||
predNounPhrase : NounPhrase -> VerbGroup = \john ->
|
predNounPhrase : NounPhrase -> VerbGroup = \john ->
|
||||||
beGroup (\\_ => john.s ! NomP) ;
|
beGroup (\\_ => john.s ! NomP) ;
|
||||||
|
|
||||||
predAdverb : Adverb -> VerbGroup = \elsewhere ->
|
predAdverb : PrepPhrase -> VerbGroup = \elsewhere ->
|
||||||
beGroup (\\_ => elsewhere.s) ;
|
beGroup (\\_ => elsewhere.s) ;
|
||||||
|
|
||||||
|
|
||||||
@@ -561,13 +581,15 @@ oper
|
|||||||
locativeNounPhrase : NounPhrase -> Adverb =
|
locativeNounPhrase : NounPhrase -> Adverb =
|
||||||
prepPhrase "in" ;
|
prepPhrase "in" ;
|
||||||
|
|
||||||
-- This is a source of the "mann with a telescope" ambiguity, and may produce
|
PrepPhrase = SS ;
|
||||||
|
|
||||||
|
-- This is a source of the "man with a telescope" ambiguity, and may produce
|
||||||
-- strange things, like "cars always" (while "cars today" is OK).
|
-- strange things, like "cars always" (while "cars today" is OK).
|
||||||
-- Semantics will have to make finer distinctions among adverbials.
|
-- Semantics will have to make finer distinctions among adverbials.
|
||||||
--
|
--
|
||||||
-- N.B. the genitive case created in this way would not make sense.
|
-- N.B. the genitive case created in this way would not make sense.
|
||||||
|
|
||||||
advCommNounPhrase : CommNounPhrase -> Adverb -> CommNounPhrase = \car,today ->
|
advCommNounPhrase : CommNounPhrase -> PrepPhrase -> CommNounPhrase = \car,today ->
|
||||||
{s = \\n => table {
|
{s = \\n => table {
|
||||||
Nom => car.s ! n ! Nom ++ today.s ;
|
Nom => car.s ! n ! Nom ++ today.s ;
|
||||||
Gen => nonExist
|
Gen => nonExist
|
||||||
@@ -601,31 +623,39 @@ oper
|
|||||||
|
|
||||||
param
|
param
|
||||||
ClForm =
|
ClForm =
|
||||||
ClIndic Tense Anteriority
|
ClIndic Order Tense Anteriority
|
||||||
| ClFut Anteriority
|
| ClFut Order Anteriority
|
||||||
| ClCondit Anteriority
|
| ClCondit Order Anteriority
|
||||||
| ClInfinit Anteriority -- "naked infinitive" clauses
|
| ClInfinit Anteriority -- "naked infinitive" clauses
|
||||||
;
|
;
|
||||||
|
|
||||||
oper
|
oper
|
||||||
cl2s : ClForm -> Number -> Person -> VPForm = \c,n,p -> case c of {
|
cl2s : ClForm -> Number -> Person -> {form : VPForm ; order : Order} = \c,n,p -> case c of {
|
||||||
ClIndic t a => VIndic t a n p ;
|
ClIndic Indirect t Simul => {form = VQuest t n p ; order = Indirect} ;
|
||||||
ClFut a => VFut a ;
|
ClIndic o t a => {form = VIndic t a n p ; order = o} ;
|
||||||
ClCondit a => VCondit a ;
|
ClFut o a => {form = VFut a ; order = o} ;
|
||||||
ClInfinit a => VInfinit a
|
ClCondit o a => {form = VCondit a ; order = o} ;
|
||||||
|
ClInfinit a => {form = VInfinit a ; order = Direct} --- order does not matter
|
||||||
} ;
|
} ;
|
||||||
|
|
||||||
Clause = {s : Bool => ClForm => Str} ;
|
Clause = {s : Bool => ClForm => Str} ;
|
||||||
|
|
||||||
predVerbGroupClause : NounPhrase -> VerbGroup -> Clause =
|
predVerbGroupClause : NounPhrase -> VerbGroup -> Clause =
|
||||||
\you,sleep -> {
|
\yo,sleep -> {
|
||||||
s = \\b,c =>
|
s = \\b,c =>
|
||||||
let
|
let
|
||||||
n = you.n ;
|
n = yo.n ;
|
||||||
cf = cl2s c n you.p
|
cfo = cl2s c n yo.p ;
|
||||||
|
cf = cfo.form ;
|
||||||
|
o = cfo.order ;
|
||||||
|
you = yo.s ! NomP ;
|
||||||
|
do = sleep.s ! b ! cf ;
|
||||||
|
sleeps = sleep.s2 ! b ! cf ++ sleep.s3 ! n
|
||||||
in
|
in
|
||||||
you.s ! NomP ++ sleep.s ! b ! cf ++ sleep.s2 ! b ! cf ++
|
case o of {
|
||||||
sleep.s3 ! n
|
Direct => you ++ do ++ sleeps ;
|
||||||
|
Indirect => do ++ you ++ sleeps
|
||||||
|
}
|
||||||
} ;
|
} ;
|
||||||
|
|
||||||
--3 Sentence-complement verbs
|
--3 Sentence-complement verbs
|
||||||
@@ -685,7 +715,7 @@ oper
|
|||||||
vvCan : VerbVerb = mkVerbAux ["be able to"] "can" "could" ["been able to"] ;
|
vvCan : VerbVerb = mkVerbAux ["be able to"] "can" "could" ["been able to"] ;
|
||||||
vvMust : VerbVerb = mkVerbAux ["have to"] "must" ["had to"] ["had to"] ;
|
vvMust : VerbVerb = mkVerbAux ["have to"] "must" ["had to"] ["had to"] ;
|
||||||
|
|
||||||
}{- -----
|
|
||||||
--2 Sentences missing noun phrases
|
--2 Sentences missing noun phrases
|
||||||
--
|
--
|
||||||
-- This is one instance of Gazdar's *slash categories*, corresponding to his
|
-- This is one instance of Gazdar's *slash categories*, corresponding to his
|
||||||
@@ -700,25 +730,26 @@ oper
|
|||||||
--
|
--
|
||||||
-- The particle always follows the verb, but the preposition can fly:
|
-- The particle always follows the verb, but the preposition can fly:
|
||||||
-- "whom you make it up with" / "with whom you make it up".
|
-- "whom you make it up with" / "with whom you make it up".
|
||||||
|
--- We reduce the current case to a more general one that has tense variation.
|
||||||
|
--- TODO: full tense variation on top level.
|
||||||
|
|
||||||
SentenceSlashNounPhrase = {s : Bool => Str ; s2 : Preposition} ;
|
SentenceSlashNounPhrase = {s : Order => Str ; s2 : Preposition} ;
|
||||||
|
ClauseSlashNounPhrase = Clause ** {s2 : Preposition} ;
|
||||||
|
|
||||||
slashTransVerb : Bool -> NounPhrase -> TransVerb -> SentenceSlashNounPhrase =
|
slashTransVerb : Bool -> NounPhrase -> TransVerb -> SentenceSlashNounPhrase =
|
||||||
\b,You,lookat ->
|
\pol,You,lookat ->
|
||||||
let {you = You.s ! NomP ;
|
let
|
||||||
looks = indicVerb {s = lookat.s} You.p You.n ;
|
youlookat = slashTransVerbCl You lookat
|
||||||
look = lookat.s ! InfImp ;
|
in {
|
||||||
do = indicVerb verbP3Do You.p You.n ;
|
s = \\o => youlookat.s ! pol ! ClIndic o Present Simul ;
|
||||||
dont = contractNot do ;
|
s2 = youlookat.s2
|
||||||
up = lookat.s1
|
} ;
|
||||||
} in
|
|
||||||
{s = table {
|
|
||||||
True => if_then_else Str b do dont ++ you ++ look ++ up ;
|
|
||||||
False => you ++ if_then_else Str b looks (dont ++ look) ++ up
|
|
||||||
} ;
|
|
||||||
s2 = lookat.s3
|
|
||||||
} ;
|
|
||||||
|
|
||||||
|
slashTransVerbCl : NounPhrase -> TransVerb -> ClauseSlashNounPhrase =
|
||||||
|
\you,lookat ->
|
||||||
|
predVerbGroupClause you (predVerb lookat) ** {s2 = lookat.s3} ;
|
||||||
|
|
||||||
|
--- TODO: "there is" with tense variation.
|
||||||
|
|
||||||
thereIs : NounPhrase -> Sentence = \abar ->
|
thereIs : NounPhrase -> Sentence = \abar ->
|
||||||
predVerbPhrase
|
predVerbPhrase
|
||||||
@@ -729,6 +760,7 @@ oper
|
|||||||
(predVerbGroup True (predNounPhrase abar)) ;
|
(predVerbGroup True (predNounPhrase abar)) ;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--2 Relative pronouns and relative clauses
|
--2 Relative pronouns and relative clauses
|
||||||
--
|
--
|
||||||
-- As described in $types.Eng.gf$, relative pronouns are inflected in
|
-- As described in $types.Eng.gf$, relative pronouns are inflected in
|
||||||
@@ -744,19 +776,24 @@ oper
|
|||||||
mother.s2 ++ which.s ! g ! n ! GenSP
|
mother.s2 ++ which.s ! g ! n ! GenSP
|
||||||
} ;
|
} ;
|
||||||
|
|
||||||
|
-- An auxiliary that allows the use of predication with relative pronouns.
|
||||||
|
|
||||||
|
relNounPhrase : RelPron -> Gender -> Number -> NounPhrase = \who,g,n ->
|
||||||
|
{s = who.s ! g ! n ; n = n ; p = P3} ;
|
||||||
|
|
||||||
-- Relative clauses can be formed from both verb phrases ("who walks") and
|
-- Relative clauses can be formed from both verb phrases ("who walks") and
|
||||||
-- slash expressions ("whom you see", "on which you sit" / "that you sit on").
|
-- slash expressions ("whom you see", "on which you sit" / "that you sit on").
|
||||||
|
|
||||||
RelClause : Type = {s : Gender => Number => Str} ;
|
RelClause : Type = {s : Gender => Number => Str} ;
|
||||||
|
|
||||||
relVerbPhrase : RelPron -> VerbPhrase -> RelClause = \who,walks ->
|
relVerbPhrase : RelPron -> VerbPhrase -> RelClause = \who,walks ->
|
||||||
{s = \\g, n => who.s ! g ! n ! NomP ++
|
{s = \\g,n => (predVerbPhrase (relNounPhrase who g n) walks).s} ;
|
||||||
indicVerb (verbOfPhrase walks) P3 n ++ walks.s2 ! n
|
|
||||||
} ;
|
--- TODO: full tense variation in relative clauses.
|
||||||
|
|
||||||
relSlash : RelPron -> SentenceSlashNounPhrase -> RelClause = \who,yousee ->
|
relSlash : RelPron -> SentenceSlashNounPhrase -> RelClause = \who,yousee ->
|
||||||
{s = \\g,n =>
|
{s = \\g,n =>
|
||||||
let {youSee = yousee.s ! False} in
|
let {youSee = yousee.s ! Direct} in
|
||||||
variants {
|
variants {
|
||||||
who.s ! g ! n ! AccP ++ youSee ++ yousee.s2 ;
|
who.s ! g ! n ! AccP ++ youSee ++ yousee.s2 ;
|
||||||
yousee.s2 ++ who.s ! g ! n ! GenSP ++ youSee
|
yousee.s2 ++ who.s ! g ! n ! GenSP ++ youSee
|
||||||
@@ -778,7 +815,6 @@ oper
|
|||||||
g = man.g
|
g = man.g
|
||||||
} ;
|
} ;
|
||||||
|
|
||||||
|
|
||||||
--2 Interrogative pronouns
|
--2 Interrogative pronouns
|
||||||
--
|
--
|
||||||
-- If relative pronouns are adjective-like, interrogative pronouns are
|
-- If relative pronouns are adjective-like, interrogative pronouns are
|
||||||
@@ -850,6 +886,8 @@ param
|
|||||||
oper
|
oper
|
||||||
Question = SS1 QuestForm ;
|
Question = SS1 QuestForm ;
|
||||||
|
|
||||||
|
--- TODO: questions in all tenses.
|
||||||
|
|
||||||
--3 Yes-no questions
|
--3 Yes-no questions
|
||||||
--
|
--
|
||||||
-- Yes-no questions are used both independently
|
-- Yes-no questions are used both independently
|
||||||
@@ -865,15 +903,17 @@ oper
|
|||||||
questVerbPhrase' False ;
|
questVerbPhrase' False ;
|
||||||
|
|
||||||
questVerbPhrase' : Bool -> NounPhrase -> VerbPhrase -> Question =
|
questVerbPhrase' : Bool -> NounPhrase -> VerbPhrase -> Question =
|
||||||
\adv,john,walk ->
|
\adv,John,walk ->
|
||||||
|
let
|
||||||
|
john = John.s ! NomP
|
||||||
|
in
|
||||||
{s = table {
|
{s = table {
|
||||||
DirQ => if_then_else Str walk.isAux
|
DirQ => walk.s ! VQuest Present John.n John.p ++
|
||||||
(indicVerb (verbOfPhrase walk) john.p john.n ++
|
john ++
|
||||||
john.s ! NomP ++ walk.s2 ! john.n)
|
walk.s2 ! VQuest Present John.n John.p ++
|
||||||
(indicVerb verbP3Do john.p john.n ++
|
walk.s3 ! John.n ;
|
||||||
john.s ! NomP ++ walk.s ! InfImp ++ walk.s2 ! john.n) ;
|
|
||||||
IndirQ => if_then_else Str adv [] (variants {"if" ; "whether"}) ++
|
IndirQ => if_then_else Str adv [] (variants {"if" ; "whether"}) ++
|
||||||
(predVerbPhrase john walk).s
|
(predVerbPhrase John walk).s
|
||||||
}
|
}
|
||||||
} ;
|
} ;
|
||||||
|
|
||||||
@@ -885,22 +925,20 @@ oper
|
|||||||
})
|
})
|
||||||
(predVerbGroup True (predNounPhrase abar)) ;
|
(predVerbGroup True (predNounPhrase abar)) ;
|
||||||
|
|
||||||
|
|
||||||
--3 Wh-questions
|
--3 Wh-questions
|
||||||
--
|
--
|
||||||
-- Wh-questions are of two kinds: ones that are like $NP - VP$ sentences,
|
-- Wh-questions are of two kinds: ones that are like $NP - VP$ sentences,
|
||||||
-- others that are line $S/NP - NP$ sentences.
|
-- others that are line $S/NP - NP$ sentences.
|
||||||
|
|
||||||
intVerbPhrase : IntPron -> VerbPhrase -> Question = \who,walk ->
|
intVerbPhrase : IntPron -> VerbPhrase -> Question = \who,walk ->
|
||||||
{s = \\_ => who.s ! NomP ++ indicVerb (verbOfPhrase walk) P3 who.n ++
|
{s = \\_ => who.s ! NomP ++ presentIndicative walk who.n P3
|
||||||
walk.s2 ! who.n
|
|
||||||
} ;
|
} ;
|
||||||
|
|
||||||
intSlash : IntPron -> SentenceSlashNounPhrase -> Question = \who,yousee ->
|
intSlash : IntPron -> SentenceSlashNounPhrase -> Question = \who,yousee ->
|
||||||
{s = \\q =>
|
{s = \\q =>
|
||||||
let {youSee = case q of {
|
let {youSee = case q of {
|
||||||
DirQ => yousee.s ! True ;
|
DirQ => yousee.s ! Indirect ;
|
||||||
IndirQ => yousee.s ! False
|
IndirQ => yousee.s ! Direct
|
||||||
}
|
}
|
||||||
} in
|
} in
|
||||||
variants {
|
variants {
|
||||||
@@ -909,9 +947,9 @@ oper
|
|||||||
}
|
}
|
||||||
} ;
|
} ;
|
||||||
|
|
||||||
--3 Interrogative adverbials
|
--3 Interrogative adverbs
|
||||||
--
|
--
|
||||||
-- These adverbials will be defined in the lexicon: they include
|
-- These adverbs will be defined in the lexicon: they include
|
||||||
-- "when", "where", "how", "why", etc, which are all invariant one-word
|
-- "when", "where", "how", "why", etc, which are all invariant one-word
|
||||||
-- expressions. In addition, they can be formed by adding prepositions
|
-- expressions. In addition, they can be formed by adding prepositions
|
||||||
-- to interrogative pronouns, in the same way as adverbials are formed
|
-- to interrogative pronouns, in the same way as adverbials are formed
|
||||||
@@ -929,7 +967,6 @@ oper
|
|||||||
\why, you, walk ->
|
\why, you, walk ->
|
||||||
{s = \\q => why.s ++ (questVerbPhrase' True you walk).s ! q} ;
|
{s = \\q => why.s ++ (questVerbPhrase' True you walk).s ! q} ;
|
||||||
|
|
||||||
|
|
||||||
--2 Imperatives
|
--2 Imperatives
|
||||||
--
|
--
|
||||||
-- We only consider second-person imperatives.
|
-- We only consider second-person imperatives.
|
||||||
@@ -937,14 +974,14 @@ oper
|
|||||||
Imperative = SS1 Number ;
|
Imperative = SS1 Number ;
|
||||||
|
|
||||||
imperVerbPhrase : VerbPhrase -> Imperative = \walk ->
|
imperVerbPhrase : VerbPhrase -> Imperative = \walk ->
|
||||||
{s = \\n => walk.s ! InfImp ++ walk.s2 ! n} ;
|
{s = \\n => walk.s ! VImperat ++ walk.s2 ! VImperat ++ walk.s3 ! n} ;
|
||||||
|
|
||||||
imperUtterance : Number -> Imperative -> Utterance = \n,I ->
|
imperUtterance : Number -> Imperative -> Utterance = \n,I ->
|
||||||
ss (I.s ! n ++ "!") ;
|
ss (I.s ! n ++ "!") ;
|
||||||
|
|
||||||
--2 Sentence adverbials
|
--2 Sentence adverbs
|
||||||
--
|
--
|
||||||
-- This class covers adverbials such as "otherwise", "therefore", which are prefixed
|
-- This class covers adverbs such as "otherwise", "therefore", which are prefixed
|
||||||
-- to a sentence to form a phrase.
|
-- to a sentence to form a phrase.
|
||||||
|
|
||||||
advSentence : SS -> Sentence -> Utterance = \hence,itiseven ->
|
advSentence : SS -> Sentence -> Utterance = \hence,itiseven ->
|
||||||
@@ -1119,4 +1156,3 @@ oper
|
|||||||
x ;
|
x ;
|
||||||
|
|
||||||
} ;
|
} ;
|
||||||
-}
|
|
||||||
@@ -1,9 +1,7 @@
|
|||||||
--# -path=.:../abstract:../../prelude
|
--# -path=.:../abstract:../../prelude
|
||||||
|
|
||||||
concrete TestResourceEng of TestResource = RulesEng, StructuralEng **
|
concrete TestResourceEng of TestResource = RulesEng, StructuralEng **
|
||||||
{}
|
open SyntaxEng, ParadigmsEng in {
|
||||||
{- -----
|
|
||||||
open SyntaxEng, ParadigmsEng in {
|
|
||||||
|
|
||||||
flags startcat=Phr ; lexer=textlit ; parser=chart ; unlexer=text ;
|
flags startcat=Phr ; lexer=textlit ; parser=chart ; unlexer=text ;
|
||||||
|
|
||||||
@@ -51,4 +49,3 @@ lin
|
|||||||
Mary = nameReg "Mary" ;
|
Mary = nameReg "Mary" ;
|
||||||
|
|
||||||
} ;
|
} ;
|
||||||
-}
|
|
||||||
Reference in New Issue
Block a user