Modul:CactaceaeTaxonSzinonimák
Megjelenés
A modult a Modul:CactaceaeTaxonSzinonimák/doc lapon tudod dokumentálni
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
-- Botanikai rövidítések, amiket nem szabad dőlttel írni
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
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), "_", " ")
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
-- 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 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
-- 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