diff options
author | Thorbjørn Lindeijer <bjorn@lindeijer.nl> | 2022-05-25 12:38:49 +0200 |
---|---|---|
committer | Thorbjørn Lindeijer <bjorn@lindeijer.nl> | 2022-05-25 12:43:44 +0200 |
commit | ca16e8d37629cf2d80bb9fb5a134ea17595de7ce (patch) | |
tree | 574948671e2f8343a9126301ff63302f556020aa | |
parent | fc973c5ec32dc10256c81e9f199cdf6e7131b155 (diff) | |
download | manaserv-ca16e8d37629cf2d80bb9fb5a134ea17595de7ce.tar.gz manaserv-ca16e8d37629cf2d80bb9fb5a134ea17595de7ce.tar.bz2 manaserv-ca16e8d37629cf2d80bb9fb5a134ea17595de7ce.tar.xz manaserv-ca16e8d37629cf2d80bb9fb5a134ea17595de7ce.zip |
Fixed compile against Lua 5.4
Now lua_resume takes 4 arguments, and the number of result values is set
on the 4th one.
-rw-r--r-- | src/scripting/luascript.cpp | 13 |
1 files changed, 9 insertions, 4 deletions
diff --git a/src/scripting/luascript.cpp b/src/scripting/luascript.cpp index 42a78955..06fbd2ab 100644 --- a/src/scripting/luascript.cpp +++ b/src/scripting/luascript.cpp @@ -159,18 +159,23 @@ bool LuaScript::resume() nbArgs = -1; #if LUA_VERSION_NUM < 502 int result = lua_resume(mCurrentState, tmpNbArgs); -#else + int nresults = lua_gettop(mCurrentState); +#elif LUA_VERSION_NUM < 504 int result = lua_resume(mCurrentState, nullptr, tmpNbArgs); + int nresults = lua_gettop(mCurrentState); +#else + int nresults = 0; + int result = lua_resume(mCurrentState, nullptr, tmpNbArgs, &nresults); #endif if (result == 0) // Thread is done { - if (lua_gettop(mCurrentState) > 0) + if (nresults > 0) LOG_WARN("Ignoring values returned by script thread!"); } else if (result == LUA_YIELD) // Thread has yielded { - if (lua_gettop(mCurrentState) > 0) + if (nresults > 0) LOG_WARN("Ignoring values passed to yield!"); } else // Thread encountered an error @@ -195,7 +200,7 @@ bool LuaScript::resume() delete mCurrentThread; } - mCurrentThread = 0; + mCurrentThread = nullptr; mCurrentState = mRootState; return done; |