Module:el-conjugaison
Ce module construit des tables de conjugaison de verbes en grec moderne.
Il s’utilise via la fonction conj, qui prend en argument la première personne du singulier du présent, de l’imparfait, de l’aoriste, du subjonctif (sans να). Lorsque l’imparfait ou l’aoriste comportent un augment, on le signale en le séparant du reste de la forme avec un tiret (-).
Exemples:
{{#invoke:el-conj|conj|pres=παίρνω|imp=έ-παιρνα|aor=πήρα|fut=πάρω}}
{{#invoke:el-conj|conj|pres=δέχομαι|imp=δέχομουν|aor=δέχτηκα|fut=δεχτώ}}
Ce module n'est pas destiné à être utilisé directement mais à être appelé par les modèles appropriés figurant dans Catégorie:Modèles de conjugaison en grec.
La documentation de ce module est générée par le modèle {{Documentation module}}.
Elle est incluse depuis la page Module:el-conjugaison/Documentation. Veuillez placer les catégories sur cette page-là.
Les éditeurs peuvent travailler dans le bac à sable (créer).
Voir les statistiques d'appel depuis le wikicode sur l'outil wstat et les appels depuis d'autres modules.
local p = {}
local acc = require("Module:el-accentuation")
local personnes = {"1re sing.", "2e sing.", "3e sing.", "1re pl.", "2e pl.", "3e pl."}
local desinences = {
present = {
s1 = {2, 'ω'}, s2 = {2, 'εις'}, s3 = {2, 'ει'},
p1 = {2, 'ουμε'}, p2 = {2, 'ετε'}, p3 = {2, 'ουν'},
gerondif = {2, 'οντας'},
},
presentA = {
s1 = {3, 'ώ'}, s2 = {3, 'άς'}, s3 = {3, 'ά'},
p1 = {3, 'άμε'}, p2 = {3, 'άτε'}, p3 = {3, 'άν'},
gerondif = {3, 'ώντας'},
},
presentE = {
s1 = {3, 'ώ'}, s2 = {3, 'είς'}, s3 = {3, 'εί'},
p1 = {3, 'ούμε'}, p2 = {3, 'είτε'}, p3 = {3, 'ούν'},
gerondif = {3, 'ώντας'},
},
presentM = {
s1 = {2, 'ομαι'}, s2 = {2, 'εσαι'}, s3 = {2, 'εται'},
p1 = {3, 'όμαστε'}, p2 = {2, 'εστε'}, p3 = {2, 'ονται'},
},
presentMA = {
s1 = {3, 'ιέμαι'}, s2 = {3, 'ιέσαι'}, s3 = {3, 'ιέται'},
p1 = {3, 'ιόμαστε'}, p2 = {3, 'ιέστε'}, p3 = {3, 'ιούνται'},
},
presentME = {
s1 = {3, 'ούμαι'}, s2 = {3, 'είσαι'}, s3 = {3, 'είται'},
p1 = {3, 'ούμαστε'}, p2 = {3, 'είστε'}, p3 = {3, 'ούνται'},
},
impfM = {
s1 = {3, 'όμουν'}, s2 = {3, 'όσουν'}, s3 = {3, 'όταν'},
p1 = {3, 'όμασταν'}, p2 = {3, 'όσασταν'}, p3 = {2, 'ονταν'},
},
passe = {
s1 = {1, 'α'}, s2 = {1, 'ες'}, s3 = {1, 'ε'},
p1 = {2, 'αμε'}, p2 = {2, 'ατε'}, p3 = {1, 'αν'},
},
}
-- tronque retourne le mot sans sa desinence. En cas d'argument
-- invalide (si le mot ne termine pas par desinence), renvoie "ERREUR"
function tronque(mot, desinence)
local l = mw.ustring.len(desinence)
if l == 0 then
return mot
end
if mw.ustring.len(mot) < l then
return "ERREUR"
end
if mw.ustring.sub(mot, -l, -1) ~= desinence then
return "ERREUR"
end
return mw.ustring.sub(mot, 1, -l-1)
end
function lang_el(mot)
return '<span lang="el" class="lang-el">' .. mot .. '</span>'
end
function lien_el(mot)
if mot == mw.title.getCurrentTitle().prefixedText then
return '[[' .. mot .. '|' .. lang_el(mot) .. ']]'
else
return '[[' .. mot .. '#el|' .. lang_el(mot) .. ']]'
end
end
function tableau(entetes, colonnes)
lignes = {'{| class="flextable"'}
table.insert(lignes, "! ")
for _, entete in ipairs(entetes) do
table.insert(lignes, "! " .. entete)
end
for p = 1, 6 do
-- une ligne par personne
table.insert(lignes, "|-")
table.insert(lignes, "! " .. personnes[p])
for i = 1, #entetes do
local mot = colonnes[i][p]
if mot == "" then
table.insert(lignes, '| |')
else
table.insert(lignes, '| class="gauche" | ' .. lien_el(mot))
end
end
end
table.insert(lignes, "|}")
return table.concat(lignes, "\n")
end
function petit_tableau(entetes, contenu)
lignes = {'{| class="flextable"'}
for i = 1, #entetes do
if contenu[i] ~= nil and contenu[i] ~= "" then
table.insert(lignes, "! " .. entetes[i])
table.insert(lignes, '| class="gauche" | ' .. contenu[i])
table.insert(lignes, "|-")
end
end
table.insert(lignes, "|}")
return table.concat(lignes, "\n")
end
function conjugue(radPres, radImp, radAor, radFut, desPres, desImp, desAor, desFut)
local entetes = {"Présent", "Imparfait", "Subjonctif", "Aoriste"}
local present = combine(radPres, desPres)
local imparfait = combine(radImp, desImp)
local aoriste = combine(radAor, desAor)
local subj = combine(radFut, desFut)
local colonnes = {present, imparfait, subj, aoriste}
local tab1 = tableau(entetes, colonnes) .. "\n"
local gerondif = ""
if desPres.gerondif ~= nil then gerondif = combine1(radPres, desPres.gerondif) end
local tempsExtra = {"Futur", "Parfait", "Impératif continu", "Impératif momentané", "Gérondif", "Participe passif", "Voix passive"}
local formesExtra = {
"θα " .. lien_el(subj[1]),
"έχω " .. subj[3],
"",
"",
gerondif,
"",
"",
}
local tab2 = petit_tableau(tempsExtra, formesExtra) .. "\n"
return tab1 .. tab2
end
function combine1(radical, des)
local rad = acc.radicaux(radical)
local i, d = des[1], des[2]
return acc.normalise(rad[i] .. d)
end
function combine(radical, des)
if radical == nil then
return {"", "", "", "", "", ""}
end
local rad = acc.radicaux(radical)
function f(des)
local i, d = des[1], des[2]
return acc.normalise(rad[i] .. d)
end
s1 = f(des.s1)
s2 = f(des.s2)
s3 = f(des.s3)
p1 = f(des.p1)
p2 = f(des.p2)
p3 = f(des.p3)
return {s1, s2, s3, p1, p2, p3}
end
function suffixe(mot, s)
local l = mw.ustring.len(s)
if mw.ustring.len(mot) < l then
return false
end
return mw.ustring.sub(mot, -l, -1) == s
end
function p.conj_auto(pres, imp, aor, fut)
if suffixe(pres, "άω") then
radPres = tronque(pres, "άω")
desPres = desinences.presentA
elseif suffixe(pres, "ω") then
radPres = tronque(pres, "ω")
desPres = desinences.present
elseif suffixe(pres, "ώ") then
radPres = tronque(pres, "ώ")
desPres = desinences.presentE
elseif suffixe(pres, "ομαι") then
radPres = tronque(pres, "ομαι")
desPres = desinences.presentM
elseif suffixe(pres, "ιέμαι") then
radPres = tronque(pres, "ιέμαι")
desPres = desinences.presentMA
elseif suffixe(pres, "ούμαι") then
radPres = tronque(pres, "ούμαι")
desPres = desinences.presentME
else
radPres = "INCORRECT"
desPres = desinences.present
end
if suffixe(imp, "α") then
radImp = tronque(imp, "α")
desImp = desinences.passe
elseif imp == "" then
radImp = nil
desImp = desinences.passe
else
radImp = tronque(imp, "όμουν")
desImp = desinences.impfM
end
radAor = tronque(aor, "α")
desAor = desinences.passe
if suffixe(fut, "ω") then
radFut = tronque(fut, "ω")
desFut = desinences.present
else
radFut = tronque(fut, "ώ")
desFut = desinences.presentE
end
return conjugue(radPres, radImp, radAor, radFut, desPres, desImp, desAor, desFut)
end
function p.conj(frame)
return p.conj_auto(frame.args.pres, frame.args.imp, frame.args.aor, frame.args.fut)
end
function p.test(frame)
return p.conj_auto("αφήνω", "άφηνα", "άφησα", "αφήσω") ..
p.conj_auto("αγαπάω", "αγαπούσα", "αγάπησα", "αγαπήσω") ..
p.conj_auto("οδηγώ", "οδηγούσα", "οδήγησα", "οδηγήσω") ..
p.conj_auto("δέχομαι", "δεχόμουν", "δέχτηκα", "δεχτώ") ..
p.conj_auto("αγαπιέμαι", "αγαπιόμουν", "αγαπήθηκα", "αγαπηθώ") ..
p.conj_auto("θεωρούμαι", "", "θεωρήθηκα", "θεωρηθώ") ..
p.conj_auto("παίρνω", "έ-παιρνα", "πήρα", "πάρω") ..
p.conj_auto("στέλνω", "έ-στελνα", "έ-στειλα", "στείλω") ..
p.conj_auto("μπαίνω", "έ-μπαινα", "μπήκα", "μπώ") ..
p.conj_auto("βγάζω", "έ-βγαζα", "έ-βγαλα", "βγάλω") ..
p.conj_auto("βρίσκω", "έ-βρισκα", "βρήκα", "βρώ") ..
p.conj_auto("βρίσκομαι", "βρισκόμουν", "βρέθηκα", "βρεθώ")
end
return p