Ugrás a tartalomhoz

„Modul:CactaceaeTaxonok” változatai közötti eltérés

Innen: MKOE wiki
Nincs szerkesztési összefoglaló
Nincs szerkesztési összefoglaló
 
(15 közbenső módosítás ugyanattól a felhasználótól nincs mutatva)
1. sor: 1. sor:
local p = {}
local p = {}


-- Szigorúan Unicode-biztos formázó függvény
-- Speciális formázó a taxonómiai nevekhez + Linkelés
local function formazSzinonimak(szoveg)
local function taxonFormazo(szoveg, isGenus, isTypeLink)
     if not szoveg or szoveg == "" then return "" end
     if not szoveg or szoveg == "" then return "" end
   
    local tiszta_szoveg = szoveg:gsub("Type:", "Típusfaj:")
   
    -- Ellenőrizzük, hogy van-e benne link jelző (@)
    local hasLinkMarker = tiszta_szoveg:find("@")
    if hasLinkMarker then
        tiszta_szoveg = tiszta_szoveg:gsub("@", "")
    end


    -- Minden tisztítást mw.ustring-gel végzünk
     local megjelenitendo = tiszta_szoveg
     local tiszta = mw.ustring.gsub(szoveg, "[đ÷¤]", "")
    tiszta = mw.ustring.gsub(tiszta, ">−", "−")
    tiszta = mw.ustring.gsub(tiszta, ">≡", "≡")
    tiszta = mw.ustring.gsub(tiszta, ">=", "=")
      
      
     -- Elválasztók előkészítése (a % elkerüli a speciális jelentést)
     -- 1. Típusfaj linkelés
    tiszta = mw.ustring.gsub(tiszta, "≡≡", "###")
    if isTypeLink then
     tiszta = mw.ustring.gsub(tiszta, "==", "###")
        local nev_resz = tiszta_szoveg:match("Típusfaj:%s*(.*)")
    tiszta = mw.ustring.gsub(tiszta, "−−", "###")
        if nev_resz then
     tiszta = mw.ustring.gsub(tiszta, "%-%-", "###")
            local tiszta_nev = mw.text.trim(nev_resz)
            megjelenitendo = "Típusfaj: [[" .. tiszta_nev .. "|''" .. tiszta_nev .. "'']]"
        else
            megjelenitendo = "[[" .. tiszta_szoveg .. "|''" .. tiszta_szoveg .. "'']]"
        end
    -- 2. Jelölt szinonima linkelés (@ karakter esetén)
     elseif hasLinkMarker then
        local tiszta_nev = mw.text.trim(tiszta_szoveg)
        megjelenitendo = "[[" .. tiszta_nev .. "|''" .. tiszta_nev .. "'']]"
    end
   
    local s = ""
    -- Formázás (félkövér a nemzetségeknek, ha nem típusfaj link)
    if isGenus and not isTypeLink and not hasLinkMarker then
        s = "'''''" .. megjelenitendo .. "'''''"
    elseif not isTypeLink and not hasLinkMarker then
        s = "''" .. megjelenitendo .. "''"
    else
        s = megjelenitendo
    end
   
    -- Álló betűs kulcsszavak
    local kulcsszavak = {
        "subgen%.", "subg%.", "sect%.", "subsect%.",
        "subsp%.", "var%.", "subvar%.", "f%.", "Típusfaj:"
    }
   
    for _, kulcs in ipairs(kulcsszavak) do
        local tiszta_kulcs = kulcs:gsub("%%", "")
        -- Itt ügyelünk rá, hogy a linkelt részen belül is javítsuk a dőlteket
        s = s:gsub(kulcs, "''" .. tiszta_kulcs .. "''")
    end
   
    s = s:gsub("''''''", ""):gsub("''''", "")
    return s
end
 
