Module:Multi-section link
This module implements {{multi-section link}}. Please see the template documentation for usage instructions.
-- This module creates a section link with multiple section names.
local p = {}
local function normalizePageName(page)
local title = mw.title.new(page)
if not title then
error(string.format("'%s' is not a valid page name", page), 3)
elseif title.namespace == 6 or title.namespace == 14 then
return ':' .. title.prefixedText
else
return title.prefixedText
end
end
function p._main(args)
local displayParts = {}
for i, v in ipairs(args) do
displayParts[i] = v
end
local nParts = #displayParts
if nParts < 1 then
error('no page name found in parameter |1=', 2)
elseif nParts == 1 then
return string.format('[[%s]]', normalizePageName(displayParts[1]))
else
local display = {}
for i, s in ipairs(displayParts) do
table.insert(display, s)
table.insert(display, string.rep('§', i))
end
table.remove(display) -- Remove the extra "§§" markers from the end
display = table.concat(display, ' ')
local page = normalizePageName(displayParts[1])
local fragment = displayParts[nParts]
return string.format('[[%s#%s|%s]]', page, fragment, display)
end
end
function p.main(frame)
local args = require('Module:Arguments').getArgs(frame, {
wrappers = 'Template:Multi-section link'
})
return p._main(args)
end
return p