(Som) Rename some parameters to begin with capital letter

This commit is contained in:
Inari Listenmaa
2019-07-01 10:44:37 +02:00
parent 0e52ffbb6a
commit 8115b26947
4 changed files with 51 additions and 53 deletions

View File

@@ -146,11 +146,11 @@ oper
fem = Fem ; fem = Fem ;
Preposition = ResSom.Preposition ; Preposition = ResSom.Preposition ;
ka = ResSom.ka ; ka = ResSom.Ka ;
ku = ResSom.ku ; ku = ResSom.Ku ;
la = ResSom.la ; la = ResSom.La ;
u = ResSom.u ; u = ResSom.U ;
noPrep = ResSom.noPrep ; noPrep = ResSom.NoPrep ;
------------------------ ------------------------
mkN = overload { mkN = overload {

View File

@@ -156,34 +156,34 @@ param
-- Prepositions -- Prepositions
param param
Preposition = u | ku | ka | la | noPrep ; Preposition = U | Ku | Ka | La | NoPrep ;
PrepositionPlus = P Preposition | Passive ; -- Hack: RGL only supports V2s as passive, so I can reuse V2's preposition slot for passives as well, and save >200 parameters. (Don't ask.) PrepositionPlus = P Preposition | Passive ; -- Hack: RGL only supports V2s as passive, so I can reuse V2's preposition slot for passives as well, and save >200 parameters. (Don't ask.)
PrepCombination = ugu | uga | ula | kaga | kula | kala PrepCombination = Ugu | Uga | Ula | Kaga | Kula | Kala
| Single PrepositionPlus ; | Single PrepositionPlus ;
oper oper
combine : PrepositionPlus -> Preposition -> PrepCombination = \p1,p2 -> combine : PrepositionPlus -> Preposition -> PrepCombination = \p1,p2 ->
let oneWay : PrepositionPlus => Preposition => PrepCombination = let oneWay : PrepositionPlus => Preposition => PrepCombination =
\\x,y => case <x,y> of { \\x,y => case <x,y> of {
<Passive,noPrep> => Single Passive ; <Passive,NoPrep> => Single Passive ;
<Passive,p> => Single (P p) ; -- TODO check if this ever happens <Passive,p> => Single (P p) ; -- TODO check if this ever happens
<P z,_> => case <z,y> of { <P z,_> => case <z,y> of {
<u,u|ku> => ugu ; <U,U|Ku> => Ugu ;
<u,ka> => uga ; <U,Ka> => Uga ;
<u,la> => ula ; <U,La> => Ula ;
<ku|ka, <Ku|Ka,
ku|ka> => kaga ; Ku|Ka> => Kaga ;
<ku,la> => kula ; <Ku,La> => Kula ;
<ka,la> => kala ; <Ka,La> => Kala ;
<noPrep,p> => Single (P p) ; <NoPrep,p> => Single (P p) ;
<p,noPrep> => Single x ; <p,NoPrep> => Single x ;
<p,_> => Single x }} -- for trying both ways <p,_> => Single x }} -- for trying both ways
in case oneWay ! P p2 ! (pp2prep p1) of { in case oneWay ! P p2 ! (pp2prep p1) of {
Single _ => oneWay ! p1 ! p2 ; Single _ => oneWay ! p1 ! p2 ;
z => z } ; z => z } ;
pp2prep : PrepositionPlus -> Preposition = \pp -> pp2prep : PrepositionPlus -> Preposition = \pp ->
case pp of {P p => p ; Passive => noPrep} ; case pp of {P p => p ; Passive => NoPrep} ;
-------------------------------------------------------------------------------- --------------------------------------------------------------------------------
-- Verbs -- Verbs

View File

