1
0
forked from GitHub/gf-rgl
Files
gf-rgl/src/zulu/NounExtZul.gf
2022-05-27 09:33:05 +02:00

219 lines
5.7 KiB
Plaintext

concrete NounExtZul of NounExt = CatZul,CatExtZul ** open ResZul, Prelude, ParamX in {
lin
-- Quant is used for demonstratives, and QuantStem for all/only
PronPostdetNP pron postdet = {
empty = pron.empty ;
s = \\nform => pron.s!nform ++ postdet.s!pron.agr ;
agr = pron.agr ;
i = RC ;
proDrop = pron.proDrop ;
isPron = True ;
heavy = True
} ;
QuantPostdet q = {
s = \\a => q.s!a
} ;
DemPostdet q = {
s = \\a => q.s!True!a
} ;
QuantDemPostdet q d = {
s = \\a => q.s!a ++ d.s!True!a
} ;
DemQuantPostdet d q = {
s = \\a => d.s!True!a ++ q.s!a
} ;
DetNum n = n ; -- ** { spec = Spec } ;
-- NonspecDet n = n ** { spec = Nonspec } ;
PostdetCN cn postdet det = let
agr = Third cn.c det.n
in {
empty = cn.empty ;
-- s = \\nform => cn.s!det.n!nform ++ cn.mod!det.n ++ postdet.s!agr ;
s = \\nform => cn.s!det.n!nform ++ postdet.s!agr ++ det.s ;
agr = agr ;
i = nominit!agr ;
proDrop = False ;
isPron = False ;
heavy = True
} ;
RelN rs n = {
empty = n.empty ;
s = \\num,nform => rs.s!(Third n.c num) ++ n.s!num!nform ;
-- mod = \\_ => [] ;
c = n.c ;
emph = False
} ;
-- TODO : check mod
ApposCN cn n = {
s = \\num,nform => cn.s!num!nform ++ n.s!num!nform ;
-- mod = \\num => n.s!num!Full ++ cn.mod!num ;
c = cn.c ; -- takes agr of cn
empty = cn.empty ;
emph = cn.emph
} ;
-- TODO : check mod
ApposN cn n = {
s = \\num,nform => cn.s!num!nform ++ n.s!num!nform ;
-- mod = \\num => n.s!num!Full ++ cn.mod!num ;
c = n.c ; -- takes agr of n
empty = cn.empty ;
emph = cn.emph
} ;
PredetN predet n = {
s = case predet.hasDem of {
True => \\num => table {
NFull | NReduced | NPoss => predet.s!(Third n.c num) ++ n.s!num!NReduced ;
NLoc => "ku" ++BIND++ predet.s!(Third n.c num) ++ n.s!num!NReduced
} ;
False => \\num,nform => predet.s!(Third n.c num) ++ n.s!num!nform
} ;
-- mod = \\_ => [] ;
c = n.c ;
empty = n.empty ;
emph = False
};
QuantPredet q = {
s = \\a => q.s!a ;
hasDem = False
} ;
DemPredet q = {
s = \\a => q.s!False!a ;
hasDem = True
} ;
QuantDemPredet q d = {
s = \\a => q.s!a ++ d.s!False!a ;
hasDem = True
} ;
EmphCN cn = {
s = \\num => table {
NFull => pron_stem!(Third cn.c num) ++BIND++ "na" ++ cn.s!num!NFull ;
NReduced => pron_stem!(Third cn.c num) ++ cn.s!num!NFull ;
NPoss => poss_pron_stem!(Third cn.c num) ++ cn.s!num!NFull ;
NLoc => "ku" ++BIND++ pron_stem!(Third cn.c num) ++ cn.s!num!NFull
} ;
-- mod = cn.mod ;
c = cn.c ;
empty = cn.empty ;
emph = True
} ;
ContrastCN cn = {
s = \\num,nform => cn.s!num!nform ++ pron_stem!(Third cn.c num) ++BIND++ "na" ;
-- mod = \\num => pron_stem!(Third cn.c num) ++BIND++ "na" ++ cn.mod!num ;
c = cn.c ;
empty = cn.empty ;
emph = cn.emph ;
emph = cn.emph
} ;
UsePNPl pn = let
agr = Third pn.c Pl
in {
empty = pn.empty ;
s = pn.s!Pl ;
agr = agr ;
i = nominit!agr ;
proDrop = False ;
isPron = False ;
heavy = True
} ;
Deverb15 v =
let
agr = Third C15 Sg ;
in
{
s = \\_ => table {
NFull => case v.r of {
RC => "uku"++BIND++(v.s!R_a) ;
(RA|RE) => "ukw"++BIND++(v.s!R_a) ;
_ => "uk"++BIND++(v.s!R_a)
} ;
NReduced => case v.r of {
RC => "ku"++BIND++(v.s!R_a) ;
(RA|RE) => "kw"++BIND++(v.s!R_a) ;
_ => "k"++BIND++(v.s!R_a)
} ;
NPoss => case v.r of {
RC => "ku"++BIND++(v.s!R_a) ;
(RA|RE) => "kw"++BIND++(v.s!R_a) ;
_ => "k"++BIND++(v.s!R_a)
} ;
NLoc => case v.r of {
RC => "eku"++BIND++(v.s!R_e)++BIND++"ni" ;
(RA|RE) => "ekw"++BIND++(v.s!R_e)++BIND++"ni" ;
_ => "ek"++BIND++(v.s!R_e)++BIND++"ni"
}
} ;
c = C15 ;
empty = []
} ;
LocNP np = {
s = table {
MainCl => \\a,p,t => let
vform = VFIndic MainCl p t ;
pcp = ap_cop_pref vform a RelType ; -- u- / uzoba / akazukuba
cop_base = loc_n_cop_base np vform
in
case vform of {
VFIndic _ Neg PresTense => (kho_cop vform a) ++ cop_base;
VFIndic _ _ _ => pcp ++ cop_base
} ;
RelCl => \\a,p,t => let
vform = VFIndic RelCl p t ;
rcp = (relConcCop vform a RC) ; -- o- / onge-
pcp = ap_cop_pref vform a RelType ; -- u- / uzoba / akazukuba
cop_base = loc_n_cop_base np vform
in
case vform of {
VFIndic _ Neg PresTense => (kho_cop vform a) ++ cop_base;
VFIndic _ _ _ => rcp ++ pcp ++ cop_base
}
} ;
} ;
LocNLoc locn = {
s = table {
MainCl => \\a,p,t => let
vform = VFIndic MainCl p t ;
pcp = ap_cop_pref vform a RelType ; -- u- / uzoba / akazukuba
cop_base = locn.s
in
case vform of {
VFIndic _ Neg PresTense => (kho_cop vform a) ++ cop_base;
VFIndic _ _ _ => pcp ++ cop_base
} ;
RelCl => \\a,p,t => let
vform = VFIndic RelCl p t ;
rcp = (relConcCop vform a RC) ; -- o- / onge-
pcp = ap_cop_pref vform a RelType ; -- u- / uzoba / akazukuba
cop_base = locn.s
in
case vform of {
VFIndic _ Neg PresTense => (kho_cop vform a) ++ cop_base;
VFIndic _ _ _ => rcp ++ pcp ++ cop_base
}
} ;
} ;
}