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ó
(Egy közbenső módosítás ugyanattól a felhasználótól nincs mutatva)
1. sor: 1. sor:
local p = {}
local p = {}


-- Szupergyors formázó: minimálisra csökkentett műveletszám
-- Szupergyors tisztító: csak sima string műveleteket használ
local function formazSzinonimak(szoveg)
local function gyorsTisztitas(szoveg)
     if not szoveg or szoveg == "" then return "" end
     if not szoveg or szoveg == "" then return "" end
 
    -- Eltávolítjuk a speciális bájtokat, amik a đ, ÷, ¤ jeleket alkotják
     -- Unicode-helyett sima string csere ahol lehet
     -- đ = \196\145, ÷ = \195\183, ¤ = \194\164
     local tiszta = szoveg:gsub("¤", "")
     local tiszta = szoveg:gsub("\196\145", ""):gsub("\195\183", ""):gsub("\194\164", "")
    tiszta = tiszta:gsub(">−", ""):gsub(">≡", ""):gsub(">=", "=")
    tiszta = tiszta:gsub(">%-", ""):gsub(">≡", ""):gsub(">=", "=")
   
     return tiszta
    -- Darabolás elválasztók mentén
    local lista = {}
    -- Sima string.gmatch-et használunk a gyorsaságért
    for r in tiszta:gmatch("[^|=−]+") do
        local tr = mw.text.trim(r)
        if tr ~= "" then
            -- Csak a legszükségesebb dőltetés
            table.insert(lista, "<li>''" .. tr .. "''</li>")
        end
    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


39. sor: 27. sor:
     local isVisible = false
     local isVisible = false
      
      
     -- Sima string iteráció (NAGYSÁGRENDDEL GYORSABB, mint az ustring)
     -- Soronkénti feldolgozás bájtszinten (ez a leggyorsabb)
    -- A ß és Ł karaktereket bájtonként kezeljük (ß = \195\159, Ł = \197\129)
     for sor in nyers:gmatch("[^\r\n]+") do
     for sor in nyers:gmatch("[^\r\n]+") do
        local b1 = sor:byte(1)
          
          
         -- Nemzetség sor keresése (ß karakter bájtkódja: \195\159)
         -- ß karakter (195 159)
         if sor:byte(1) == 195 and sor:byte(2) == 159 then
         if b1 == 195 and sor:byte(2) == 159 then
            -- Csak akkor nézzük meg alaposabban, ha a szűrő benne van a sorban
             if sor:find(szuro, 1, true) then
             if sor:find(szuro, 1, true) then
                 local nemz = sor:match("ß%s*([^:]+)")
                 local nemz = sor:match("ß%s*([^:]+)")
                 if nemz and mw.text.trim(nemz):gsub("¤", "") == szuro then
                 if nemz and mw.text.trim(nemz):gsub("\194\164", "") == szuro then
                     isVisible = true
                     isVisible = true
                     counter = counter + 1
                     counter = counter + 1
                     local tip = sor:match("::%s*(.+)") or ""
                     local tip = sor:match("::%s*(.+)") or ""
                     table.insert(rows, "|-\n| " .. counter .. "\n| '''[[:Kategória:" .. szuro .. "|" .. szuro .. "]]'''\n| " .. formazSzinonimak(tip))
                     table.insert(rows, {counter, "'''[[:Kategória:"..szuro.."|"..szuro.."]]'''", tip})
                 else
                 else isVisible = false end
                    isVisible = false
             else isVisible = false end
                end
             else
                isVisible = false
            end
              
              
         -- Faj sor keresése (Ł karakter bájtkódja: \197\129)
         -- Ł karakter (197 129)
         elseif isVisible and sor:byte(1) == 197 and sor:byte(2) == 129 then
         elseif isVisible and b1 == 197 and sor:byte(2) == 129 then
             local t, sz = sor:match("Ł%s*([^¤]+)¤¤¤(.*)")
             local t, sz = sor:match("Ł%s*([^¤]+)¤¤¤(.*)")
             if t then
             if t then
                 counter = counter + 1
                 counter = counter + 1
                 table.insert(rows, "|-\n| " .. counter .. "\n| ''[[" .. mw.text.trim(t) .. "]]''\n| " .. formazSzinonimak(sz))
                 table.insert(rows, {counter, "''[["..mw.text.trim(t).."]]''", sz})
             end
             end
         end
         end
       
         if counter >= 1000 then break end
        -- Ha elértük az 500 sort, álljunk meg (Opuntia-nál ez is sok lehet)
         if counter >= 500 then break end
     end
     end


     if #rows == 0 then return "Nincs találat: " .. szuro end
     if #rows == 0 then return "Nincs találat: " .. szuro end
    -- TÁBLÁZAT ÖSSZEÁLLÍTÁSA (Csak itt formázunk, hogy spóroljunk a CPU-val)
    local finalRows = {}
    for i, data in ipairs(rows) do
        local szinonimak = ""
        if data[3] ~= "" then
            local t = gyorsTisztitas(data[3])
            local lista = {}
            -- Egyszerű darabolás
            for r in t:gmatch("[^|≡=−]+") do
                local tr = mw.text.trim(r)
                if tr ~= "" and tr ~= "''" then
                    table.insert(lista, "<li>''" .. tr .. "''</li>")
                end
            end
            if #lista > 0 then
                szinonimak = '<ul style="margin-left:1.1em; list-style-type:disc; padding:0; margin:0;">' .. table.concat(lista) .. "</ul>"
            end
        end
        table.insert(finalRows, "|-\n| " .. data[1] .. "\n| " .. data[2] .. "\n| " .. szinonimak)
    end


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


