Module:For: Difference between revisions
Appearance
Added tracking for args[1] == "other uses" |
m Wrong category name |
||
| Line 15: | Line 15: | ||
local use = args[1] --cases with parameter 1 unspecified should probably be flagged | local use = args[1] --cases with parameter 1 unspecified should probably be flagged | ||
if use == 'other uses' then | if use == 'other uses' then | ||
use = use .. '[[Category: | use = use .. '[[Category:Hatnote templates using unusual parameters]]' | ||
end | end | ||
local pages = {} | local pages = {} | ||
Revision as of 18:18, 10 May 2016
Documentation for this module may be created at Module:For/doc
local mArguments --initialize lazily
local mHatlist = require('Module:Hatnote list')
local mHatnote = require('Module:Hatnote')
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] --cases with parameter 1 unspecified should probably be flagged
if use == 'other uses' then
use = use .. '[[Category:Hatnote templates using unusual parameters]]'
end
local pages = {}
function two (a, b, c) 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}})
)
end
return p