開啟主選單

求真百科

變更

模块:Unsubst

移除 1,884 位元組, 6 年前
已保护“模块:Unsubst”:高風險模板([编辑=仅管理员](无限期)[移动=仅管理员](无限期))
local checkType = require('libraryUtil').checkType
 
local p = {}
 
local BODY_PARAM = '$B'
local specialParams = {
['$paramsN'] = 'parameter listtemplate name', ['$aliases'] = 'parameter aliases', ['$flags'] = 'flags'-- Deprecated,but keeping until it is removed from transcluding templates ['$B'] = 'template content',
}
p[''] = function p.main(frame, body) -- If we are substing, this function returns a template invocation, and if -- not, it returns the template body. The template body can be specified in -- the body parameter, or in the template parameter defined in the -- BODY_PARAM variable. This function can be called from Lua or from -- #invoke.  -- Return the template body if we aren't substing. if not mw.isSubstingframe:getParent() then if body ~= nil then return body elseif frame.args[BODY_PARAM] ~= nil then return frame.args[BODY_PARAM] else error(string.format( "no template content specified (use parameter '%s' from {{#invoke:Unsubst|}} makes no sense without a parent frame' )", BODY_PARAM ), 2) end
end
  -- Sanity check for the if not frame object. if type(frame) ~= args['table$B'] then or typeerror(frame.getParent) ~= 'function' or not frame{{#invoke:getParentUnsubst|}} requires parameter $B (template content) then error( "argument #1 to 'main' must be a frame object with a parent " .. "frame available", 2 )
end
  -- Find the invocation name. local mTemplateInvocation = require('Module:Template invocation') local name = mTemplateInvocationif mw.name(frame:getParentisSubsting():getTitle())then ---- substing -- Combine passed args with passed defaults local args = {} if string.find( ','..(frame.args['$flags'] or '')..',', ',%s*override%s*,' ) then for k, v in pairs( frame:getParent().args ) do args[k] = v end
for k, v in pairs( frame.args ) do
if not specialParams[k] then
if v == '__DATE__' then
v = mw.getContentLanguage():formatDate( 'F Y' ) end args[k] = v end end else for k, v in pairs( frame.args ) do if not specialParams[k] then if v == '__DATE__' then v = mw.getContentLanguage():formatDate( 'F Y年n月' )
end
args[k] = v
args[k] = v
end
end
-- Trim parameters, if not specified otherwiseBuild an equivalent template invocation if not string.find( ','..(frame.args['$flags'] or '')..',', ',%s*keep% --whitespace%s*First,' ) thenfind the title to use for k, v in pairs( args ) do args[k] local titleobj = mw.ustringtitle.matchnew(v, '^%s*frame:getParent():getTitle(.*)%s*$') or '' end end  -- Pull information from parameter aliases local aliases = {}title if frametitleobj.args['$aliases'] namespace == 10 then-- NS_TEMPLATE local list title = mwtitleobj.text.split( frame.args['$aliases'], '%s*,%s*' ) for k, v in ipairs( list ) doelseif titleobj.namespace == 0 then -- NS_MAIN local tmp title = mw.text.split( v, '%s*>%s*:' ) aliases[tonumber(mw.ustring.match(tmp[1], '^[1-9][0-9]*$')) or tmp[1]] = ((tonumber(mwtitleobj.ustring.match(tmp[2], '^[1-9][0-9]*$'))) or tmp[2])text end end for k, v in pairs( aliases ) do if args[k] and ( not args[v] or args[v] == '' ) thenelse args[v] title = args[k]titleobj.prefixedText
end
args[k] = nil
end
-- Remove empty parameters, if specified if string.find( ','..(frame.Build the invocation body with numbered args['$flags'] or '')..',', ',%s*remove%-empty%s*first,' ) thennamed local tmp ret = 0'{{' .. title
for k, v in ipairs( args ) do
if string.find( v ~, '= '' or ( args[k+1] and args[k+, 1] ~= '' ) or ( args[k+2] and args[k+2] ~= '' , true ) then tmp -- likely something like 1=foo= k elsebar, we need to do it as a named arg
break
end
ret = ret .. '|' .. v
args[k] = nil
end
for k, v in pairs( args ) do
if v =ret = ret .. '|' then if not (type(.. k) =.. '= 'number' and k < tmp) then args[k] = nil end end.. v
end
return ret .. '}}'
else
---- Not substing
-- Just return the "body"
return frame.args['$B'] .. (frame.args['$N'] and frame:getParent():getTitle() == mw.title.getCurrentTitle().prefixedText and '[[Category:使用$N的Module:Unsubst调用]]' or '')
end
 
-- Order parameters
if frame.args['$params'] then
local params, tmp = mw.text.split( frame.args['$params'], '%s*,%s*' ), {}
for k, v in ipairs(params) do
v = tonumber(mw.ustring.match(v, '^[1-9][0-9]*$')) or v
if args[v] then tmp[v], args[v] = args[v], nil end
end
for k, v in pairs(args) do tmp[k], args[k] = args[k], nil end
args = tmp
end
 
return mTemplateInvocation.invocation(name, args)
end
 
p[''] = p.main -- For backwards compatibility
return p
匿名用戶