Want to contribute? Join the Discord and ask for the editor role.
Module:For: Difference between revisions
From RTGame Wiki
RTGame>Alistair3149 m (1 revision imported) |
m (1 revision imported) |
(No difference)
|
Latest revision as of 16:51, 2 May 2021
This documentation is transcluded from Module:For/doc. Changes can be proposed in the talk page.
Module:For's function For is invoked by Template:For.
Module:For requires Module:Arguments.
Module:For requires Module:Hatnote.
Module:For requires Module:Hatnote list.
Module:For requires Module:Yesno.
This template is imported from Module:For on Wikipedia.
This template is imported from the English Wikipedia. Although the visual appearance might be different, the functionality is identical. Please refer to the Module:For page on Wikipedia for detailed documentation.
Module:For implements the {{For}}
template.
local mArguments --initialize lazily
local mHatlist = require('Module:Hatnote list')
local mHatnote = require('Module:Hatnote')
local yesNo = require('Module:Yesno')
local p = {}
--Implements {{For}} from the frame
--uses capitalized "For" to avoid collision with Lua reserved word "for"
function p.For (frame)
mArguments = require('Module:Arguments')
return p._For(mArguments.getArgs(frame))
end
--Implements {{For}} but takes a manual arguments table
function p._For (args)
local use = args[1]
if (not use) then
return mHatnote.makeWikitextError(
'no context parameter provided. Use {{other uses}} for "other uses" hatnotes.',
'Template:For#Errors',
args.category
)
end
local pages = {}
function two (a, b) return a, b, 1 end --lets us run ipairs from 2
for k, v in two(ipairs(args)) do table.insert(pages, v) end
return mHatnote._hatnote(
mHatlist.forSeeTableToString({{use = use, pages = pages}}),
{selfref = args.selfref}
) .. (
(use == 'other uses') and yesNo(args.category) and
'[[Category:Hatnote templates using unusual parameters]]' or ''
)
end
return p