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ó
1. sor: 1. sor:
local p = {}
local p = {}


-- Segédfüggvény a szimbólumok és HTML lista kezeléséhez
-- Segédfüggvény a szimbólumok és HTML lista kezeléséhez (Unicode-biztos)
local function formazSzinonimak(szoveg)
local function formazSzinonimak(szoveg)
     if not szoveg or szoveg == "" then return "" end
     if not szoveg or szoveg == "" then return "" end


     -- 1. Felesleges karakterek törlése (đ, ÷, ¤)
     -- 1. Felesleges karakterek törlése (Unicode-biztosan)
     local tiszta = szoveg:gsub("[đ÷]", ""):gsub("¤+", "")
     local tiszta = mw.ustring.gsub(szoveg, "[đ÷]", "")
    tiszta = mw.ustring.gsub(tiszta, "¤+", "")
      
      
     -- 2. Kacsacsőrös jelek egyszerűsítése (ezek NEM indítanak új sort)
     -- 2. Kacsacsőrös jelek egyszerűsítése (maradnak az adott sorban)
     tiszta = tiszta:gsub(">−", "−")
     tiszta = mw.ustring.gsub(tiszta, ">−", "−")
     tiszta = tiszta:gsub(">≡", "≡")
     tiszta = mw.ustring.gsub(tiszta, ">≡", "≡")
     tiszta = tiszta:gsub(">=", "=")
     tiszta = mw.ustring.gsub(tiszta, ">=", "=")


     -- 3. Új listapont jelölők átalakítása (ideiglenes elválasztó: | )
     -- 3. Új listapont jelölők átalakítása (ideiglenes elválasztó: | )
     -- Csak a duplázott jeleknél darabolunk!
     -- Csak a duplázott jeleknél darabolunk
     tiszta = tiszta:gsub("≡≡", "|≡")
     tiszta = mw.ustring.gsub(tiszta, "≡≡", "|≡")
     tiszta = tiszta:gsub("==", "|=")
     tiszta = mw.ustring.gsub(tiszta, "==", "|=")
     tiszta = tiszta:gsub("−−", "|−")
     tiszta = mw.ustring.gsub(tiszta, "−−", "|−")
     tiszta = tiszta:gsub("%%-%%-", "|−") -- sima dupla kötőjel esetére
    -- A sima kötőjeleket külön kezeljük, mert a Lua mintában a - speciális karakter
     tiszta = mw.ustring.gsub(tiszta, "%-%-", "|−")


     -- 4. HTML lista építése
     -- 4. HTML lista építése
     local lista_elemek = {}
     local lista_elemek = {}
      
      
     -- Darabolás a '|' mentén
     -- Darabolás az mw.text.gsplit-tel (ez biztonságosabb)
     for resz in mw.text.gsplit(tiszta, "|", true) do
     for resz in mw.text.gsplit(tiszta, "|", true) do
         local tiszta_resz = mw.text.trim(resz)
         local tiszta_resz = mw.text.trim(resz)
29. sor: 31. sor:
             -- Botanikai nevek dőltetése a részen belül
             -- Botanikai nevek dőltetése a részen belül
             local szavak = {}
             local szavak = {}
             for szo in tiszta_resz:gmatch("%S+") do
             for szo in mw.ustring.gmatch(tiszta_resz, "%S+") do
                 -- Szimbólumok és rövidítések maradnak állók
                 -- Ha a szó szimbólumot, vesszőt tartalmaz vagy technikai rövidítés, marad álló
                 if szo:match("[≡=−]") or szo:find(",") or szo == "var." or szo == "subsp." or szo == "f." or szo == "Type:" then
                 if mw.ustring.find(szo, "[≡=−,]") or szo == "var." or szo == "subsp." or szo == "f." or szo == "Type:" then
                     table.insert(szavak, szo)
                     table.insert(szavak, szo)
                 else
                 else
44. sor: 46. sor:
      
      
     if #lista_elemek > 0 then
     if #lista_elemek > 0 then
        -- Ha csak egyetlen elem van (nincs benne dupla jel), akkor is listába tesszük az egységesség kedvéért
         return '<ul style="margin-left: 1.1em; list-style-type: disc; padding: 0; margin-top: 0; margin-bottom: 0;">' ..  
         return '<ul style="margin-left: 1.1em; list-style-type: disc; padding: 0; margin-top: 0; margin-bottom: 0;">' ..  
               table.concat(lista_elemek) ..  
               table.concat(lista_elemek) ..  
