From b8a7503a30a06f53e0cfbc602b210bea1b49ec82 Mon Sep 17 00:00:00 2001 From: Pavel Labath Date: Fri, 8 Jul 2011 19:08:49 +0200 Subject: Small optimization of the newindexDeny{Write,Modify} functions --- src/FbTk/LuaUtil.cc | 23 ++++++++++++++++++++--- 1 file changed, 20 insertions(+), 3 deletions(-) diff --git a/src/FbTk/LuaUtil.cc b/src/FbTk/LuaUtil.cc index 456abac..7c24331 100644 --- a/src/FbTk/LuaUtil.cc +++ b/src/FbTk/LuaUtil.cc @@ -25,7 +25,12 @@ #include "LuaUtil.hh" +namespace FbTk { + namespace { + const char newindexDenyWriteName[] = "FbTk::Lua::newindexDenyWrite"; + const char newindexDenyModifyName[] = "FbTk::Lua::newindexDenyModify"; + int newindexDenyWrite(lua::state *l) { if(l->isstring(-2)) throw std::runtime_error("Cannot modify field '" + l->tostring(-2) + "'."); @@ -53,9 +58,20 @@ namespace { return 0; } -} -namespace FbTk { + void registerNewindexes(Lua &l) { + l.checkstack(1); + lua::stack_sentry s(l); + + l.pushfunction(&newindexDenyWrite); + l.rawsetfield(lua::REGISTRYINDEX, newindexDenyWriteName); + + l.pushfunction(&newindexDenyModify); + l.rawsetfield(lua::REGISTRYINDEX, newindexDenyModifyName); + } + + Lua::RegisterInitFunction register_newindexes(®isterNewindexes); +} // anonymous namespace Lua::InitFunctions Lua::s_init_functions; @@ -81,7 +97,8 @@ void Lua::makeReadOnly(int index, bool only_existing_fields) { } } rawsetfield(-2, "__index"); - pushfunction(only_existing_fields ? &newindexDenyModify : &newindexDenyWrite); + rawgetfield(lua::REGISTRYINDEX, + only_existing_fields ? newindexDenyModifyName : newindexDenyWriteName); rawsetfield(-2, "__newindex"); pushboolean(false); -- cgit v0.11.2