From d451271bf4fce61ff0ca4469fc18cc1abd01e6e8 Mon Sep 17 00:00:00 2001 From: ThePhD Date: Sun, 4 Sep 2016 10:54:55 -0400 Subject: [PATCH] protected function updates --- .gitignore | 1 + sol/protected_function.hpp | 6 ++++-- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/.gitignore b/.gitignore index 67ddbed9..ac54ec14 100644 --- a/.gitignore +++ b/.gitignore @@ -68,3 +68,4 @@ main.o lua-5.3.3/ *.pdf main.lua +LuaJIT-2.1.0/ diff --git a/sol/protected_function.hpp b/sol/protected_function.hpp index 05554c2c..cdca41e7 100644 --- a/sol/protected_function.hpp +++ b/sol/protected_function.hpp @@ -87,7 +87,8 @@ namespace sol { protected_function_result invoke(types<>, std::index_sequence<>, std::ptrdiff_t n, handler& h) const { int stacksize = lua_gettop(base_t::lua_state()); - int firstreturn = (std::max)(1, stacksize - static_cast(n) - 1); + int poststacksize = stacksize; + int firstreturn = 1; int returncount = 0; call_status code = call_status::ok; #ifndef SOL_NO_EXCEPTIONS @@ -105,8 +106,9 @@ namespace sol { try { #endif // No Exceptions code = luacall(n, LUA_MULTRET, h); - int poststacksize = lua_gettop(base_t::lua_state()); + poststacksize = lua_gettop(base_t::lua_state()); returncount = poststacksize - (stacksize - 1); + firstreturn = (std::max)(1, poststacksize - (returncount - 1) - static_cast(h.valid())); #ifndef SOL_NO_EXCEPTIONS } // Handle C++ errors thrown from C++ functions bound inside of lua