-- Szinonimák feldolgozása
local function formazSzinonimak(sor)
    if not sor or sor == "" then return "" end
 
    local lista = {}
 
    -- 1. Típusfaj kinyerése
    local nyers_resz = sor:match("^([^%d]+)1#")
     if nyers_resz then
        local tisztitott = mw.text.trim(nyers_resz:gsub("^::%s*", ""))
        if tisztitott ~= "" then
            table.insert(lista, "<li>" .. taxonFormazo(tisztitott, false, true) .. "</li>")
        end
    end


    local lista_elemek = {}
     -- 2. Számozott blokkok (szinonimák)
   
    local aktualis_sor = ""
     -- Saját daraboló logika mw.ustring alapokon (elkerüli az mw.text.split hibáját)
     for szint, jel, tartalom in mw.ustring.gmatch(sor, "(%d)%s*([^%d%s#]+)%s*([^#]+)%s*%d#") do
     for resz in mw.ustring.gmatch(tiszta, "[^#]+") do
         if szint == "3" or szint == "4" then
        local tiszta_resz = mw.text.trim(resz)
             local tiszta_jel = mw.ustring.sub(jel, 1, 1)
         if tiszta_resz ~= "" then
             local trimmed_tartalom = mw.text.trim(tartalom)
            -- Dőltetés: Alapból dőlt, a jelek állóként "kilépnek"
            local formazott = "''" .. tiszta_resz .. "''"
            formazott = mw.ustring.gsub(formazott, "≡", "''≡''")
            formazott = mw.ustring.gsub(formazott, "=", "''=''")
             formazott = mw.ustring.gsub(formazott, "−", "''−''")
             formazott = mw.ustring.gsub(formazott, "Type:", "''Type:''")
            formazott = mw.ustring.gsub(formazott, "var%.", "''var.''")
            formazott = mw.ustring.gsub(formazott, "subsp%.", "''subsp.''")
            formazott = mw.ustring.gsub(formazott, "f%.", "''f.''")
              
              
             -- Felesleges dupla aposztrófok takarítása
             -- Ha van @ jel, linkeljük, függetlenül attól, hogy nemzetség vagy faj
             formazott = mw.ustring.gsub(formazott, "''''", "")
             local formalt_nev = taxonFormazo(trimmed_tartalom, not trimmed_tartalom:find(" "), false)
              
            local elem = tiszta_jel .. " " .. formalt_nev
            table.insert(lista_elemek, "<li>" .. formazott .. "</li>")
 
             if szint == "3" then
                if aktualis_sor ~= "" then table.insert(lista, "<li>" .. aktualis_sor .. "</li>") end
                aktualis_sor = elem
            else
                aktualis_sor = aktualis_sor .. " " .. elem
            end
         end
         end
     end
     end
   
 
     if #lista_elemek == 0 then return "" end
     if aktualis_sor ~= "" then
     return '<ul style="margin-left: 1.1em; list-style-type: disc; padding: 0; margin: 0;">' .. table.concat(lista_elemek) .. "</ul>"
        table.insert(lista, "<li>" .. aktualis_sor .. "</li>")
    end
 
     return #lista > 0 and '<ul style="margin-left:1.1em; list-style-type:disc; padding:0; margin:0;">' .. table.concat(lista) .. "</ul>" or ""
end
end


