Module:Namespace detect/data: Difference between revisions

    m>Jackmcbarn
    (IMO, aliasing variables like that makes readability worse)
    m>Jackmcbarn
    (Undid revision 600634263 by Jackmcbarn (talk): Oh, this seems to have been for performance. Still not sure if it's a good idea, but will leave for now)
    Line 19: Line 19:
    -- }
    -- }
    --]]
    --]]
    local ustringLower = mw.ustring.lower
    local tinsert = table.insert
    local subjectNamespaces = mw.site.subjectNamespaces
    local talk = cfg.talk
    local mappings = {}
    local mappings = {}
    mappings[mw.ustring.lower(mw.site.subjectNamespaces[0].name)] = {cfg.main}
    mappings[ustringLower(subjectNamespaces[0].name)] = {cfg.main}
    mappings[cfg.talk] = {cfg.talk}
    mappings[talk] = {talk}
    for nsid, ns in pairs(mw.site.subjectNamespaces) do
    for nsid, ns in pairs(subjectNamespaces) do
    if nsid ~= 0 then -- Exclude main namespace.
    if nsid ~= 0 then -- Exclude main namespace.
    local nsname = mw.ustring.lower(ns.name)
    local nsname = ustringLower(ns.name)
    local canonicalName = mw.ustring.lower(ns.canonicalName)
    local canonicalName = ustringLower(ns.canonicalName)
    mappings[nsname] = {nsname}
    mappings[nsname] = {nsname}
    if canonicalName ~= nsname then
    if canonicalName ~= nsname then
    table.insert(mappings[nsname], canonicalName)
    tinsert(mappings[nsname], canonicalName)
    end
    end
    for _, alias in ipairs(ns.aliases) do
    for _, alias in ipairs(ns.aliases) do
    table.insert(mappings[nsname], mw.ustring.lower(alias))
    tinsert(mappings[nsname], ustringLower(alias))
    end
    end
    end
    end