Module:No globals: Difference between revisions
Jump to navigation
Jump to search
en>Jackmcbarn (don't bother saving old __index or __newindex) |
en>Jackmcbarn (setting doesn't need exception for name) |
||
Line 7: | Line 7: | ||
end | end | ||
function mt.__newindex(t, k, v) | function mt.__newindex(t, k, v) | ||
if | if k ~= 'arg' then | ||
error('Tried to write global ' .. tostring(k), 2) | error('Tried to write global ' .. tostring(k), 2) | ||
end | end |
Revision as of 20:48, 23 April 2014
This is a meta module.
This module is meant to be used only by other modules. It should not be invoked in wikitext.
This module prevents the use of global variables within Scribunto modules, in order to avoid creating bugs that are difficult to track down. When using this module, an error will be thrown if any nil global is read or if any global is written to, with the exception of arg. The arg variable is excluded because it is necessary for Scribunto's require function to work properly.
Usage
Place require('Module:No globals')
at the top of the module using it.
This module was adapted from Module:No globals on Wikipedia.
Adaptation is noted for reference and attribution only. This module may differ from the original in function or in usage.
Adaptation is noted for reference and attribution only. This module may differ from the original in function or in usage.
The above documentation is transcluded from Module:No globals/doc.
Editors can experiment in this module's sandbox and testcases pages.
Subpages of this module.
Editors can experiment in this module's sandbox and testcases pages.
Subpages of this module.
local mt = getmetatable(_G) or {}
function mt.__index (t, k)
if k ~= 'name' and k ~= 'arg' then
error('Tried to read nil global ' .. tostring(k), 2)
end
return nil
end
function mt.__newindex(t, k, v)
if k ~= 'arg' then
error('Tried to write global ' .. tostring(k), 2)
end
rawset(t, k, v)
end
setmetatable(_G, mt)