Aller au contenu

« Module:Episode/index » : différence entre les versions

De Stargate Wiki Sémantique
Contenu supprimé Contenu ajouté
Page créée avec « local p = {} local sources = { "Module:Episode/SG1Season1", "Module:Episode/SG1Season2", "Module:Episode/SG1Season3", "Module:Episode/SG1Season4", "Module:Episode/SG1Season5", "Module:Episode/SG1Season6", "Module:Episode/SG1Season7", "Module:Episode/SG1Season8", "Module:Episode/SG1Season9", "Module:Episode/SG1Season10", "Module:Episode/SGASeason1", "Module:Episode/SGASeason2", "Module:Episode/SGASeason3", "Module:Episode/SGASeason4", "Module:Episo... »
 
Aucun résumé des modifications
Balise : Révocation manuelle
 
(15 versions intermédiaires par le même utilisateur non affichées)
Ligne 1 : Ligne 1 :
local data = mw.loadData("Module:Episode/index/data")

local p = {}
local p = {}

local sources = {
"Module:Episode/SG1Season1",
"Module:Episode/SG1Season2",
"Module:Episode/SG1Season3",
"Module:Episode/SG1Season4",
"Module:Episode/SG1Season5",
"Module:Episode/SG1Season6",
"Module:Episode/SG1Season7",
"Module:Episode/SG1Season8",
"Module:Episode/SG1Season9",
"Module:Episode/SG1Season10",
"Module:Episode/SGASeason1",
"Module:Episode/SGASeason2",
"Module:Episode/SGASeason3",
"Module:Episode/SGASeason4",
"Module:Episode/SGASeason5",
"Module:Episode/SGUSeason1",
"Module:Episode/SGUSeason2",
"Module:Episode/SGISeason1",
"Module:Episode/SGOSeason1",
"Module:Episode/SGUMovies",
}

p.index = {}


local function normalize(s)
local function normalize(s)
-- Default to empty string if nil
s = s or ""
s = s or ""

-- Trim leading and trailing whitespace
s = mw.text.trim(s)
s = mw.text.trim(s)


-- Normalize Unicode to NFD (decomposed form)
-- Décomposition Unicode
-- This allows us to remove accents by stripping combining marks
s = mw.ustring.toNFD(s)
s = mw.ustring.toNFD(s)


-- Suppression des diacritiques (accents)
-- Remove combining diacritical marks (U+0300 to U+036F)
local combining_start = mw.ustring.char(0x0300)
s = mw.ustring.gsub(s, "%pM", "")
local combining_end = mw.ustring.char(0x036F)
s = mw.ustring.gsub(s, "[" .. combining_start .. "-" .. combining_end .. "]", "")


-- Normalize apostrophes to a single straight apostrophe
-- Normalisation apostrophes
s = mw.ustring.gsub(s, "[’‘´`]", "'")
s = mw.ustring.gsub(s, "[’‘´`]", "'")


-- Guillemets
-- Normalize curly quotes to straight quotes
s = mw.ustring.gsub(s, "[“”]", "\"")
s = mw.ustring.gsub(s, "[“”]", "\"")


-- Tirets
-- Normalize all dash types to a simple hyphen
s = mw.ustring.gsub(s, "[–—−]", "-")
s = mw.ustring.gsub(s, "[–—−]", "-")


-- Espaces multiples
-- Collapse multiple spaces into a single space
s = mw.ustring.gsub(s, "%s+", " ")
s = mw.ustring.gsub(s, "%s+", " ")


return mw.ustring.lower(mw.text.trim(s))
-- Convert to lowercase
s = mw.ustring.lower(s)

-- Final trim
s = mw.text.trim(s)

return s
end
end

-- Building the multi-key index
for _, modname in ipairs(sources) do
local ok, mod = pcall(require, modname)
if ok and mod.episodes then
for _, ep in ipairs(mod.episodes) do
for _, key in ipairs(ep.alias or {}) do
local nkey = normalize(key)
if p.index[nkey] then
mw.log(string.format(
"[EpisodeIndex] Collision d'alias détectée : '%s' → %s et %s",
nkey,
p.index[nkey].id or "(sans id)",
ep.id or "(sans id)"
))
else
p.index[nkey] = ep
end
end
end
end
end


-- Access function


function p.get(key)
function p.get(key)
local ep = p.index[normalize(key)]
return data[normalize(key)]
if not ep then return nil end
return {
id = ep.id,
namespace = ep.namespace or "",
page_title = ep.page_title,
title_fr = ep.title_fr,
title_qc = ep.title_qc,
title_vo = ep.title_vo,
property = ep.property,
season = ep.season or "",
episode = ep.episode or "",
}
end
end



Dernière version du 31 mai 2026 à 20:48

Documentation icon Documentation module[créer]
local data = mw.loadData("Module:Episode/index/data")

local p = {}

local function normalize(s)
    s = s or ""
    s = mw.text.trim(s)

    -- Décomposition Unicode
    s = mw.ustring.toNFD(s)

    -- Suppression des diacritiques (accents)
    s = mw.ustring.gsub(s, "%pM", "")

    -- Normalisation apostrophes
    s = mw.ustring.gsub(s, "[’‘´`]", "'")

    -- Guillemets
    s = mw.ustring.gsub(s, "[“”]", "\"")

    -- Tirets
    s = mw.ustring.gsub(s, "[–—−]", "-")

    -- Espaces multiples
    s = mw.ustring.gsub(s, "%s+", " ")

    return mw.ustring.lower(mw.text.trim(s))
end

function p.get(key)
    return data[normalize(key)]
end

return p