<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en-GB">
	<id>https://stockhub.co/index.php?action=history&amp;feed=atom&amp;title=Module%3ASandbox%2FArtoria2e5%2FFallback</id>
	<title>Module:Sandbox/Artoria2e5/Fallback - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://stockhub.co/index.php?action=history&amp;feed=atom&amp;title=Module%3ASandbox%2FArtoria2e5%2FFallback"/>
	<link rel="alternate" type="text/html" href="https://stockhub.co/index.php?title=Module:Sandbox/Artoria2e5/Fallback&amp;action=history"/>
	<updated>2026-05-27T10:36:51Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.43.5</generator>
	<entry>
		<id>https://stockhub.co/index.php?title=Module:Sandbox/Artoria2e5/Fallback&amp;diff=145158&amp;oldid=prev</id>
		<title>imported&gt;Plastikspork: Plastikspork moved page Module:Arguments/Fallback to Module:Sandbox/Artoria2e5/Fallback without leaving a redirect: Per user request</title>
		<link rel="alternate" type="text/html" href="https://stockhub.co/index.php?title=Module:Sandbox/Artoria2e5/Fallback&amp;diff=145158&amp;oldid=prev"/>
		<updated>2020-04-02T17:16:07Z</updated>

		<summary type="html">&lt;p&gt;Plastikspork moved page &lt;a href=&quot;/index.php?title=Module:Arguments/Fallback&amp;amp;action=edit&amp;amp;redlink=1&quot; class=&quot;new&quot; title=&quot;Module:Arguments/Fallback (page does not exist)&quot;&gt;Module:Arguments/Fallback&lt;/a&gt; to &lt;a href=&quot;/research/Module:Sandbox/Artoria2e5/Fallback&quot; title=&quot;Module:Sandbox/Artoria2e5/Fallback&quot;&gt;Module:Sandbox/Artoria2e5/Fallback&lt;/a&gt; without leaving a redirect: Per user request&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;-- A simple index fallback implementation for tables.&lt;br /&gt;
-- Useful for template argument aliasing.&lt;br /&gt;
-- Hmm, what about __newindex?&lt;br /&gt;
&lt;br /&gt;
local function makeFallback(args, arg_aliases)&lt;br /&gt;
	local oldArgsMeta = getmetatable(args) or {}&lt;br /&gt;
	local newArgsMeta = {}&lt;br /&gt;
	&lt;br /&gt;
	-- Forget about thread-safety.&lt;br /&gt;
	-- States kept to avoid strange loops.&lt;br /&gt;
	local referencedKeys = {} -- dataType:Set/hashtable-impl&lt;br /&gt;
	local attemptDepth = 0    -- useful for &amp;quot;last nil&amp;quot; case&lt;br /&gt;
	&lt;br /&gt;
	-- Start the new metatable as a copy of the old metatable.&lt;br /&gt;
	for k, v in ipairs(oldArgsMeta) do&lt;br /&gt;
		newArgsMeta[k] = v&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
	-- Change the __index metamethod to our implementation.&lt;br /&gt;
	-- See https://www.lua.org/pil/13.4.1.html.&lt;br /&gt;
	newArgsMeta.__index = function (t, k)&lt;br /&gt;
		-- My friend, why are you here again?&lt;br /&gt;
		if referencedKeys[k] then&lt;br /&gt;
			-- You have to be drunk. Go home.&lt;br /&gt;
			return nil&lt;br /&gt;
		end&lt;br /&gt;
		referencedKeys[k] = true&lt;br /&gt;
		&lt;br /&gt;
		-- Try the old metamethod first.&lt;br /&gt;
		-- Thanks to closures, this whole oldArgsMeta object will stay.&lt;br /&gt;
		if oldArgsMeta.__index ~= nil then&lt;br /&gt;
			local val = oldArgsMeta.__index(t, k)&lt;br /&gt;
			if val ~= nil then&lt;br /&gt;
				referencedKeys = {}&lt;br /&gt;
				return val&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		&lt;br /&gt;
		attemptDepth = attemptDepth + 1&lt;br /&gt;
		-- Now try use the aliases given.&lt;br /&gt;
		for _, v in ipairs(arg_aliases[k] or {}) do&lt;br /&gt;
			-- If a working value is found, use it.&lt;br /&gt;
			-- Note: mw-argument-specific empty str chk.&lt;br /&gt;
			if t[v] ~= nil and t[v] ~= &amp;#039;&amp;#039; then&lt;br /&gt;
				referencedKeys = {}&lt;br /&gt;
				return t[v]&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		attemptDepth = attemptDepth - 1&lt;br /&gt;
		&lt;br /&gt;
		if attemptDepth == 0 then&lt;br /&gt;
			referencedKeys = {}&lt;br /&gt;
		end&lt;br /&gt;
		return nil&lt;br /&gt;
	end&lt;br /&gt;
	setmetatable(args, newArgsMeta)&lt;br /&gt;
	return args  -- just in case someone wants a return value.&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
return makeFallback&lt;br /&gt;
&lt;br /&gt;
--[[&lt;br /&gt;
P.S. Don&amp;#039;t blame me for writing these obj-states. Sure, we can use an&lt;br /&gt;
accumulator and do some &amp;quot;index with acc&amp;quot; ourselves, but that sounds like too&lt;br /&gt;
much work done just to avoid states.&lt;br /&gt;
&lt;br /&gt;
Here is that custom index function in case anyone is curious about it:&lt;br /&gt;
&lt;br /&gt;
	function index_w_acc(t, k, acc)&lt;br /&gt;
	    local v = rawget(t, k)&lt;br /&gt;
	    if v ~= nil&lt;br /&gt;
	        return v&lt;br /&gt;
	    else&lt;br /&gt;
	        return getmetatable(t).__index(k, acc)&lt;br /&gt;
	   end&lt;br /&gt;
	end&lt;br /&gt;
&lt;br /&gt;
My guess is that it will certainly be slower than the native t[k] one. Perhaps&lt;br /&gt;
not getting the metatable every time will help a bit.&lt;br /&gt;
]]--&lt;/div&gt;</summary>
		<author><name>imported&gt;Plastikspork</name></author>
	</entry>
</feed>