complete RGL implementation for Mongolian by Nyamsuren Erdenebadrakh

This commit is contained in:
nyamaakaa
2015-03-13 13:40:22 +00:00
parent 4ff30e6771
commit 053f2377b2
39 changed files with 54028 additions and 0 deletions

View File

@@ -0,0 +1,110 @@
--# -path=.:../abstract:../common:../../prelude
concrete SentenceMon of Sentence = CatMon ** open Prelude, ResMon in {
flags optimize=all_subs ; coding=utf8 ;
lin
-- Clauses
PredVP np vp = (mkClause np.s np.n vp.vt Nom vp) ;
PredSCVP sc vp = (mkClause (\\_ => sc.s) Sg vp.vt Nom vp) ;
-- Imperatives
ImpVP vp = {s = \\pol,f =>
let
neg = case pol of {
Neg => (variants {"битгий" ; "бүү"}) ;
_ => []
}
in
case f of {
ImpF n False => case n of {
Sg => "чи" ++ neg ++ (vp.s ! VPImper pol False).fin ;
_ => "та нар" ++ neg ++ (vp.s ! VPImper pol False).fin } ;
ImpF _ True => "та" ++ neg ++ (vp.s ! VPImper pol True).fin
}
} ;
-- Clauses missing object noun phrases
SlashVP np vp = (mkClause np.s np.n vp.vt Nom vp) ** {c2 = vp.c2} ;
AdvSlash slash adv = {
s = \\t,ant,pol,styp => slash.s ! t ! ant ! pol ! styp ++ adv.s ;
c2 = slash.c2
} ;
SlashPrep cl prep = cl ** {c2 = prep} ;
SlashVS np vs slash =
(mkClause np.s np.n vs.vt Nom
(insertEmbedCompl (slash.s ++ "") (predV vs))) ** {c2 = slash.c2} ;
-- Sentences
-- The particle "нь" is used often as a subject indicator.
-- It sets off what precedes it as the subject (Hangin 1968:46).
EmbedS s = {
s = s.s ! Part Subject
} ;
EmbedQS qs = {
s = qs.s ! QIndir ++ "гэдэг нь"
} ;
EmbedVP vp = {
s = infVP vp Nom ++ "нь"
} ;
UseCl t p cl = {
s = \\_ => t.s ++ p.s ++ cl.s ! t.t ! t.a ! p.p ! Part Subject
} ;
UseQCl t p cl = {
s = \\q => t.s ++ p.s ++ cl.s ! t.t ! t.a ! p.p ! q
} ;
UseRCl t p rcl = {
s = table {
ComplSubj => t.s ++ p.s ++ rcl.s ! t.t ! t.a ! p.p ! (Part Subject) ;
ComplObj => t.s ++ p.s ++ rcl.s ! t.t ! t.a ! p.p ! (Part Object) ;
ComplAdv => t.s ++ p.s ++ rcl.s ! t.t ! t.a ! p.p ! (Part Adverbiale) ;
Attributive => t.s ++ p.s ++ rcl.s ! t.t ! t.a ! p.p ! (Part Rel) ;
NoSubj => t.s ++ p.s ++ rcl.s ! t.t ! t.a ! p.p ! (Part emptySubject)
} ;
existSubject = rcl.existSubject
} ;
UseSlash t p cl = {
s = t.s ++ p.s ++ cl.s ! t.t ! t.a ! p.p ! Main ;
c2 = cl.c2
} ;
-- An adverb can be added to the beginning of a sentence.
AdvS a s = {
s = \\_ => a.s ++ s.s ! Main
} ;
ExtAdvS a s = {s = \\stype => a.s ++ "," ++ s.s ! stype} ;
-- A sentence can be modified by a relative clause referring to its contents.
RelS s rs = case rs.existSubject of {
True => {s = \\_ => rs.s ! ComplSubj ++ s.s ! Main} ;
False => {s = \\_ => rs.s ! NoSubj ++ s.s ! Main}
} ;
-- Subjunctive clauses
SSubjS xs subj ys = case subj.isPre of {
True => {s = \\_ => subj.s ++ xs.s ! (Sub Condl) ++ ys.s ! Main} ;
False => {s = \\_ => xs.s ! Main ++ subj.s ++ ys.s ! Main}
} ;
}