return p
return p

A lap 2026. január 7., 10:36-kori változata

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

local p = {}

-- Szupergyors tisztító: csak sima string műveleteket használ
local function gyorsTisztitas(szoveg)
    if not szoveg or szoveg == "" then return "" end
    -- Eltávolítjuk a speciális bájtokat, amik a đ, ÷, ¤ jeleket alkotják
    -- đ = \196\145, ÷ = \195\183, ¤ = \194\164
    local tiszta = szoveg:gsub("\196\145", ""):gsub("\195\183", ""):gsub("\194\164", "")
    tiszta = tiszta:gsub(">%-", "−"):gsub(">≡", "≡"):gsub(">=", "=")
    return tiszta
end

function p.tablazat(frame)
    local args = frame:getParent().args
    local szuro = args[1] and mw.text.trim(args[1]) or ""
    
    if szuro == "" then
        return "<div style='color:red;'>Hiba: Adj meg egy nemzetséget!</div>"
    end

    local status, dataModul = pcall(require, 'Modul:CactaceaeTaxonokData')
    if not status then return "Hiba: Adatmodul hiányzik." end
    local nyers = dataModul.getAdatok()

    local rows = {}
    local counter = 0
    local isVisible = false
    
    -- Soronkénti feldolgozás bájtszinten (ez a leggyorsabb)
    for sor in nyers:gmatch("[^\r\n]+") do
        local b1 = sor:byte(1)
        
        -- ß karakter (195 159)
        if b1 == 195 and sor:byte(2) == 159 then
            if sor:find(szuro, 1, true) then
                local nemz = sor:match("ß%s*([^:]+)")
                if nemz and mw.text.trim(nemz):gsub("\194\164", "") == szuro then
                    isVisible = true
                    counter = counter + 1
                    local tip = sor:match("::%s*(.+)") or ""
                    table.insert(rows, {counter, "'''[[:Kategória:"..szuro.."|"..szuro.."]]'''", tip})
                else isVisible = false end
            else isVisible = false end
            
        -- Ł karakter (197 129)
        elseif isVisible and b1 == 197 and sor:byte(2) == 129 then
            local t, sz = sor:match("Ł%s*([^¤]+)¤¤¤(.*)")
            if t then
                counter = counter + 1
                table.insert(rows, {counter, "''[["..mw.text.trim(t).."]]''", sz})
            end
        end
        if counter >= 1000 then break end
    end

    if #rows == 0 then return "Nincs találat: " .. szuro end

    -- TÁBLÁZAT ÖSSZEÁLLÍTÁSA (Csak itt formázunk, hogy spóroljunk a CPU-val)
    local finalRows = {}
    for i, data in ipairs(rows) do
        local szinonimak = ""
        if data[3] ~= "" then
            local t = gyorsTisztitas(data[3])
            local lista = {}
            -- Egyszerű darabolás
            for r in t:gmatch("[^|≡=−]+") do
                local tr = mw.text.trim(r)
                if tr ~= "" and tr ~= "''" then
                    table.insert(lista, "<li>''" .. tr .. "''</li>")
                end
            end
            if #lista > 0 then
                szinonimak = '<ul style="margin-left:1.1em; list-style-type:disc; padding:0; margin:0;">' .. table.concat(lista) .. "</ul>"
            end
        end
        table.insert(finalRows, "|-\n| " .. data[1] .. "\n| " .. data[2] .. "\n| " .. szinonimak)
    end

    local head = '{| class="wikitable sortable datatable-hook stripe hover compact" style="width:100%; font-size:90%;"\n! # !! Taxonnév !! Típusfaj, szinonima\n'
    return frame:preprocess(head .. table.concat(finalRows, "\n") .. "\n|}")
end

return p