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ó
 
(23 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
local function formazSzinonimak(szoveg)
local function taxonFormazo(szoveg, isGenusLevel, isTypeLink)
     if not szoveg or szoveg == "" then return "" end
     if not szoveg or szoveg == "" then return "" end
    -- Minden tisztítást mw.ustring-gel végzünk
    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)
    local tiszta_szoveg = szoveg:gsub("Type:", "Típusfaj:")
     tiszta = mw.ustring.gsub(tiszta, "≡≡", "###")
     -- Idézőjelek és link jelölő takarítása
    tiszta = mw.ustring.gsub(tiszta, "==", "###")
     local nyers = tiszta_szoveg:gsub("@", ""):gsub("'", ""):gsub("\"", "")
    tiszta = mw.ustring.gsub(tiszta, "−−", "###")
     nyers = mw.text.trim(nyers)
     tiszta = mw.ustring.gsub(tiszta, "%-%-", "###")


    local lista_elemek = {}
     -- 1. Típusfaj linkelés
   
     if isTypeLink then
     -- Saját daraboló logika mw.ustring alapokon (elkerüli az mw.text.split hibáját)
         local nev_resz = nyers:match("Típusfaj:%s*(.*)")
     for resz in mw.ustring.gmatch(tiszta, "[^#]+") do
         if nev_resz then
         local tiszta_resz = mw.text.trim(resz)
             local t = mw.text.trim(nev_resz)
         if tiszta_resz ~= "" then
             return "''Típusfaj:'' [[" .. t .. "|''" .. t .. "'']]"
            -- Dőltetés: Alapból dőlt, a jelek állóként "kilépnek"
        else
             local formazott = "''" .. tiszta_resz .. "''"
             return "[[" .. nyers .. "|''" .. nyers .. "'']]"
            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
            formazott = mw.ustring.gsub(formazott, "''''", "")
           
            table.insert(lista_elemek, "<li>" .. formazott .. "</li>")
         end
         end
     end
     end
   
    if #lista_elemek == 0 then return "" end
    return '<ul style="margin-left: 1.1em; list-style-type: disc; padding: 0; margin: 0;">' .. table.concat(lista_elemek) .. "</ul>"
end


function p.tablazat(frame)
    -- 2. Link jelölt szinonima (@)
     -- Paraméterkezelés
    if tiszta_szoveg:find("@") then
     local parent_args = frame:getParent().args
        return "[[" .. nyers .. "|''" .. nyers .. "'']]"
     local szuroNemzettseg = parent_args[1] or frame.args[1]
    end
     if szuroNemzettseg then szuroNemzettseg = mw.text.trim(szuroNemzettseg) end
 
     if szuroNemzettseg == "" then szuroNemzettseg = nil end
     -- 3. Normál formázás szavanként
     local szavak = mw.text.split(nyers, " ")
     local formalt_szavak = {}
    local allo_kulcsszavak = {
        ["subgen."] = true, ["subg."] = true, ["sect."] = true,
        ["subsect."] = true, ["subsp."] = true, ["var."] = true,
        ["f."] = true
     }
 
    for _, szo in ipairs(szavak) do
        if allo_kulcsszavak[szo] then
            -- A rövidítés ÁLLÓ betűs (nincs körülötte semmilyen jelölő)
            table.insert(formalt_szavak, szo)
        else
            -- A latin név részei
            if isGenusLevel then
                -- 1-es szintű sorban: VASTAG-DŐLT
                table.insert(formalt_szavak, "'''''" .. szo .. "'''''")
            else
                -- 2-es szintű (faj) sorban: SIMA DŐLT
                table.insert(formalt_szavak, "''" .. szo .. "''")
            end
        end
     end


     -- Adatok betöltése
     return table.concat(formalt_szavak, " ")
    local status, adatModul = pcall(require, 'Modul:CactaceaeTaxonokData')
end
    if not status then return "Hiba: A 'Modul:CactaceaeTaxonokData' nem található!" end
    local nyers_adat = adatModul.getAdatok()


    local rows = {}
-- Szinonimák feldolgozása
     local sorszam = 0
