Module:Multi-section link/sandbox: Difference between revisions
Appearance
Content deleted Content added
No edit summary |
No edit summary |
||
Line 20: | Line 20: | ||
end |
end |
||
local nParts = #displayParts |
local nParts = #displayParts |
||
if nParts < 1 then |
|||
displayParts[1] = "" |
|||
end |
|||
if nParts == 1 then |
if nParts == 1 then |
||
return string.format('[[%s]]', normalizePageName(displayParts[1])) |
return string.format('[[%s]]', normalizePageName(displayParts[1])) |
Revision as of 09:54, 9 December 2024
![]() | This is the module sandbox page for Module:Multi-section link (diff). |
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
displayParts[1] = ""
end
if nParts == 1 then
return string.format('[[%s]]', normalizePageName(displayParts[1]))
else
local display = {}
for i, s in ipairs(displayParts) do
table.insert(display, s)
if i ~= nParts then
table.insert(display, ' ')
table.insert(display, string.rep('§', i))
table.insert(display, ' ')
end
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