[Scummvm-git-logs] scummvm branch-2-7 -> 2cd111b7e43710a232c70f4fb15a1d3387e021fb

aquadran noreply at scummvm.org
Tue Jan 31 15:10:58 UTC 2023


This automated email contains information about 1 new commit which have been
pushed to the 'scummvm' repo located at https://github.com/scummvm/scummvm .

Summary:
2cd111b7e4 GRIM: Restore LUA W/A for release. It might still needed for old save games.


Commit: 2cd111b7e43710a232c70f4fb15a1d3387e021fb
    https://github.com/scummvm/scummvm/commit/2cd111b7e43710a232c70f4fb15a1d3387e021fb
Author: Paweł Kołodziejski (aquadran at gmail.com)
Date: 2023-01-31T16:10:31+01:00

Commit Message:
GRIM: Restore LUA W/A for release. It might still needed for old save games.

Changed paths:
    engines/grim/lua/ldo.cpp


diff --git a/engines/grim/lua/ldo.cpp b/engines/grim/lua/ldo.cpp
index 1d2a309bfd2..1189598a3b8 100644
--- a/engines/grim/lua/ldo.cpp
+++ b/engines/grim/lua/ldo.cpp
@@ -233,8 +233,18 @@ int32 luaD_call(StkId base, int32 nResults) {
 			firstResult = callC(fvalue(funcObj), base);
 		} else {
 			TObject *im = luaT_getimbyObj(funcObj, IM_FUNCTION);
-			if (ttype(im) == LUA_T_NIL)
-				lua_error("call expression not a function");
+			if (ttype(im) == LUA_T_NIL) {
+				// NOTE: Originally this throwed the lua_error. Anyway it is commented here because
+				// when in year 4 bi.exit() calls bi.book.act:free(). But bi.book.act is nil,
+				// hence it enters this branch and the error blocks the game.
+				// Now we try instead to survive and go on with the function.
+				lua_Task *t = lua_state->task;
+				lua_state->task = t->next;
+				lua_state->prevTask = tmpTask;
+				luaM_free(t);
+				warning("Lua: call expression not a function");
+				return 1;
+			}
 			luaD_callTM(im, (lua_state->stack.top - lua_state->stack.stack) - (base - 1), nResults);
 			continue;
 		}




More information about the Scummvm-git-logs mailing list