function p.tablazat(frame)
function p.tablazat(frame)
    -- Paraméterkezelés
     local args = frame:getParent().args
     local parent_args = frame:getParent().args
     local szuro = args[1] and mw.text.trim(args[1]) or ""
     local szuroNemzettseg = parent_args[1] or frame.args[1]
      
    if szuroNemzettseg then szuroNemzettseg = mw.text.trim(szuroNemzettseg) end
     local status, dataModul = pcall(require, 'Modul:CactaceaeTaxonokData')
    if szuroNemzettseg == "" then szuroNemzettseg = nil end
     if not status then return "Hiba: Modul:CactaceaeTaxonokData nem található." end
 
     local nyers = dataModul.getAdatok()
     -- Adatok betöltése
     local status, adatModul = pcall(require, 'Modul:CactaceaeTaxonokData')
     if not status then return "Hiba: A 'Modul:CactaceaeTaxonokData' nem található!" end
     local nyers_adat = adatModul.getAdatok()


     local rows = {}
     local rows = {}
     local sorszam = 0
     local counter = 0
     local jelenlegiNemzettseg = ""
     local isVisible = false
    local megjelenit = true
 
    -- Soronkénti feldolgozás Unicode-biztosan
    for sor in mw.ustring.gmatch(nyers_adat, "[^\r\n]+") do
        local taxon_link = ""
        local szinonimak_nyers = ""


        -- Kezdőkarakter ellenőrzése mw.ustring.sub-bal
    for sor in nyers:gmatch("[^\r\n]+") do
         local elso = mw.ustring.sub(sor, 1, 1)
         local szint = sor:sub(1, 1)


         if elso == "ß" then
         if szint == "1" then
            -- Nemzetség sor: ß Név :: Típusfaj
             local nemz = sor:match("^1%s+([^%s:]+)")
             local nemz, tip = mw.ustring.match(sor, "^ß%s*([^:]+)::%s*(.+)")
             if nemz then
             if nemz then
                 jelenlegiNemzettseg = mw.text.trim(mw.ustring.gsub(nemz, "¤", ""))
                 if szuro == "" or nemz == szuro then
               
                     isVisible = true
                -- Szűrés logikája
                    counter = counter + 1
                if not szuroNemzettseg or szuroNemzettseg == jelenlegiNemzettseg then
                    local nemz_display = "'''''" .. nemz .. "'''''"
                     taxon_link = "'''[[:Kategória:" .. jelenlegiNemzettseg .. "|" .. jelenlegiNemzettseg .. "]]'''"
                    local nemz_link = "[[:Kategória:" .. nemz .. "|" .. nemz_display .. "]]"
                     szinonimak_nyers = tip
                     local maradek = sor:match("^1%s+[^%s:]+%s*(.*)$") or ""
                     megjelenit = true
                     table.insert(rows, "|-\n| " .. counter .. "\n| style=\"white-space:nowrap\" | " .. nemz_link .. "\n| " .. formazSzinonimak(maradek))
                 else
                 else
                     megjelenit = false
                     isVisible = false
                 end
                 end
             end
             end
         elseif elso == "Ł" and megjelenit then
         elseif szint == "2" and isVisible then
            -- Faj sor: Ł Név ¤¤¤ Szinonimák
             local fajnev, maradek = sor:match("^2%s+([^2#]+)2#%s*(.*)")
             local tiszta_sor = mw.ustring.sub(sor, 2) -- Ł levágása
             if fajnev then
            local t, sz = mw.ustring.match(tiszta_sor, "^%s*([^¤]+)¤¤¤(.*)")
                counter = counter + 1
             if t then
                 local tiszta_fajnev = mw.text.trim(fajnev)
                 local tiszta_nev = mw.text.trim(t)
                 table.insert(rows, "|-\n| " .. counter .. "\n| style=\"white-space:nowrap\" | [[" .. tiszta_fajnev .. "|''" .. tiszta_fajnev .. "'']]\n| " .. formazSzinonimak(maradek))
                 taxon_link = "''[[" .. tiszta_nev .. "]]''"
                szinonimak_nyers = sz
             end
             end
        end
        -- Ha van érvényes taxonunk és meg kell jeleníteni
        if taxon_link ~= "" then
            sorszam = sorszam + 1
            table.insert(rows, "|-\n| " .. sorszam .. "\n| " .. taxon_link .. "\n| " .. formazSzinonimak(szinonimak_nyers))
        end
        -- Biztonsági gát (CPU limit miatt)
        if sorszam > 1500 then
            table.insert(rows, "|-\n| colspan='3' | <span style='color:red;'>Hiba: A lista túl hosszú. Kérlek, szűrj egy nemzetségre!</span>")
            break
         end
         end
     end
     end


     -- Táblázat összeállítása
     if #rows == 0 then return "Nincs találat." end
     local res = '{| class="wikitable sortable datatable-hook stripe hover compact" data-page-length="50" style="width:100%; font-size:90%;"\n'
     local head = '{| class="wikitable sortable datatable-hook stripe hover compact" style="width:100%; font-size:90%;"\n! # !! Taxonnév !! Típusfaj, szinonimák\n'
    res = res .. "! # !! Taxonnév !! Típusfaj, szinonima\n"
     return frame:preprocess(head .. table.concat(rows, "\n") .. "\n|}")
     res = res .. table.concat(rows, "\n") .. "\n|}"
   
    return frame:preprocess(res)
end
end


return p
return p

A lap jelenlegi, 2026. január 10., 00:54-kori változata

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

local p = {}

-- Speciális formázó a taxonómiai nevekhez + Linkelés
local function taxonFormazo(szoveg, isGenus, isTypeLink)
    if not szoveg or szoveg == "" then return "" end
    
    local tiszta_szoveg = szoveg:gsub("Type:", "Típusfaj:")
    
    -- Ellenőrizzük, hogy van-e benne link jelző (@)
    local hasLinkMarker = tiszta_szoveg:find("@")
    if hasLinkMarker then
        tiszta_szoveg = tiszta_szoveg:gsub("@", "")
    end

    local megjelenitendo = tiszta_szoveg
    
    -- 1. Típusfaj linkelés
    if isTypeLink then
        local nev_resz = tiszta_szoveg:match("Típusfaj:%s*(.*)")
        if nev_resz then
            local tiszta_nev = mw.text.trim(nev_resz)
            megjelenitendo = "Típusfaj: [[" .. tiszta_nev .. "|''" .. tiszta_nev .. "'']]"
        else
            megjelenitendo = "[[" .. tiszta_szoveg .. "|''" .. tiszta_szoveg .. "'']]"
        end
    -- 2. Jelölt szinonima linkelés (@ karakter esetén)
    elseif hasLinkMarker then
        local tiszta_nev = mw.text.trim(tiszta_szoveg)
        megjelenitendo = "[[" .. tiszta_nev .. "|''" .. tiszta_nev .. "'']]"
    end
    
    local s = ""
    -- Formázás (félkövér a nemzetségeknek, ha nem típusfaj link)
    if isGenus and not isTypeLink and not hasLinkMarker then
        s = "'''''" .. megjelenitendo .. "'''''"
    elseif not isTypeLink and not hasLinkMarker then
        s = "''" .. megjelenitendo .. "''"
    else
        s = megjelenitendo
    end
    
    -- Álló betűs kulcsszavak
    local kulcsszavak = {
        "subgen%.", "subg%.", "sect%.", "subsect%.", 
        "subsp%.", "var%.", "subvar%.", "f%.", "Típusfaj:"
    }
    
    for _, kulcs in ipairs(kulcsszavak) do
        local tiszta_kulcs = kulcs:gsub("%%", "")
        -- Itt ügyelünk rá, hogy a linkelt részen belül is javítsuk a dőlteket
        s = s:gsub(kulcs, "''" .. tiszta_kulcs .. "''")
    end
    
    s = s:gsub("''''''", ""):gsub("''''", "")
    return s
