Actions

Module

Difference between revisions of "Parameters"

From Unofficial Stationeers Wiki

(start)
(sort)
Line 3: Line 3:
  
 
local DEFINITIONS = {
 
local DEFINITIONS = {
native_name = {
 
code = "<!-- name in local language; if more than one, separate " ..
 
"using {{Plainlist}} and omit native_name_lang -->",
 
dlist = "name in local language; if more than one, separate " ..
 
"using {{tl|Plainlist}} and omit {{para|native_name_lang}}"},
 
 
coordinates = {
 
coordinates = {
 
code = "<!-- use {{Coord}} -->",
 
code = "<!-- use {{Coord}} -->",
Line 14: Line 9:
 
code = "<!-- use {{Coord}} -->",
 
code = "<!-- use {{Coord}} -->",
 
dlist = "using {{tl|Coord}} "},
 
dlist = "using {{tl|Coord}} "},
url = {
+
native_name = {
code = "<!-- use {{URL|example.com}} -->",
+
code = "<!-- name in local language; if more than one, separate " ..
dlist = "using {{tl|URL}} "},
+
"using {{Plainlist}} and omit native_name_lang -->",
website = {
+
dlist = "name in local language; if more than one, separate " ..
code = "<!-- use {{URL|example.com}} -->",
+
"using {{tl|Plainlist}} and omit {{para|native_name_lang}}"},
dlist = "using {{tls|URL|example.com}} "},
 
 
native_name_lang = {
 
native_name_lang = {
 
code = "<!-- language two- or three-letter ISO code -->",
 
code = "<!-- language two- or three-letter ISO code -->",
Line 28: Line 22:
 
end_date = {
 
end_date = {
 
code = "<!-- {{End date|YYYY|MM|DD|df=y}} -->",
 
code = "<!-- {{End date|YYYY|MM|DD|df=y}} -->",
dlist = "use {{tlx|Start date|YYYY|MM|DD|df=y}}"},}
+
dlist = "use {{tlx|Start date|YYYY|MM|DD|df=y}}"},
 +
url = {
 +
code = "<!-- use {{URL|example.com}} -->",
 +
dlist = "using {{tl|URL}} "},
 +
website = {
 +
code = "<!-- use {{URL|example.com}} -->",
 +
dlist = "using {{tls|URL|example.com}} "},}
  
 
local p = {}
 
local p = {}

Revision as of 08:28, 31 July 2015


-- This module implements [[Template:Parameters]].
-- [SublimeLinter luacheck-globals:mw]

local DEFINITIONS = {
	coordinates = {
		code = "<!-- use {{Coord}} -->",
		dlist = "using {{tl|Coord}} "},
	coords = {
		code = "<!-- use {{Coord}} -->",
		dlist = "using {{tl|Coord}} "},
	native_name = {
		code = "<!-- name in local language; if more than one, separate " ..
			"using {{Plainlist}} and omit native_name_lang -->",
		dlist = "name in local language; if more than one, separate " ..
			"using {{tl|Plainlist}} and omit {{para|native_name_lang}}"},
	native_name_lang = {
		code = "<!-- language two- or three-letter ISO code -->",
		dlist = "language two- or three-letter ISO code"},
	start_date = {
		code = "<!-- {{Start date|YYYY|MM|DD|df=y}} -->",
		dlist = "use {{tlx|Start date|YYYY|MM|DD|df=y}}"},
	end_date = {
		code = "<!-- {{End date|YYYY|MM|DD|df=y}} -->",
		dlist = "use {{tlx|Start date|YYYY|MM|DD|df=y}}"},
	url = {
		code = "<!-- use {{URL|example.com}} -->",
		dlist = "using {{tl|URL}} "},
	website = {
		code = "<!-- use {{URL|example.com}} -->",
		dlist = "using {{tls|URL|example.com}} "},}

local p = {}
local removeDuplicates = require('Module:TableTools').removeDuplicates
local yesno = require('Module:Yesno')

local function makeInvokeFunction(funcName)
	return function(frame)
		local getArgs = require('Module:Arguments').getArgs
		return p[funcName](getArgs(frame, {removeBlanks = false}))
	end
end

local function extractParams(source)
	local parameters = {}
	for parameter in string.gmatch(source, '{{{(.-)%f[}|<>]') do
		table.insert(parameters, parameter)
	end
	return removeDuplicates(parameters)
end

local function strMap(iter, transform, sort)
	local returnTable = {}
	for _, v in pairs(iter) do
		table.insert(returnTable, transform(v))
	end
	if sort then
		table.sort(returnTable)
	end
	return table.concat(returnTable)
end

function p._check(args)
	local title = args._base or mw.title.getCurrentTitle().fullText
	return string.format(
		'{{#invoke:Check for unknown parameters|check|unknown=' ..
		'[[Category:Pages using %s with unknown parameters]]|%s}}', title,
		table.concat(extractParams(args.base), '|'))
end

function p._code(args)
	local definitions = yesno(args.definitions)
	local title = args._base or mw.title.getCurrentTitle().baseText
	return string.format([[{{%s
%s}}]], title, strMap(extractParams(args.base),
		function(s)
			if definitions then
				return string.format('| %s = %s\n', s,
					DEFINITIONS[s] and DEFINITIONS[s].code or '')
			else
				return string.format('| %s = \n', s)
			end
		end))
end

function p._compare(args)
	local Set = require('Module:Set')

	local function normaliseParams(parameters)
		local paramsNorm = {}
		-- Prepare a key lookup metatable, which will hold the original
		-- parameter names for each normalised parameter, e.g.
		-- [test] = {TEST, Test}. paramIndex functions like a Python
		-- defaultdict, where the default is a table.
		local paramIndex = setmetatable({}, {__index = function(t, k)
			if not rawget(t, k) then
				rawset(t, k, {})
			end
			return rawget(t, k)
		end})
		for _, parameter in pairs(parameters) do
			table.insert(paramsNorm,
				string.lower(string.gsub(parameter, '%A', '')))
			table.insert(paramIndex[
				string.lower(string.gsub(parameter, '%A', ''))], parameter)
		end

		paramsNorm = removeDuplicates(paramsNorm)
		-- Overload key lookup in paramsNorm. While [[Module:Set]] will
		-- operate on the table (which is to say, the normalised parameters
		-- array), key access will be by way of the paramIndex metatable.
		setmetatable(paramsNorm, {__index = paramIndex})
		return paramsNorm
	end

	local baseParams = extractParams(args.base)
	local otherParams = extractParams(args.other)
	local baseNormParams = normaliseParams(Set.valueComplement(
			otherParams, baseParams))
	local otherNormParams = normaliseParams(otherParams)

	return string.format([[Identical:
%s
Similar:
%s
Disparate:
%s]],
	strMap(Set.valueIntersection(baseParams, otherParams),
		function(v) return string.format('* %s\n', v) end, true),
	strMap(Set.valueIntersection(baseNormParams, otherNormParams),
		function(v) return string.format('* %s < %s [%s]\n',
			table.concat(baseNormParams[v], '; '),
			table.concat(otherNormParams[v], '; '),
			v)
		end, true),
	strMap(Set.valueComplement(otherNormParams, baseNormParams),
		function(v) return strMap(baseNormParams[v],
			function(s) return string.format('* %s\n', s) end, true)
		end, true))
end

function p._demo(args)
	local title = args._base and ('|_template=' .. args._base) or ''
	return string.format('{{Parameter names example%s|%s}}', title,
		table.concat(extractParams(args.base), '|'))
end

function p._dlist(args)
	local definitions = yesno(args.definitions, true)
	return strMap(extractParams(args.base),
		function(s)
			if definitions then
				return string.format('; %s: %s\n', s,
					DEFINITIONS[s] and DEFINITIONS[s].dlist or '')
			else
				return string.format('; %s: \n', s)
			end
		end)
end

function p._list(args)
	return strMap(extractParams(args.base),
		function(s) return string.format('* %s\n', s) end)
end

p.check = makeInvokeFunction('_check')
p.code = makeInvokeFunction('_code')
p.compare = makeInvokeFunction('_compare')
p.demo = makeInvokeFunction('_demo')
p.dlist = makeInvokeFunction('_dlist')
p.list = makeInvokeFunction('_list')

return p