Module:Parameter names example: Difference between revisions
Jump to navigation
Jump to search
>Mr. Stradivarius (create a replacement for Template:Parameter names example) |
>Andrybak (add popular variants of demonstration purposes parameters: nocat=yes, categories=no, and demo=yes) |
||
(7 intermediate revisions by 3 users not shown) | |||
Line 11: | Line 11: | ||
local function italicize(s) | local function italicize(s) | ||
return "''" .. s .. "''" | return "''" .. s .. "''" | ||
end | |||
local function plain(s) | |||
return s | |||
end | end | ||
Line 16: | Line 20: | ||
-- Find how we want to format the arguments to the template. | -- Find how we want to format the arguments to the template. | ||
local formatFunc | local formatFunc | ||
if args. | if args._display == 'italics' or args._display == 'italic' then | ||
formatFunc = italicize | formatFunc = italicize | ||
elseif args._display == 'plain' then | |||
formatFunc = plain | |||
else | else | ||
formatFunc = makeParam | formatFunc = makeParam | ||
Line 24: | Line 30: | ||
-- Build the table of template arguments. | -- Build the table of template arguments. | ||
local targs = {} | local targs = {} | ||
for | for k, v in pairs(args) do | ||
targs[ | if type(k) == 'number' then | ||
targs[v] = formatFunc(v) | |||
elseif not k:find('^_') then | |||
targs[k] = v | |||
end | |||
end | |||
targs['nocat'] = 'yes'; | |||
targs['categories'] = 'no'; | |||
targs['demo'] = 'yes'; | |||
-- Find the template name. | |||
local template | |||
if args._template then | |||
template = args._template | |||
else | |||
local currentTitle = mw.title.getCurrentTitle() | |||
if currentTitle.prefixedText:find('/sandbox$') then | |||
template = currentTitle.prefixedText | |||
else | |||
template = currentTitle.basePageTitle.prefixedText | |||
end | |||
end | end | ||
-- | -- Call the template with the arguments. | ||
frame = frame or mw.getCurrentFrame() | frame = frame or mw.getCurrentFrame() | ||
local success, result = pcall( | |||
frame.expandTemplate, | |||
frame, | |||
{title = template, args = targs} | |||
) | |||
if success then | |||
return result | |||
else | |||
return '' | |||
end | |||
end | end | ||
Latest revision as of 23:07, 25 March 2020
Documentation for this module may be created at Module:Parameter names example/doc
-- This module implements {{parameter names example}}. local p = {} local function makeParam(s) local lb = '{' local rb = '}' return lb:rep(3) .. s .. rb:rep(3) end local function italicize(s) return "''" .. s .. "''" end local function plain(s) return s end function p._main(args, frame) -- Find how we want to format the arguments to the template. local formatFunc if args._display == 'italics' or args._display == 'italic' then formatFunc = italicize elseif args._display == 'plain' then formatFunc = plain else formatFunc = makeParam end -- Build the table of template arguments. local targs = {} for k, v in pairs(args) do if type(k) == 'number' then targs[v] = formatFunc(v) elseif not k:find('^_') then targs[k] = v end end targs['nocat'] = 'yes'; targs['categories'] = 'no'; targs['demo'] = 'yes'; -- Find the template name. local template if args._template then template = args._template else local currentTitle = mw.title.getCurrentTitle() if currentTitle.prefixedText:find('/sandbox$') then template = currentTitle.prefixedText else template = currentTitle.basePageTitle.prefixedText end end -- Call the template with the arguments. frame = frame or mw.getCurrentFrame() local success, result = pcall( frame.expandTemplate, frame, {title = template, args = targs} ) if success then return result else return '' end end function p.main(frame) local args = require('Module:Arguments').getArgs(frame, { wrappers = 'Template:Parameter names example' }) return p._main(args, frame) end return p