aboutsummaryrefslogtreecommitdiff
path: root/engines
diff options
context:
space:
mode:
authorStrangerke2012-04-28 16:24:47 +0200
committerEugene Sandulenko2018-03-28 17:36:57 +0200
commitd65cd866e73e54c4e6971e1ef82d6c988f283e9a (patch)
treef0721c4c67fcf7ed347bdcbf42b8198946413d3b /engines
parentb9a2c968db63eb43f08a468d383f17f59aa14786 (diff)
downloadscummvm-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.cpp2
-rw-r--r--engines/lilliput/script.cpp62
-rw-r--r--engines/lilliput/script.h4
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();