<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://moasspedia.org/w/index.php?action=history&amp;feed=atom&amp;title=Module%3ALog_globals</id>
	<title>Module:Log globals - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://moasspedia.org/w/index.php?action=history&amp;feed=atom&amp;title=Module%3ALog_globals"/>
	<link rel="alternate" type="text/html" href="https://moasspedia.org/w/index.php?title=Module:Log_globals&amp;action=history"/>
	<updated>2026-04-13T13:22:56Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.37.2</generator>
	<entry>
		<id>https://moasspedia.org/w/index.php?title=Module:Log_globals&amp;diff=2612&amp;oldid=prev</id>
		<title>Wikipedia&gt;Erutuon: return rawget and rawset so as not to interfere with operation of module</title>
		<link rel="alternate" type="text/html" href="https://moasspedia.org/w/index.php?title=Module:Log_globals&amp;diff=2612&amp;oldid=prev"/>
		<updated>2018-09-30T18:07:40Z</updated>

		<summary type="html">&lt;p&gt;return rawget and rawset so as not to interfere with operation of module&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;local mt = getmetatable(_G) or {}&lt;br /&gt;
&lt;br /&gt;
local function print(val)&lt;br /&gt;
	if type(val) == &amp;quot;table&amp;quot; then&lt;br /&gt;
		local printout = {}&lt;br /&gt;
		local i = 1&lt;br /&gt;
		for k, v in pairs(val) do&lt;br /&gt;
			table.insert(printout, (&amp;quot;[%s] = %s&amp;quot;):format(tostring(k), tostring(v)) )&lt;br /&gt;
			i = i + 1&lt;br /&gt;
			if i &amp;gt; 5 then&lt;br /&gt;
				table.insert(printout, &amp;quot;...&amp;quot;)&lt;br /&gt;
				break&lt;br /&gt;
			end&lt;br /&gt;
		end&lt;br /&gt;
		printout = { table.concat(printout, &amp;quot;, &amp;quot;) }&lt;br /&gt;
		table.insert(printout, 1, &amp;quot;{&amp;quot;)&lt;br /&gt;
		table.insert(printout, &amp;quot;}&amp;quot;)&lt;br /&gt;
		return table.concat(printout)&lt;br /&gt;
	elseif type(val) == &amp;quot;string&amp;quot; then&lt;br /&gt;
		return &amp;#039;&amp;quot;&amp;#039; .. val .. &amp;#039;&amp;quot;&amp;#039;&lt;br /&gt;
	else&lt;br /&gt;
		return tostring(val)&lt;br /&gt;
	end&lt;br /&gt;
end&lt;br /&gt;
		&lt;br /&gt;
&lt;br /&gt;
mt.__newindex = function (self, key, value)&lt;br /&gt;
	if key ~= &amp;quot;arg&amp;quot; then&lt;br /&gt;
		mw.log(&amp;quot;Global variable &amp;quot; .. print(key) .. &amp;quot; was set to &amp;quot;&lt;br /&gt;
			.. print(value) .. &amp;quot; somewhere:&amp;quot;,&lt;br /&gt;
			debug.traceback(&amp;quot;&amp;quot;, 2))&lt;br /&gt;
	end&lt;br /&gt;
	return rawset(self, key, value)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
mt.__index = function (self, key)&lt;br /&gt;
	if key ~= &amp;quot;arg&amp;quot; then&lt;br /&gt;
		mw.log(&amp;quot;Nil global variable &amp;quot; .. print(key) .. &amp;quot; was read somewhere:&amp;quot;,&lt;br /&gt;
			debug.traceback(&amp;quot;&amp;quot;, 2))&lt;br /&gt;
	end&lt;br /&gt;
	return rawget(self, key)&lt;br /&gt;
end&lt;br /&gt;
&lt;br /&gt;
setmetatable(_G, mt)&lt;/div&gt;</summary>
		<author><name>Wikipedia&gt;Erutuon</name></author>
	</entry>
</feed>