Ugrás a tartalomhoz

Modul:CactaceaeTaxonSzinonimák

Innen: MKOE wiki
A lap korábbi változatát látod, amilyen Dr. Gyúró Zoltán (vitalap | szerkesztései) 2026. január 11., 14:55-kor történt szerkesztése után volt.

A modult a Modul:CactaceaeTaxonSzinonimák/doc lapon tudod dokumentálni

local p = {}

-- Szigorú tisztítás az összehasonlításhoz és megjelenítéshez
local function cleanName(s)
    if not s or s == "" then return "" end
    -- Eltávolítjuk a sallangokat: számok, jelek, kettőskereszt, @, kettőspontok
    local cleaned = mw.ustring.gsub(s, "[%d#@≡=%-−%:]+", "")
    return mw.text.trim(cleaned)
end

-- Függvény a nevek dőlt betűs formázásához a rövidítések kihagyásával
local function formatItalic(name)
    if not name or name == "" then return "" end
    local keywords = {"subgen%.", "subg%.", "sect%.", "subsect%.", "subsp%.", "var%.", "subvar%.", "f%."}
    local formatted = name
    for _, kw in ipairs(keywords) do
        formatted = mw.ustring.gsub(formatted, " (" .. kw .. ") ", "'' %1 ''")
    end
    return "''" .. formatted .. "''"
end

function p.keres(frame)
    local keresettTaxon = frame.args[1] or frame:getParent().args[1]
    if not keresettTaxon or keresettTaxon == "" then return "Nincs megadva taxon!" end
    
    -- Alulvonás kezelése a PAGENAME miatt
    keresettTaxon = mw.ustring.gsub(mw.text.trim(keresettTaxon), "_", " ")
    local keresettAlacsony = cleanName(keresettTaxon):lower()
    
    local dataModul = require("Modul:CactaceaeTaxonokData")
    local nyersAdat = dataModul.getAdatok()
    
    local homoHTML = "≡" 
    local hibaHTML = "−" 
    
    local talaltSor = nil

    -- 1. KERESÉS ÉS ELŐTISZTÍTÁS
    for sor in nyersAdat:gmatch("[^\r\n]+") do
        -- Biztonságos Type-eltávolítás: ha nincs Type, marad az eredeti sor
        local tisztaSor = mw.ustring.gsub(sor, "%s*::%s*Type:.-(%d#)", " %1")
        
        if mw.ustring.find(tisztaSor:lower(), keresettAlacsony, 1, true) then
            local darabok = mw.text.split(tisztaSor, "#")
            for _, darab in ipairs(darabok) do
                if cleanName(darab):lower() == keresettAlacsony then
                    talaltSor = tisztaSor
                    break
                end
            end
        end
        if talaltSor then break end
    end
    
    -- Ha nem találtunk semmit, itt állunk meg
    if not talaltSor or talaltSor == "" then
        return "A megadott taxon (''" .. keresettTaxon .. "'') nem található az adatbázisban."
    end
    
    -- 2. FELDOLGOZÁS (Itt már biztosan van string a talaltSor-ban)
    local elsoNevMatch = mw.ustring.match(talaltSor, "^%d+ ([^#≡=%-−]+)")
    local ervenyesNevFinal = cleanName(elsoNevMatch or "Ismeretlen taxon")

    local eredmeny = ""
    if cleanName(ervenyesNevFinal):lower() == keresettAlacsony then
        eredmeny = "== A " .. formatItalic(ervenyesNevFinal) .. " szinonimái ==\n\n"
    else
        eredmeny = "== A " .. formatItalic(ervenyesNevFinal) .. " szinonimái ==\n*(A keresett ''" .. keresettTaxon .. "'' ennek a taxonnak a szinonimája)*\n\n"
    end
    
    local lista = {}
    local szinonimaDarabok = mw.text.split(talaltSor, "#")
    
    for _, darab in ipairs(szinonimaDarabok) do
        local jel = mw.ustring.match(darab, "([≡=%-−])")
        local szint = mw.ustring.match(darab, "(%d+)$")
        
        if jel and szint then
            local tisztaNev = cleanName(darab)
            local szam = tonumber(szint)
            local aktJel = (jel == "≡") and homoHTML or ((jel == "-" or jel == "−") and hibaHTML or jel)
            
            if tisztaNev ~= "" then
                if szam == 4 and #lista > 0 then
                    table.insert(lista[#lista].nevek, {jel = aktJel, nev = tisztaNev})
                else
                    table.insert(lista, {
                        elsoJel = aktJel,
                        nevek = {{jel = "", nev = tisztaNev}}
                    })
                end
            end
        end
    end
    
    -- 3. ÖSSZEÁLLÍTÁS
    if #lista == 0 then return eredmeny .. "* Nincsenek szinonimák." end
    
    for _, csoport in ipairs(lista) do
        local sorElemei = {}
        for i, adat in ipairs(csoport.nevek) do
            local elem = formatItalic(adat.nev)
            if i > 1 then elem = adat.jel .. " " .. elem end
            table.insert(sorElemei, elem)
        end
        eredmeny = eredmeny .. "* " .. csoport.elsoJel .. " " .. table.concat(sorElemei, ", ") .. "\n"
    end
    
    return eredmeny
end

return p