Módulo:Separated entries

Permanently protected module
Origem: Wikipédia, a enciclopédia livre.
Documentação do módulo[ver] [editar] [histórico] [purgar]

Uso

O Módulo:Separated entries serve como auxiliar de predefinição para mw.text.listToText. Ele aceita qualquer número de parâmetros posicionais e junta-os com um |separator=. |conjunction= pode ser definido opcionalmente se um separador diferente é necessário entre o último e penúltimo itens. O parâmetro inicial pode ser informado utilizando |start=. Os espaços em branco no inicio e fim são removidos; se o |separator= conter espaços, use o código de escape HTML  . Separated entries não produz erros por padrão.

{{#invoke:Separated entries|main|separator=...}}

-- This module takes positional parameters as input and concatenates them with
-- an optional separator. The final separator (the "conjunction") can be
-- specified independently, enabling natural-language lists like
-- "foo, bar, baz and qux". The starting parameter can also be specified.

local compressSparseArray = require('Module:TableTools').compressSparseArray
local p = {}

function p._main(args)
	local separator = args.separator
		-- Decode (convert to Unicode) HTML escape sequences, such as " " for space.
		and mw.text.decode(args.separator) or ''
	local conjunction = args.conjunction and mw.text.decode(args.conjunction) or separator
	-- Discard values before the starting parameter.
	local start
	if args.start and args.start ~= '' then
	start = tonumber(args.start)
	elseif args.iniciar and args.iniciar ~= '' then
	start = tonumber(args.iniciar)
	elseif args['começar'] and args['começar'] ~= '' then
	start = tonumber(args['começar'])
	end
	if start then
		for i = 1, start - 1 do args[i] = nil end
	end
	-- Discard named parameters.
	local values = compressSparseArray(args)
	return mw.text.listToText(values, separator, conjunction)
end

local function makeInvokeFunction(separator, conjunction, first)
	return function (frame)
		local args = require('Módulo:Arguments').getArgs(frame)
		args.separator = separator or args.separator or args.separador
		args.conjunction = conjunction or args.conjunction or args['conjunção']
		args.first = first or args.first or args.primeiro or args.primeira
		return p._main(args)
	end
end

p.main = makeInvokeFunction()
p.br = makeInvokeFunction('<br />')
p.comma = makeInvokeFunction(mw.message.new('comma-separator'):plain())

return p