Module:For: Difference between revisions

From Zoophilia Wiki
Jump to navigationJump to search
meta>Nihiltres
(A prototype)
 
m (1 revision imported)
 
(14 intermediate revisions by 4 users not shown)
Line 1: Line 1:
local mArguments --initialize lazily
local mArguments --initialize lazily
local mHatlist = require('Module:Hatnote list/sandbox') --remove "/sandbox" once forSeeTableToString is in main module
local mHatlist = require('Module:Hatnote list')
local mHatnote = require('Module:Hatnote')
local mHatnote = require('Module:Hatnote')
local yesNo = require('Module:Yesno')
local p = {}
local p = {}


Line 8: Line 9:
function p.For (frame)
function p.For (frame)
mArguments = require('Module:Arguments')
mArguments = require('Module:Arguments')
return p._for(mArguments.getArgs(frame))
return p._For(mArguments.getArgs(frame))
end
end


--Implements {{For}} but takes a manual arguments table
--Implements {{For}} but takes a manual arguments table
function p._For (args)
function p._For (args)
local use = args[1] --cases with parameter 1 unspecified, i.e. using "other uses", should probably be flagged
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 = {}
local pages = {}
for k, v in pairs(args) do
function two (a, b) return a, b, 1 end --lets us run ipairs from 2
if type(k) == 'number' and k > 1 then
for k, v in two(ipairs(args)) do table.insert(pages, v) end
table.insert(pages, v)
local title = mw.title.getCurrentTitle()
end
local skipCat = title.isTalkPage or title.namespace == 2 --don't categorise talk pages and userspace
end
local oddCat = skipCat and '' or '[[Category:Hatnote templates using unusual parameters]]'
local category = yesNo(args.category)
return mHatnote._hatnote(
return mHatnote._hatnote(
mHatlist.forSeeTableToString({{use = use, pages = pages}})
mHatlist.forSeeTableToString({{use = use, pages = pages}}),
)
{selfref = args.selfref}
) .. (
(use == 'other uses') and ((category == true) or (category == nil)) and
oddCat or ''
)
end
end


return p
return p

Latest revision as of 00:47, 15 June 2021

Implements {{for}}.


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
	local title = mw.title.getCurrentTitle()
	local skipCat = title.isTalkPage or title.namespace == 2 --don't categorise talk pages and userspace
	local oddCat = skipCat and '' or '[[Category:Hatnote templates using unusual parameters]]'
	local category = yesNo(args.category)
	return mHatnote._hatnote(
		mHatlist.forSeeTableToString({{use = use, pages = pages}}),
		{selfref = args.selfref}
	) .. (
			(use == 'other uses') and ((category == true) or (category == nil)) and
			oddCat or ''
		)
end

return p