Jump to content

Module:For loop/sandbox: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
No edit summary
Add a "outputTemp" param
Line 23: Line 23:
local sep = args[1] or ''
local sep = args[1] or ''
local constantArgs = p.getConstants(args)
local constantArgs = p.getConstants(args)
local variableVals = p.getVariableVals(args)
local outputTemp = args.outputTemplate
if outputTemp and #outputTemp == 0 then
outputTemp = nil
end
local variableVals = p.getVariableVals(args, outputTemp)


local result = ''
local result = {}
local addSeparator = false;
local addSeparator = false;
for i, v in ipairs(variableVals) do
for i, v in ipairs(variableVals) do
v = mw.text.trim(v) -- trim whitespace
v = mw.text.trim(v) -- trim whitespace
if #v > 0 or not yesno(args.skipBlanks) then
if #v > 0 or not yesno(args.skipBlanks) then
if addSeparator then
if addSeparator and not outputTemp then
result = result .. sep
result[#result + 1] = sep
end
end
addSeparator = true;
addSeparator = true
local targs = constantArgs
local targs = constantArgs
targs[variableParam] = variableValPrefix .. v .. variableValPostfix
targs[variableParam] = variableValPrefix .. v .. variableValPostfix
if calltemplates then
if calltemplates then
result = result .. p.callTemplate(template, targs)
result[#result] = p.callTemplate(template, targs)
else
else
result = result .. makeTemplate(template, targs)
result = result .. makeTemplate(template, targs)
Line 43: Line 47:
end
end
end
end
if outputTemp then
return result
if callTemplates then
return p.callTemplate(outputTemp, result)
else
return makeTemplate(outputTemp, result)
end
else
return table.concat(result)
end
end
end


Line 60: Line 72:
end
end


function p.getVariableVals(args)
function p.getVariableVals(args, outputTemp)
local variableVals = {}
local variableVals = {}
if args.start or args.stop or args.by then
if args.start or args.stop or args.by then
Line 74: Line 86:
else
else
for i, v in ipairs(args) do
for i, v in ipairs(args) do
if i ~= 1 then
if outputTemp or i ~= 1 then
variableVals[i - 1] = v
variableVals[i - 1] = v
end
end

Revision as of 02:24, 17 February 2019

-- This module implements {{for loop}}.

local getArgs = require('Module:Arguments').getArgs
local yesno = require('Module:Yesno')
local makeTemplate = require('Module:Template invocation').invocation
p = {}

function p.main(frame)
	local args = getArgs(frame, {
		trim = false,
		removeBlanks = false
	})
	return p._main(args)
end

function p._main(args)
	local template = args['call'] or 'void'
	local calltemplates = yesno(args.substall or "", true) or not mw.isSubsting()
	local variableParam = args.pv
	variableParam = tonumber(variableParam) or variableParam or 1 -- fix for positional parameters
	local variableValPrefix = args.prefix or ''
	local variableValPostfix = args.postfix or ''
	local sep = args[1] or ''
	local constantArgs = p.getConstants(args)
	local outputTemp = args.outputTemplate
	if outputTemp and #outputTemp == 0 then
		outputTemp = nil
	end
	local variableVals = p.getVariableVals(args, outputTemp)

	local result = {}
	local addSeparator = false;
	for i, v in ipairs(variableVals) do
		v = mw.text.trim(v) -- trim whitespace
		if #v > 0 or not yesno(args.skipBlanks) then
			if addSeparator and not outputTemp then
				result[#result + 1] = sep
			end
			addSeparator = true
			local targs = constantArgs
			targs[variableParam] = variableValPrefix .. v .. variableValPostfix
			if calltemplates then
				result[#result] = p.callTemplate(template, targs)
			else
				result = result .. makeTemplate(template, targs)
			end
		end
	end
	if outputTemp then
		if callTemplates then
			return p.callTemplate(outputTemp, result)
		else
			return makeTemplate(outputTemp, result)
		end
	else
		return table.concat(result)
	end
end

function p.getConstants(args)
	local constantArgNums = p.getArgNums(args, 'pc', 'n')
	local constantArgs = {}
	for _, num in ipairs(constantArgNums) do
		local keyArg = 'pc' .. tostring(num) .. 'n'
		local valArg = 'pc' .. tostring(num) .. 'v'
		local key = args[keyArg]
		key = tonumber(key) or key
		local value = args[valArg]
		constantArgs[key] = value
	end
	return constantArgs
end

function p.getVariableVals(args, outputTemp)
	local variableVals = {}
	if args.start or args.stop or args.by then
		if args[2] then
			error("Both start/stop/by and numbered parameters specified")
		end
		start = tonumber(args.start or 1)
		stop = tonumber(args.stop or 1)
		by = tonumber(args.by or 1)
		for i = start, stop, by do 
			variableVals [#variableVals + 1] = i
		end
	else
		for i, v in ipairs(args) do
			if outputTemp or i ~= 1 then
				variableVals[i - 1] = v
			end
		end
	end
	return variableVals
end

function p.getArgNums(args, prefix, suffix)
	-- Returns a table containing the numbers of the arguments that exist
	-- for the specified prefix and suffix.
	local nums = {}
	local pattern = '^' .. prefix .. '([1-9]%d*)' .. suffix .. '$'
	for k, v in pairs(args) do
		local num = tostring(k):match(pattern)
		if num then
			nums[#nums + 1] = tonumber(num)
		end
	end
	table.sort(nums)
	return nums
end

function p.callTemplate(template, targs)
	return mw.getCurrentFrame():expandTemplate{title = template, args = targs}
end

return p