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


-- Tisztító függvény: @, számok, kettőskereszt és felesleges szóközök eltávolítása
 
-- Javított tisztítás: a szavak közötti kötőjelet meghagyja, de a számokat és technikai jeleket törli
local function cleanName(s)
local function cleanName(s)
     if not s or s == "" then return "" end
     if not s or s == "" then return "" end
     -- Eltávolítunk minden nem névbe való karaktert (számok, jelek, kettőskereszt, @)
     -- A számokat, kettőskeresztet, egyenlőségjelet és kettőspontot töröljük
     local cleaned = mw.ustring.gsub(s, "[%d#@≡=%-−]+", "")
     local cleaned = mw.ustring.gsub(s, "[%d#≡=:]+", "")
     -- A "Type:" kulcsszót is vegyük ki az összehasonlításnál, ha benne maradt volna
   
     cleaned = mw.ustring.gsub(cleaned, "Type:", "")
     -- A kötőjelet/mínuszjelet CSAK akkor töröljük, ha a név szélén van (határolójel)
    cleaned = mw.ustring.gsub(cleaned, "^[%-−%s]+", "")
     cleaned = mw.ustring.gsub(cleaned, "[%-−%s]+$", "")
   
     return mw.text.trim(cleaned)
     return mw.text.trim(cleaned)
end
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
   
    local isLinked = mw.ustring.sub(name, 1, 1) == "@"
    local workingName = name
    if isLinked then
        workingName = mw.ustring.sub(name, 2)
    end
   
    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
   
    formatted = "''" .. formatted .. "''"
   
    if isLinked then
        -- A belső linket egy class-szal ellátott span-be tesszük
        formatted = '<span class="syn">[[' .. workingName .. '|' .. formatted .. ']]</span>'
    end
   
    return formatted
end


function p.keres(frame)
function p.keres(frame)
15. sor: 51. sor:
     if not keresettTaxon or keresettTaxon == "" then return "Nincs megadva taxon!" end
     if not keresettTaxon or keresettTaxon == "" then return "Nincs megadva taxon!" end
      
      
     keresettTaxon = mw.text.trim(keresettTaxon)
    -- Alulvonás kezelése a PAGENAME miatt
     local keresettAlap = cleanName(keresettTaxon)
     keresettTaxon = mw.ustring.gsub(mw.text.trim(keresettTaxon), "_", " ")
     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 = "&#8801;" -- ≡
     local homoHTML = "&#8801;"  
     local hibaHTML = "&#8722;" -- −
     local hibaHTML = "&#8722;"  
      
      
     local talaltSor = nil
     local talaltSor = nil


     -- 1. KERESÉS: Végigmegyünk a sorokon
     -- 1. KERESÉS ÉS ELŐTISZTÍTÁS
     for sor in nyersAdat:gmatch("[^\r\n]+") do
     for sor in nyersAdat:gmatch("[^\r\n]+") do
         -- A sort darabokra szedjük a # mentén (minden egység egy taxon + szint)
         -- Típust információk eltávolítása, ha van
         local darabok = mw.text.split(sor, "#")
         local tisztaSor = mw.ustring.gsub(sor, "%s*::%s*Type:.-(%d#)", " %1")
         local illeszkedik = false
         local sorAlacsony = mw.ustring.gsub(tisztaSor:lower(), "@", "")
          
          
         for _, darab in ipairs(darabok) do
         -- Gyors előszűrés
            local nevAdatban = cleanName(darab)
        if mw.ustring.find(sorAlacsony, keresettAlacsony, 1, true) then
           
            local darabok = mw.text.split(tisztaSor, "#")
            -- SZIGORÚ TELJES EGYEZÉS ELLENŐRZÉSE
            for _, darab in ipairs(darabok) do
            if nevAdatban:lower() == keresettAlap:lower() then
                local nevAdatban = mw.ustring.gsub(cleanName(darab), "@", "")
                illeszkedik = true
                if nevAdatban:lower() == keresettAlacsony then
                 break
                    talaltSor = tisztaSor
                    break
                 end
             end
             end
         end
         end
       
         if talaltSor then break end
         if illeszkedik then
            talaltSor = sor
            break
        end
     end
     end
      
      
     if not talaltSor then
     if not talaltSor or talaltSor == "" then
         return "A megadott taxon (''" .. keresettTaxon .. "'') nem található az adatbázisban."
         return "A megadott taxon (''" .. keresettTaxon .. "'') nem található az adatbázisban."
     end
     end
      
      
     -- 2. FELDOLGOZÁS: Az érvényes név kinyerése a sor elejéről
     -- 2. FELDOLGOZÁS
     local ervenyesNevFinal = cleanName(mw.ustring.match(talaltSor, "%d+ ([^#:=%-−]+)") or "")
    -- Az érvényes nevet az első '#' jelig keressük, így a kötőjel nem töri meg
    local eredmeny = "== A ''" .. ervenyesNevFinal .. "'' szinonimái ==\n\n"
     local nyersElsoNev = mw.ustring.match(talaltSor, "^%d+ (.-)#")
                        or mw.ustring.match(talaltSor, "^%d+ (.-)[=%-−]")
                        or mw.ustring.match(talaltSor, "^%d+ (.+)")
      
      
     -- Típus-információ (Type:) kinyerése
     local ervenyesNevFinal = cleanName(nyersElsoNev or "Ismeretlen taxon")
     local tipusInfo = mw.ustring.match(talaltSor, "Type: ([^1-4#]+)")
 
     if tipusInfo then
     local eredmeny = ""
         eredmeny = eredmeny .. "'''Típus:''' ''" .. mw.text.trim(tipusInfo) .. "''\n\n"
    local tisztaErvenyes = mw.ustring.gsub(ervenyesNevFinal, "@", ""):lower()
   
    -- Fejléc összeállítása
    if tisztaErvenyes == keresettAlacsony then
        eredmeny = "=== A(z) " .. formatItalic(ervenyesNevFinal) .. " szinonimái ===\n\n"
     else
         eredmeny = "=== A(z) " .. formatItalic(ervenyesNevFinal) .. " szinonimái ===\n* (A(z) ''" .. keresettTaxon .. "'' a(z) ''" .. ervenyesNevFinal .. "'' szinonimája)*\n\n"
     end
     end
 
   
     local lista = {}
     local lista = {}
     local szinonimaDarabok = mw.text.split(talaltSor, "#")
     local szinonimaDarabok = mw.text.split(talaltSor, "#")
      
      
     for _, darab in ipairs(szinonimaDarabok) do
     for _, darab in ipairs(szinonimaDarabok) do
        -- Jel és szint keresése a darabban
         local jel = mw.ustring.match(darab, "([≡=%-−])")
         local jel = mw.ustring.match(darab, "([≡=%-−])")
         local szint = mw.ustring.match(darab, "(%d+)$")
         local szint = mw.ustring.match(darab, "(%d+)$")
