Modul:Check for unknown parameters: Perbedaan antara revisi

tidak ada ringkasan suntingan
Tidak ada ringkasan suntingan
Tag: Dikembalikan
Tidak ada ringkasan suntingan
Tag: Pengembalian manual
Baris 1: Baris 1:
-- This module may be used to compare the arguments passed to the parent
-- with a list of arguments, returning a specified result if an argument is
-- not on the list
local p = {}
local p = {}


-- Returns the expiry of a restriction of an action on a given title, or unknown if it cannot be known.
local function trim(s)
-- If no title is specified, the title of the page being displayed is used.
return s:match('^%s*(.-)%s*$')
function p._main(action, pagename)
end
local title
 
if type(pagename) == 'table' and pagename.prefixedText then
local function isnotempty(s)
title = pagename
return s and trim(s) ~= ''
elseif pagename then
end
title = mw.title.new(pagename)
 
else
function p.check (frame)
title = mw.title.getCurrentTitle()
local args = frame.args
local pargs = frame:getParent().args
local ignoreblank = isnotempty(frame.args['ignoreblank'])
local showblankpos = isnotempty(frame.args['showblankpositional'])
local knownargs = {}
local unknown = frame.args['unknown'] or 'Found _VALUE_, '
local preview = frame.args['preview']
 
local values = {}
local res = {}
local regexps = {}
 
-- 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 = trim(v)
knownargs[v] = 1
elseif k:find('^regexp[1-9][0-9]*$') then
table.insert(regexps, '^' .. v .. '$')
end
end
end
pagename = title.prefixedText
if isnotempty(preview) then  
if action == 'autoreview' then
preview = '<div class="hatnote" style="color:red"><strong>Peringatan:</strong> ' .. preview .. ' (pesan ini hanya ditampilkan dalam pratinjau).</div>'
local stabilitySettings = mw.ext.FlaggedRevs.getStabilitySettings(title)
elseif preview == nil then
return stabilitySettings and stabilitySettings.expiry or 'unknown'
preview = unknown
elseif action ~= 'edit' and action ~= 'move' and action ~= 'create' and action ~= 'upload' then
error( 'First parameter must be one of edit, move, create, upload, autoreview', 2 )
end
end
local rawExpiry = mw.getCurrentFrame():callParserFunction('PROTECTIONEXPIRY', action, pagename)
 
if rawExpiry == 'infinity' then
-- loop over the parent args, and make sure they are on the list
return 'infinity'
for k, v in pairs(pargs) do
elseif rawExpiry == '' then
if type(k) == 'string' and knownargs[k] == nil then
return 'unknown'
local knownflag = false
else
for i, regexp in ipairs(regexps) do
local year, month, day, hour, minute, second = rawExpiry:match(
if mw.ustring.match(k, regexp) then
'^(%d%d%d%d)(%d%d)(%d%d)(%d%d)(%d%d)(%d%d)$'
knownflag = true
)
break
if year then
end
return string.format(
end
'%s-%s-%sT%s:%s:%s',
if not knownflag and ( not ignoreblank or isnotempty(v) )  then
year, month, day, hour, minute, second
k = mw.ustring.gsub(k, '[^%w\-_ ]', '?')
)
table.insert(values, k)
else
end
error('internal error in Modul:Effective protection expiry; malformed expiry timestamp')
elseif type(k) == 'number' and
knownargs[tostring(k)] == nil and
( showblankpos or isnotempty(v) )
then
local vlen = mw.ustring.len(v)
v = mw.ustring.sub(v, 1, (vlen < 25) and vlen or 25)
v = mw.ustring.gsub(v, '[^%w\-_ ]', '?')
table.insert(values, k .. ' = ' .. v .. ((vlen >= 25) and ' ...' or ''))
end
end
end
end
end


setmetatable(p, { __index = function(t, k)
-- add resuls to the output tables
return function(frame)
if #values > 0 then
return t._main(k, frame.args[1])
if frame:preprocess( "{{REVISIONID}}" ) == "" then
unknown = preview
end
for k, v in pairs(values) do
if v == '' then
-- Fix odd bug for | = which gets stripped to the empty string and
-- breaks category links
v = ' '
end
local r =  unknown:gsub('_VALUE_', v)
table.insert(res, r)
end
end
end
end })
 
return table.concat(res)
end


return p
return p