From 013f1711c48edcebc3215fb5cfd1aaf1a796701a Mon Sep 17 00:00:00 2001 From: Max Horn Date: Fri, 2 Feb 2007 13:53:59 +0000 Subject: Workaround for bug #1621210 (FOA: Kerner counts incorrectly during end sequence) svn-id: r25335 --- engines/scumm/script_v5.cpp | 33 ++++++++++++++++++++++++--------- 1 file changed, 24 insertions(+), 9 deletions(-) diff --git a/engines/scumm/script_v5.cpp b/engines/scumm/script_v5.cpp index 2f2374f722..c126d40131 100644 --- a/engines/scumm/script_v5.cpp +++ b/engines/scumm/script_v5.cpp @@ -2758,15 +2758,30 @@ void ScummEngine_v5::decodeParseString() { } } break; - case 15: // SO_TEXTSTRING - // WORKAROUND: This happens when Chaos introduces - // herself to bishop Mandible. Of all the places to put - // a typo... - if (_game.id == GID_LOOM && strcmp((const char *) _scriptPointer, "I am Choas.") == 0) - printString(textSlot, (const byte *) "I am Chaos."); - else - printString(textSlot, _scriptPointer); - _scriptPointer += resStrLen(_scriptPointer) + 1; + case 15:{ // SO_TEXTSTRING + const int len = resStrLen(_scriptPointer); + + if (_game.id == GID_LOOM && strcmp((const char *) _scriptPointer, "I am Choas.") == 0) { + // WORKAROUND: This happens when Chaos introduces + // herself to bishop Mandible. Of all the places to put + // a typo... + printString(textSlot, (const byte *) "I am Chaos."); + } else if (_game.id == GID_INDY4 && _roomResource == 23 && vm.slot[_currentScript].number == 167 && + len == 24 && 0==memcmp(_scriptPointer+16, "pregod", 6)) { + // WORKAROUND for bug #1621210. + byte tmpBuf[25]; + memcpy(tmpBuf, _scriptPointer, 25); + if (tmpBuf[22] == '8') + strcpy((char *)tmpBuf+16, "^18^"); + else + strcpy((char *)tmpBuf+16, "^19^"); + printf("evil workaround active"); + printString(textSlot, tmpBuf); + } else { + printString(textSlot, _scriptPointer); + } + _scriptPointer += len + 1; + } // In SCUMM V1-V3, there were no 'default' values for the text slot -- cgit v1.2.3