local function formazSzinonimak(sor, isParentGenus)
    local jelenlegiNemzettseg = ""
     if not sor or sor == "" then return "" end
     local megjelenit = true
     local lista = {}


     -- Soronkénti feldolgozás Unicode-biztosan
     -- Típusfaj
     for sor in mw.ustring.gmatch(nyers_adat, "[^\r\n]+") do
     local tipus_resz = sor:match("^([^%d]+)1#")
         local taxon_link = ""
    if tipus_resz then
         local szinonimak_nyers = ""
         local t = mw.text.trim(tipus_resz:gsub("^::%s*", ""))
         if t ~= "" then
            table.insert(lista, "<li>" .. taxonFormazo(t, false, true) .. "</li>")
        end
    end


        -- Kezdőkarakter ellenőrzése mw.ustring.sub-bal
    -- Szinonimák (3# és 4#)
         local elso = mw.ustring.sub(sor, 1, 1)
    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 = mw.text.trim(tartalom)
           
            -- Meghatározzuk a formázási szintet
            local subGen = trimmed:find("subg%.") or trimmed:find("sect%.") or trimmed:find("subsect%.")
            local isGenusLevel = isParentGenus or subGen
           
            local formalt = taxonFormazo(trimmed, isGenusLevel, false)
            local elem = tiszta_jel .. " " .. formalt


        if elso == "ß" then
            if szint == "3" then
            -- Nemzetség sor: ß Név :: Típusfaj
                if aktualis_sor ~= "" then table.insert(lista, "<li>" .. aktualis_sor .. "</li>") end
            local nemz, tip = mw.ustring.match(sor, "^ß%s*([^:]+)::%s*(.+)")
                 aktualis_sor = elem
            if nemz then
             else
                jelenlegiNemzettseg = mw.text.trim(mw.ustring.gsub(nemz, "¤", ""))
                 aktualis_sor = aktualis_sor .. " " .. elem
               
                -- Szűrés logikája
                if not szuroNemzettseg or szuroNemzettseg == jelenlegiNemzettseg then
                    taxon_link = "'''[[:Kategória:" .. jelenlegiNemzettseg .. "|" .. jelenlegiNemzettseg .. "]]'''"
                    szinonimak_nyers = tip
                    megjelenit = true
                 else
                    megjelenit = false
                end
             end
        elseif elso == "Ł" and megjelenit then
            -- Faj sor: Ł Név ¤¤¤ Szinonimák
            local tiszta_sor = mw.ustring.sub(sor, 2) -- Ł levágása
            local t, sz = mw.ustring.match(tiszta_sor, "^%s*([^¤]+)¤¤¤(.*)")
            if t then
                 local tiszta_nev = mw.text.trim(t)
                taxon_link = "''[[" .. tiszta_nev .. "]]''"
                szinonimak_nyers = sz
             end
             end
         end
         end
    end
    if aktualis_sor ~= "" then table.insert(lista, "<li>" .. aktualis_sor .. "</li>") end
   
    if #lista == 0 then return "" end
    return '<ul style="list-style-type:disc; padding:0; margin:0 0 0 1.5em;">' .. table.concat(lista) .. "</ul>"
end


        -- Ha van érvényes taxonunk és meg kell jeleníteni
function p.tablazat(frame)
        if taxon_link ~= "" then
    local args = frame:getParent().args
            sorszam = sorszam + 1
    local szuro = args[1] and mw.text.trim(args[1]) or ""
            table.insert(rows, "|-\n| " .. sorszam .. "\n| " .. taxon_link .. "\n| " .. formazSzinonimak(szinonimak_nyers))
    local status, dataModul = pcall(require, 'Modul:CactaceaeTaxonokData')
        end
    if not status then return "Hiba: Adatmodul hiányzik." end
    local nyers = dataModul.getAdatok()


         -- Biztonsági gát (CPU limit miatt)
    local rows, counter, isVisible = {}, 0, false
         if sorszam > 1500 then
    for sor in nyers:gmatch("[^\r\n]+") do
            table.insert(rows, "|-\n| colspan='3' | <span style='color:red;'>Hiba: A lista túl hosszú. Kérlek, szűrj egy nemzetségre!</span>")
        local szint = sor:sub(1, 1)
             break
         if szint == "1" then
            local nemz = sor:match("^1%s+([^%s:]+)")
            isVisible = (szuro == "" or nemz == szuro)
            if nemz and isVisible then
                counter = counter + 1
                local nemz_link = "[[:Kategória:" .. nemz .. "|'''''" .. nemz .. "''''']]"
                local maradek = sor:match("^1%s+[^%s:]+%s*(.*)$") or ""
                table.insert(rows, "|-\n| " .. counter .. "\n| style=\"white-space:nowrap\" | " .. nemz_link .. "\n| " .. formazSzinonimak(maradek, true))
            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 = mw.text.trim(fajnev)
                table.insert(rows, "|-\n| " .. counter .. "\n| style=\"white-space:nowrap\" | [[" .. tiszta .. "|''" .. tiszta .. "'']]\n| " .. formazSzinonimak(maradek, false))
             end
         end
         end
     end
     end
    -- Táblázat összeállítása
    local res = '{| class="wikitable sortable datatable-hook stripe hover compact" data-page-length="50" style="width:100%; font-size:90%;"\n'
    res = res .. "! # !! Taxonnév !! Típusfaj, szinonima\n"
    res = res .. table.concat(rows, "\n") .. "\n|}"
      
      
     return frame:preprocess(res)
    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
end


return p
return p

A lap jelenlegi, 2026. január 10., 08:06-kori változata

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

local p = {}

-- Speciális formázó a taxonómiai nevekhez
local function taxonFormazo(szoveg, isGenusLevel, isTypeLink)
    if not szoveg or szoveg == "" then return "" end
    
    local tiszta_szoveg = szoveg:gsub("Type:", "Típusfaj:")
    -- Idézőjelek és link jelölő takarítása
    local nyers = tiszta_szoveg:gsub("@", ""):gsub("'", ""):gsub("\"", "")
    nyers = mw.text.trim(nyers)

    -- 1. Típusfaj linkelés
    if isTypeLink then
        local nev_resz = nyers:match("Típusfaj:%s*(.*)")
        if nev_resz then
            local t = mw.text.trim(nev_resz)
            return "''Típusfaj:'' [[" .. t .. "|''" .. t .. "'']]"
        else
            return "[[" .. nyers .. "|''" .. nyers .. "'']]"
        end
    end

    -- 2. Link jelölt szinonima (@)
    if tiszta_szoveg:find("@") then
        return "[[" .. nyers .. "|''" .. nyers .. "'']]"
    end

    -- 3. Normál formázás szavanként
    local szavak = mw.text.split(nyers, " ")
    local formalt_szavak = {}
    local allo_kulcsszavak = {
        ["subgen."] = true, ["subg."] = true, ["sect."] = true, 
        ["subsect."] = true, ["subsp."] = true, ["var."] = true, 
        ["f."] = true
    }

    for _, szo in ipairs(szavak) do
        if allo_kulcsszavak[szo] then
            -- A rövidítés ÁLLÓ betűs (nincs körülötte semmilyen jelölő)
            table.insert(formalt_szavak, szo)
        else
            -- A latin név részei
            if isGenusLevel then
                -- 1-es szintű sorban: VASTAG-DŐLT
                table.insert(formalt_szavak, "'''''" .. szo .. "'''''")
            else
                -- 2-es szintű (faj) sorban: SIMA DŐLT
                table.insert(formalt_szavak, "''" .. szo .. "''")
            end
        end
    end

    return table.concat(formalt_szavak, " ")
end

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

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

    -- Szinonimák (3# és 4#)
    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 = mw.text.trim(tartalom)
            
            -- Meghatározzuk a formázási szintet
            local subGen = trimmed:find("subg%.") or trimmed:find("sect%.") or trimmed:find("subsect%.")
            local isGenusLevel = isParentGenus or subGen
            
            local formalt = taxonFormazo(trimmed, isGenusLevel, false)
            local elem = tiszta_jel .. " " .. formalt

            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
    
    if #lista == 0 then return "" end
    return '<ul style="list-style-type:disc; padding:0; margin:0 0 0 1.5em;">' .. table.concat(lista) .. "</ul>"
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: Adatmodul hiányzik." end
    local nyers = dataModul.getAdatok()

    local rows, counter, isVisible = {}, 0, 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:]+)")
            isVisible = (szuro == "" or nemz == szuro)
            if nemz and isVisible then
                counter = counter + 1
                local nemz_link = "[[:Kategória:" .. nemz .. "|'''''" .. nemz .. "''''']]"
                local maradek = sor:match("^1%s+[^%s:]+%s*(.*)$") or ""
                table.insert(rows, "|-\n| " .. counter .. "\n| style=\"white-space:nowrap\" | " .. nemz_link .. "\n| " .. formazSzinonimak(maradek, true))
            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 = mw.text.trim(fajnev)
                table.insert(rows, "|-\n| " .. counter .. "\n| style=\"white-space:nowrap\" | [[" .. tiszta .. "|''" .. tiszta .. "'']]\n| " .. formazSzinonimak(maradek, false))
            end
        end
    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