Module:Lang/documentor tool: Difference between revisions
From Zoophilia Wiki
Jump to navigationJump to search
meta>Trappist the monk create; |
meta>Trappist the monk No edit summary |
||
Line 2: | Line 2: | ||
local p = {}; | local p = {}; | ||
--[=[------------------------< L A N G - X X _ | --[=[------------------------< L A N G - X X _ S E T T I N G S >----------------------------------------------- | ||
{{#invoke:Lang/documentor tool|lang_xx_settings|template={{ROOTPAGENAME}}}} | {{#invoke:Lang/documentor tool|lang_xx_settings|template={{ROOTPAGENAME}}}} | ||
Line 12: | Line 12: | ||
function p.lang_xx_settings (frame) | function p.lang_xx_settings (frame) | ||
local page = mw.title.makeTitle ('Template', frame.args['template'] or frame.args[1]); | local page = mw.title.makeTitle ('Template', frame.args['template'] or frame.args[1]); -- get a page object for this page in 'Template:' namespace | ||
if not page then | if not page then | ||
return 'error message | return ''; -- TODO: error message? | ||
end | end | ||
local content = page:getContent(); -- get unparsed content | local content = page:getContent(); -- get unparsed content | ||
if not page then | if not page then | ||
return 'error message | return ''; -- TODO: error message? | ||
end | end | ||
Revision as of 13:39, 15 November 2017
Documentation for this module may be created at Module:Lang/documentor tool/doc
require('Module:No globals');
local p = {};
--[=[------------------------< L A N G - X X _ S E T T I N G S >-----------------------------------------------
{{#invoke:Lang/documentor tool|lang_xx_settings|template={{ROOTPAGENAME}}}}
reads the content of the template and extracts the parameters from {{#invoke:Lang|...}} for display on the template's
documentation page
]=]
function p.lang_xx_settings (frame)
local page = mw.title.makeTitle ('Template', frame.args['template'] or frame.args[1]); -- get a page object for this page in 'Template:' namespace
if not page then
return ''; -- TODO: error message?
end
local content = page:getContent(); -- get unparsed content
if not page then
return ''; -- TODO: error message?
end
local out = {};
local params;
if content:match ('{{%s*#invoke:%s*[Ll]ang%s*|[^|]+|[^}]+}}') then -- if this template uses [[Module:Lang]]
params = content:match ('{{%s*#invoke:%s*[Ll]ang%s*|[^|]+(|[^}]+)}}') -- extract the #invoke:'s parameters
if not params then
return ''; -- there should be at least one or the template/module won't work TODO: error message?
end
table.insert (out, '{| class="wikitable" style="text-align:right; float:right"\n|+settings') -- start a wikitable
for k, v in params:gmatch ('%s*|%s*([^%s=]+)%s*=%s*([^%s|]+)') do -- get the parameter names (k) and values (v)
table.insert (out, table.concat ({k, '\n|', v})); -- make rudimentary wikitable entries
end
return table.concat ({table.concat (out,'\n|-\n! scope="row" | '), '\n|-\n|}'}); -- add inter-row markup and close the wikitable and done
else
return ''; -- does not use [[Module:Lang]] so abandon quietly
end
end
return p;