<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en-GB">
	<id>https://the-democratika.com/wiki/index.php?action=history&amp;feed=atom&amp;title=Module%3ADemo</id>
	<title>Module:Demo - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://the-democratika.com/wiki/index.php?action=history&amp;feed=atom&amp;title=Module%3ADemo"/>
	<link rel="alternate" type="text/html" href="https://the-democratika.com/wiki/index.php?title=Module:Demo&amp;action=history"/>
	<updated>2026-04-04T21:14:09Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.43.0</generator>
	<entry>
		<id>https://the-democratika.com/wiki/index.php?title=Module:Demo&amp;diff=9237&amp;oldid=prev</id>
		<title>&gt;BrandonXLF: Undid revision 1240199590 by BrandonXLF (talk)</title>
		<link rel="alternate" type="text/html" href="https://the-democratika.com/wiki/index.php?title=Module:Demo&amp;diff=9237&amp;oldid=prev"/>
		<updated>2024-08-14T02:31:11Z</updated>

		<summary type="html">&lt;p&gt;Undid revision &lt;a href=&quot;/wiki/index.php/Special:Diff/1240199590&quot; title=&quot;Special:Diff/1240199590&quot;&gt;1240199590&lt;/a&gt; by &lt;a href=&quot;/wiki/index.php/Special:Contributions/BrandonXLF&quot; title=&quot;Special:Contributions/BrandonXLF&quot;&gt;BrandonXLF&lt;/a&gt; (&lt;a href=&quot;/wiki/index.php?title=User_talk:BrandonXLF&amp;amp;action=edit&amp;amp;redlink=1&quot; class=&quot;new&quot; title=&quot;User talk:BrandonXLF (page does not exist)&quot;&gt;talk&lt;/a&gt;)&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;local p = {}&lt;br /&gt;
