# HG changeset patch # User Matthew Wild # Date 1238462293 -3600 # Node ID 7f161205121d50f940afb603922a569816291238 # Parent dae54304967d7e57e3b64a6079405aa500b92a0e Add lock_globals() and unlock_globals() functions (for when you really need to use globals) diff -r dae54304967d -r 7f161205121d prosody --- a/prosody Tue Mar 31 02:17:11 2009 +0100 +++ b/prosody Tue Mar 31 02:18:13 2009 +0100 @@ -152,7 +152,17 @@ end -- setup error handling -setmetatable(_G, { __index = function (t, k) error("Attempt to read a non-existent global '"..k.."'", 2); end, __newindex = function (t, k, v) error("Attempt to set a global: "..tostring(k).." = "..tostring(v), 2); end }); +local locked_globals_mt = { __index = function (t, k) error("Attempt to read a non-existent global '"..k.."'", 2); end, __newindex = function (t, k, v) error("Attempt to set a global: "..tostring(k).." = "..tostring(v), 2); end } + +function unlock_globals() + setmetatable(_G, nil); +end + +function lock_globals() + setmetatable(_G, locked_globals_mt); +end + +lock_globals(); eventmanager.fire_event("server-started");