diff options
Diffstat (limited to 'engines/adl/adl_v2.cpp')
-rw-r--r-- | engines/adl/adl_v2.cpp | 109 |
1 files changed, 66 insertions, 43 deletions
diff --git a/engines/adl/adl_v2.cpp b/engines/adl/adl_v2.cpp index 757ea91a42..4089ab3e30 100644 --- a/engines/adl/adl_v2.cpp +++ b/engines/adl/adl_v2.cpp @@ -54,50 +54,73 @@ void AdlEngine_v2::insertDisk(byte volume) { _currentVolume = volume; } +typedef Common::Functor1Mem<ScriptEnv &, int, AdlEngine_v2> OpcodeV2; +#define SetOpcodeTable(x) table = &x; +#define Opcode(x) table->push_back(new OpcodeV2(this, &AdlEngine_v2::x)) +#define OpcodeUnImpl() table->push_back(new OpcodeV2(this, 0)) + void AdlEngine_v2::setupOpcodeTables() { - _condOpcodes.resize(0x0b); - _condOpcodes[0x01] = opcode(o2_isFirstTime); - _condOpcodes[0x02] = opcode(o2_isRandomGT); - _condOpcodes[0x03] = opcode(o1_isItemInRoom); - _condOpcodes[0x04] = opcode(o2_isNounNotInRoom); - _condOpcodes[0x05] = opcode(o1_isMovesGT); - _condOpcodes[0x06] = opcode(o1_isVarEQ); - _condOpcodes[0x07] = opcode(o2_isCarryingSomething); - _condOpcodes[0x09] = opcode(o1_isCurPicEQ); - _condOpcodes[0x0a] = opcode(o1_isItemPicEQ); - - _actOpcodes.resize(0x21); - _actOpcodes[0x01] = opcode(o1_varAdd); - _actOpcodes[0x02] = opcode(o1_varSub); - _actOpcodes[0x03] = opcode(o1_varSet); - _actOpcodes[0x04] = opcode(o1_listInv); - _actOpcodes[0x05] = opcode(o2_moveItem); - _actOpcodes[0x06] = opcode(o1_setRoom); - _actOpcodes[0x07] = opcode(o2_setCurPic); - _actOpcodes[0x08] = opcode(o2_setPic); - _actOpcodes[0x09] = opcode(o1_printMsg); - _actOpcodes[0x0a] = opcode(o1_setLight); - _actOpcodes[0x0b] = opcode(o1_setDark); - _actOpcodes[0x0c] = opcode(o2_moveAllItems); - _actOpcodes[0x0d] = opcode(o1_quit); - _actOpcodes[0x0f] = opcode(o2_save); - _actOpcodes[0x10] = opcode(o2_restore); - _actOpcodes[0x11] = opcode(o1_restart); - _actOpcodes[0x12] = opcode(o2_placeItem); - _actOpcodes[0x13] = opcode(o1_setItemPic); - _actOpcodes[0x14] = opcode(o1_resetPic); - _actOpcodes[0x15] = opcode(o1_goDirection<IDI_DIR_NORTH>); - _actOpcodes[0x16] = opcode(o1_goDirection<IDI_DIR_SOUTH>); - _actOpcodes[0x17] = opcode(o1_goDirection<IDI_DIR_EAST>); - _actOpcodes[0x18] = opcode(o1_goDirection<IDI_DIR_WEST>); - _actOpcodes[0x19] = opcode(o1_goDirection<IDI_DIR_UP>); - _actOpcodes[0x1a] = opcode(o1_goDirection<IDI_DIR_DOWN>); - _actOpcodes[0x1b] = opcode(o1_takeItem); - _actOpcodes[0x1c] = opcode(o1_dropItem); - _actOpcodes[0x1d] = opcode(o1_setRoomPic); - _actOpcodes[0x1e] = opcode(o2_tellTime); - _actOpcodes[0x1f] = opcode(o2_setRoomFromVar); - _actOpcodes[0x20] = opcode(o2_initDisk); + Common::Array<const Opcode *> *table = 0; + + SetOpcodeTable(_condOpcodes); + // 0x00 + OpcodeUnImpl(); + Opcode(o2_isFirstTime); + Opcode(o2_isRandomGT); + Opcode(o1_isItemInRoom); + // 0x04 + Opcode(o2_isNounNotInRoom); + Opcode(o1_isMovesGT); + Opcode(o1_isVarEQ); + Opcode(o2_isCarryingSomething); + // 0x08 + OpcodeUnImpl(); + Opcode(o1_isCurPicEQ); + Opcode(o1_isItemPicEQ); + + SetOpcodeTable(_actOpcodes); + // 0x00 + OpcodeUnImpl(); + Opcode(o1_varAdd); + Opcode(o1_varSub); + Opcode(o1_varSet); + // 0x04 + Opcode(o1_listInv); + Opcode(o2_moveItem); + Opcode(o1_setRoom); + Opcode(o2_setCurPic); + // 0x08 + Opcode(o2_setPic); + Opcode(o1_printMsg); + Opcode(o1_setLight); + Opcode(o1_setDark); + // 0x0c + Opcode(o2_moveAllItems); + Opcode(o1_quit); + OpcodeUnImpl(); + Opcode(o2_save); + // 0x10 + Opcode(o2_restore); + Opcode(o1_restart); + Opcode(o2_placeItem); + Opcode(o1_setItemPic); + // 0x14 + Opcode(o1_resetPic); + Opcode(o1_goDirection<IDI_DIR_NORTH>); + Opcode(o1_goDirection<IDI_DIR_SOUTH>); + Opcode(o1_goDirection<IDI_DIR_EAST>); + // 0x18 + Opcode(o1_goDirection<IDI_DIR_WEST>); + Opcode(o1_goDirection<IDI_DIR_UP>); + Opcode(o1_goDirection<IDI_DIR_DOWN>); + Opcode(o1_takeItem); + // 0x1c + Opcode(o1_dropItem); + Opcode(o1_setRoomPic); + Opcode(o2_tellTime); + Opcode(o2_setRoomFromVar); + // 0x20 + Opcode(o2_initDisk); } void AdlEngine_v2::initState() { |