73. sor: 115. sor:
             local tisztaNev = cleanName(darab)
             local tisztaNev = cleanName(darab)
             local szam = tonumber(szint)
             local szam = tonumber(szint)
           
             local aktJel = (jel == "≡") and homoHTML or ((jel == "-" or jel == "−") and hibaHTML or jel)
             local aktJel = jel
            if jel == "≡" then aktJel = homoHTML end
            if jel == "-" or jel == "−" then aktJel = hibaHTML end
              
              
             if tisztaNev ~= "" then
             if tisztaNev ~= "" then
                 -- Szint-alapú csoportosítás (3-as: új sor, 4-es: soron belül)
                 -- Ha a szint 4, akkor az előző szinonima mellé fűzzük (kombináció)
                 if szam == 4 and #lista > 0 then
                 if szam == 4 and #lista > 0 then
                     table.insert(lista[#lista].nevek, {jel = aktJel, nev = tisztaNev})
                     table.insert(lista[#lista].nevek, {jel = aktJel, nev = tisztaNev})
                 else
                 else
                    -- Új szinonima sor indítása
                     table.insert(lista, {
                     table.insert(lista, {
                         elsoJel = aktJel,
                         elsoJel = aktJel,
92. sor: 132. sor:
     end
     end
      
      
     -- 3. MEGJELENÍTÉS összeállítása
     -- 3. MEGJELENÍTÉS ÖSSZEÁLLÍTÁSA
     if #lista == 0 and not tipusInfo then return eredmeny .. "* Nincsenek szinonimák." end
     if #lista == 0 then return eredmeny .. "* Nincsenek szinonimák." end
      
      
     for _, csoport in ipairs(lista) do
     for _, csoport in ipairs(lista) do
         local sorElemei = {}
         local sorElemei = {}
         for i, adat in ipairs(csoport.nevek) do
         for i, adat in ipairs(csoport.nevek) do
             if i == 1 then
            local elem = formatItalic(adat.nev)
                table.insert(sorElemei, "''" .. adat.nev .. "''")
             if i > 1 then elem = adat.jel .. " " .. elem end
             else
             table.insert(sorElemei, elem)
                table.insert(sorElemei, adat.jel .. " ''" .. adat.nev .. "''")
            end
         end
         end
        -- Vesszővel választjuk el az egy sorban lévőket
         eredmeny = eredmeny .. "* " .. csoport.elsoJel .. " " .. table.concat(sorElemei, ", ") .. "\n"
         eredmeny = eredmeny .. "* " .. csoport.elsoJel .. " " .. table.concat(sorElemei, ", ") .. "\n"
     end
     end

A lap jelenlegi, 2026. január 26., 00:14-kori változata

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

-- require("Modul:CactaceaeTaxonokData")
-- Sablon:Kaktusz_szinonimák

local p = {}


-- Javított tisztítás: a szavak közötti kötőjelet meghagyja, de a számokat és technikai jeleket törli
local function cleanName(s)
    if not s or s == "" then return "" end
    -- A számokat, kettőskeresztet, egyenlőségjelet és kettőspontot töröljük
    local cleaned = mw.ustring.gsub(s, "[%d#≡=:]+", "")
    
    -- A kötőjelet/mínuszjelet CSAK akkor töröljük, ha a név szélén van (határolójel)
    cleaned = mw.ustring.gsub(cleaned, "^[%-−%s]+", "")
    cleaned = mw.ustring.gsub(cleaned, "[%-−%s]+$", "")
    
    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
    
    local isLinked = mw.ustring.sub(name, 1, 1) == "@"
    local workingName = name
    if isLinked then
        workingName = mw.ustring.sub(name, 2)
    end
    
    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
    
    formatted = "''" .. formatted .. "''"
    
    if isLinked then
        -- A belső linket egy class-szal ellátott span-be tesszük
        formatted = '<span class="syn">[[' .. workingName .. '|' .. formatted .. ']]</span>'
    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), "_", " ")
    local keresettAlacsony = mw.ustring.gsub(cleanName(keresettTaxon), "@", ""):lower()
    
    local dataModul = require("Modul:CactaceaeTaxonokData")
    local nyersAdat = dataModul.getAdatok()
    
    local homoHTML = "&#8801;" 
    local hibaHTML = "&#8722;" 
    
    local talaltSor = nil

    -- 1. KERESÉS ÉS ELŐTISZTÍTÁS
    for sor in nyersAdat:gmatch("[^\r\n]+") do
        -- Típust információk eltávolítása, ha van
        local tisztaSor = mw.ustring.gsub(sor, "%s*::%s*Type:.-(%d#)", " %1")
        local sorAlacsony = mw.ustring.gsub(tisztaSor:lower(), "@", "")
        
        -- Gyors előszűrés
        if mw.ustring.find(sorAlacsony, keresettAlacsony, 1, true) then
            local darabok = mw.text.split(tisztaSor, "#")
            for _, darab in ipairs(darabok) do
                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
    -- Az érvényes nevet az első '#' jelig keressük, így a kötőjel nem töri meg
    local nyersElsoNev = mw.ustring.match(talaltSor, "^%d+ (.-)#") 
                         or mw.ustring.match(talaltSor, "^%d+ (.-)[≡=%-−]")
                         or mw.ustring.match(talaltSor, "^%d+ (.+)")
    
    local ervenyesNevFinal = cleanName(nyersElsoNev or "Ismeretlen taxon")

    local eredmeny = ""
    local tisztaErvenyes = mw.ustring.gsub(ervenyesNevFinal, "@", ""):lower()
    
    -- Fejléc összeállítása
    if tisztaErvenyes == keresettAlacsony then
        eredmeny = "=== A(z) " .. formatItalic(ervenyesNevFinal) .. " szinonimái ===\n\n"
    else
        eredmeny = "=== A(z) " .. formatItalic(ervenyesNevFinal) .. " szinonimái ===\n* (A(z) ''" .. keresettTaxon .. "'' a(z) ''" .. ervenyesNevFinal .. "''  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
                -- Ha a szint 4, akkor az előző szinonima mellé fűzzük (kombináció)
                if szam == 4 and #lista > 0 then
                    table.insert(lista[#lista].nevek, {jel = aktJel, nev = tisztaNev})
                else
                    -- Új szinonima sor indítása
                    table.insert(lista, {
                        elsoJel = aktJel,
                        nevek = {{jel = "", nev = tisztaNev}}
                    })
                end
            end
        end
    end
    
    -- 3. MEGJELENÍTÉS ÖSSZEÁLLÍTÁSA
    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