aboutsummaryrefslogtreecommitdiff
path: root/engines/lilliput
diff options
context:
space:
mode:
authorsylvaintv2012-05-01 14:35:19 +0200
committerEugene Sandulenko2018-03-28 17:36:57 +0200
commiteabe891bf65f8f5bfd4ce1a27fdadfe53a37e16a (patch)
tree183d9d9b482ba2fd2af78ef2727c5a79f74017c1 /engines/lilliput
parent19f8bd899a23bad9d53bef7c5bc73fc3a5b05050 (diff)
downloadscummvm-rg350-eabe891bf65f8f5bfd4ce1a27fdadfe53a37e16a.tar.gz
scummvm-rg350-eabe891bf65f8f5bfd4ce1a27fdadfe53a37e16a.tar.bz2
scummvm-rg350-eabe891bf65f8f5bfd4ce1a27fdadfe53a37e16a.zip
LILLIPUT: Improved getValue2 decompilation
+ some renaming
Diffstat (limited to 'engines/lilliput')
-rw-r--r--engines/lilliput/lilliput.cpp45
-rw-r--r--engines/lilliput/lilliput.h8
-rw-r--r--engines/lilliput/script.cpp382
-rw-r--r--engines/lilliput/script.h23
4 files changed, 244 insertions, 214 deletions
diff --git a/engines/lilliput/lilliput.cpp b/engines/lilliput/lilliput.cpp
index 7add061be8..3b44949804 100644
--- a/engines/lilliput/lilliput.cpp
+++ b/engines/lilliput/lilliput.cpp
@@ -150,7 +150,7 @@ LilliputEngine::LilliputEngine(OSystem *syst, const LilliputGameDescription *gd)
_byte12FE3 = 0;
_byte16F08 = 0;
- _rulesBuffer2PrevIndx = 0;
+ currentScriptCharacter = 0;
_currentScriptCharacterPosition = 0;
_word10804 = 0;
_word17081_nextIndex = 0;
@@ -192,7 +192,7 @@ LilliputEngine::LilliputEngine(OSystem *syst, const LilliputGameDescription *gd)
_array11D49[i] = 0xFFFF;
_characterPositionX[i] = 0xFFFF;
_characterPositionY[i] = 0xFFFF;
- _rulesBuffer2_3[i] = 0;
+ _characterPositionAltitude[i] = 0;
_characterFrameArray[i] = 0;
_rulesBuffer2_5[i] = 0xFF;
_rulesBuffer2_6[i] = 4;
@@ -216,7 +216,7 @@ LilliputEngine::LilliputEngine(OSystem *syst, const LilliputGameDescription *gd)
for (int i = 0; i < 160; i++)
_displayStringBuf[i] = 0;
- _ptr_rulesBuffer2_15 = NULL;
+ _currentCharacterVariables = NULL;
_bufferIdeogram = NULL;
_bufferMen = NULL;
_bufferMen2 = NULL;
@@ -687,7 +687,7 @@ void LilliputEngine::sub16217() {
for (int i = index; i >= 0; i--) {
if (_rulesBuffer2_5[i] != 0xFF) {
int index2 = _rulesBuffer2_5[i];
- _rulesBuffer2_3[i] = _rulesBuffer2_3[index2] + _rulesBuffer2_7[i];
+ _characterPositionAltitude[i] = _characterPositionAltitude[index2] + _rulesBuffer2_7[i];
int tmpVal = _rulesBuffer2_6[i];
_characterDirectionArray[i] = _characterDirectionArray[index2];
int var3 = _characterPositionX[index2];
@@ -726,7 +726,7 @@ void LilliputEngine::sub16217() {
_characterRelativePositionY[i] = tmpVal3;
tmpVal2 = _characterPositionX[i] - _word16213;
tmpVal3 = _characterPositionY[i] - _word16215;
- int tmpVal4 = _rulesBuffer2_3[i];
+ int tmpVal4 = _characterPositionAltitude[i];
_characterDisplayX[i] = ((60 + tmpVal2 - tmpVal3) * 2) & 0xFF;
_characterDisplayY[i] = (20 + tmpVal2 + tmpVal3 - tmpVal4) & 0xFF;
_charactersToDisplay[_numCharactersToDisplay] = i;
@@ -1127,10 +1127,10 @@ void LilliputEngine::sortCharacters() {
continue;
if (_characterRelativePositionX[index1] == _characterRelativePositionX[index2]) {
- if (_rulesBuffer2_3[index1] < _rulesBuffer2_3[index2])
+ if (_characterPositionAltitude[index1] < _characterPositionAltitude[index2])
continue;
- if (_rulesBuffer2_3[index1] == _rulesBuffer2_3[index2]) {
+ if (_characterPositionAltitude[index1] == _characterPositionAltitude[index2]) {
if (_characterDisplayY[index1] < _characterDisplayY[index2])
continue;
}
@@ -1536,12 +1536,12 @@ void LilliputEngine::sub12F37() {
int index2 = 0;
for (int i = 0; i < _numCharacters; i++) {
- if (_rulesBuffer2_15[index1] != 0 ) {
- if (_rulesBuffer2_15[index1] == 1) {
- _rulesBuffer2_15[index1] = 0;
+ if (_characterVariables[index1] != 0 ) {
+ if (_characterVariables[index1] == 1) {
+ _characterVariables[index1] = 0;
} else {
- --_rulesBuffer2_15[index1];
- if (_rulesBuffer2_15[index1] == 1)
+ --_characterVariables[index1];
+ if (_characterVariables[index1] == 1)
_scriptHandler->_characterScriptEnabled[index2] = 1;
}
}
@@ -1763,25 +1763,25 @@ void LilliputEngine::sub16B76(int index) {
void LilliputEngine::sub166C0(int index) {
debugC(2, kDebugEngine, "sub166C0(%d)", index);
- _rulesBuffer2_3[index] += 1;
+ _characterPositionAltitude[index] += 1;
}
void LilliputEngine::sub166C6(int index) {
debugC(2, kDebugEngine, "sub166C6(%d)", index);
- _rulesBuffer2_3[index] += 2;
+ _characterPositionAltitude[index] += 2;
}
void LilliputEngine::sub166CC(int index) {
debugC(2, kDebugEngine, "sub166CC(%d)", index);
- _rulesBuffer2_3[index] -= 1;
+ _characterPositionAltitude[index] -= 1;
}
void LilliputEngine::sub166D2(int index) {
debugC(2, kDebugEngine, "sub166D2(%d)", index);
- _rulesBuffer2_3[index] -= 2;
+ _characterPositionAltitude[index] -= 2;
}
void LilliputEngine::sub166B1(int index) {
@@ -2140,7 +2140,7 @@ void LilliputEngine::loadRules() {
curWord = (curWord << 3) + 4;
_characterPositionY[j] = curWord;
- _rulesBuffer2_3[j] = (f.readUint16LE() & 0xFF);
+ _characterPositionAltitude[j] = (f.readUint16LE() & 0xFF);
_characterFrameArray[j] = f.readUint16LE();
_rulesBuffer2_5[j] = f.readByte();
_rulesBuffer2_6[j] = f.readByte();
@@ -2154,7 +2154,7 @@ void LilliputEngine::loadRules() {
_rulesBuffer2_14[j] = f.readByte();
for (int k = 0; k < 32; k++)
- _rulesBuffer2_15[(j * 32) + k] = f.readByte();
+ _characterVariables[(j * 32) + k] = f.readByte();
for (int k = 0; k < 32; k++)
_rulesBuffer2_16[(j * 32) + k] = f.readByte();
@@ -2307,14 +2307,14 @@ void LilliputEngine::initPalette() {
void LilliputEngine::sub170EE(int index) {
debugC(1, kDebugEngine, "sub170EE(%d)", index);
- _rulesBuffer2PrevIndx = index;
+ currentScriptCharacter = index;
assert (index < 40);
int var2 = _characterPositionX[index];
int var4 = _characterPositionY[index];
_currentScriptCharacterPosition = (((var2 >> 3) & 0xFF) << 8) + ((var4 >> 3) & 0xFF);
- _ptr_rulesBuffer2_15 = &_rulesBuffer2_15[_rulesBuffer2PrevIndx * 32];
+ _currentCharacterVariables = &_characterVariables[currentScriptCharacter * 32];
}
void LilliputEngine::sub130DD() {
@@ -2370,14 +2370,15 @@ void LilliputEngine::handleGameScripts() {
if (tmpVal == 0xFF)
return;
-/*for (int i = 0; i < _gameScriptIndexSize; i++) {
+ for (int i = 0; i < _gameScriptIndexSize; i++) {
assert(tmpVal < _gameScriptIndexSize);
debugC(1, kDebugEngine, "================= Game Script %d ==================", i);
ScriptStream script = ScriptStream(&_arrayGameScripts[_arrayGameScriptIndex[i]], _arrayGameScriptIndex[i + 1] - _arrayGameScriptIndex[i]);
_scriptHandler->disasmScript(script);
debugC(1, kDebugEngine, "============= End Game Script %d ==================", i);
}
-*/
+
+while(1);
assert(tmpVal < _gameScriptIndexSize);
debugC(1, kDebugEngine, "================= Game Script %d for character %d ==================", tmpVal, index);
diff --git a/engines/lilliput/lilliput.h b/engines/lilliput/lilliput.h
index 8820cb9fc1..f8fab06653 100644
--- a/engines/lilliput/lilliput.h
+++ b/engines/lilliput/lilliput.h
@@ -147,10 +147,10 @@ public:
int _array12861[30];
byte *_rulesChunk1;
- int _rulesBuffer2PrevIndx;
+ int currentScriptCharacter;
int _characterPositionX[40];
int _characterPositionY[40];
- byte _rulesBuffer2_3[40];
+ byte _characterPositionAltitude[40];
int _characterFrameArray[40];
byte _rulesBuffer2_5[40];
byte _rulesBuffer2_6[40];
@@ -162,8 +162,8 @@ public:
byte _rulesBuffer2_12[40];
byte _rulesBuffer2_13[40];
byte _rulesBuffer2_14[40];
- byte _rulesBuffer2_15[40 * 32];
- byte *_ptr_rulesBuffer2_15;
+ byte _characterVariables[40 * 32];
+ byte *_currentCharacterVariables;
byte _rulesBuffer2_16[40 * 32];
int *_rulesChunk3;
int _rulesChunk3_size;
diff --git a/engines/lilliput/script.cpp b/engines/lilliput/script.cpp
index 3a3ea6d2a7..477912e548 100644
--- a/engines/lilliput/script.cpp
+++ b/engines/lilliput/script.cpp
@@ -553,25 +553,7 @@ void LilliputScript::handleOpcodeType2(int curWord) {
}
}
-enum KValueType {
- kNone,
- kImmediateValue,
- kCompareOperation,
- kComputeOperation,
- kGetValue1,
- kGetValue2,
-};
-
-struct OpCode {
- const char* _opName;
- int _numArgs;
- KValueType _arg1;
- KValueType _arg2;
- KValueType _arg3;
- KValueType _arg4;
- KValueType _arg5;
-};
static const OpCode opCodes1[] = {
{ "OC_sub173DF", 1, kGetValue2, kNone, kNone, kNone, kNone },
@@ -732,6 +714,89 @@ static const OpCode opCodes2[] = {
/* 0x65 */ { "OC_sub1853B", 0, kNone, kNone, kNone, kNone, kNone }
};
+Common::String LilliputScript::getArgumentString(KValueType type, ScriptStream& script) {
+
+ Common::String str;
+ if(type == kImmediateValue) {
+ str = Common::String::format("0x%x", script.readUint16LE());
+ } else if (type == kGetValue1) {
+ int val = script.readUint16LE();
+ if(val < 1000) {
+ str = Common::String::format("0x%x", val);
+ } else if (val > 1004) {
+ str = Common::String::format("getValue1(0x%x)", val);
+ } else if ( val == 1000 ) {
+ str = Common::String("_byte129A0");
+ } else if( val == 1001 ) {
+ str = Common::String("characterIndex");
+ } else if( val == 1002 ) {
+ str = Common::String("_word16F00");
+ } else if( val == 1003 ) {
+ str = Common::String("_currentCharacterVariables[6]");
+ } else if( val == 1004 ) {
+ str = Common::String("_word10804");
+ }
+ } else if (type == kGetValue2) {
+ int curWord = script.readUint16LE();
+ int tmpVal = curWord >> 8;
+ switch(tmpVal) {
+ case 0xFF:
+ str = "(_rulesBuffer2_13[currentCharacter],_rulesBuffer2_14[currentCharacter])";
+ break;
+ case 0xFE: {
+ int index = curWord & 0xFF;
+ assert((index >= 0) && (index < 40));
+ str = Common::String::format("_vm->_rulesBuffer2_13[%d],_vm->_rulesBuffer2_14[%d]", index, index);
+ break;
+ }
+ case 0xFD:
+ str = "_currentScriptCharacterPosition";
+ break;
+ case 0xFC: {
+ int index = curWord & 0xFF;
+ assert(index < 40);
+ str = Common::String::format("(characterPositionTileX[%d], characterPositionTileY[%d])", index, index);
+ break;
+ }
+ case 0xFB: {
+ str = "(characterPositionTileX[_word16F00], characterPositionTileY[_word16F00])";
+ break;
+ }
+ case 0xFA:
+ str = Common::String::format("(_array10999[currentCharacter], _array109C1[currentCharacter])");
+ break;
+ case 0xF9:
+ str = Common::String::format("(_currentCharacterVariables[4], _currentCharacterVariables[5])");
+ break;
+ case 0xF8: {
+ int index = curWord & 0xFF;
+ assert((index >= 0) && (index < 40));
+ str = Common::String::format("_vm->_rulesBuffer12_3[%d]", index);
+ }
+ case 0xF7: {
+ str = Common::String::format("(_characterPositionTileX[_currentCharacterVariables[6]], _characterPositionTileY[_currentCharacterVariables[6]])");
+ break;
+ }
+ case 0xF6:
+ str = "_savedMousePosDivided";
+ break;
+ default:
+ str = Common::String::format("(0x%x,0x%x)", curWord >> 8, curWord & 0xFF);
+ break;
+ }
+ } else if (type == kCompareOperation) {
+ int comp = script.readUint16LE();
+ if(comp != '<' && comp != '>')
+ comp = '=';
+ str = Common::String::format("%c", comp );
+ }
+ else if (type == kComputeOperation) {
+ int comp = script.readUint16LE();
+ str = Common::String::format("%c", comp );
+ }
+ return str;
+}
+
void LilliputScript::disasmScript( ScriptStream script) {
while(!script.eos()) {
@@ -777,35 +842,8 @@ void LilliputScript::disasmScript( ScriptStream script) {
str += "(";
for (int p = 0; p < opCode->_numArgs; p++) {
- if(*opArgType == kImmediateValue) {
- str += Common::String::format("0x%x", script.readUint16LE());
- } else if (*opArgType == kGetValue1) {
- int val = script.readUint16LE();
- if(val < 1000)
- {
- str += Common::String::format("0x%x", val);
- } else if (val > 1004) {
- str += Common::String::format("getValue1(0x%x)", val);
- } else if ( val == 1000 ) {
- str += Common::String("_byte129A0");
- } else if( val == 1001 ) {
- str += Common::String("characterIndex");
- } else if( val == 1002 ) {
- str += Common::String("_word16F00");
- } else if( val == 1003 ) {
- str += Common::String("currentCharacter_var6");
- } else if( val == 1004 ) {
- str += Common::String("_word10804");
- }
- } else if (*opArgType == kGetValue2) {
- str += Common::String::format("getValue2(0x%x)", script.readUint16LE());
- } else if (*opArgType == kCompareOperation) {
- int comp = script.readUint16LE();
- if(comp != '<' && comp != '>')
- comp = '=';
- str += Common::String::format("%c", comp );
- }
+ str += getArgumentString(*opArgType, script);
if(p != opCode->_numArgs - 1)
str += ", ";
@@ -845,37 +883,7 @@ void LilliputScript::disasmScript( ScriptStream script) {
str += "(";
for (int p = 0; p < opCode->_numArgs; p++) {
- if(*opArgType == kImmediateValue) {
- str += Common::String::format("0x%x", script.readUint16LE());
- } else if (*opArgType == kGetValue1) {
- int val = script.readUint16LE();
- if(val < 1000)
- {
- str += Common::String::format("0x%x", val);
- } else if (val > 1004) {
- str += Common::String::format("getValue1(0x%x)", val);
- } else if ( val == 1000 ) {
- str += Common::String("_byte129A0");
- } else if( val == 1001 ) {
- str += Common::String("characterIndex");
- } else if( val == 1002 ) {
- str += Common::String("_word16F00");
- } else if( val == 1003 ) {
- str += Common::String("currentCharacter_var6");
- } else if( val == 1004 ) {
- str += Common::String("_word10804");
- }
- } else if (*opArgType == kGetValue2) {
- str += Common::String::format("getValue2(0x%x)", script.readUint16LE());
- } else if (*opArgType == kCompareOperation) {
- int comp = script.readUint16LE();
- if(comp != '<' && comp != '>')
- comp = '=';
- str += Common::String::format("%c", comp );
- } else if (*opArgType == kComputeOperation) {
- int comp = script.readUint16LE();
- str += Common::String::format("%c", comp );
- }
+ str += getArgumentString(*opArgType, script);
if (p != opCode->_numArgs - 1)
str += ", ";
@@ -1105,7 +1113,7 @@ void LilliputScript::sub17D40(bool &forceReturnFl) {
debugC(1, kDebugScript, "sub17D40()");
forceReturnFl = false;
- if ((_vm->_displayMap != 1) && (_vm->_characterRelativePositionX[_vm->_rulesBuffer2PrevIndx] != 0xFF))
+ if ((_vm->_displayMap != 1) && (_vm->_characterRelativePositionX[_vm->currentScriptCharacter] != 0xFF))
return;
forceReturnFl = true;
@@ -1264,11 +1272,11 @@ int LilliputScript::getValue1() {
case 1000:
return (int)_byte129A0;
case 1001:
- return _vm->_rulesBuffer2PrevIndx;
+ return _vm->currentScriptCharacter;
case 1002:
return _word16F00;
case 1003:
- return (int)_vm->_ptr_rulesBuffer2_15[6];
+ return (int)_vm->_currentCharacterVariables[6];
case 1004:
return _word10804;
default:
@@ -1284,8 +1292,8 @@ int LilliputScript::getValue2() {
int tmpVal = curWord >> 8;
switch(tmpVal) {
case 0xFF:
- assert((_vm->_rulesBuffer2PrevIndx >= 0) && (_vm->_rulesBuffer2PrevIndx < 40));
- return ((_vm->_rulesBuffer2_13[_vm->_rulesBuffer2PrevIndx] << 8) + _vm->_rulesBuffer2_14[_vm->_rulesBuffer2PrevIndx]);
+ assert((_vm->currentScriptCharacter >= 0) && (_vm->currentScriptCharacter < 40));
+ return ((_vm->_rulesBuffer2_13[_vm->currentScriptCharacter] << 8) + _vm->_rulesBuffer2_14[_vm->currentScriptCharacter]);
case 0xFE: {
int index = curWord & 0xFF;
assert((index >= 0) && (index < 40));
@@ -1310,16 +1318,16 @@ int LilliputScript::getValue2() {
return (var1 << 8) + var2;
}
case 0xFA:
- return ((_vm->_array10999[_vm->_rulesBuffer2PrevIndx] << 8) + _vm->_array109C1[_vm->_rulesBuffer2PrevIndx]);
+ return ((_vm->_array10999[_vm->currentScriptCharacter] << 8) + _vm->_array109C1[_vm->currentScriptCharacter]);
case 0xF9:
- return ((_vm->_ptr_rulesBuffer2_15[4] << 8) + _vm->_ptr_rulesBuffer2_15[5]);
+ return ((_vm->_currentCharacterVariables[4] << 8) + _vm->_currentCharacterVariables[5]);
case 0xF8: {
int index = curWord & 0xFF;
assert((index >= 0) && (index < 40));
return _vm->_rulesBuffer12_3[index];
}
case 0xF7: {
- int index = _vm->_ptr_rulesBuffer2_15[6];
+ int index = _vm->_currentCharacterVariables[6];
assert(index < 40);
byte var1 = _vm->_characterPositionX[index] >> 3;
byte var2 = _vm->_characterPositionY[index] >> 3;
@@ -1344,15 +1352,15 @@ void LilliputScript::sub130B6() {
}
}
-byte *LilliputScript::getBuffer215Ptr() {
- debugC(2, kDebugScript, "getBuffer215Ptr()");
+byte *LilliputScript::getCharacterVariablePtr() {
+ debugC(2, kDebugScript, "getCharacterVariablePtr()");
int tmpVal = getValue1();
tmpVal *= 32;
tmpVal += _currScript->readUint16LE();
assert(tmpVal < 40 * 32);
- return &_vm->_rulesBuffer2_15[tmpVal];
+ return &_vm->_characterVariables[tmpVal];
}
byte LilliputScript::OC_sub173DF() {
@@ -1402,7 +1410,7 @@ byte LilliputScript::OC_sub1740A() {
byte LilliputScript::OC_sub17434() {
debugC(1, kDebugScript, "OC_sub17434()");
- byte *tmpArr = getBuffer215Ptr();
+ byte *tmpArr = getCharacterVariablePtr();
byte var1 = tmpArr[0];
uint16 oper = _currScript->readUint16LE();
int16 var2 = _currScript->readUint16LE();
@@ -1506,12 +1514,12 @@ byte LilliputScript::OC_sub174D8() {
byte LilliputScript::OC_sub1750E() {
debugC(1, kDebugScript, "OC_sub1750E()");
- byte* buf1 = getBuffer215Ptr();
+ byte* buf1 = getCharacterVariablePtr();
int var1 = *buf1;
int operation = _currScript->readUint16LE();
- byte* buf2 = getBuffer215Ptr();
+ byte* buf2 = getCharacterVariablePtr();
int var2 = *buf2;
return compareValues(var1, operation, var2);
@@ -1558,7 +1566,7 @@ byte LilliputScript::OC_compWord16EF8() {
debugC(1, kDebugScript, "OC_compWord16EF8()");
int tmpVal = getValue1();
- if (tmpVal == _vm->_rulesBuffer2PrevIndx)
+ if (tmpVal == _vm->currentScriptCharacter)
return 1;
return 0;
}
@@ -1573,7 +1581,7 @@ byte LilliputScript::OC_sub175C8() {
if (tmpVal < 2000) {
_currScript->seek(_currScript->pos() - 2);
int index = getValue1();
- int var1 = _array10B51[(_vm->_rulesBuffer2PrevIndx * 40) + index];
+ int var1 = _array10B51[(_vm->currentScriptCharacter * 40) + index];
if ((var1 & 0xFF) < var4)
return 0;
@@ -1583,7 +1591,7 @@ byte LilliputScript::OC_sub175C8() {
if (tmpVal == 3000) {
for (int i = 0; i < _vm->_numCharacters; i++) {
- int var1 = _array10B51[(_vm->_rulesBuffer2PrevIndx * 40) + i];
+ int var1 = _array10B51[(_vm->currentScriptCharacter * 40) + i];
if ((var1 & 0xFF) >= var4) {
_word16F00 = i;
return 1;
@@ -1595,7 +1603,7 @@ byte LilliputScript::OC_sub175C8() {
tmpVal -= 2000;
byte var4b = tmpVal & 0xFF;
for (int i = 0; i < _vm->_numCharacters; i++) {
- int var1 = _array10B51[(_vm->_rulesBuffer2PrevIndx * 40) + i];
+ int var1 = _array10B51[(_vm->currentScriptCharacter * 40) + i];
if ((var1 & 0xFF) >= var4) {
if (_vm->_rulesBuffer2_12[i] == var4b) {
_word16F00 = i;
@@ -1611,7 +1619,7 @@ byte LilliputScript::OC_sub17640() {
debugC(1, kDebugScript, "OC_sub176C4()");
int var4 = _currScript->readUint16LE();
- int index = _vm->_rulesBuffer2PrevIndx * 40;
+ int index = _vm->currentScriptCharacter * 40;
int subIndex = 0xFFFF;
int tmpVal = _currScript->readUint16LE();
@@ -1668,7 +1676,7 @@ byte LilliputScript::OC_sub176C4() {
if (tmpVal < 2000) {
_currScript->seek(_currScript->pos() - 2);
int index = getValue1();
- int var1 = _array10B51[(_vm->_rulesBuffer2PrevIndx * 40) + index];
+ int var1 = _array10B51[(_vm->currentScriptCharacter * 40) + index];
if (((var1 & 0xFF) >= var4) || ((var1 >> 8) < var4))
return 0;
@@ -1678,7 +1686,7 @@ byte LilliputScript::OC_sub176C4() {
if (tmpVal == 3000) {
for (int i = 0; i < _vm->_numCharacters; i++) {
- int var1 = _array10B51[(_vm->_rulesBuffer2PrevIndx * 40) + i];
+ int var1 = _array10B51[(_vm->currentScriptCharacter * 40) + i];
if (((var1 & 0xFF) < var4) && ((var1 >> 8) >= var4)) {
_word16F00 = i;
return 1;
@@ -1690,7 +1698,7 @@ byte LilliputScript::OC_sub176C4() {
tmpVal -= 2000;
byte var4b = tmpVal & 0xFF;
for (int i = 0; i < _vm->_numCharacters; i++) {
- int var1 = _array10B51[(_vm->_rulesBuffer2PrevIndx * 40) + i];
+ int var1 = _array10B51[(_vm->currentScriptCharacter * 40) + i];
if (((var1 & 0xFF) < var4) && ((var1 >> 8) >= var4)) {
if (_vm->_rulesBuffer2_12[i] == var4b) {
_word16F00 = i;
@@ -1716,7 +1724,7 @@ byte LilliputScript::OC_sub17766() {
debugC(1, kDebugScript, "OC_sub17766()");
byte var1 = (_currScript->readUint16LE() & 0xFF);
- if ((var1 == _array12839[_vm->_rulesBuffer2PrevIndx]) && (_array12811[_vm->_rulesBuffer2PrevIndx] != 16))
+ if ((var1 == _array12839[_vm->currentScriptCharacter]) && (_array12811[_vm->currentScriptCharacter] != 16))
return 1;
return 0;
@@ -1726,7 +1734,7 @@ byte LilliputScript::OC_sub17782() {
debugC(1, kDebugScript, "OC_sub17782()");
byte var1 = (_currScript->readUint16LE() & 0xFF);
- if ((var1 == _array12839[_vm->_rulesBuffer2PrevIndx]) && (_array12811[_vm->_rulesBuffer2PrevIndx] == 16))
+ if ((var1 == _array12839[_vm->currentScriptCharacter]) && (_array12811[_vm->currentScriptCharacter] == 16))
return 1;
return 0;
@@ -1787,9 +1795,9 @@ byte LilliputScript::OC_sub177F5() {
byte var1 = _currScript->readUint16LE() & 0xFF;
byte var2 = _currScript->readUint16LE() & 0xFF;
- assert(_vm->_ptr_rulesBuffer2_15 != NULL);
+ assert(_vm->_currentCharacterVariables != NULL);
- if ((var1 == _vm->_ptr_rulesBuffer2_15[0]) && (var2 == _vm->_ptr_rulesBuffer2_15[1]))
+ if ((var1 == _vm->_currentCharacterVariables[0]) && (var2 == _vm->_currentCharacterVariables[1]))
return 1;
return 0;
@@ -1799,8 +1807,8 @@ byte LilliputScript::OC_sub17812() {
debugC(1, kDebugScript, "OC_sub17812()");
byte curByte = (_currScript->readUint16LE() & 0xFF);
- assert(_vm->_ptr_rulesBuffer2_15 != NULL);
- if (_vm->_ptr_rulesBuffer2_15[0] == curByte)
+ assert(_vm->_currentCharacterVariables != NULL);
+ if (_vm->_currentCharacterVariables[0] == curByte)
return 1;
return 0;
}
@@ -1837,7 +1845,7 @@ byte LilliputScript::OC_sub1785C() {
int count = 0;
for (int i = 0; i < _vm->_numCharacters; i++) {
- if (curByte == _vm->_rulesBuffer2_15[(32 * i)])
+ if (curByte == _vm->_characterVariables[(32 * i)])
++count;
}
@@ -1878,8 +1886,8 @@ byte LilliputScript::OC_sub178BA() {
byte LilliputScript::OC_sub178C2() {
debugC(1, kDebugScript, "OC_sub178C2()");
- assert(_vm->_ptr_rulesBuffer2_15 != NULL);
- if (_vm->_ptr_rulesBuffer2_15[2] == 1)
+ assert(_vm->_currentCharacterVariables != NULL);
+ if (_vm->_currentCharacterVariables[2] == 1)
return 1;
return 0;
}
@@ -1901,7 +1909,7 @@ byte LilliputScript::OC_sub178D2() {
byte LilliputScript::OC_sub178E8() {
debugC(1, kDebugScript, "OC_sub178E8()");
- byte *bufPtr = getBuffer215Ptr();
+ byte *bufPtr = getCharacterVariablePtr();
byte var1 = bufPtr[0];
byte curByte = (_currScript->readUint16LE() & 0xFF);
@@ -1914,10 +1922,10 @@ byte LilliputScript::OC_sub178E8() {
byte LilliputScript::OC_sub178FC() {
debugC(1, kDebugScript, "OC_sub178FC()");
- assert(_vm->_ptr_rulesBuffer2_15 != NULL);
+ assert(_vm->_currentCharacterVariables != NULL);
byte curByte = (_currScript->readUint16LE() & 0xFF);
- if (curByte <= _vm->_ptr_rulesBuffer2_15[0])
+ if (curByte <= _vm->_currentCharacterVariables[0])
return 1;
return 0;
}
@@ -1938,10 +1946,10 @@ byte LilliputScript::OC_sub1790F() {
byte LilliputScript::OC_sub1792A() {
debugC(1, kDebugScript, "OC_sub1792A()");
- assert(_vm->_ptr_rulesBuffer2_15 != NULL);
+ assert(_vm->_currentCharacterVariables != NULL);
byte curByte = (_currScript->readUint16LE() & 0xFF);
- if (_vm->_ptr_rulesBuffer2_15[1] == curByte)
+ if (_vm->_currentCharacterVariables[1] == curByte)
return 1;
return 0;
@@ -1953,7 +1961,7 @@ byte LilliputScript::OC_sub1793E() {
if (_vm->_currentScriptCharacterPosition == 0xFFFF)
return 0;
- if (_vm->_array16E94[_vm->_rulesBuffer2PrevIndx] == 0)
+ if (_vm->_array16E94[_vm->currentScriptCharacter] == 0)
return 0;
return 1;
@@ -1962,8 +1970,8 @@ byte LilliputScript::OC_sub1793E() {
byte LilliputScript::OC_sub1795E() {
debugC(1, kDebugScript, "OC_sub1795E()");
- assert(_vm->_ptr_rulesBuffer2_15 != NULL);
- if (_vm->_ptr_rulesBuffer2_15[3] == 1)
+ assert(_vm->_currentCharacterVariables != NULL);
+ if (_vm->_currentCharacterVariables[3] == 1)
return 1;
return 0;
@@ -2016,8 +2024,8 @@ byte LilliputScript::OC_sub179C2() {
debugC(1, kDebugScript, "OC_sub179C2()");
int var1 = getValue2();
- if ((_vm->_array10999[_vm->_rulesBuffer2PrevIndx] == (var1 >> 8))
- && (_vm->_array109C1[_vm->_rulesBuffer2PrevIndx] == (var1 & 0xFF)))
+ if ((_vm->_array10999[_vm->currentScriptCharacter] == (var1 >> 8))
+ && (_vm->_array109C1[_vm->currentScriptCharacter] == (var1 & 0xFF)))
return 1;
return 0;
@@ -2099,7 +2107,7 @@ void LilliputScript::OC_sub17D57() {
if (forceReturnFl)
return;
- _word1881B = _vm->_rulesBuffer2PrevIndx;
+ _word1881B = _vm->currentScriptCharacter;
sub18B3C(curWord);
}
@@ -2133,7 +2141,7 @@ void LilliputScript::sub18B7C(int var1, int var3) {
void LilliputScript::OC_sub17D7F() {
debugC(1, kDebugScript, "OC_sub17D7F()");
- int var1 = getBuffer215Ptr()[0];
+ int var1 = getCharacterVariablePtr()[0];
int var2 = (_currScript->readUint16LE() & 0xFF);
int var3 = var1 / var2;
@@ -2144,7 +2152,7 @@ void LilliputScript::OC_sub17D7F() {
if (forceReturnFl)
return;
- _word1881B = _vm->_rulesBuffer2PrevIndx;
+ _word1881B = _vm->currentScriptCharacter;
sub18B7C(var1, var3);
}
@@ -2188,7 +2196,7 @@ void LilliputScript::OC_sub17E15() {
void LilliputScript::OC_sub17B03() {
debugC(1, kDebugScript, "OC_sub17B03()");
- byte *bufPtr = getBuffer215Ptr();
+ byte *bufPtr = getCharacterVariablePtr();
int oper = _currScript->readUint16LE();
int var3 = _currScript->readUint16LE();
@@ -2198,7 +2206,7 @@ void LilliputScript::OC_sub17B03() {
void LilliputScript::OC_getRandom_type2() {
debugC(1, kDebugScript, "OC_getRandom_type2()");
- byte* bufPtr = getBuffer215Ptr();
+ byte* bufPtr = getCharacterVariablePtr();
int maxVal = _currScript->readUint16LE();
int randomVal = _vm->_rnd->getRandomNumber(maxVal);
*bufPtr = randomVal;
@@ -2264,15 +2272,15 @@ void LilliputScript::OC_incByte16F04() {
void LilliputScript::OC_sub17BA5() {
debugC(1, kDebugScript, "OC_sub17BA5()");
- byte *tmpArr = getBuffer215Ptr();
+ byte *tmpArr = getCharacterVariablePtr();
byte oper = (_currScript->readUint16LE() & 0xFF);
- byte var3 = getBuffer215Ptr()[0];
+ byte var3 = getCharacterVariablePtr()[0];
computeOperation(tmpArr, oper, var3);
}
void LilliputScript::OC_setByte18823() {
debugC(1, kDebugScript, "OC_setByte18823()");
- byte *tmpArr = getBuffer215Ptr();
+ byte *tmpArr = getCharacterVariablePtr();
_byte18823 = *tmpArr;
}
@@ -2283,7 +2291,7 @@ void LilliputScript::OC_callScript() {
int var1 = getValue1();
_vm->sub170EE(var1);
- int tmpIndex = _vm->_rulesBuffer2PrevIndx;
+ int tmpIndex = _vm->currentScriptCharacter;
assert(index < _vm->_gameScriptIndexSize);
int scriptIndex = _vm->_arrayGameScriptIndex[index];
@@ -2313,9 +2321,9 @@ void LilliputScript::OC_sub17ACC() {
debugC(1, kDebugScript, "OC_sub17ACC()");
int var = getValue2();
- _vm->_array10999[_vm->_rulesBuffer2PrevIndx] = var >> 8;
- _vm->_array109C1[_vm->_rulesBuffer2PrevIndx] = var & 0xFF;
- _vm->_array109E9[_vm->_rulesBuffer2PrevIndx] = 0xFF;
+ _vm->_array10999[_vm->currentScriptCharacter] = var >> 8;
+ _vm->_array109C1[_vm->currentScriptCharacter] = var & 0xFF;
+ _vm->_array109E9[_vm->currentScriptCharacter] = 0xFF;
}
void LilliputScript::OC_resetByte16F04() {
@@ -2328,14 +2336,14 @@ void LilliputScript::OC_sub17AE1() {
debugC(1, kDebugScript, "OC_sub17AE1()");
byte var3 = (_currScript->readUint16LE() & 0xFF);
- sub16C5C(_vm->_rulesBuffer2PrevIndx, var3);
+ sub16C5C(_vm->currentScriptCharacter, var3);
}
void LilliputScript::OC_sub17AEE() {
debugC(1, kDebugScript, "OC_sub17AEE()");
byte var3 = (_currScript->readUint16LE() & 0xFF);
- sub16C5C(_vm->_rulesBuffer2PrevIndx + 1, var3);
+ sub16C5C(_vm->currentScriptCharacter + 1, var3);
}
void LilliputScript::OC_setWord10804() {
@@ -2347,13 +2355,13 @@ void LilliputScript::OC_setWord10804() {
void LilliputScript::OC_sub17C0E() {
debugC(1, kDebugScript, "OC_sub17C0E()");
- assert(_vm->_ptr_rulesBuffer2_15 != NULL);
- byte var1 = (_vm->_ptr_rulesBuffer2_15[4] << 8) + _vm->_ptr_rulesBuffer2_15[5];
- byte b2 = _vm->_ptr_rulesBuffer2_15[6];
+ assert(_vm->_currentCharacterVariables != NULL);
+ byte var1 = (_vm->_currentCharacterVariables[4] << 8) + _vm->_currentCharacterVariables[5];
+ byte b2 = _vm->_currentCharacterVariables[6];
byte *mapPtr = getMapPtr(var1);
- mapPtr[b2] = _vm->_ptr_rulesBuffer2_15[7];
- mapPtr[3] = _vm->_ptr_rulesBuffer2_15[8];
+ mapPtr[b2] = _vm->_currentCharacterVariables[7];
+ mapPtr[3] = _vm->_currentCharacterVariables[8];
if (b2 == 0) {
_byte12A09 = 1;
@@ -2379,7 +2387,7 @@ void LilliputScript::OC_sub17C76() {
int var1 = getValue1();
_vm->_rulesBuffer2_5[var1] = 0xFF;
- _vm->_rulesBuffer2_3[var1] = 0;
+ _vm->_characterPositionAltitude[var1] = 0;
_characterScriptEnabled[var1] = 1;
}
@@ -2409,7 +2417,7 @@ void LilliputScript::OC_sub17C8B() {
int var1 = 2 << 8;
int var4 = _currScript->readUint16LE();
int var2 = _currScript->readUint16LE();
- var2 = ((var2 & 0xFF) << 8 ) + _vm->_rulesBuffer2PrevIndx;
+ var2 = ((var2 & 0xFF) << 8 ) + _vm->currentScriptCharacter;
sub171AF(var1, var2, var4);
}
@@ -2420,7 +2428,7 @@ void LilliputScript::OC_sub17CA2() {
int var1 = 1 << 8;
int var4 = _currScript->readUint16LE();
int var2 = _currScript->readUint16LE();
- var2 = ((var2 & 0xFF) << 8 ) + _vm->_rulesBuffer2PrevIndx;
+ var2 = ((var2 & 0xFF) << 8 ) + _vm->currentScriptCharacter;
sub171AF(var1, var2, var4);
}
@@ -2431,7 +2439,7 @@ void LilliputScript::OC_sub17CB9() {
int var4 = _currScript->readUint16LE();
int var1 = getValue1();
int var2 = _currScript->readUint16LE();
- var2 = ((var2 & 0xFF) << 8 ) + _vm->_rulesBuffer2PrevIndx;
+ var2 = ((var2 & 0xFF) << 8 ) + _vm->currentScriptCharacter;
sub171AF(var1, var2, var4);
}
@@ -2442,7 +2450,7 @@ void LilliputScript::OC_sub17CD1() {
int var1 = 3 << 8;
int var4 = _currScript->readUint16LE();
int var2 = _currScript->readUint16LE();
- var2 = ((var2 & 0xFF) << 8 ) + _vm->_rulesBuffer2PrevIndx;
+ var2 = ((var2 & 0xFF) << 8 ) + _vm->currentScriptCharacter;
sub171AF(var1, var2, var4);
}
@@ -2457,15 +2465,15 @@ void LilliputScript::OC_sub17CEF() {
debugC(1, kDebugScript, "OC_sub17CEF()");
int var1 = _currScript->readUint16LE();
- sub1823E(_vm->_rulesBuffer2PrevIndx , var1, _vm->_ptr_rulesBuffer2_15);
+ sub1823E(_vm->currentScriptCharacter , var1, _vm->_currentCharacterVariables);
sub17B6C(0);
}
void LilliputScript::OC_sub17D1B() {
debugC(1, kDebugScript, "OC_sub17D1B()");
- assert(_vm->_ptr_rulesBuffer2_15 != NULL);
- ++_vm->_ptr_rulesBuffer2_15[1];
+ assert(_vm->_currentCharacterVariables != NULL);
+ ++_vm->_currentCharacterVariables[1];
}
void LilliputScript::OC_sub17D23() {
@@ -2473,7 +2481,7 @@ void LilliputScript::OC_sub17D23() {
int var1 = _currScript->readUint16LE();
int var2 = getValue2();
- byte* buf = _vm->_ptr_rulesBuffer2_15 + 4;
+ byte* buf = _vm->_currentCharacterVariables + 4;
computeOperation(buf, var1, var2 >> 8);
computeOperation(buf + 1, var1, var2 & 0xFF);
}
@@ -2482,7 +2490,7 @@ void LilliputScript::OC_sub17E6D() {
debugC(1, kDebugScript, "OC_sub17E6D()");
int var1 = _currScript->readUint16LE();
- _vm->_rulesBuffer2_12[_vm->_rulesBuffer2PrevIndx] = (var1 - 2000) & 0xFF;
+ _vm->_rulesBuffer2_12[_vm->currentScriptCharacter] = (var1 - 2000) & 0xFF;
}
void LilliputScript::OC_changeCurrentCharacterSprite() {
@@ -2490,8 +2498,8 @@ void LilliputScript::OC_changeCurrentCharacterSprite() {
int var1 = _currScript->readUint16LE();
int var2 = _currScript->readUint16LE();
- _vm->_characterFrameArray[_vm->_rulesBuffer2PrevIndx] = var1;
- _vm->_spriteSizeArray[_vm->_rulesBuffer2PrevIndx] = var2;
+ _vm->_characterFrameArray[_vm->currentScriptCharacter] = var1;
+ _vm->_spriteSizeArray[_vm->currentScriptCharacter] = var2;
}
@@ -2499,7 +2507,7 @@ byte *LilliputScript::sub173D2() {
debugC(2, kDebugScript, "sub173D2()");
int index = _currScript->readUint16LE();
- return &_vm->_ptr_rulesBuffer2_15[index];
+ return &_vm->_currentCharacterVariables[index];
}
void LilliputScript::OC_sub17E99() {
@@ -2538,9 +2546,9 @@ void LilliputScript::OC_sub17EF4() {
debugC(1, kDebugScript, "OC_sub17EF4()");
int var1 = getValue2();
- int posTile = sub17285(_vm->_rulesBuffer2PrevIndx);
+ int posTile = sub17285(_vm->currentScriptCharacter);
int dir = _vm->sub16B0C(posTile, var1);
- _vm->_characterDirectionArray[_vm->_rulesBuffer2PrevIndx] = dir;
+ _vm->_characterDirectionArray[_vm->currentScriptCharacter] = dir;
}
void LilliputScript::OC_sub17F08() {
@@ -2550,8 +2558,8 @@ void LilliputScript::OC_sub17F08() {
static const byte _directionsArray[] = { 0, 2, 0, 1, 3, 2, 3, 1 };
- int dx = _vm->_characterPositionX[index] - _vm->_characterDisplayX[_vm->_rulesBuffer2PrevIndx];
- int dy = _vm->_characterPositionY[index] - _vm->_characterDisplayY[_vm->_rulesBuffer2PrevIndx];
+ int dx = _vm->_characterPositionX[index] - _vm->_characterDisplayX[_vm->currentScriptCharacter];
+ int dy = _vm->_characterPositionY[index] - _vm->_characterDisplayY[_vm->currentScriptCharacter];
int flag = 0;
if (dx < 0) {
@@ -2566,27 +2574,27 @@ void LilliputScript::OC_sub17F08() {
flag |= 1;
}
- _vm->_characterDirectionArray[_vm->_rulesBuffer2PrevIndx] = _directionsArray[flag];
+ _vm->_characterDirectionArray[_vm->currentScriptCharacter] = _directionsArray[flag];
}
void LilliputScript::OC_sub17F4F() {
debugC(1, kDebugScript, "OC_sub17F4F()");
int var = getValue1();
- _array10A39[_vm->_rulesBuffer2PrevIndx] = var;
- _vm->_array109E9[_vm->_rulesBuffer2PrevIndx] = 0xFF;
+ _array10A39[_vm->currentScriptCharacter] = var;
+ _vm->_array109E9[_vm->currentScriptCharacter] = 0xFF;
}
void LilliputScript::OC_sub17F68() {
- if (_vm->_rulesBuffer2PrevIndx != _viewportCharacterTarget)
+ if (_vm->currentScriptCharacter != _viewportCharacterTarget)
return;
static const byte _byte_17F60[] = { 0xFF, 0xFD, 0xFD, 0xFA };
static const byte _byte_17F64[] = { 0xFD, 0xFA, 0xFF, 0xFD };
- int cx = _byte_17F60[_vm->_characterDirectionArray[_vm->_rulesBuffer2PrevIndx]];
- int cy = _byte_17F64[_vm->_characterDirectionArray[_vm->_rulesBuffer2PrevIndx]];
+ int cx = _byte_17F60[_vm->_characterDirectionArray[_vm->currentScriptCharacter]];
+ int cy = _byte_17F64[_vm->_characterDirectionArray[_vm->currentScriptCharacter]];
- int pos = sub17285(_vm->_rulesBuffer2PrevIndx);
+ int pos = sub17285(_vm->currentScriptCharacter);
int posx = pos >> 8;
int posy = pos & 0xFF;
@@ -2619,7 +2627,7 @@ void LilliputScript::OC_sub17FD2() {
debugC(1, kDebugScript, "OC_sub17FD2()");
int var1 = getValue1();
- _vm->_ptr_rulesBuffer2_15[6] = var1 & 0xFF;
+ _vm->_currentCharacterVariables[6] = var1 & 0xFF;
}
@@ -2628,10 +2636,10 @@ void LilliputScript::OC_sub17FDD() {
int index = _currScript->readUint16LE();
- int tmpVal = (_vm->_rulesBuffer2PrevIndx * 32) + index;
+ int tmpVal = (_vm->currentScriptCharacter * 32) + index;
assert (tmpVal < 40 * 32);
- _array10AB1[_vm->_rulesBuffer2PrevIndx] = _vm->_rulesBuffer2_16[tmpVal];
- _array12811[_vm->_rulesBuffer2PrevIndx] = 16;
+ _array10AB1[_vm->currentScriptCharacter] = _vm->_rulesBuffer2_16[tmpVal];
+ _array12811[_vm->currentScriptCharacter] = 16;
}
void LilliputScript::OC_setByte10B29() {
@@ -2644,15 +2652,15 @@ void LilliputScript::OC_sub18007() {
debugC(1, kDebugScript, "OC_sub18007()");
int curWord = _currScript->readUint16LE();
- assert(_vm->_ptr_rulesBuffer2_15 != NULL);
- _vm->_ptr_rulesBuffer2_15[2] = curWord & 0xFF;
+ assert(_vm->_currentCharacterVariables != NULL);
+ _vm->_currentCharacterVariables[2] = curWord & 0xFF;
}
void LilliputScript::OC_sub18014() {
debugC(1, kDebugScript, "OC_sub18014()");
- assert(_vm->_ptr_rulesBuffer2_15 != NULL);
- _vm->_ptr_rulesBuffer2_15[2] = 0;
+ assert(_vm->_currentCharacterVariables != NULL);
+ _vm->_currentCharacterVariables[2] = 0;
}
void LilliputScript::OC_sub1801D() {
@@ -2668,7 +2676,7 @@ void LilliputScript::OC_sub1801D() {
y += _currScript->readUint16LE();
_vm->_characterPositionY[var1] = y;
- _vm->_rulesBuffer2_3[var1] = _currScript->readUint16LE();
+ _vm->_characterPositionAltitude[var1] = _currScript->readUint16LE();
_vm->_characterDirectionArray[var1] = _currScript->readUint16LE();
}
@@ -2685,13 +2693,13 @@ void LilliputScript::OC_sub18074() {
int var2 = _currScript->readUint16LE();
byte var1 = (_currScript->readUint16LE() & 0xFF);
- _vm->_rulesBuffer2_16[(_vm->_rulesBuffer2PrevIndx * 32) + var2] = var1;
+ _vm->_rulesBuffer2_16[(_vm->currentScriptCharacter * 32) + var2] = var1;
}
void LilliputScript::OC_setCurrentCharacterDirection() {
debugC(1, kDebugScript, "OC_setCurrentCharacterDirection()");
- _vm->_characterDirectionArray[_vm->_rulesBuffer2PrevIndx] = (_currScript->readUint16LE() & 0xFF);
+ _vm->_characterDirectionArray[_vm->currentScriptCharacter] = (_currScript->readUint16LE() & 0xFF);
}
void LilliputScript::OC_sub18099() {
@@ -2752,7 +2760,7 @@ void LilliputScript::OC_sub1810A() {
void LilliputScript::OC_sub1812D() {
debugC(1, kDebugScript, "OC_sub1812D()");
- _vm->_rulesBuffer2_3[_vm->_rulesBuffer2PrevIndx] = (_currScript->readUint16LE() & 0xFF);
+ _vm->_characterPositionAltitude[_vm->currentScriptCharacter] = (_currScript->readUint16LE() & 0xFF);
}
void LilliputScript::OC_sub1817F() {
@@ -2789,7 +2797,7 @@ void LilliputScript::OC_sub181BB() {
int b = _currScript->readUint16LE();
int d = _currScript->readUint16LE() & 0xFF;
int s = _currScript->readUint16LE();
- int c = _vm->_ptr_rulesBuffer2_15[s];
+ int c = _vm->_currentCharacterVariables[s];
int c2 = 0;
if ( d == 0x2D ) {
@@ -2827,7 +2835,7 @@ void LilliputScript::OC_sub18213() {
maxItem = _array1813B[i] >> 8;
}
}
- sub1823E(_vm->_rulesBuffer2PrevIndx, maxItem, &_vm->_rulesBuffer2_15[var1]);
+ sub1823E(_vm->currentScriptCharacter, maxItem, &_vm->_characterVariables[var1]);
}
void LilliputScript::OC_sub18252() {
@@ -2861,7 +2869,7 @@ void LilliputScript::OC_sub18260() {
void LilliputScript::OC_sub182EC() {
debugC(1, kDebugScript, "OC_sub182EC()");
- byte *tmpArr = getBuffer215Ptr();
+ byte *tmpArr = getCharacterVariablePtr();
byte var1 = (_currScript->readUint16LE() & 0xFF);
byte var2 = (_currScript->readUint16LE() & 0xFF);
@@ -2905,26 +2913,26 @@ void LilliputScript::OC_sub1834C() {
debugC(1, kDebugScript, "OC_sub1834C()");
byte curWord = _currScript->readUint16LE() & 0xFF;
- assert(_vm->_ptr_rulesBuffer2_15 != NULL);
+ assert(_vm->_currentCharacterVariables != NULL);
- _vm->_ptr_rulesBuffer2_15[3] = curWord;
+ _vm->_currentCharacterVariables[3] = curWord;
}
void LilliputScript::OC_setArray122C1() {
debugC(1, kDebugScript, "OC_setArray122C1()");
int var1 = _currScript->readUint16LE();
- _array122C1[_vm->_rulesBuffer2PrevIndx] = var1;
+ _array122C1[_vm->currentScriptCharacter] = var1;
}
void LilliputScript::OC_sub18367() {
debugC(1, kDebugScript, "OC_sub18367()");
- _characterScriptEnabled[_vm->_rulesBuffer2PrevIndx] = 1;
- _vm->_ptr_rulesBuffer2_15[0] = _array122C1[_vm->_rulesBuffer2PrevIndx];
- _vm->_ptr_rulesBuffer2_15[1] = 0;
- _vm->_ptr_rulesBuffer2_15[2] = 0;
- _vm->_ptr_rulesBuffer2_15[3] = 0;
+ _characterScriptEnabled[_vm->currentScriptCharacter] = 1;
+ _vm->_currentCharacterVariables[0] = _array122C1[_vm->currentScriptCharacter];
+ _vm->_currentCharacterVariables[1] = 0;
+ _vm->_currentCharacterVariables[2] = 0;
+ _vm->_currentCharacterVariables[3] = 0;
}
void LilliputScript::OC_sub17D04() {
@@ -2933,7 +2941,7 @@ void LilliputScript::OC_sub17D04() {
byte var1 = getValue1();
byte var2 = _currScript->readUint16LE() & 0xFF;
- sub1823E(var1, var2, &_vm->_rulesBuffer2_15[var1]);
+ sub1823E(var1, var2, &_vm->_characterVariables[var1]);
}
void LilliputScript::OC_sub18387() {
@@ -2996,7 +3004,7 @@ void LilliputScript::OC_sub1844A() {
void LilliputScript::OC_sub1847F() {
debugC(1, kDebugScript, "OC_sub1847F()");
- byte *buf215Ptr = getBuffer215Ptr();
+ byte *buf215Ptr = getCharacterVariablePtr();
byte tmpVal = buf215Ptr[0];
int curWord = _currScript->readUint16LE();
assert(curWord != 0);
@@ -3108,7 +3116,7 @@ void LilliputScript::OC_initArr18560() {
void LilliputScript::OC_sub18678() {
debugC(1, kDebugScript, "OC_initArr18578()");
- _savedBuffer215Ptr = getBuffer215Ptr();
+ _savedBuffer215Ptr = getCharacterVariablePtr();
_heroismBarX = _currScript->readUint16LE();
_heroismBarBottomY = _currScript->readUint16LE();
}
diff --git a/engines/lilliput/script.h b/engines/lilliput/script.h
index e964c3c602..c5b67f81f3 100644
--- a/engines/lilliput/script.h
+++ b/engines/lilliput/script.h
@@ -33,6 +33,26 @@ namespace Lilliput {
class LilliputEngine;
+enum KValueType {
+ kNone,
+ kImmediateValue,
+ kCompareOperation,
+ kComputeOperation,
+ kGetValue1,
+ kGetValue2,
+};
+
+
+struct OpCode {
+ const char* _opName;
+ int _numArgs;
+ KValueType _arg1;
+ KValueType _arg2;
+ KValueType _arg3;
+ KValueType _arg4;
+ KValueType _arg5;
+};
+
class LilliputScript {
public:
byte _byte12A04;
@@ -70,6 +90,7 @@ public:
~LilliputScript();
void disasmScript(ScriptStream script);
+ static Common::String getArgumentString(KValueType type, ScriptStream& script);
void runScript(ScriptStream script);
void runMenuScript(ScriptStream script);
private:
@@ -121,7 +142,7 @@ private:
int getValue1();
int getValue2();
- byte *getBuffer215Ptr();
+ byte *getCharacterVariablePtr();
byte compareValues(byte var1, int oper, int var2);
void computeOperation(byte *bufPtr, int oper, int var2);