Ugrás a tartalomhoz

„Modul:CactaceaeTaxonSzinonimák” 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 = {}


-- Segédfüggvény a nevek megtisztítására a számoktól, kettőskereszttől és felesleges szóközöktől
-- Szigorú tisztítás az összehasonlításhoz és megjelenítéshez
local function cleanName(s)
local function cleanName(s)
     if not s then return "" end
     if not s or s == "" then return "" end
     -- Eltávolítja a számokat és a kettőskeresztet, majd a felesleges szóközöket
     -- MÓDOSÍTVA: A @ jelet meghagyjuk, hogy később linkelhessünk,
     local cleaned = s:gsub("%d+", ""):gsub("#", "")
    -- de a számokat, egyéb jeleket, kettőskeresztet és kettőspontokat töröljük.
     local cleaned = mw.ustring.gsub(s, "[%d#≡=%-−%:]+", "")
     return mw.text.trim(cleaned)
     return mw.text.trim(cleaned)
end
-- Függvény a nevek dőlt betűs formázásához és linkeléséhez
local function formatItalic(name)
    if not name or name == "" then return "" end
   
    -- Ellenőrizzük, hogy van-e @ jel (link jelölő)
    local isLinked = mw.ustring.sub(name, 1, 1) == "@"
    local workingName = name
    if isLinked then
        workingName = mw.ustring.sub(name, 2) -- Levágjuk a @ jelet
    end
   
    -- A dőlt betűs formázásból kihagyandó rendszertani kategóriák
    local keywords = {"subgen%.", "subg%.", "sect%.", "subsect%.", "subsp%.", "var%.", "subvar%.", "f%."}
   
    local formatted = workingName
    for _, kw in ipairs(keywords) do
        formatted = mw.ustring.gsub(formatted, " (" .. kw .. ") ", "'' %1 ''")
    end
   
    -- Alap dőlt formázás
    formatted = "''" .. formatted .. "''"
   
    -- Ha volt @ jel, akkor linkeljük az egészet
    if isLinked then
        formatted = "[[" .. workingName .. "|" .. formatted .. "]]"
    end
   
    return formatted
end
end


12. sor: 43. sor:
     local keresettTaxon = frame.args[1] or frame:getParent().args[1]
     local keresettTaxon = frame.args[1] or frame:getParent().args[1]
     if not keresettTaxon or keresettTaxon == "" then return "Nincs megadva taxon!" end
     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), "_", " ")
    -- Az összehasonlításhoz továbbra is @ nélkül kell a név
    local keresettAlacsony = mw.ustring.gsub(cleanName(keresettTaxon), "@", ""):lower()
      
      
     local dataModul = require("Modul:CactaceaeTaxonokData")
     local dataModul = require("Modul:CactaceaeTaxonokData")
     local nyersAdat = dataModul.getAdatok()
     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
     for sor in nyersAdat:gmatch("[^\r\n]+") do
         -- Keressük a keresett kifejezést a sorban
         local tisztaSor = mw.ustring.gsub(sor, "%s*::%s*Type:.-(%d#)", " %1")
        if sor:find(keresettTaxon, 1, true) then
       
           
        -- Az előszűrésnél levágjuk a @ jelet, hogy megtalálja a nevet
            -- 1. Érvényes név kinyerése (a sor elején az első szám után)
        local sorAlacsony = mw.ustring.gsub(tisztaSor:lower(), "@", "")
            local ervenyesNevNyers = sor:match("%d+ ([^#:=≡%-]+)")
       
            local ervenyesNev = cleanName(ervenyesNevNyers)
        if mw.ustring.find(sorAlacsony, keresettAlacsony, 1, true) then
           
             local darabok = mw.text.split(tisztaSor, "#")
            -- 2. Szinonima-blokkok feldolgozása
             for _, darab in ipairs(darabok) do
            -- A sor többi részét daraboljuk fel a főbb elválasztójelek mentén (= vagy -)
                -- Az összehasonlításhoz itt is @ mentesítünk
            -- A ≡ jelet belső elválasztónak használjuk
                local nevAdatban = mw.ustring.gsub(cleanName(darab), "@", "")
            local eredmeny = "== A ''" .. ervenyesNev .. "'' szinonimái ==\n\n"
                 if nevAdatban:lower() == keresettAlacsony then
           
                     talaltSor = tisztaSor
            -- Eltávolítjuk a sor elejéről az érvényes nevet és az első számot
                     break
            local szinonimaResz = sor:gsub("^%d+ [^#]+#", "")
           
            -- Azokat a részeket keressük, amik = vagy - jellel kezdődnek, vagy az elején vannak ≡ jellel
             -- A logikát átalakítjuk: minden "=" vagy "-" új sort kezd.
            -- A "" jelekkel elválasztott neveket egy csoportba gyűjtjük.
              
            local sorok = {}
            -- Először szétvágjuk a heterotipikus (=) és hibás (-) jelek mentén
            -- De a ≡ jeleket megtartjuk a darabokon belül
            local utolsoPozicio = 1
            for pozicio, jel in szinonimaResz:gmatch("()([=≡%-])") do
                 local darab = szinonimaResz:sub(utolsoPozicio, pozicio - 1)
                if utolsoPozicio > 1 then
                     local elozoJel = szinonimaResz:sub(utolsoPozicio - 1, utolsoPozicio - 1)
                     table.insert(sorok, {jel = elozoJel, szoveg = cleanName(darab)})
                 end
                 end
                utolsoPozicio = pozicio + 1
            end
            -- Utolsó darab hozzáadása
            local utolsoDarab = szinonimaResz:sub(utolsoPozicio)
            if utolsoPozicio > 1 then
                local elozoJel = szinonimaResz:sub(utolsoPozicio - 1, utolsoPozicio - 1)
                table.insert(sorok, {jel = elozoJel, szoveg = cleanName(utolsoDarab)})
             end
             end
        end
        if talaltSor then break end
    end
   
    if not talaltSor or talaltSor == "" then
        return "A megadott taxon (''" .. keresettTaxon .. "'') nem található az adatbázisban."
    end
   
    -- 2. FELDOLGOZÁS
    local elsoNevMatch = mw.ustring.match(talaltSor, "^%d+ ([^#≡=%-−]+)")
    local ervenyesNevFinal = cleanName(elsoNevMatch or "Ismeretlen taxon")


            -- 3. Csoportosítás és kiírás
    local eredmeny = ""
            local aktualisListaElem = ""
    -- Összehasonlítás @ nélkül
            for i, elem in ipairs(sorok) do
    local tisztaErvenyes = mw.ustring.gsub(ervenyesNevFinal, "@", ""):lower()
                if elem.jel == "≡" then
   
                    -- Ha ez egy homotipikus szinonima, hozzáfűzzük az aktuális sorhoz
    if tisztaErvenyes == keresettAlacsony then
                    if aktualisListaElem == "" then
        eredmeny = "=== A(z) " .. formatItalic(ervenyesNevFinal) .. " szinonimái ===\n\n"
                        aktualisListaElem = "* ''" .. elem.szoveg .. "''"
    else
                    else
        eredmeny = "=== A(z) " .. formatItalic(ervenyesNevFinal) .. " szinonimái ===\n* (A keresett ''" .. keresettTaxon .. "'' ennek a taxonnak a szinonimája)*\n\n"
                        aktualisListaElem = aktualisListaElem .. " ≡ ''" .. elem.szoveg .. "''"
    end
                     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
                 else
                     -- Ha "=" vagy "-", akkor az eddigit kiírjuk, és újat kezdünk
                     table.insert(lista, {
                    if aktualisListaElem ~= "" then
                        elsoJel = aktJel,
                         eredmeny = eredmeny .. aktualisListaElem .. "\n"
                         nevek = {{jel = "", nev = tisztaNev}}
                     end
                     })
                    aktualisListaElem = "* " .. elem.jel .. " ''" .. elem.szoveg .. "''"
                 end
                 end
             end
             end
            -- Az utolsó kint maradt elemet is hozzáadjuk
            if aktualisListaElem ~= "" then
                eredmeny = eredmeny .. aktualisListaElem .. "\n"
            end
           
            return eredmeny
         end
         end
     end
     end
      
      
     return "A megadott taxon nem található."
     -- 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
