diff options
author | Strangerke | 2012-04-28 16:24:47 +0200 |
---|---|---|
committer | Eugene Sandulenko | 2018-03-28 17:36:57 +0200 |
commit | d65cd866e73e54c4e6971e1ef82d6c988f283e9a (patch) | |
tree | f0721c4c67fcf7ed347bdcbf42b8198946413d3b /engines | |
parent | b9a2c968db63eb43f08a468d383f17f59aa14786 (diff) | |
download | scummvm-rg350-d65cd866e73e54c4e6971e1ef82d6c988f283e9a.tar.gz scummvm-rg350-d65cd866e73e54c4e6971e1ef82d6c988f283e9a.tar.bz2 scummvm-rg350-d65cd866e73e54c4e6971e1ef82d6c988f283e9a.zip |
LILLIPUT: Implement 2 opcodes, fix a duplicate variable detected by SylvainTV
Diffstat (limited to 'engines')
-rw-r--r-- | engines/lilliput/lilliput.cpp | 2 | ||||
-rw-r--r-- | engines/lilliput/script.cpp | 62 | ||||
-rw-r--r-- | engines/lilliput/script.h | 4 |
3 files changed, 56 insertions, 12 deletions
diff --git a/engines/lilliput/lilliput.cpp b/engines/lilliput/lilliput.cpp index bc2a818ece..2a6c009e16 100644 --- a/engines/lilliput/lilliput.cpp +++ b/engines/lilliput/lilliput.cpp @@ -638,7 +638,7 @@ void LilliputEngine::sub16217() { _scriptHandler->_array16123[i] = (_characterPositionX[i] & 0xFF); _scriptHandler->_array1614B[i] = (_characterPositionY[i] & 0xFF); - _scriptHandler->_array16173[i] = 0xFF; + _characterRelativePositionX[i] = 0xFF; _characterRelativePositionY[i] = 0xFF; _characterDisplayX[i] = 0xFF; _characterDisplayY[i] = 0xFF; diff --git a/engines/lilliput/script.cpp b/engines/lilliput/script.cpp index c63a12523c..c9c3512d8e 100644 --- a/engines/lilliput/script.cpp +++ b/engines/lilliput/script.cpp @@ -66,7 +66,6 @@ LilliputScript::LilliputScript(LilliputEngine *vm) : _vm(vm), _currScript(NULL) _array12839[i] = 0xFF; _array16123[i] = 0; _array1614B[i] = 0; - _array16173[i] = 0xFF; _array122C1[i] = 0; } @@ -763,14 +762,15 @@ void LilliputScript::sub16C5C(int index, byte var3) { sub16C86(index, buf); } -int LilliputScript::sub17D40(int var) { - debugC(1, kDebugScript, "sub17D40(%d)", var); +void LilliputScript::sub17D40(bool &forceReturnFl) { + debugC(1, kDebugScript, "sub17D40()"); - if ((displayMap != 1) && (_array16173[_vm->_rulesBuffer2PrevIndx] != 0xFF)) - return var; + forceReturnFl = false; + if ((displayMap != 1) && (_vm->_characterRelativePositionX[_vm->_rulesBuffer2PrevIndx] != 0xFF)) + return; - warning("sub17D40() - FIXME: Unexpected POP"); - return var; + forceReturnFl = true; + return; } void LilliputScript::sub18A56(byte *buf) { @@ -1575,7 +1575,9 @@ void LilliputScript::OC_sub17D57() { int curWord = _currScript->readUint16LE(); - if((displayMap == 1) || (_array16173[_vm->_rulesBuffer2PrevIndx] == 0xFF)) + bool forceReturnFl = false; + sub17D40(forceReturnFl); + if (forceReturnFl) return; _word1881B = _vm->_rulesBuffer2PrevIndx; @@ -1583,9 +1585,51 @@ void LilliputScript::OC_sub17D57() { } +void LilliputScript::sub18B7C(int var1, int var3) { + debugC(2, kDebugScript, "sub18B7C(%d, %d)", var1, var3); + + if (var1 == 0xFFFF) + return; + + _word18776 = var1; + int index = _vm->_rulesChunk3[var1]; + + while (_vm->_rulesChunk4[index] == 91) + ++index; + + for (int i = 0; i < var3; i++) { + int tmpVal = 93; + while (tmpVal == 93) { + tmpVal = _vm->_rulesChunk4[index]; + ++index; + } + } + + if (_vm->_rulesChunk4[index] == 0) + return; + + sub18A56(&_vm->_rulesChunk4[index]); +} + void LilliputScript::OC_sub17D7F() { - warning("OC_sub17D7F"); + debugC(1, kDebugScript, "OC_sub17D7F()"); + + int var1 = getBuffer215Ptr()[0]; + int var2 = (_currScript->readUint16LE() & 0xFF); + int var3 = var1 / var2; + + var1 = _currScript->readUint16LE(); + + bool forceReturnFl = false; + sub17D40(forceReturnFl); + if (forceReturnFl) + return; + + _word1881B = _vm->_rulesBuffer2PrevIndx; + + sub18B7C(var1, var3); } + void LilliputScript::OC_sub17DB9() { warning("OC_sub17DB9"); } diff --git a/engines/lilliput/script.h b/engines/lilliput/script.h index fe8347f1cb..19094e81fb 100644 --- a/engines/lilliput/script.h +++ b/engines/lilliput/script.h @@ -43,7 +43,6 @@ public: byte _array122E9[20]; byte _array16123[40]; byte _array1614B[40]; - byte _array16173[40]; byte _array12811[40]; byte _array10AB1[40]; byte _array122FD[20]; @@ -102,13 +101,14 @@ private: void sub17B6C(int var1); void sub16C86(int index, byte *buf); void sub16C5C(int index, byte var3); - int sub17D40(int var); + void sub17D40(bool &forceReturnFl); void sub18A56(byte *buf); void sub18B3C(int var); void sub18BE6(byte var1, int var2, int var4); byte *getMapPtr(int val); byte *sub173D2(); void sub171AF(int var1, int var2, int var4); + void sub18B7C(int var1, int var3); int getValue1(); int getValue2(); |