@@ -325,51 +325,49 @@ oper
prep : Preposition -> (Prep ** {c2 : Preposition}) = \p -> prepTable ! P p ** {c2 = p} ; prep : Preposition -> (Prep ** {c2 : Preposition}) = \p -> prepTable ! P p ** {c2 = p} ;
prepTable : PrepositionPlus => Prep = table { prepTable : PrepositionPlus => Prep = table {
P ku => mkPrep "ku" "igu" "kugu" "nagu" "idinku" "lagu" ; P Ku => mkPrep "ku" "igu" "kugu" "nagu" "idinku" "lagu" ;
P ka => mkPrep "ka" "iga" "kaa" "naga" "idinka" "laga" ; P Ka => mkPrep "ka" "iga" "kaa" "naga" "idinka" "laga" ;
P la => mkPrep "la" "ila" "kula" "nala" "idinla" "lala" ; P La => mkPrep "la" "ila" "kula" "nala" "idinla" "lala" ;
P u => mkPrep "u" "ii" "kuu" "noo" "idiin" "loo" ; P U => mkPrep "u" "ii" "kuu" "noo" "idiin" "loo" ;
P noPrep => mkPrep [] "i" "ku" "na" "idin" "la" ; P NoPrep => mkPrep [] "i" "ku" "na" "idin" "la" ;
-- impersonal subject clitic combining with object clitics. -- impersonal subject clitic combining with object clitics.
Passive => mkPrep "la" "la i" "lagu" "nala" "laydin" "la" Passive => mkPrep "la" "la i" "lagu" "nala" "laydin" "la"
} ; } ;
prepCombTable : Agreement => PrepCombination => Str = table { prepCombTable : Agreement => PrepCombination => Str = table {
Sg1 => table { ugu => "iigu" ; uga => "iiga" ; Sg1 => table { Ugu => "iigu" ; Uga => "iiga" ;
ula => "iila" ; kaga => "igaga" ; Ula => "iila" ; Kaga => "igaga" ;
kula => "igula" ; kala => "igala" ; Kula => "igula" ; Kala => "igala" ;
Single p => (prepTable ! p).s ! Sg1 } ; Single p => (prepTable ! p).s ! Sg1 } ;
Sg2 => table { ugu => "kuugu" ; uga => "kaaga" ; Sg2 => table { Ugu => "kuugu" ; Uga => "kaaga" ;
ula => "kuula" ; kaga => "kaaga" ; Ula => "kuula" ; Kaga => "kaaga" ;
kula => "kugula" ; kala => "kaala" ; Kula => "kugula" ; Kala => "kaala" ;
Single p => (prepTable ! p).s ! Sg2 } ; Single p => (prepTable ! p).s ! Sg2 } ;
Pl1 Excl => Pl1 Excl =>
table { ugu => "noogu" ; uga => "nooga" ; table { Ugu => "noogu" ; Uga => "nooga" ;
ula => "noola" ; kaga => "nagaga" ; Ula => "noola" ; Kaga => "nagaga" ;
kula => "nagula" ; kala => "nagala" ; Kula => "nagula" ; Kala => "nagala" ;
Single p => (prepTable ! p).s ! Pl1 Excl } ; Single p => (prepTable ! p).s ! Pl1 Excl } ;
Pl1 Incl => Pl1 Incl =>
table { ugu => "inoogu" ; uga => "inooga" ; table { Ugu => "inoogu" ; Uga => "inooga" ;
ula => "inoola" ; kaga => "inagaga" ; Ula => "inoola" ; Kaga => "inagaga" ;
kula => "inagula" ; kala => "inagala" ; Kula => "inagula" ; Kala => "inagala" ;
Single p => (prepTable ! p).s ! Pl1 Incl } ; Single p => (prepTable ! p).s ! Pl1 Incl } ;
Pl2 => table { ugu => "idiinku" ; uga => "idiinka" ; Pl2 => table { Ugu => "idiinku" ; Uga => "idiinka" ;
ula => "idiinla" ; kaga => "idinkaga" ; Ula => "idiinla" ; Kaga => "idinkaga" ;
kula => "idinkula" ; kala => "idinkala" ; Kula => "idinkula" ; Kala => "idinkala" ;
Single p => (prepTable ! p).s ! Pl2 } ; Single p => (prepTable ! p).s ! Pl2 } ;
Impers => Impers =>
table { ugu => "loogu" ; uga => "looga" ; table { Ugu => "loogu" ; Uga => "looga" ;
ula => "loola" ; kaga => "lagaga" ; Ula => "loola" ; Kaga => "lagaga" ;
kula => "lagula" ; kala => "lagala" ; Kula => "lagula" ; Kala => "lagala" ;
Single p => (prepTable ! p).s ! Impers } ; Single p => (prepTable ! p).s ! Impers } ;
a => table { ugu => "ugu" ; uga => "uga" ; a => table { Ugu => "ugu" ; Uga => "uga" ;
ula => "ula" ; kaga => "kaga" ; Ula => "ula" ; Kaga => "kaga" ;
kula => "kula" ; kala => "kala" ; Kula => "kula" ; Kala => "kala" ;
Single p => (prepTable ! p).s ! a } Single p => (prepTable ! p).s ! a }
} ; } ;
-- TODO: Negationen má `inte' skrivs samman med en föregående preposition.
-------------------------------------------------------------------------------- --------------------------------------------------------------------------------
-- Adjectives -- Adjectives
@@ -631,8 +629,8 @@ oper
comp = \\_ => <[],[]> ; comp = \\_ => <[],[]> ;
pred = NoPred ; pred = NoPred ;
adv = [] ; adv = [] ;
c2 = P noPrep ; c2 = P NoPrep ;
c3 = noPrep ; c3 = NoPrep ;
obj2 = {s = [] ; a = Unassigned} ; obj2 = {s = [] ; a = Unassigned} ;
secObj = [] secObj = []
} ; } ;
@@ -688,10 +686,10 @@ oper
insertAdv : VerbPhrase -> Adverb -> VerbPhrase = \vp,adv -> insertAdv : VerbPhrase -> Adverb -> VerbPhrase = \vp,adv ->
case adv.c2 of { case adv.c2 of {
noPrep => vp ** {adv = adv.s} ; -- The adverb is not formed with PrepNP NoPrep => vp ** {adv = adv.s} ; -- The adverb is not formed with PrepNP
prep => case <vp.c2,vp.obj2.a,vp.c3> of { prep => case <vp.c2,vp.obj2.a,vp.c3> of {
<P noPrep,Unassigned,_> => insertComp (vp ** {c2 = P adv.c2}) adv.np ; -- should cover for obligatory argument that is not introduced with a preposition <P NoPrep,Unassigned,_> => insertComp (vp ** {c2 = P adv.c2}) adv.np ; -- should cover for obligatory argument that is not introduced with a preposition
<_ ,_ ,noPrep> => insertComp (vp ** {c3 = adv.c2}) adv.np ; <_ ,_ ,NoPrep> => insertComp (vp ** {c3 = adv.c2}) adv.np ;
-- if complement slots are full, put preposition just as a string. TODO check word order. -- if complement slots are full, put preposition just as a string. TODO check word order.
_ => vp ** {adv = (prepTable ! P adv.c2).s ! adv.np.a ++ adv.np.s ! Abs} _ => vp ** {adv = (prepTable ! P adv.c2).s ! adv.np.a ++ adv.np.s ! Abs}
} }

View File

@@ -96,7 +96,7 @@ lin
-- : VP -> Prep -> VPSlash ; -- live in (it) -- : VP -> Prep -> VPSlash ; -- live in (it)
-- NB. We need possibly a MissingArg kind of solution here too -- NB. We need possibly a MissingArg kind of solution here too
-- VPSlashPrep vp prep = vp ** -- VPSlashPrep vp prep = vp **
-- { c2 = case vp.c2 of { noPrep => prep.prep ; -- { c2 = case vp.c2 of { NoPrep => prep.prep ;
-- x => x }} ; -- x => x }} ;