Difference between revisions of "Module:Separated entries"

From annadreambrush.com/wiki
Jump to navigation Jump to search
imported>Izkala
(Reverted 1 edit by Jc86035 (talk): Rv test - named parameters are automatically trimmed. (TW))
imported>Amorymeltzer
m (Changed protection level for "Module:Separated entries": High-risk Lua module: Over 2M transclusions ([Edit=Require administrator access] (indefinite) [Move=Require administrator access] (indefinite)))
 
(8 intermediate revisions by 3 users not shown)
Line 1: Line 1:
local getArgs = require('Module:Arguments').getArgs
+
-- 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 = {}
 
local p = {}
+
 
function p.main(frame)
+
function p._main(args)
local args = getArgs(frame, {
+
local separator = args.separator
removeBlanks = true,
+
-- Decode (convert to Unicode) HTML escape sequences, such as " " for space.
trim = false
+
and mw.text.decode(args.separator) or ''
})
+
local conjunction = args.conjunction and mw.text.decode(args.conjunction) or separator
return p._main(args)
+
-- Discard values before the starting parameter.
 +
local start = tonumber(args.start)
 +
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
 
end
 
function p._main(origArgs)
 
local separator = origArgs.separator or ''
 
local conjunction = origArgs.conjunction or separator
 
  
args = {}
+
local function makeInvokeFunction(separator, conjunction, first)
for k, v in pairs(origArgs) do
+
return function (frame)
-- Discard named parameters.
+
local args = require('Module:Arguments').getArgs(frame)
if type(k) == 'number' then
+
args.separator = separator or args.separator
table.insert(args, mw.text.trim(v))
+
args.conjunction = conjunction or args.conjunction
end
+
args.first = first or args.first
 +
return p._main(args)
 
end
 
end
return mw.text.listToText(args, separator, conjunction)
 
 
end
 
end
+
 
 +
p.main = makeInvokeFunction()
 +
p.br = makeInvokeFunction('<br />')
 +
p.comma = makeInvokeFunction(mw.message.new('comma-separator'):plain())
 +
 
 
return p
 
return p

Latest revision as of 21:54, 17 December 2018

Usage

Module:Separated entries serves as a template front-end to mw.text.listToText. It takes any number of positional parameters and pieces them together with |separator=. |conjunction= can be optionally defined if a different separator is desired between the last and second last items. The starting positional parameter can be specified using |start=. Leading and trailing whitespace is stripped; if the |separator= should contain spaces, use the HTML escape code &#32;. Separated entries does not raise any errors by design.

{{#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 "&#32;" 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 = tonumber(args.start)
	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('Module:Arguments').getArgs(frame)
		args.separator = separator or args.separator
		args.conjunction = conjunction or args.conjunction
		args.first = first or args.first
		return p._main(args)
	end
end

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

return p