Files
gf-rgl/src/malay/ResMay.gf
2021-08-19 10:17:24 +02:00

235 lines
5.4 KiB
Plaintext

resource ResMay = ParamMay ** open Prelude, Predef, ParamMay in {
--------------------------------------------------------------------------------
-- Nouns
oper
Noun : Type = {
s : NForm => Str
} ;
Noun2 : Type = Noun ** {c2 : Preposition} ;
Noun3 : Type = Noun2 ** {c3 : Preposition} ;
CNoun : Type = Noun ** {
} ;
PNoun : Type = Noun ;
mkNoun : Str -> Noun = \anjing -> {
s = table {
NF Sg p => anjing + ParamMay.poss2str p ;
NF Pl p => duplicate anjing + ParamMay.poss2str p
}
} ;
useN : Noun -> CNoun = \n -> n ;
---------------------------------------------
-- Pronoun
Pronoun : Type = {
s : Str ;
p : Person ; -- for relative clauses
empty : Str ; -- need to avoid GF being silly. See https://inariksit.github.io/gf/2018/08/28/gf-gotchas.html#metavariables-or-those-question-marks-that-appear-when-parsing
} ;
mkPron : Str -> Person -> Pronoun = \str,p -> {
s = str ;
p = p ;
empty = []
} ;
---------------------------------------------
-- NP
NounPhrase : Type = {
s : Possession => Str ; -- maybe need to keep +nya etc. open for becoming possessed? TODO check
a : NPAgr ; -- NP can be made out of nouns and pronouns, need to retain its origin
empty : Str ; -- need to avoid GF being silly. See https://inariksit.github.io/gf/2018/08/28/gf-gotchas.html#metavariables-or-those-question-marks-that-appear-when-parsing
} ;
emptyNP : NounPhrase = {
s = \\_ => [] ;
a = NotPron ;
empty = []
} ;
--------------------------------------------------------------------------------
-- Det, Quant, Card, Ord
BaseQuant : Type = {
s : Str ;
poss : Possession ;
} ;
Determiner : Type = BaseQuant ** {
sp : NForm => Str ;
n : Number ;
-- numtype : NumType ; -- number as in "5" or "Sg/Pl", often makes a difference in lots of things
} ;
Quant : Type = BaseQuant ** {
sp : NForm => Str ;
} ;
Num : Type = {
s : DForm => Str ; -- independent or attribute
n : Number
} ;
baseNum : Num = {
s = \\_ => [] ;
n = Sg ;
numtype = NoNum
} ;
Numeral : Type = Num ** {
ord : Str
} ;
baseQuant : BaseQuant = {
s = [] ;
poss = Bare ;
} ;
mkQuant : Str -> Quant = \str -> baseQuant ** {
s = str ;
sp = \\_ => str
} ;
--------------------------------------------------------------------------------
-- Prepositions
Preposition : Type = {
s : Str ; -- dengan
obj : Person => Str ; -- dengan+nya -- needed in relative clauses to refer to the object
isPoss : Bool ;
} ;
mkPrep : Str -> Preposition = \dengan -> {
s = dengan ;
obj = \\p => dengan + poss2str (Poss p) ;
isPoss = False ;
} ;
emptyPrep : Preposition = {
s = [] ;
obj = table {
P1 => BIND ++ "ku" ;
P2 => BIND ++ "mu" ;
P3 => BIND ++ "nya" } ;
isPoss = True ;
} ;
applyPrep : Preposition -> NounPhrase -> Str = \prep,np ->
case np.a of {
IsPron p => prep.obj ! p ++ np.empty ;
NotPron => prep.s ++ np.s ! Bare
} ;
--------------------------------------------------------------------------------
-- Adjectives
Adjective : Type = Verb ; -- TODO check if meaningful
Adjective2 : Type = Adjective ;
mkAdj : Str -> Adjective = \str -> {s = \\_ => str} ;
AdjPhrase : Type = Adjective ; -- ** {compar : Str} ;
--------------------------------------------------------------------------------
-- Verbs
Verb : Type = {
s : VForm => Str
} ;
Verb2 : Type = Verb ** {
c2 : Preposition ;
passive : Str
} ;
Verb3 : Type = Verb2 ** {
c3 : Preposition
} ;
-- VV : Type = Verb ** {vvtype : VVForm} ;
mkVerb : Str -> Prefix -> Verb = \str,p -> {
s = table {
Root => str ;
Active => prefix p str
}
} ;
mkVerb2 : Verb -> Preposition -> Verb2 = \v,pr -> v ** {
c2 = pr ;
passive = "di" + v.s ! Root -- TODO check
} ;
mkVerb3 : Verb -> (p,q : Preposition) -> Verb3 = \v,p,q ->
mkVerb2 v p ** {c3 = q} ;
copula : Verb = {s = \\_ => "ada"} ; -- TODO
------------------
-- Adv
Adverb : Type = SS ;
------------------
-- VP
VerbPhrase : Type = {
s : VForm => Polarity => Str ; -- tidak or bukan
} ;
VPSlash : Type = VerbPhrase ** {
c2 : Preposition ;
} ;
useV : Verb -> VerbPhrase = \v -> v ** {
s = \\vf,pol => verbneg pol ++ v.s ! vf
} ;
useComp : Str -> VerbPhrase = \s -> {
s = \\vf,pol => nounneg pol ++ s ;
} ;
verbneg : Polarity -> Str = \pol -> case pol of {
Neg => "tidak" ; -- or "tak"?
Pos => []
} ;
nounneg : Polarity -> Str = \pol -> case pol of {
Neg => "bukan" ;
Pos => []
} ;
--------------------------------------------------------------------------------
-- Cl, S
Clause : Type = {
subj : Str ;
pred : VForm => Polarity => Str -- Cl may become relative clause, need to keep open VForm
} ;
RClause : Type = {
subj : Str ;
pred : Person => Polarity => Str
} ;
RS : Type = {s : Person => Str} ;
ClSlash : Type = Clause ** {c2 : Preposition} ;
Sentence : Type = {s : Str} ;
predVP : NounPhrase -> VerbPhrase -> Clause = \np,vp -> {
subj = np.s ! Bare ;
pred = vp.s
} ;
predVPSlash : NounPhrase -> VPSlash -> ClSlash = \np,vps ->
predVP np <vps : VerbPhrase> ** {c2 = vps.c2} ;
--------------------------------------------------------------------------------
-- linrefs
}