mirror of
https://github.com/GrammaticalFramework/gf-rgl.git
synced 2026-06-10 23:56:32 -06:00
31 lines
887 B
Plaintext
31 lines
887 B
Plaintext
--# -path=.:../common:../abstract
|
|
|
|
resource MakeStructuralFin = open CatFin, ParadigmsFin, MorphoFin, Prelude in {
|
|
|
|
oper
|
|
mkConj : Str -> Str -> ParadigmsFin.Number -> Conj = \x,y,n ->
|
|
{s1 = x ; s2 = y ; n = n ; lock_Conj = <>} ;
|
|
mkSubj : Str -> Subj = \x ->
|
|
{s = x ; lock_Subj = <>} ;
|
|
mkIQuant : Str -> IQuant = \s ->
|
|
{s = \\n,c => s ; lock_IQuant = <>} ; ----
|
|
|
|
mkIDet : Bool -> Str -> N -> Number -> IDet = \isNum,pref,s,n ->
|
|
lin IDet {s = \\c => pref ++ s.s ! NCase n c ; n = n ; isNum = isNum} ;
|
|
|
|
mkDet = overload {
|
|
mkDet : N -> Number -> Det = \s,n ->
|
|
lin Det (MorphoFin.mkDet n s) ;
|
|
mkDet : Str -> Bool -> Det -> Det = \s,isNeg,d ->
|
|
d ** {
|
|
s1 = \\c => s ++ d.s1 ! c ;
|
|
sp = \\c => s ++ d.sp ! c ;
|
|
isNeg = isNeg ;
|
|
} ;
|
|
} ;
|
|
|
|
partDet : N -> Number -> Det = \s,n ->
|
|
lin Det (MorphoFin.partDet False n s) ;
|
|
|
|
}
|