<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://chabadpedia.com/index.php?action=history&amp;feed=atom&amp;title=Module%3AUser</id>
	<title>Module:User - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://chabadpedia.com/index.php?action=history&amp;feed=atom&amp;title=Module%3AUser"/>
	<link rel="alternate" type="text/html" href="https://chabadpedia.com/index.php?title=Module:User&amp;action=history"/>
	<updated>2026-04-10T19:56:56Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.43.1</generator>
	<entry>
		<id>https://chabadpedia.com/index.php?title=Module:User&amp;diff=8305&amp;oldid=prev</id>
		<title>Shia.k: Created page with &quot;--[=[ -- This module implements {{user}}. {{user}} is a high-use template, sometimes -- with thousands of transclusions on a page. This module optimises the -- template&#039;s performance by reducing the number of parameters called from -- wikitext, while still allowing all the features provided by -- Module:UserLinks. It is about twice as fast as the version of {{user}} -- that called the {{user-multi}} template from wikitext. --]=]  local mUserLinks = require(&#039;Module:Us...&quot;</title>
		<link rel="alternate" type="text/html" href="https://chabadpedia.com/index.php?title=Module:User&amp;diff=8305&amp;oldid=prev"/>
		<updated>2025-04-17T19:24:28Z</updated>

		<summary type="html">&lt;p&gt;Created page with &amp;quot;--[=[ -- This module implements {{user}}. {{user}} is a high-use template, sometimes -- with thousands of transclusions on a page. This module optimises the -- template&amp;#039;s performance by reducing the number of parameters called from -- wikitext, while still allowing all the features provided by -- &lt;a href=&quot;/index.php/Module:UserLinks&quot; title=&quot;Module:UserLinks&quot;&gt;Module:UserLinks&lt;/a&gt;. It is about twice as fast as the version of {{user}} -- that called the {{user-multi}} template from wikitext. --]=]  local mUserLinks = require(&amp;#039;Module:Us...&amp;quot;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;--[=[&lt;br /&gt;
-- This module implements {{user}}. {{user}} is a high-use template, sometimes&lt;br /&gt;
-- with thousands of transclusions on a page. This module optimises the&lt;br /&gt;
-- template&amp;#039;s performance by reducing the number of parameters called from&lt;br /&gt;
-- wikitext, while still allowing all the features provided by&lt;br /&gt;
-- [[Module:UserLinks]]. It is about twice as fast as the version of {{user}}&lt;br /&gt;
-- that called the {{user-multi}} template from wikitext.&lt;br /&gt;
--]=]&lt;br /&gt;
&lt;br /&gt;
local mUserLinks = require(&amp;#039;Module:UserLinks&amp;#039;)&lt;br /&gt;
local mShared = require(&amp;#039;Module:UserLinks/shared&amp;#039;)&lt;br /&gt;
local yesno = require(&amp;#039;Module:Yesno&amp;#039;)&lt;br /&gt;
&lt;br /&gt;
local p = {}&lt;br /&gt;
&lt;br /&gt;
local function validateArg(arg)&lt;br /&gt;
	-- Validates one argument. Whitespace is stripped, and blank arguments&lt;br /&gt;
	-- are treated as nil.&lt;br /&gt;
	if not arg then&lt;br /&gt;
		return nil&lt;br /&gt;
	end&lt;br /&gt;
	arg = arg:match(&amp;#039;^%s*(.-)%s*$&amp;#039;)&lt;br /&gt;
	if arg ~= &amp;#039;&amp;#039; then&lt;br /&gt;
		return arg&lt;br /&gt;
	else&lt;br /&gt;
		return nil&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.main(frame, opts)&lt;br /&gt;
	-- Grab the user, project and lang args from wikitext.&lt;br /&gt;
	local argKeys = {&lt;br /&gt;
		user = {&lt;br /&gt;
			1,&lt;br /&gt;
			&amp;#039;User&amp;#039;,&lt;br /&gt;
			&amp;#039;user&amp;#039;&lt;br /&gt;
		},&lt;br /&gt;
		project = {&lt;br /&gt;
			2,&lt;br /&gt;
			&amp;#039;Project&amp;#039;,&lt;br /&gt;
			&amp;#039;project&amp;#039;&lt;br /&gt;
		},&lt;br /&gt;
		lang = {&lt;br /&gt;
			3,&lt;br /&gt;
			&amp;#039;Lang&amp;#039;,&lt;br /&gt;
			&amp;#039;lang&amp;#039;&lt;br /&gt;
		}&lt;br /&gt;
	}&lt;br /&gt;
	local origArgs = require(&amp;#039;Module:Arguments&amp;#039;).getArgs(frame)&lt;br /&gt;
	local args = {}&lt;br /&gt;
	for argKey, t in pairs(argKeys) do&lt;br /&gt;
		for i, origArgKey in ipairs(t) do&lt;br /&gt;
			local value = origArgs[origArgKey]&lt;br /&gt;
			value = validateArg(value)&lt;br /&gt;
			if value then&lt;br /&gt;
				args[argKey] = value&lt;br /&gt;
				-- If we have found a value, break the loop. For the average&lt;br /&gt;
				-- invocation this saves two argument lookups.&lt;br /&gt;
				break&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
	end&lt;br /&gt;
	&lt;br /&gt;
	-- Generate options. Some of these need wikitext args also.&lt;br /&gt;
	local options = {&lt;br /&gt;
		span = false,&lt;br /&gt;
		separator = validateArg(origArgs.separator) or &amp;#039;dot&amp;#039;,&lt;br /&gt;
		isDemo = yesno(validateArg(origArgs.demo))&lt;br /&gt;
	}&lt;br /&gt;
	&lt;br /&gt;
	-- Input the codes directly. This saves two argument lookups for each&lt;br /&gt;
	-- invocation.&lt;br /&gt;
	local codes = type(opts) and opts or {&amp;#039;t&amp;#039;, &amp;#039;c&amp;#039;}&lt;br /&gt;
	&lt;br /&gt;
	-- Generate mop icon for formeradmin&lt;br /&gt;
	local mop = (origArgs.mop and yesno(origArgs.mop)) and require(&amp;#039;Module:Icon&amp;#039;)._main({&amp;#039;mop&amp;#039;}) or &amp;#039;&amp;#039;&lt;br /&gt;
	&lt;br /&gt;
	-- Plug the data into [[Module:UserLinks]].&lt;br /&gt;
	local snippets = mUserLinks.getSnippets(args)&lt;br /&gt;
	local links = mUserLinks.getLinks(snippets)&lt;br /&gt;
	local success, result = pcall(mUserLinks.export, codes, links, options)&lt;br /&gt;
	if success then&lt;br /&gt;
		return mop .. result&lt;br /&gt;
	else&lt;br /&gt;
		return mShared.makeWikitextError(result, options.isDemo)&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
function p.admin(frame)&lt;br /&gt;
	return p.main(frame, {&amp;#039;t&amp;#039;,&amp;#039;c&amp;#039;,&amp;#039;bls&amp;#039;,&amp;#039;pr&amp;#039;,&amp;#039;del&amp;#039;,&amp;#039;m&amp;#039;,&amp;#039;rl&amp;#039;,&amp;#039;rfa&amp;#039;})&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.eight(frame)&lt;br /&gt;
	return p.main(frame, {&amp;#039;t&amp;#039;, &amp;#039;c&amp;#039;, &amp;#039;ca&amp;#039;, &amp;#039;ct&amp;#039;, &amp;#039;e&amp;#039;})&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.five(frame)&lt;br /&gt;
	return p.main(frame, {&amp;#039;t&amp;#039;, &amp;#039;c&amp;#039;, &amp;#039;dc&amp;#039;, &amp;#039;m&amp;#039;, &amp;#039;bu&amp;#039;, &amp;#039;bl&amp;#039;})&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.four(frame)&lt;br /&gt;
	return p.main(frame, {&amp;#039;t&amp;#039;, &amp;#039;c&amp;#039;, &amp;#039;e&amp;#039;})&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.formeradmin(frame)&lt;br /&gt;
	return p.main(frame, {&amp;#039;t&amp;#039;,&amp;#039;c&amp;#039;,&amp;#039;fa&amp;#039;,&amp;#039;bls&amp;#039;,&amp;#039;pr&amp;#039;,&amp;#039;del&amp;#039;,&amp;#039;rl&amp;#039;,&amp;#039;mr&amp;#039;,&amp;#039;lr&amp;#039;})&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.seven(frame)&lt;br /&gt;
	return p.main(frame, {&amp;#039;t&amp;#039;, &amp;#039;c&amp;#039;, &amp;#039;ct&amp;#039;, &amp;#039;l&amp;#039;, &amp;#039;e&amp;#039;})&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.six(frame)&lt;br /&gt;
	return p.main(frame, {&amp;#039;t&amp;#039;, &amp;#039;c&amp;#039;, &amp;#039;ct&amp;#039;, &amp;#039;l&amp;#039;, &amp;#039;m&amp;#039;, &amp;#039;bl&amp;#039;})&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.three(frame)&lt;br /&gt;
	return p.main(frame, {&amp;#039;t&amp;#039;, &amp;#039;c&amp;#039;, &amp;#039;l&amp;#039;})&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
function p.two(frame)&lt;br /&gt;
	return p.main(frame, {&amp;#039;t&amp;#039;, &amp;#039;c&amp;#039;, &amp;#039;ct&amp;#039;})&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
p[&amp;#039;&amp;#039;] = p.main&lt;br /&gt;
p[&amp;#039;2&amp;#039;] = p.two&lt;br /&gt;
p[&amp;#039;3&amp;#039;] = p.three&lt;br /&gt;
p[&amp;#039;4&amp;#039;] = p.four&lt;br /&gt;
p[&amp;#039;5&amp;#039;] = p.five&lt;br /&gt;
p[&amp;#039;6&amp;#039;] = p.six&lt;br /&gt;
p[&amp;#039;7&amp;#039;] = p.seven&lt;br /&gt;
p[&amp;#039;8&amp;#039;] = p.eight&lt;br /&gt;
p[&amp;#039;former admin&amp;#039;] = p.formeradmin&lt;br /&gt;
&lt;br /&gt;
return p&lt;/div&gt;</summary>
		<author><name>Shia.k</name></author>
	</entry>
</feed>