Modulo:Controło paràmatri sconosesti
--[[
* Modulo par controłar se un modeło el dòpara paràmatri sconosesti.
* El va doparà inte el modeło, spesifegàndoghe ła lista de paràmatri vàłidi e
* el testo da far tornar in cazo de eror, cofà un mesajo o na categoria de servìsio.
*
* Mòduło inportà da:
* http://en.wikipedia.org/w/index.php?title=Module:Check_for_unknown_parameters&oldid=669492475
]]--
local p = {}
local function isnotempty(s)
return s and s:match( '^%s*(.-)%s*$' ) ~= ''
end
function p.check (frame)
local args = frame.args
local pargs = frame:getParent().args
local ignoreblank = isnotempty(frame.args['ignoravodi'])
local checkpos = isnotempty(frame.args['controłopozisionałi'])
local knownargs = {}
local unknown = 'Catà _VALUE_, '
local res = {}
local regexps = {}
local comments = {}
local commentstr = ''
-- abiłità in tuti i spàsio nome ma no in cheło de discusione e utensa,
-- o sanò solché in cheło metesto inte el paràmatro "ns"
local ns = mw.title.getCurrentTitle().namespace
if args.ns then
if ns ~= tonumber(args.ns) then
return ''
end
elseif ns == 2 or (ns % 2 == 1) then
return ''
end
-- create the list of known args, regular expressions, and the return string
for k, v in pairs(args) do
if type(k) == 'number' then
v = mw.ustring.gsub(v, '^%s*(.-)%s*$', '%1')
knownargs[v] = 1
else
if (k == 'sconosesto' and type(v) == 'string') then
unknown = v
elseif (mw.ustring.match(k, '^regexp[%d]*$') and type(v) == 'string') then
table.insert(regexps, '^' .. v .. '$')
end
end
end
-- loop over the parent args, and make sure they are on the list
for k,v in pairs(pargs) do
if (type(k) == 'string' and knownargs[k] == nil) then
local knownflag = nil
for r = 1,#regexps do
if ( mw.ustring.match(k,regexps[r]) ) then
knownflag = 1
end
end
if ( (not knownflag) and ( (not ignoreblank) or (ignoreblank and isnotempty(v)) ) ) then
k = mw.ustring.gsub(k, '[^%w\-_ ]', '?')
local r = mw.ustring.gsub(unknown, '_VALUE_', k)
table.insert(res, r)
table.insert(comments, '"' .. k .. '"')
end
elseif (checkpos and type(k) == 'number' and knownargs[tostring(k)] == nil) then
if ( (not ignoreblank) or (ignoreblank and isnotempty(v)) ) then
local r = mw.ustring.gsub(unknown, '_VALUE_', k)
table.insert(res, r)
table.insert(comments, '"' .. k .. '"')
end
end
end
if (#comments > 0) then
commentstr = '<!-- Modulo:Controło paràmatri sconosesti: ' ..
table.concat(comments, ', ') .. '-->'
end
return table.concat(res) .. commentstr
end
return p