From aa04e311f1b923b6ec8f07e2af1e85cc02dd2a49 Mon Sep 17 00:00:00 2001 From: Paul Gilbert Date: Sat, 18 Nov 2017 19:37:29 -0500 Subject: XEEN: Fixes for cmdTakeOrGive script opcode --- engines/xeen/scripts.cpp | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-) (limited to 'engines') diff --git a/engines/xeen/scripts.cpp b/engines/xeen/scripts.cpp index 48b58ddcad..e5af78b57d 100644 --- a/engines/xeen/scripts.cpp +++ b/engines/xeen/scripts.cpp @@ -539,11 +539,9 @@ void Scripts::cmdMoveObj(Common::Array ¶ms) { void Scripts::cmdTakeOrGive(Common::Array ¶ms) { Party &party = *_vm->_party; Screen &screen = *_vm->_screen; - int mode1, mode2, mode3; + int mode1, mode2, mode3, param2; uint32 mask1, mask2, mask3; byte *extraP; - // TODO: See if this needs to maintain values set in other opcodes - int param2 = 0; mode1 = params[0]; switch (mode1) { @@ -562,11 +560,11 @@ void Scripts::cmdTakeOrGive(Common::Array ¶ms) { break; default: mask1 = params[1]; - extraP = ¶ms[2]; + extraP = ¶ms[9]; break; } - mode2 = *extraP++; + param2 = mode2 = *extraP++; switch (mode2) { case 16: case 34: @@ -605,7 +603,7 @@ void Scripts::cmdTakeOrGive(Common::Array ¶ms) { break; } - if (mode2) + if (mode2 == 67) screen.closeWindows(); switch (_event->_opcode) { -- cgit v1.2.3