Modul:Verb: Unterschied zwischen den Versionen

Aus KGS-Wiki
Keine Bearbeitungszusammenfassung
Keine Bearbeitungszusammenfassung
Zeile 376: Zeile 376:
lektionen = {}
lektionen = {}
if params.lInf ~= "0" then
if params.lInf ~= "0" then
lektionen:insert(lInf)
table.insert(lektionen, lInf)
end
end
if params.lPerf ~= "0" then
if params.lPerf ~= "0" then
lektionen:insert(lInf)
table.insert(lektionen, lPerf)
end
end
if params.lPPP ~= "0" then
if params.lPPP ~= "0" then
lektionen:insert(lInf)
table.insert(lektionen, lPPP)
end
end
pagecontent = pagecontent .. p.renderBox(frame)
pagecontent = pagecontent .. p.renderBox(frame)

Version vom 25. Juni 2024, 06:27 Uhr

Dieses Modul erzeugt lateinische Konjugationstabellen aus gegebenen Stämmen.

💬
Beispiel
  • {{subst:#invoke:Verb|render|dare|20|da|ded|28|dat|47|PraesGV=AP|PerfGV=AP}} für ein Vollverb mit Aktiv und Passiv in Präsens- und Perfektstämmen
  • {{subst:#invoke:Verb|render|sequi||sequ|||secut||PraesGV=P|PerfGV=P}} für ein Deponens
  • {{subst:#invoke:Verb|render|gaudere|4|gaude|||gavis||PraesGV=AP|PerfGV=P}} für ein Semideponens, das in Perfektstämmen nur Passivformen bildet
  • {{subst:#invoke:Verb|render|facere|17|faci|fec|27|||PraesGV=A|PerfGV=A}} für ein Defectivum, das nur aktivische Formen bildet.
Erläuterung
{{subst: Immer nur mit subst einbinden, damit die Formen im Seitenquelltext landen und für die Suchfunktion auffindbar sind.
#invoke:Verb| Name des Moduls
render| rufe die Funktion render auf
irrumare| Infinitiv
0| Optional: Lektion, in der der Infinitiv eingeführt wurde
irruma| Präsensstamm
irrumav| Perfektstamm
0| Optional: Lektion, in der der Perfektstamm eingeführt wurde
irrumat| Stamm des PPP
0| Optional: Lektion, in der das PPP eingeführt wurde
PraesGV=AP Optional: Verfügbare Genera verbi in den präsentischen Zeiten.
Erlaubte Werte
  • AP: Verb bildet Aktiv- und Passivformen (Standard)
  • A: Verb bildet nur Aktivformen
  • P: Verb bildet nur Passivformen (Deponens)
PerfGV=AP}} Optional: Verfügbare Genera verbi in den perfektischen Zeiten.
Erlaubte Werte
  • AP: Verb bildet Aktiv- und Passivformen (Standard)
  • A: Verb bildet nur Aktivformen
  • P: Verb bildet nur Passivformen (Deponens)
👉
Hinweis

Dieses Modul sollte immer mit subst: eingebunden werden, damit alle Formen im durchsuchbaren Seitenquelltext landen und eine Suche nach dem auch zu dare führt.


local p = {}
local utils = require('Modul:LateinUtils')

local IND_AKT  = 1
local KONJ_AKT = 2
local IND_PASS = 3
local KONJ_PASS= 4
local IMPERATIV= 5
local PERSONEN = {'1. Person Singular', '2. Person Singular', '3. Person Singular';
                  '1. Person Plural',   '2. Person Plural',   '3. Person Plural'}
local MODI = {}
MODI[IND_AKT]  = "Indikativ Aktiv"
MODI[KONJ_AKT] = "Konjunktiv Aktiv"
MODI[IND_PASS] = "Indikativ Passiv"
MODI[KONJ_PASS]= "Konjunktiv Passiv"
MODI[IMPERATIV]= "Imperativ"
local PRAES = 1
local PERF  = 2
local FUTUR = 3
local OST = {'o', 's', 't', 'mus', 'tis', 'nt'}
local MST = {'m', 's', 't', 'mus', 'tis', 'nt'}
local ORRISTUR = {'or', 'ris', 'tur', 'mur', 'mini', 'ntur'}
local RRISTUR = {'r', 'ris', 'tur', 'mur', 'mini', 'ntur'}


function init()
	local frame = mw.getCurrentFrame()
    return {
        inf    = frame.args[1] or frame:getParent().args[1] or 'Infinitiv';
        lInf   = frame.args[2] or frame:getParent().args[2] or 0;
        praes  = frame.args[3] or frame:getParent().args[3] or 'Präsensstamm + ';
        perf   = frame.args[4] or frame:getParent().args[4] or 'Perfektstamm + ';
        lPerf  = frame.args[5] or frame:getParent().args[5] or 0;
        ppp    = frame.args[6] or frame:getParent().args[6] or 'PPP-Stamm + ';
        lPPP   = frame.args[7] or frame:getParent().args[7] or 0;
        praesGV= frame.args.PraesGV or frame:getParent().args.PraesGV or 'AP';
        perfGV = frame.args.PerfGV or frame:getParent().args.PerfGV or 'AP';
    }
end

function bildeInfinitive(params)
	local inf = params.inf
	local praes = params.praes
	local perf = params.perf
	local ppp = params.ppp
	local formen = {{},{}, {}}
	formen[PRAES][IND_AKT] = inf
	if inf:match(praes:sub(-1,-1) .. "r[ei]$") then
		formen[PRAES][IND_PASS] = praes .. "ri"
	elseif praes:match("i$") then
		formen[PRAES][IND_PASS] = praes
	else 
		formen[PRAES][IND_PASS] = praes .. "i"
	end
	formen[PERF][IND_AKT] = perf .. "isse"
	formen[PERF][IND_PASS] = ppp .. "um/am/um esse"
	formen[FUTUR][IND_AKT] = ppp .. "urum/am/um esse"
	formen[FUTUR][IND_PASS] = ppp .. "um iri"
	return formen
end

function bildePartizipien(params)
	local formen = {}
	if params.praes:match("[ae]$") then
		formen[PRAES] = params.praes .. "ns, " .. params.praes .. "ntis"
	else
		formen[PRAES] = params.praes .. "ens, " .. params.praes .. "entis"
	end
	formen[PERF] = params.ppp .. "us/a/um"
	formen[FUTUR] = params.ppp .. "urus/a/um"
	return formen
end

function bildeND(params)
	local formen = {}
	if params.praes:match("[ae]$") then
		formen[1] = params.praes .. "ndi"
		formen[2] = params.praes .. "ndus/a/um"
	else
		formen[1] = params.praes .. "endi"
		formen[2] = params.praes .. "endus/a/um"
	end
	return formen
end

function bildePraesens(params)
    local praes = params.praes
    local formen = createFormTable(params.praesGV)
    local endungen = {}
    endungen[IND_AKT]  = OST
    endungen[KONJ_AKT] = MST
    endungen[IND_PASS] = ORRISTUR
    endungen[KONJ_PASS]= RRISTUR
    formen[IMPERATIV] = {}
    if not praes:match("[aei]$") then
        for person = 1, 6, 1 do
            setIfPossible(formen[IND_AKT],  person, praes .. 'i' .. endungen[IND_AKT][person])
            setIfPossible(formen[IND_PASS], person, praes .. 'i' .. endungen[IND_PASS][person])
            setIfPossible(formen[KONJ_AKT], person, praes .. 'a' .. endungen[KONJ_AKT][person])
            setIfPossible(formen[KONJ_PASS],person, praes .. 'a' .. endungen[KONJ_PASS][person])
        end
        setIfPossible(formen[IND_AKT],  1, praes .. 'o')
        setIfPossible(formen[IND_PASS], 1, praes .. 'or')
        setIfPossible(formen[IND_PASS], 2, praes .. 'eris')
        setIfPossible(formen[IND_AKT],  6, praes .. 'unt')
        setIfPossible(formen[IND_PASS], 6, praes .. 'untur')
    end
    if praes:match("a$") then
        setIfPossible(formen[IND_AKT],  1, praes:sub(1,-2) .. 'o')
        setIfPossible(formen[IND_PASS], 1, praes:sub(1,-2) .. 'or')
        setIfPossible(formen[KONJ_AKT], 1, praes:sub(1,-2) .. 'em')
        setIfPossible(formen[KONJ_PASS],1, praes:sub(1,-2) .. 'er')
        for person = 2, 6, 1 do
            setIfPossible(formen[IND_AKT],  person, praes .. endungen[IND_AKT][person])
            setIfPossible(formen[IND_PASS], person, praes .. endungen[IND_PASS][person])
            setIfPossible(formen[KONJ_AKT], person, praes:sub(1,-2) .. 'e' .. endungen[KONJ_AKT][person])
            setIfPossible(formen[KONJ_PASS],person, praes:sub(1,-2) .. 'e' .. endungen[KONJ_PASS][person])
        end
    end
    if praes:match("[ei]$") then
        for person = 1, 6, 1 do
            setIfPossible(formen[IND_AKT],  person, praes .. endungen[IND_AKT][person])
            setIfPossible(formen[IND_PASS], person, praes .. endungen[IND_PASS][person])
            setIfPossible(formen[KONJ_AKT], person, praes .. 'a' .. endungen[KONJ_AKT][person])
            setIfPossible(formen[KONJ_PASS],person, praes .. 'a' .. endungen[KONJ_PASS][person])
        end
        if not praes:match("e$") then
            setIfPossible(formen[IND_AKT],  6, praes .. 'unt')
            setIfPossible(formen[IND_PASS], 6, praes .. 'untur')
        end
    end
    if praes:match("i$") and not params.inf:match("ir[ei]$") then
        setIfPossible(formen[IND_PASS], 2, praes:sub(1,-2) .. 'eris')
    end
    	
    if params.praesGV:match("A") then
    	if praes:match("[aei]$") then
    		setIfPossible(formen[IMPERATIV],2, praes .. "!")
    		setIfPossible(formen[IMPERATIV],5, praes .. "te!")
    	else
    		setIfPossible(formen[IMPERATIV],2, praes .. "e!")
    		setIfPossible(formen[IMPERATIV],5, praes .. "ite!")
    	end
    else
    	if praes:match("[aei]$") then
    		setIfPossible(formen[IMPERATIV],2, praes .. "re!")
    		setIfPossible(formen[IMPERATIV],5, praes .. "mini!")
    	else
    		setIfPossible(formen[IMPERATIV],2, praes .. "ere!")
    		setIfPossible(formen[IMPERATIV],5, praes .. "imini!")
    	end
    end
    return formen
end

function bildeImperfekt(params)
    local inf = params.inf
    local praes = params.praes
    local formen = createFormTable(params.praesGV)
    local endungen = {}
    endungen[IND_AKT]  = MST
    endungen[KONJ_AKT] = MST
    endungen[IND_PASS] = RRISTUR
    endungen[KONJ_PASS]= RRISTUR

    local ind_stamm = praes .. 'ba'
    local konj_stamm = inf
    if not praes:match("[ae]$") then
        ind_stamm = praes .. 'eba'
    end
    
    if not inf:match("r[ei]$") then
        konj_stamm = inf:sub(1,-2) .. 'ere'
    end
    if inf:match("ri$") then
        konj_stamm = praes .. 're'
    end
    local staemme = {}
    staemme[IND_AKT]  = ind_stamm
    staemme[IND_PASS] = ind_stamm
    staemme[KONJ_AKT] = konj_stamm
    staemme[KONJ_PASS]= konj_stamm
    for person = 1, 6, 1 do
    	for tm,_ in pairs(formen) do
            setIfPossible(formen[tm], person, staemme[tm] .. endungen[tm][person])
        end
    end
    return formen
end

function bildeFuturI(params)
    local praes = params.praes
    local formen = {}
    local endungen = {}
    endungen[IND_AKT]  = MST
    endungen[IND_PASS] = RRISTUR
    if params.praesGV:match("A") then
        formen[IND_AKT]  = {}
    end
    if params.praesGV:match("P") then
        formen[IND_PASS] = {}
    end
    if praes:match("[ae]$") then
        setIfPossible(formen[IND_AKT],  1, praes .. 'bo')
        setIfPossible(formen[IND_PASS], 1, praes .. 'bor')
        for person = 2, 5, 1 do
        	for tm,_ in pairs(formen) do
                setIfPossible(formen[tm], person, praes .. 'bi' .. endungen[tm][person])
            end
        end
        setIfPossible(formen[IND_PASS], 2, praes .. 'beris')
        setIfPossible(formen[IND_AKT],  6, praes .. 'bunt')
        setIfPossible(formen[IND_PASS], 6, praes .. 'buntur')
    else
        setIfPossible(formen[IND_AKT],  1, praes .. 'am')
        setIfPossible(formen[IND_PASS], 1, praes .. 'ar')
        for person = 2, 6, 1 do
        	for m,_ in pairs(formen) do
                setIfPossible(formen[m], person, praes .. 'e' .. endungen[m][person])
            end
        end
    end
    return formen
end

function bildePerfekt(params)
    local perf = params.perf
    local ppp = params.ppp
    local formen = createFormTable(params.perfGV)
    local endungen = {}
    endungen[IND_AKT]  = {'i', 'isti', 'it', 'imus', 'istis', 'erunt'}
    endungen[KONJ_AKT] = MST
    endungen[IND_PASS] = {'us/a/um sum', 'us/a/um es', 'us/a/um est', 'i/ae/a sumus', 'i/ae/a estis', 'i/ae/a sunt'}
    endungen[KONJ_PASS]= {'us/a/um sim', 'us/a/um sis', 'us/a/um sit', 'i/ae/a simus', 'i/ae/a sitis', 'i/ae/a sint'}
    for person = 1, 6, 1 do
        setIfPossible(formen[IND_AKT], person, perf .. endungen[IND_AKT][person])
        setIfPossible(formen[KONJ_AKT], person, perf .. 'eri' .. endungen[KONJ_AKT][person])
        setIfPossible(formen[IND_PASS], person, ppp .. endungen[IND_PASS][person])
        setIfPossible(formen[KONJ_PASS], person, ppp .. endungen[KONJ_PASS][person])
    end
    return formen
end

function bildePlusquamperfekt(params)
    local perf = params.perf
    local ppp = params.ppp
    local formen = createFormTable(params.perfGV)
    local endungen = {'us/a/um', 'us/a/um', 'us/a/um', 'i/ae/a', 'i/ae/a', 'i/ae/a'}
  
    for person = 1, 6, 1 do
        setIfPossible(formen[IND_AKT],  person, perf .. 'era' .. MST[person])
        setIfPossible(formen[KONJ_AKT], person, perf .. 'isse' .. MST[person])
        setIfPossible(formen[IND_PASS], person, ppp .. endungen[person] .. ' era' .. MST[person])
        setIfPossible(formen[KONJ_PASS],person, ppp .. endungen[person] .. ' esse' .. MST[person])
    end
    return formen
end

function bildeFuturII(params)
    local perf = params.perf
    local ppp = params.ppp
    local formen = {}
    local endungen = {'us/a/um', 'us/a/um', 'us/a/um', 'i/ae/a', 'i/ae/a', 'i/ae/a'}
  
    if params.perfGV:match("A") then
        formen[IND_AKT] = {}
    end
    if params.perfGV:match("P") then
    	formen[IND_PASS] = {}
    end
    for person = 1, 6, 1 do
        setIfPossible(formen[IND_AKT],  person, perf .. 'eri' .. MST[person])
        setIfPossible(formen[IND_PASS], person, ppp .. endungen[person] .. ' eri' .. MST[person])
    end
    
    setIfPossible(formen[IND_AKT],  1, perf .. 'ero')
    setIfPossible(formen[IND_PASS], 1, ppp .. 'us/a/um ero')
    setIfPossible(formen[IND_PASS], 6, ppp .. 'i/ae/a erunt')
    return formen
end

function renderInfinitive(formen, praesGV, perfGV)
	local table = ""
	table = table .. '{| class="wikitable mw-collapsible"\n'
	table = table .. '|+ [[Infinitiv]]e\n! !! Aktiv'
	if praesGV == "AP" or perfGV == "AP" then
		table = table .. ' !! Passiv'
	end
	table = table .. '\n|-\n! Präsens\n'
	if praesGV:match("A") then
		table = table .. ' || ' .. utils.enclose(formen[PRAES][IND_AKT])
	end
	if praesGV:match("P") then
		table = table .. ' || ' .. utils.enclose(formen[PRAES][IND_PASS])
	end
	table = table .. '\n|-\n! Perfekt\n'
	if perfGV:match("A") then
		table = table .. ' || ' .. utils.enclose(formen[PERF][IND_AKT])
	end
	if perfGV:match("P") then
		table = table .. ' || ' .. utils.enclose(formen[PERF][IND_PASS])
	end
	table = table .. '\n|-\n! Futur\n || ' .. utils.enclose(formen[FUTUR][IND_AKT])
	if praesGV:match("AP") or perfGV:match("AP") then
		table = table .. ' || ' .. utils.enclose(formen[FUTUR][IND_PASS])
	end
	table = table .. '\n|}\n'
	return table
end

function renderPartizipien(formen, perfGV)
	local table = ''
	table = table .. '{| class="wikitable mw-collapsible"\n'
	table = table .. '|+ [[Partizip]]ien\n'
	table = table .. '! [[Partizip Präsens Aktiv]]\n|| ' .. utils.enclose(formen[PRAES]) .. '\n'
	if perfGV == "AP" then
		table = table .. '|-\n! [[Partizip Perfekt Passiv]]\n|| ' .. utils.enclose(formen[PERF]) .. '\n'
	elseif perfGV == "P" then
		table = table .. '|-\n! [[Partizip Perfekt Deponens]]\n|| ' .. utils.enclose(formen[PERF]) .. '\n'
	end
	table = table .. '|-\n! [[Partizip Futur Aktiv]]\n|| ' .. utils.enclose(formen[FUTUR]) .. '\n'
	table = table .. '|}'
	return table
end

function renderND(formen)
	local table = ''
	table = table .. '{| class="wikitable mw-collapsible"\n'
	table = table .. "|+ ''nd''-Formen\n"
	table = table .. "! [[Gerundium]] !! [[Gerundivum]]\n"
	table = table .. "|-\n| " .. utils.enclose(formen[1]) .. ' || ' .. utils.enclose(formen[2]) .. '\n|}'
	return table
end

function render(tempus, formen, gv)
    local table = ''
    table = table .. '{| class="wikitable mw-collapsible"\n'
    table = table .. '|+ [[' .. tempus .. ']]\n! Person'
    for k,_ in pairs(formen) do
    	table = table .. ' !! ' .. utils.renderTemplate("Verb-TH", {TEMPUS = tempus, MODUS = MODI[k]:match("^%w+"), GV = MODI[k]:match("%w+$"), TYPE = gv})
    end
    table = table .. '\n|-\n'
    for person = 1, 6, 1 do
        table = table .. '! ' .. PERSONEN[person] .. '\n'
        for _,tm in pairs(formen) do
            table = table .. ' || ' .. utils.enclose(tm[person])
        end
        table = table .. '\n|-\n'
    end
    table = table .. '|}'
    return table
end

function setIfPossible(maybeArray,index,value)
	if maybeArray then
		maybeArray[index] = value
	end
end

function createFormTable(gv)
	local formen = {}
	if gv:match("A") then
    	formen[IND_AKT] = {}
    	formen[KONJ_AKT] = {}
    end
    if gv:match("P") then
    	formen[IND_PASS] = {}
    	formen[KONJ_PASS] = {}
    end
    return formen
end

function p.render(frame)
    params = init()
	local pagecontent = ''
	lektionen = {}
	if params.lInf ~= "0" then
		table.insert(lektionen, lInf)
	end
	if params.lPerf ~= "0" then
		table.insert(lektionen, lPerf)
	end
	if params.lPPP ~= "0" then
		table.insert(lektionen, lPPP)
	end
	pagecontent = pagecontent .. p.renderBox(frame)
    pagecontent = pagecontent .. p.renderFormen(frame)
    pagecontent = pagecontent .. utils.renderFooter(params.inf, praesens[praesTemp][1], lektionen)
    return pagecontent
end

function p.renderBox(frame)
	local pagecontent = ""
    params = init()
    if params.praesGV:match('A') then
        praesTemp = IND_AKT
    else
        praesTemp = IND_PASS
    end
    if params.perfGV:match('A') then
        perfTemp = IND_AKT
    else
        perfTemp = IND_PASS
    end
    infinitive = bildeInfinitive(params)
    praesens = bildePraesens(params)
    perfekt = bildePerfekt(params)
    local stammformen = {params.inf, praesens[praesTemp][1], perfekt[perfTemp][1]}
    if not params.ppp:match("PPP") and params.perfGV == "AP" then
    	table.insert(stammformen, params.ppp .. "um")
    	stammformen["lPPP"] = params.lPPP
    end
    stammformen["lInf"] = params.lInf
    stammformen["lPerf"]= params.lPerf
    if not mw.isSubsting() then
    	pagecontent = pagecontent .. utils.renderTemplate("Achtung", {"Dieses Modul sollte nur mit <code>{{subst:#invoke:Verb|...}}</code> eingebunden werden! "})
    end
    pagecontent = pagecontent .. "{{DISPLAYTITLE:" .. params.inf .. "}}\n"
    pagecontent = pagecontent .. utils.renderTemplate("Legende Verb", {}) .. "\n"
    pagecontent = pagecontent .. utils.renderWortwolke(params.inf) .. "\n"
    pagecontent = pagecontent .. utils.renderVokabelbox('Stammformen', stammformen)
    pagecontent = pagecontent .. '\n'
    if params.praesGV == "P" and params.perfGV == "P" then
    	pagecontent = pagecontent .. utils.renderTemplate("Deponens", {}) .. '\n'
    elseif params.praesGV == "P" or params.perfGV == "P" then
    	pagecontent = pagecontent .. utils.renderTemplate("Semideponens", {}) .. '\n'
    end
	return pagecontent
end

function p.renderFormen(frame)
	local pagecontent = ""
    params = init()
    pagecontent = pagecontent .. "\n\n== Infinite Formen ==\n\n"
    pagecontent = pagecontent .. renderInfinitive(infinitive, params.praesGV, params.perfGV)
    pagecontent = pagecontent .. '\n\n'
    pagecontent = pagecontent .. renderPartizipien(bildePartizipien(params), params.perfGV)
    pagecontent = pagecontent .. '\n\n'
    pagecontent = pagecontent .. renderND(bildeND(params))
    pagecontent = pagecontent .. "\n\n== Formen mit Präsensstamm ==\n\n"
    pagecontent = pagecontent .. render('Präsens', praesens, params.praesGV)
    pagecontent = pagecontent .. '\n\n'
    pagecontent = pagecontent .. render('Imperfekt', bildeImperfekt(params), params.praesGV)
    pagecontent = pagecontent .. '\n\n'
    pagecontent = pagecontent .. render('Futur I', bildeFuturI(params), params.praesGV)
    pagecontent = pagecontent .. "\n\n== Formen mit Perfektstamm/PPP ==\n\n"
    pagecontent = pagecontent .. render('Perfekt', perfekt, params.perfGV)
    pagecontent = pagecontent .. '\n\n'
    pagecontent = pagecontent .. render('Plusquamperfekt', bildePlusquamperfekt(params), params.perfGV)
    pagecontent = pagecontent .. '\n\n'
    pagecontent = pagecontent .. render('Futur II', bildeFuturII(params), params.perfGV)
    return pagecontent
end	

function p.renderFooter(frame)
	local pagecontent = ""
    params = init()
    pagecontent = pagecontent .. "\n\n== Weblinks ==\n\n"
    pagecontent = pagecontent .. "* " .. utils.renderTemplate('Navigium', {params.inf}) .. "\n"
    pagecontent = pagecontent .. "* " .. utils.renderTemplate("Georges", {praesens[praesTemp][1]}) .. "\n"
    pagecontent = pagecontent .. utils.renderTemplate("Vokabel-Kategorien", {params.lInf})
    pagecontent = pagecontent .. utils.addCampusCategoryIfSet(params.lPerf)
    pagecontent = pagecontent .. utils.addCampusCategoryIfSet(params.lPPP)
    return pagecontent
end

return p