diff options
author | madmaxoft <github@xoft.cz> | 2014-01-19 23:45:26 +0100 |
---|---|---|
committer | madmaxoft <github@xoft.cz> | 2014-01-19 23:45:26 +0100 |
commit | 4a01879911c5673612693531c4f8970c1644947b (patch) | |
tree | 38c8ba5c9571accc9f172843da2db741e78ae6a4 /src/Bindings/LuaState.cpp | |
parent | Merge pull request #569 from worktycho/EnchantmentsFix (diff) | |
download | cuberite-4a01879911c5673612693531c4f8970c1644947b.tar cuberite-4a01879911c5673612693531c4f8970c1644947b.tar.gz cuberite-4a01879911c5673612693531c4f8970c1644947b.tar.bz2 cuberite-4a01879911c5673612693531c4f8970c1644947b.tar.lz cuberite-4a01879911c5673612693531c4f8970c1644947b.tar.xz cuberite-4a01879911c5673612693531c4f8970c1644947b.tar.zst cuberite-4a01879911c5673612693531c4f8970c1644947b.zip |
Diffstat (limited to 'src/Bindings/LuaState.cpp')
-rw-r--r-- | src/Bindings/LuaState.cpp | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/src/Bindings/LuaState.cpp b/src/Bindings/LuaState.cpp index 00e62fcf6..bfee1d037 100644 --- a/src/Bindings/LuaState.cpp +++ b/src/Bindings/LuaState.cpp @@ -914,6 +914,40 @@ bool cLuaState::CheckParamString(int a_StartParam, int a_EndParam) +bool cLuaState::CheckParamFunction(int a_StartParam, int a_EndParam) +{ + ASSERT(IsValid()); + + if (a_EndParam < 0) + { + a_EndParam = a_StartParam; + } + + for (int i = a_StartParam; i <= a_EndParam; i++) + { + if (lua_isfunction(m_LuaState, i)) + { + continue; + } + // Not the correct parameter + lua_Debug entry; + VERIFY(lua_getstack(m_LuaState, 0, &entry)); + VERIFY(lua_getinfo (m_LuaState, "n", &entry)); + AString ErrMsg = Printf("Error in function '%s' parameter #%d. Function expected, got %s", + (entry.name != NULL) ? entry.name : "?", i, GetTypeText(i).c_str() + ); + LogStackTrace(); + return false; + } // for i - Param + + // All params checked ok + return true; +} + + + + + bool cLuaState::CheckParamEnd(int a_Param) { tolua_Error tolua_err; |