« Module:Episode/index » : différence entre les versions
Apparence
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) |
||
-- |
-- 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) |
|||
s = mw.ustring.gsub(s, "%pM", "") |
|||
local combining_end = mw.ustring.char(0x036F) |
|||
s = mw.ustring.gsub(s, "[" .. combining_start .. "-" .. combining_end .. "]", "") |
|||
-- |
-- Normalisation apostrophes |
||
s = mw.ustring.gsub(s, "[’‘´`]", "'") |
s = mw.ustring.gsub(s, "[’‘´`]", "'") |
||
| ⚫ | |||
-- 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+", " ") |
||
| ⚫ | |||
-- Convert to lowercase |
|||
| ⚫ | |||
| ⚫ | |||
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) |
||
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
| Il sera peut-être nécessaire de créer une page documentation pour ce module Scribunto programmé dans la page créer Les éditeurs peuvent faire des tests sur les pages bac à sable (créer | miroir) et études de cas (créer) du module. Veuillez ajouter les catégories dans la sous-page /documentation. Sous-pages de ce module. |
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