end


return p
return p

A lap jelenlegi, 2026. január 11., 15:53-kori változata

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
    -- MÓDOSÍTVA: A @ jelet meghagyjuk, hogy később linkelhessünk, 
    -- de a számokat, egyéb jeleket, kettőskeresztet és kettőspontokat töröljük.
    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 és linkeléséhez
local function formatItalic(name)
    if not name or name == "" then return "" end
    
    -- Ellenőrizzük, hogy van-e @ jel (link jelölő)
    local isLinked = mw.ustring.sub(name, 1, 1) == "@"
    local workingName = name
    if isLinked then
        workingName = mw.ustring.sub(name, 2) -- Levágjuk a @ jelet
    end
    
    -- A dőlt betűs formázásból kihagyandó rendszertani kategóriák
    local keywords = {"subgen%.", "subg%.", "sect%.", "subsect%.", "subsp%.", "var%.", "subvar%.", "f%."}
    
    local formatted = workingName
    for _, kw in ipairs(keywords) do
        formatted = mw.ustring.gsub(formatted, " (" .. kw .. ") ", "'' %1 ''")
    end
    
    -- Alap dőlt formázás
    formatted = "''" .. formatted .. "''"
    
    -- Ha volt @ jel, akkor linkeljük az egészet
    if isLinked then
        formatted = "[[" .. workingName .. "|" .. formatted .. "]]"
    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), "_", " ")
    -- Az összehasonlításhoz továbbra is @ nélkül kell a név
    local keresettAlacsony = mw.ustring.gsub(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
        local tisztaSor = mw.ustring.gsub(sor, "%s*::%s*Type:.-(%d#)", " %1")
        
        -- Az előszűrésnél levágjuk a @ jelet, hogy megtalálja a nevet
        local sorAlacsony = mw.ustring.gsub(tisztaSor:lower(), "@", "")
        
        if mw.ustring.find(sorAlacsony, keresettAlacsony, 1, true) then
            local darabok = mw.text.split(tisztaSor, "#")
            for _, darab in ipairs(darabok) do
                -- Az összehasonlításhoz itt is @ mentesítünk
                local nevAdatban = mw.ustring.gsub(cleanName(darab), "@", "")
                if nevAdatban:lower() == keresettAlacsony then
                    talaltSor = tisztaSor
                    break
                end
            end
        end
        if talaltSor then break end
    end
    
    if not talaltSor or talaltSor == "" then
        return "A megadott taxon (''" .. keresettTaxon .. "'') nem található az adatbázisban."
    end
    
    -- 2. FELDOLGOZÁS
    local elsoNevMatch = mw.ustring.match(talaltSor, "^%d+ ([^#≡=%-−]+)")
    local ervenyesNevFinal = cleanName(elsoNevMatch or "Ismeretlen taxon")

    local eredmeny = ""
    -- Összehasonlítás @ nélkül
    local tisztaErvenyes = mw.ustring.gsub(ervenyesNevFinal, "@", ""):lower()
    
    if tisztaErvenyes == keresettAlacsony then
        eredmeny = "=== A(z) " .. formatItalic(ervenyesNevFinal) .. " szinonimái ===\n\n"
    else
        eredmeny = "=== A(z) " .. 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