diff options
Diffstat (limited to 'engines')
-rw-r--r-- | engines/lilliput/lilliput.cpp | 17 | ||||
-rw-r--r-- | engines/lilliput/lilliput.h | 2 | ||||
-rw-r--r-- | engines/lilliput/script.cpp | 77 | ||||
-rw-r--r-- | engines/lilliput/script.h | 16 |
4 files changed, 56 insertions, 56 deletions
diff --git a/engines/lilliput/lilliput.cpp b/engines/lilliput/lilliput.cpp index 21b18f9133..dcf572fe0c 100644 --- a/engines/lilliput/lilliput.cpp +++ b/engines/lilliput/lilliput.cpp @@ -1205,7 +1205,7 @@ void LilliputEngine::sortCharacters() { } void LilliputEngine::scrollToViewportCharacterTarget() { - debugC(2, kDebugEngineTBC, "scrollToViewportCharacterTarget()"); + debugC(2, kDebugEngine, "scrollToViewportCharacterTarget()"); if (_scriptHandler->_viewportCharacterTarget == -1) return; @@ -1215,7 +1215,7 @@ void LilliputEngine::scrollToViewportCharacterTarget() { Common::Point newPos = _scriptHandler->_viewportPos; if (var2 >= 1) { - if (var2 >= 6) { + if (var2 > 6) { newPos.x += 4; if (newPos.x > 56) newPos.x = 56; @@ -1226,16 +1226,17 @@ void LilliputEngine::scrollToViewportCharacterTarget() { newPos.x = 0; } - if (var4 >= 1) { + if ((var4 < 1) && (newPos.y < 4)) + newPos.y = 0; + else { + if (var4 < 1) + newPos.y -= 4; + if (var4 > 6) { newPos.y += 4; if (newPos.y >= 56) newPos.y = 56; } - } else { - newPos.y -= 4; - if (newPos.y < 0) - newPos.y = 0; } viewportScrollTo(newPos); @@ -1362,7 +1363,7 @@ void LilliputEngine::sub15498(Common::Point pos, int var2) { } void LilliputEngine::checkSpeechClosing() { - debugC(2, kDebugEngineTBC, "checkSpeechClosing()"); + debugC(2, kDebugEngine, "checkSpeechClosing()"); if (_scriptHandler->_speechTimer != 0) { --_scriptHandler->_speechTimer; diff --git a/engines/lilliput/lilliput.h b/engines/lilliput/lilliput.h index 322e34a969..b980333646 100644 --- a/engines/lilliput/lilliput.h +++ b/engines/lilliput/lilliput.h @@ -155,7 +155,7 @@ public: int _array12861[30]; byte *_rulesChunk1; - int _currentScriptCharacter; + int16 _currentScriptCharacter; int16 _characterPositionX[40]; int16 _characterPositionY[40]; char _characterPositionAltitude[40]; diff --git a/engines/lilliput/script.cpp b/engines/lilliput/script.cpp index 3187b20a19..04b83117d4 100644 --- a/engines/lilliput/script.cpp +++ b/engines/lilliput/script.cpp @@ -44,7 +44,7 @@ LilliputScript::LilliputScript(LilliputEngine *vm) : _vm(vm), _currScript(NULL) _heroismBarBottomY = 0; _viewportPos.x = 0; _viewportPos.y = 0; - _word18776 = 0; + _currentSpeechId = 0; _array129A5[0] = 0; _array129A5[1] = 1; _array129A5[2] = 2; @@ -106,7 +106,7 @@ byte LilliputScript::handleOpcodeType1(int curWord) { return OC_for(); break; case 0x7: - return OC_compWord18776(); + return OC_compCurrentSpeechId(); break; case 0x8: return OC_checkSaveFlag(); @@ -250,7 +250,7 @@ void LilliputScript::handleOpcodeType2(int curWord) { OC_ChangeIsoMap(); break; case 0x2: - OC_sub17D57_speech1(); + OC_startSpeech(); break; case 0x3: OC_sub17D7F_speech2(); @@ -259,7 +259,7 @@ void LilliputScript::handleOpcodeType2(int curWord) { OC_sub17DB9_speech3(); break; case 0x5: - OC_sub17DF9_speech1param(); + OC_startSpeechIfMute(); break; case 0x6: OC_sub17E07_speech4param(); @@ -563,7 +563,7 @@ static const OpCode opCodes1[] = { { "OC_CompareLastRandomValue", 2, kCompareOperation, kImmediateValue, kNone, kNone, kNone }, { "OC_getRandom", 1, kImmediateValue, kNone, kNone, kNone, kNone }, { "OC_for", 2, kImmediateValue, kImmediateValue, kNone, kNone, kNone }, - { "OC_compWord18776", 1, kImmediateValue, kNone, kNone, kNone, kNone }, + { "OC_compCurrentSpeechId", 1, kImmediateValue, kNone, kNone, kNone, kNone }, { "OC_checkSaveFlag", 0, kNone, kNone, kNone, kNone, kNone }, { "OC_compByte16F04", 2, kCompareOperation, kImmediateValue, kNone, kNone, kNone }, { "OC_sub174D8", 2, kGetValue1, kGetValue1, kNone, kNone, kNone }, @@ -612,10 +612,10 @@ static const OpCode opCodes1[] = { static const OpCode opCodes2[] = { /* 0x00 */ { "OC_setWord18821", 1, kGetValue1, kNone, kNone, kNone, kNone }, /* 0x01 */ { "OC_ChangeIsoMap", 3, kgetPosFromScript, kImmediateValue, kImmediateValue, kNone, kNone }, -/* 0x02 */ { "OC_sub17D57_speech1", 1, kImmediateValue, kNone, kNone, kNone, kNone }, +/* 0x02 */ { "OC_startSpeech", 1, kImmediateValue, kNone, kNone, kNone, kNone }, /* 0x03 */ { "OC_sub17D7F_speech2", 4, kGetValue1, kImmediateValue, kImmediateValue, kImmediateValue, kNone }, /* 0x04 */ { "OC_sub17DB9_speech3", 2, kImmediateValue, kImmediateValue, kNone, kNone, kNone }, // todo -/* 0x05 */ { "OC_sub17DF9_speech1param", 1, kImmediateValue, kNone, kNone, kNone, kNone }, +/* 0x05 */ { "OC_startSpeechIfMute", 1, kImmediateValue, kNone, kNone, kNone, kNone }, /* 0x06 */ { "OC_sub17E07_speech4param", 4, kGetValue1, kImmediateValue, kImmediateValue, kImmediateValue, kNone }, // pb /* 0x07 */ { "OC_sub17E15_speech2param", 2, kImmediateValue, kImmediateValue, kNone, kNone, kNone }, /* 0x08 */ { "OC_ComputeCharacterVariable", 4, kGetValue1, kImmediateValue, kComputeOperation, kImmediateValue, kNone }, @@ -1067,7 +1067,7 @@ void LilliputScript::sub16C86(int index, byte *buf) { } void LilliputScript::sub16C5C(int index, byte var3) { - debugC(1, kDebugScriptTBC, "sub16C5C(%d, %d)", index, var3); + debugC(1, kDebugScript, "sub16C5C(%d, %d)", index, var3); assert(index < 40); _array12839[index] = var3; @@ -1085,8 +1085,8 @@ void LilliputScript::sub16C5C(int index, byte var3) { sub16C86(index, buf); } -void LilliputScript::sub17D40(bool &forceReturnFl) { - debugC(1, kDebugScriptTBC, "sub17D40()"); +void LilliputScript::checkSpeechAllowed(bool &forceReturnFl) { + debugC(1, kDebugScript, "checkSpeechAllowed()"); forceReturnFl = false; if ((_vm->_displayMap != 1) && (_vm->_characterRelativePositionX[_vm->_currentScriptCharacter] != 0xFF)) @@ -1246,15 +1246,15 @@ void LilliputScript::listAllTexts() { } } -void LilliputScript::sub18B3C(int var) { - debugC(2, kDebugScriptTBC, "sub18B3C(%d)", var); +void LilliputScript::startSpeech(int speechId) { + debugC(2, kDebugScriptTBC, "startSpeech(%d)", speechId); - if (var == -1) + if (speechId == -1) return; - _word18776 = var; + _currentSpeechId = speechId; - int index = _vm->_packedStringIndex[var]; + int index = _vm->_packedStringIndex[speechId]; int count = 0; while (_vm->_packedStrings[index + count] == 0x5B) ++count; @@ -1458,12 +1458,12 @@ byte LilliputScript::OC_for() { return 1; } -byte LilliputScript::OC_compWord18776() { - debugC(1, kDebugScriptTBC, "OC_compWord18776()"); +byte LilliputScript::OC_compCurrentSpeechId() { + debugC(1, kDebugScriptTBC, "OC_compCurrentSpeechId()"); int var1 = _currScript->readUint16LE(); - if (var1 == _word18776) + if (var1 == _currentSpeechId) return 1; return 0; @@ -2119,19 +2119,18 @@ void LilliputScript::OC_ChangeIsoMap() { } } -void LilliputScript::OC_sub17D57_speech1() { - debugC(1, kDebugScriptTBC, "OC_sub17D57_speech1()"); +void LilliputScript::OC_startSpeech() { + debugC(1, kDebugScript, "OC_startSpeech()"); int curWord = _currScript->readUint16LE(); bool forceReturnFl = false; - sub17D40(forceReturnFl); + checkSpeechAllowed(forceReturnFl); if (forceReturnFl) return; _talkingCharacter = _vm->_currentScriptCharacter; - sub18B3C(curWord); - + startSpeech(curWord); } void LilliputScript::sub18B7C(int var1, int var3) { @@ -2140,15 +2139,15 @@ void LilliputScript::sub18B7C(int var1, int var3) { if (var1 == 0xFFFF) return; - _word18776 = var1; + _currentSpeechId = var1; int index = _vm->_packedStringIndex[var1]; - while (_vm->_packedStrings[index] == 91) + while (_vm->_packedStrings[index] == '[') ++index; for (int i = 0; i < var3; i++) { - int tmpVal = 93; - while (tmpVal == 93) { + byte tmpVal = ' '; + while (tmpVal != ']') { tmpVal = _vm->_packedStrings[index]; ++index; } @@ -2170,7 +2169,7 @@ void LilliputScript::OC_sub17D7F_speech2() { var1 = _currScript->readUint16LE(); bool forceReturnFl = false; - sub17D40(forceReturnFl); + checkSpeechAllowed(forceReturnFl); if (forceReturnFl) return; @@ -2192,7 +2191,7 @@ void LilliputScript::OC_sub17DB9_speech3() { _currScript->writeUint16LE(tmpVal, -2); bool forceReturnFl = false; - sub17D40(forceReturnFl); + checkSpeechAllowed(forceReturnFl); if (forceReturnFl) return; @@ -2202,11 +2201,11 @@ void LilliputScript::OC_sub17DB9_speech3() { } -void LilliputScript::OC_sub17DF9_speech1param() { - debugC(1, kDebugScriptTBC, "OC_sub17DF9_speech1param()"); +void LilliputScript::OC_startSpeechIfMute() { + debugC(1, kDebugScript, "OC_startSpeechIfMute()"); if (_talkingCharacter == -1) { - OC_sub17D57_speech1(); + OC_startSpeech(); return; } @@ -2299,12 +2298,12 @@ void LilliputScript::OC_sub17E37_speech4() { debugC(1, kDebugScriptTBC, "OC_sub17E37_speech4()"); bool forceReturnFl = false; - sub17D40(forceReturnFl); + checkSpeechAllowed(forceReturnFl); if (forceReturnFl) return; _talkingCharacter = _vm->_currentScriptCharacter; - sub18B3C(5); + startSpeech(5); } void LilliputScript::OC_resetByte1714E() { @@ -2390,14 +2389,14 @@ void LilliputScript::OC_resetByte16F04() { } void LilliputScript::OC_sub17AE1() { - debugC(1, kDebugScriptTBC, "OC_sub17AE1()"); + debugC(1, kDebugScript, "OC_sub17AE1()"); byte var3 = (_currScript->readUint16LE() & 0xFF); sub16C5C(_vm->_currentScriptCharacter, var3); } void LilliputScript::OC_sub17AEE() { - debugC(1, kDebugScriptTBC, "OC_sub17AEE()"); + debugC(1, kDebugScript, "OC_sub17AEE()"); byte var3 = (_currScript->readUint16LE() & 0xFF); sub16C5C(_vm->_currentScriptCharacter + 1, var3); @@ -2766,7 +2765,7 @@ void LilliputScript::OC_sub18074() { } void LilliputScript::OC_setCurrentCharacterDirection() { - debugC(1, kDebugScriptTBC, "OC_setCurrentCharacterDirection()"); + debugC(1, kDebugScript, "OC_setCurrentCharacterDirection()"); _vm->_characterDirectionArray[_vm->_currentScriptCharacter] = (_currScript->readUint16LE() & 0xFF); } @@ -3238,7 +3237,7 @@ void LilliputScript::OC_sub186A1() { } void LilliputScript::OC_sub186E5_snd() { - debugC(1, kDebugScriptTBC, "OC_sub186E5_snd()"); + debugC(1, kDebugScript, "OC_sub186E5_snd()"); int index = getValue1(); assert(index < 40); @@ -3260,7 +3259,7 @@ void LilliputScript::OC_sub1870A_snd() { } void LilliputScript::OC_sub18725_snd() { - debugC(1, kDebugScriptTBC, "OC_sub18725_snd()"); + debugC(1, kDebugScript, "OC_sub18725_snd()"); int var4 = getValue1() | 0xFF00; diff --git a/engines/lilliput/script.h b/engines/lilliput/script.h index 5fdca27391..de15fe102d 100644 --- a/engines/lilliput/script.h +++ b/engines/lilliput/script.h @@ -73,8 +73,8 @@ public: byte *_savedBuffer215Ptr; Common::Point _viewportPos; - int _viewportCharacterTarget; - int _talkingCharacter; + int16 _viewportCharacterTarget; + int16 _talkingCharacter; int _heroismBarX; int _heroismBarBottomY; @@ -108,7 +108,7 @@ private: byte _speechDisplaySpeed; int _word16F00; - int _word18776; + int _currentSpeechId; int _word18821; int _word129A3; @@ -122,9 +122,9 @@ private: void sub17B6C(int var1); void sub16C86(int index, byte *buf); void sub16C5C(int index, byte var3); - void sub17D40(bool &forceReturnFl); + void checkSpeechAllowed(bool &forceReturnFl); void decodePackedText(char *buf); - void sub18B3C(int var); + void startSpeech(int var); void displayNumber(byte var1, Common::Point pos); byte *getMapPtr(Common::Point val); byte *getCurrentCharacterVarFromScript(); @@ -150,7 +150,7 @@ private: byte OC_CompareLastRandomValue(); byte OC_getRandom(); byte OC_for(); - byte OC_compWord18776(); + byte OC_compCurrentSpeechId(); byte OC_checkSaveFlag(); byte OC_compByte16F04(); byte OC_sub174D8(); @@ -197,10 +197,10 @@ private: // Opcodes Type 2 void OC_setWord18821(); void OC_ChangeIsoMap(); - void OC_sub17D57_speech1(); + void OC_startSpeech(); void OC_sub17D7F_speech2(); void OC_sub17DB9_speech3(); - void OC_sub17DF9_speech1param(); + void OC_startSpeechIfMute(); void OC_sub17E07_speech4param(); void OC_sub17E15_speech2param(); void OC_ComputeCharacterVariable(); |