end

-- Szinonimák feldolgozása
local function formazSzinonimak(sor)
    if not sor or sor == "" then return "" end

    local lista = {}

    -- 1. Típusfaj kinyerése
    local nyers_resz = sor:match("^([^%d]+)1#")
    if nyers_resz then
        local tisztitott = mw.text.trim(nyers_resz:gsub("^::%s*", ""))
        if tisztitott ~= "" then
            table.insert(lista, "<li>" .. taxonFormazo(tisztitott, false, true) .. "</li>")
        end
    end

    -- 2. Számozott blokkok (szinonimák)
    local aktualis_sor = ""
    for szint, jel, tartalom in mw.ustring.gmatch(sor, "(%d)%s*([^%d%s#]+)%s*([^#]+)%s*%d#") do
        if szint == "3" or szint == "4" then
            local tiszta_jel = mw.ustring.sub(jel, 1, 1)
            local trimmed_tartalom = mw.text.trim(tartalom)
            
            -- Ha van @ jel, linkeljük, függetlenül attól, hogy nemzetség vagy faj
            local formalt_nev = taxonFormazo(trimmed_tartalom, not trimmed_tartalom:find(" "), false)
            local elem = tiszta_jel .. " " .. formalt_nev

            if szint == "3" then
                if aktualis_sor ~= "" then table.insert(lista, "<li>" .. aktualis_sor .. "</li>") end
                aktualis_sor = elem
            else
                aktualis_sor = aktualis_sor .. " " .. elem
            end
        end
    end

    if aktualis_sor ~= "" then
        table.insert(lista, "<li>" .. aktualis_sor .. "</li>")
    end

    return #lista > 0 and '<ul style="margin-left:1.1em; list-style-type:disc; padding:0; margin:0;">' .. table.concat(lista) .. "</ul>" or ""
end

function p.tablazat(frame)
    local args = frame:getParent().args
    local szuro = args[1] and mw.text.trim(args[1]) or ""
    
    local status, dataModul = pcall(require, 'Modul:CactaceaeTaxonokData')
    if not status then return "Hiba: Modul:CactaceaeTaxonokData nem található." end
    local nyers = dataModul.getAdatok()

    local rows = {}
    local counter = 0
    local isVisible = false

    for sor in nyers:gmatch("[^\r\n]+") do
        local szint = sor:sub(1, 1)

        if szint == "1" then
            local nemz = sor:match("^1%s+([^%s:]+)")
            if nemz then
                if szuro == "" or nemz == szuro then
                    isVisible = true
                    counter = counter + 1
                    local nemz_display = "'''''" .. nemz .. "'''''"
                    local nemz_link = "[[:Kategória:" .. nemz .. "|" .. nemz_display .. "]]"
                    local maradek = sor:match("^1%s+[^%s:]+%s*(.*)$") or ""
                    table.insert(rows, "|-\n| " .. counter .. "\n| style=\"white-space:nowrap\" | " .. nemz_link .. "\n| " .. formazSzinonimak(maradek))
                else
                    isVisible = false
                end
            end
        elseif szint == "2" and isVisible then
            local fajnev, maradek = sor:match("^2%s+([^2#]+)2#%s*(.*)")
            if fajnev then
                counter = counter + 1
                local tiszta_fajnev = mw.text.trim(fajnev)
                table.insert(rows, "|-\n| " .. counter .. "\n| style=\"white-space:nowrap\" | [[" .. tiszta_fajnev .. "|''" .. tiszta_fajnev .. "'']]\n| " .. formazSzinonimak(maradek))
            end
        end
    end

    if #rows == 0 then return "Nincs találat." end
    local head = '{| class="wikitable sortable datatable-hook stripe hover compact" style="width:100%; font-size:90%;"\n! # !! Taxonnév !! Típusfaj, szinonimák\n'
    return frame:preprocess(head .. table.concat(rows, "\n") .. "\n|}")
end

return p