63. sor: 64. sor:


     local sorszam = 0
     local sorszam = 0
     for sor in nyers_adat:gmatch("[^\r\n]+") do
    -- Itt is ustring.gmatch-ot használunk a biztonság kedvéért
     for sor in mw.ustring.gmatch(nyers_adat, "[^\r\n]+") do
         local taxon = ""
         local taxon = ""
         local szinonimak = ""
         local szinonimak = ""


         if sor:match("^ß") then
         if mw.ustring.match(sor, "^ß") then
             local nemzettseg, tipus = sor:match("^ß%s*([^:]+)::%s*(.+)")
             local nemzettseg, tipus = mw.ustring.match(sor, "^ß%s*([^:]+)::%s*(.+)")
             if nemzettseg then
             if nemzettseg then
                 taxon = "'''" .. mw.text.trim(nemzettseg) .. "'''"
                 taxon = "'''" .. mw.text.trim(nemzettseg):gsub("¤+", "") .. "'''"
                 szinonimak = tipus
                 szinonimak = tipus
             end
             end
         elseif sor:match("^Ł") then
         elseif mw.ustring.match(sor, "^Ł") then
             local tiszta = sor:gsub("^Ł%s*", "")
             local tiszta_sor = mw.ustring.gsub(sor, "^Ł%s*", "")
             local t, sz = tiszta:match("([^¤]+)¤¤¤(.*)")
             local t, sz = mw.ustring.match(tiszta_sor, "([^¤]+)¤¤¤(.*)")
             if t then
             if t then
                 taxon = "''" .. mw.text.trim(t) .. "''"
                 taxon = "''" .. mw.text.trim(t) .. "''"

A lap 2026. január 7., 07:49-kori változata

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

local p = {}

-- Segédfüggvény a szimbólumok és HTML lista kezeléséhez (Unicode-biztos)
local function formazSzinonimak(szoveg)
    if not szoveg or szoveg == "" then return "" end

    -- 1. Felesleges karakterek törlése (Unicode-biztosan)
    local tiszta = mw.ustring.gsub(szoveg, "[đ÷]", "")
    tiszta = mw.ustring.gsub(tiszta, "¤+", "")
    
    -- 2. Kacsacsőrös jelek egyszerűsítése (maradnak az adott sorban)
    tiszta = mw.ustring.gsub(tiszta, ">−", "−")
    tiszta = mw.ustring.gsub(tiszta, ">≡", "≡")
    tiszta = mw.ustring.gsub(tiszta, ">=", "=")

    -- 3. Új listapont jelölők átalakítása (ideiglenes elválasztó: | )
    -- Csak a duplázott jeleknél darabolunk
    tiszta = mw.ustring.gsub(tiszta, "≡≡", "|≡")
    tiszta = mw.ustring.gsub(tiszta, "==", "|=")
    tiszta = mw.ustring.gsub(tiszta, "−−", "|−")
    -- A sima kötőjeleket külön kezeljük, mert a Lua mintában a - speciális karakter
    tiszta = mw.ustring.gsub(tiszta, "%-%-", "|−")

    -- 4. HTML lista építése
    local lista_elemek = {}
    
    -- Darabolás az mw.text.gsplit-tel (ez biztonságosabb)
    for resz in mw.text.gsplit(tiszta, "|", true) do
        local tiszta_resz = mw.text.trim(resz)
        if tiszta_resz ~= "" then
            -- Botanikai nevek dőltetése a részen belül
            local szavak = {}
            for szo in mw.ustring.gmatch(tiszta_resz, "%S+") do
                -- Ha a szó szimbólumot, vesszőt tartalmaz vagy technikai rövidítés, marad álló
                if mw.ustring.find(szo, "[≡=−,]") or szo == "var." or szo == "subsp." or szo == "f." or szo == "Type:" then
                    table.insert(szavak, szo)
                else
                    table.insert(szavak, "''" .. szo .. "''")
                end
            end
            
            local kesz_elem = table.concat(szavak, " ")
            table.insert(lista_elemek, "<li>" .. kesz_elem .. "</li>")
        end
    end
    
    if #lista_elemek > 0 then
        return '<ul style="margin-left: 1.1em; list-style-type: disc; padding: 0; margin-top: 0; margin-bottom: 0;">' .. 
               table.concat(lista_elemek) .. 
               "</ul>"
    else
        return ""
    end
end

function p.tablazat(frame)
    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 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"

    local sorszam = 0
    -- Itt is ustring.gmatch-ot használunk a biztonság kedvéért
    for sor in mw.ustring.gmatch(nyers_adat, "[^\r\n]+") do
        local taxon = ""
        local szinonimak = ""

        if mw.ustring.match(sor, "^ß") then
            local nemzettseg, tipus = mw.ustring.match(sor, "^ß%s*([^:]+)::%s*(.+)")
            if nemzettseg then
                taxon = "'''" .. mw.text.trim(nemzettseg):gsub("¤+", "") .. "'''"
                szinonimak = tipus
            end
        elseif mw.ustring.match(sor, "^Ł") then
            local tiszta_sor = mw.ustring.gsub(sor, "^Ł%s*", "")
            local t, sz = mw.ustring.match(tiszta_sor, "([^¤]+)¤¤¤(.*)")
            if t then
                taxon = "''" .. mw.text.trim(t) .. "''"
                szinonimak = sz
            end
        end

        if taxon ~= "" then
            sorszam = sorszam + 1
            res = res .. "|-\n"
            res = res .. "| " .. sorszam .. "\n"
            res = res .. '| style="white-space: nowrap;" | ' .. taxon .. "\n"
            res = res .. "| " .. formazSzinonimak(szinonimak) .. "\n"
        end
    end

    res = res .. "|}"
    
    return frame:preprocess(res)
end

return p