Modul:Check for unknown parameters: Perbedaan antara revisi

Dari Wiki Javasatu
Loncat ke navigasi Loncat ke pencarian
Tidak ada ringkasan suntingan
Tag: Dikembalikan
k (1 revisi diimpor)
 
(2 revisi perantara oleh pengguna yang sama tidak ditampilkan)
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

Revisi terkini sejak 7 Oktober 2023 14.33

Dokumentasi untuk modul ini dapat dibuat di Modul:Check for unknown parameters/doc

-- 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 function trim(s)
	return s:match('^%s*(.-)%s*$')
end

local function isnotempty(s)
	return s and trim(s) ~= ''
end

function p.check (frame)
	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
	if isnotempty(preview) then 
		preview = '<div class="hatnote" style="color:red"><strong>Peringatan:</strong> ' .. preview .. ' (pesan ini hanya ditampilkan dalam pratinjau).</div>'
	elseif preview == nil then
		preview = unknown
	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 = false
			for i, regexp in ipairs(regexps) do
				if mw.ustring.match(k, regexp) then
					knownflag = true
					break
				end
			end
			if not knownflag and ( not ignoreblank or isnotempty(v) )  then
				k = mw.ustring.gsub(k, '[^%w\-_ ]', '?')
				table.insert(values, k)
			end
		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

	-- add resuls to the output tables
	if #values > 0 then
		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

	return table.concat(res)
end

return p