&lt;br /&gt;
--creates a frame object that cannot access any of the parent&amp;#039;s args&lt;br /&gt;
--unless a table containing a list keys of not to inherit is provided&lt;br /&gt;
function disinherit(frame, onlyTheseKeys)&lt;br /&gt;
	local parent = frame:getParent() or frame&lt;br /&gt;
	local orphan = parent:newChild{}&lt;br /&gt;
	orphan.getParent = parent.getParent --returns nil&lt;br /&gt;
	orphan.args = {}&lt;br /&gt;
	if onlyTheseKeys then&lt;br /&gt;
		local family = {parent, frame}&lt;br /&gt;
		for f = 1, 2 do&lt;br /&gt;
			for k, v in pairs(family[f] and family[f].args or {}) do&lt;br /&gt;
				orphan.args[k] = orphan.args[k] or v&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		parent.args = mw.clone(orphan.args)&lt;br /&gt;
		setmetatable(orphan.args, nil)&lt;br /&gt;
		for _, k in ipairs(onlyTheseKeys) do&lt;br /&gt;
			rawset(orphan.args, k, nil)&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	return orphan, parent&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function getSeparator(args, default)&lt;br /&gt;
	local br = tonumber(args.br) and (&amp;#039;&amp;lt;br&amp;gt;&amp;#039;):rep(args.br) or args.br&lt;br /&gt;
	local sep = args.sep or br or default&lt;br /&gt;
	return #sep &amp;gt; 0 and &amp;#039; &amp;#039; .. sep .. &amp;#039; &amp;#039; or sep&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.get(frame, arg, passArgs)&lt;br /&gt;
	local orphan, frame = disinherit(frame, passArgs and {arg or 1})&lt;br /&gt;
	local code = frame.args[arg or 1] or &amp;#039;&amp;#039;&lt;br /&gt;
	if code:match&amp;#039;UNIQ%-%-nowiki&amp;#039; then&lt;br /&gt;
		code = mw.text.unstripNoWiki(code)&lt;br /&gt;
			:gsub(&amp;#039;&amp;amp;lt;&amp;#039;, &amp;#039;&amp;lt;&amp;#039;)&lt;br /&gt;
			:gsub(&amp;#039;&amp;amp;gt;&amp;#039;, &amp;#039;&amp;gt;&amp;#039;)&lt;br /&gt;
			:gsub(&amp;#039;&amp;amp;quot;&amp;#039;, &amp;#039;&amp;quot;&amp;#039;)&lt;br /&gt;
			-- Replace `&amp;amp;#125;%-` with `}-` because of some server quirk leading to&lt;br /&gt;
			-- =mw.text.unstripNoWiki(mw.getCurrentFrame():preprocess(&amp;#039;&amp;lt;nowiki&amp;gt;}-&amp;lt;/nowiki&amp;gt;&amp;#039;))&lt;br /&gt;
			-- outputting `&amp;amp;#125;-` instead of `}-`, while it&amp;#039;s ok with `&amp;lt;nowiki&amp;gt;} -&amp;lt;/nowiki&amp;gt;`&lt;br /&gt;
			:gsub(&amp;#039;&amp;amp;#125;%-&amp;#039;, &amp;#039;}-&amp;#039;)&lt;br /&gt;
			-- The same with `-&amp;amp;#123;`&lt;br /&gt;
			:gsub(&amp;#039;%-&amp;amp;#123;&amp;#039;, &amp;#039;-{&amp;#039;)&lt;br /&gt;
	end&lt;br /&gt;
	local kill_categories = frame.args.demo_kill_categories or frame.args.nocat&lt;br /&gt;
	return {&lt;br /&gt;
		source = code,&lt;br /&gt;
		output = orphan:preprocess(code):gsub(kill_categories and &amp;#039;%[%[Category.-%]%]&amp;#039; or &amp;#039;&amp;#039;, &amp;#039;&amp;#039;),&lt;br /&gt;
		frame = frame&lt;br /&gt;
	}&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.main(frame, demoTable)&lt;br /&gt;
	local show = demoTable or p.get(frame)&lt;br /&gt;
	local args = show.frame.args&lt;br /&gt;
	if show[args.result_arg] then&lt;br /&gt;
		return show[args.result_arg]&lt;br /&gt;
	end&lt;br /&gt;
	local yesno = require(&amp;#039;Module:Yesno&amp;#039;)&lt;br /&gt;
	args.reverse = yesno(args.reverse, false)&lt;br /&gt;
	args.sep = getSeparator(args, &amp;#039;&amp;#039;)&lt;br /&gt;
	local source = frame:extensionTag{&lt;br /&gt;
		name = &amp;#039;syntaxhighlight&amp;#039;,&lt;br /&gt;
		args = {&lt;br /&gt;
			lang = &amp;#039;wikitext&amp;#039;,&lt;br /&gt;
			style = args.style&lt;br /&gt;
		},&lt;br /&gt;
		content = show.source&lt;br /&gt;
	}&lt;br /&gt;
	return args.reverse and&lt;br /&gt;
		show.output .. args.sep .. source or&lt;br /&gt;
		source .. args.sep .. show.output&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
-- Alternate function to return an inline result&lt;br /&gt;
function p.inline(frame, demoTable)&lt;br /&gt;
	local show = demoTable or p.get(frame)&lt;br /&gt;
	local args = show.frame.args&lt;br /&gt;
	if show[args.result_arg] then&lt;br /&gt;
		return show[args.result_arg]&lt;br /&gt;
	end&lt;br /&gt;
	local yesno = require(&amp;#039;Module:Yesno&amp;#039;)&lt;br /&gt;
	args.reverse = yesno(args.reverse, false)&lt;br /&gt;
	args.sep = getSeparator(args, args.reverse and &amp;#039;←&amp;#039; or &amp;#039;→&amp;#039;)&lt;br /&gt;
	local source =  frame:extensionTag{&lt;br /&gt;
		name = &amp;#039;syntaxhighlight&amp;#039;,&lt;br /&gt;
		args = {&lt;br /&gt;
			lang = &amp;#039;wikitext&amp;#039;,&lt;br /&gt;
			inline = true,&lt;br /&gt;
			style = args.style&lt;br /&gt;
		},&lt;br /&gt;
		content = show.source&lt;br /&gt;
	}&lt;br /&gt;
	return args.reverse and&lt;br /&gt;
		show.output .. args.sep .. source or&lt;br /&gt;
		source .. args.sep .. show.output&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
--passing of args into other module without preprocessing&lt;br /&gt;
function p.module(frame)&lt;br /&gt;
	local orphan, frame = disinherit(frame, {&lt;br /&gt;
		&amp;#039;demo_template&amp;#039;,&lt;br /&gt;
		&amp;#039;demo_module&amp;#039;,&lt;br /&gt;
		&amp;#039;demo_module_func&amp;#039;,&lt;br /&gt;
		&amp;#039;demo_main&amp;#039;,&lt;br /&gt;
		&amp;#039;demo_sep&amp;#039;,&lt;br /&gt;
		&amp;#039;demo_br&amp;#039;,&lt;br /&gt;
		&amp;#039;demo_result_arg&amp;#039;,&lt;br /&gt;
		&amp;#039;demo_kill_categories&amp;#039;,&lt;br /&gt;
		&amp;#039;nocat&amp;#039;&lt;br /&gt;
	})&lt;br /&gt;
	local template = frame.args.demo_template and &amp;#039;Template:&amp;#039;..frame.args.demo_template&lt;br /&gt;
	local demoFunc = frame.args.demo_module_func or &amp;#039;main\n&amp;#039;&lt;br /&gt;
	local demoModule = require(&amp;#039;Module:&amp;#039; .. frame.args.demo_module)[demoFunc:match(&amp;#039;^%s*(.-)%s*$&amp;#039;)]&lt;br /&gt;
	frame.args.br, frame.args.result_arg = frame.args.demo_sep or frame.args.demo_br, frame.args.demo_result_arg&lt;br /&gt;
	local kill_categories = frame.args.demo_kill_categories or frame.args.nocat&lt;br /&gt;
	if demoModule then&lt;br /&gt;
		local named = {insert = function(self, ...) table.insert(self, ...) return self end}&lt;br /&gt;
		local source = {insert = named.insert, &amp;#039;{{&amp;#039;, frame.args.demo_template or frame.args.demo_module, &amp;#039;\n&amp;#039;}&lt;br /&gt;
		if not template then&lt;br /&gt;
			source:insert(2, &amp;#039;#invoke:&amp;#039;):insert(4, &amp;#039;|&amp;#039;):insert(5, demoFunc)&lt;br /&gt;
		end&lt;br /&gt;
		local insertNamed = #source + 1&lt;br /&gt;
		for k, v in pairs(orphan.args) do&lt;br /&gt;
			local nan, insert = type(k) ~= &amp;#039;number&amp;#039;, {v}&lt;br /&gt;
			local target = nan and named or source&lt;br /&gt;
			target:insert&amp;#039;|&amp;#039;&lt;br /&gt;
			if nan then&lt;br /&gt;
				target:insert(k):insert&amp;#039;=&amp;#039;:insert&amp;#039;\n&amp;#039;&lt;br /&gt;
				table.insert(insert, 1, #target)&lt;br /&gt;
			end&lt;br /&gt;
			target:insert(unpack(insert))&lt;br /&gt;
			local nowiki = v:match(&amp;#039;nowiki&amp;#039;)&lt;br /&gt;
			if nowiki or v:match(&amp;#039;{{.-}}&amp;#039;) then&lt;br /&gt;
				orphan.args[k] = frame:preprocess(nowiki and mw.text.unstripNoWiki(v) or v)&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		source:insert&amp;#039;}}&amp;#039;&lt;br /&gt;
		table.insert(source, insertNamed, table.concat(named))&lt;br /&gt;
		return p.main(orphan, {&lt;br /&gt;
			source = table.concat(source), &amp;quot;&amp;lt;&amp;gt;&amp;#039;|=~&amp;quot;,&lt;br /&gt;
			output = tostring(demoModule(orphan)):gsub(kill_categories and &amp;#039;%[%[Category.-%]%]&amp;#039; or &amp;#039;&amp;#039;, &amp;#039;&amp;#039;),&lt;br /&gt;
			frame = frame&lt;br /&gt;
		})&lt;br /&gt;
	else&lt;br /&gt;
		return &amp;quot;ERROR: Invalid module function: &amp;quot;..demoFunc&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>&gt;BrandonXLF</name></author>
	</entry>
</feed>