aboutsummaryrefslogtreecommitdiff
path: root/engines
diff options
context:
space:
mode:
Diffstat (limited to 'engines')
-rw-r--r--engines/access/scripts.cpp76
-rw-r--r--engines/access/scripts.h14
2 files changed, 72 insertions, 18 deletions
diff --git a/engines/access/scripts.cpp b/engines/access/scripts.cpp
index 337aa43eb5..38f9f92329 100644
--- a/engines/access/scripts.cpp
+++ b/engines/access/scripts.cpp
@@ -78,9 +78,9 @@ int Scripts::executeScript() {
void Scripts::executeCommand(int commandIndex, const byte *&pScript) {
static const ScriptMethodPtr COMMAND_LIST[] = {
- &Scripts::CMDENDOBJECT, &Scripts::CMDJUMPLOOK, &Scripts::CMDJUMPHELP, &Scripts::CMDJUMPGET, &Scripts::CMDJUMPMOVE,
- &Scripts::CMDJUMPUSE, &Scripts::CMDJUMPTALK, &Scripts::CMDNULL, &Scripts::CMDPRINT, &Scripts::CMDRETPOS, &Scripts::CMDANIM,
- &Scripts::CMDSETFLAG, &Scripts::CMDCHECKFLAG, &Scripts::cmdGoto, &Scripts::CMDSETINV, &Scripts::CMDSETINV,
+ &Scripts::CMDENDOBJECT, &Scripts::cmdJumpLook, &Scripts::cmdJumpHelp, &Scripts::cmdJumpGet, &Scripts::cmdJumpMove,
+ &Scripts::cmdJumpUse, &Scripts::cmdJumpTalk, &Scripts::CMDNULL, &Scripts::CMDPRINT, &Scripts::CMDRETPOS, &Scripts::CMDANIM,
+ &Scripts::cmdSetFlag, &Scripts::CMDCHECKFLAG, &Scripts::cmdGoto, &Scripts::CMDSETINV, &Scripts::CMDSETINV,
&Scripts::CMDCHECKINV, &Scripts::CMDSETTEX, &Scripts::CMDNEWROOM, &Scripts::CMDCONVERSE, &Scripts::CMDCHECKFRAME,
&Scripts::CMDCHECKANIM, &Scripts::CMDSND, &Scripts::CMDRETNEG, &Scripts::CMDRETPOS, &Scripts::CMDCHECKLOC, &Scripts::CMDSETANIM,
&Scripts::CMDDISPINV, &Scripts::CMDSETTIMER, &Scripts::CMDSETTIMER, &Scripts::CMDCHECKTIMER, &Scripts::CMDSETTRAVEL,
@@ -100,18 +100,72 @@ void Scripts::executeCommand(int commandIndex, const byte *&pScript) {
}
void Scripts::CMDENDOBJECT(const byte *&pScript) { }
-void Scripts::CMDJUMPLOOK(const byte *&pScript) { }
-void Scripts::CMDJUMPHELP(const byte *&pScript) { }
-void Scripts::CMDJUMPGET(const byte *&pScript) { }
-void Scripts::CMDJUMPMOVE(const byte *&pScript) { }
-void Scripts::CMDJUMPUSE(const byte *&pScript) { }
-void Scripts::CMDJUMPTALK(const byte *&pScript) { }
+
+void Scripts::cmdJumpLook(const byte *&pScript) {
+ if (_vm->_selectCommand == 0)
+ cmdGoto(pScript);
+ else
+ pScript += 2;
+}
+
+void Scripts::cmdJumpHelp(const byte *&pScript) {
+ if (_vm->_selectCommand == 8)
+ cmdGoto(pScript);
+ else
+ pScript += 2;
+}
+
+void Scripts::cmdJumpGet(const byte *&pScript) {
+ if (_vm->_selectCommand == 3)
+ cmdGoto(pScript);
+ else
+ pScript += 2;
+}
+
+void Scripts::cmdJumpMove(const byte *&pScript) {
+ if (_vm->_selectCommand == 2)
+ cmdGoto(pScript);
+ else
+ pScript += 2;
+}
+
+void Scripts::cmdJumpUse(const byte *&pScript) {
+ if (_vm->_selectCommand == 4)
+ cmdGoto(pScript);
+ else
+ pScript += 2;
+}
+
+void Scripts::cmdJumpTalk(const byte *&pScript) {
+ if (_vm->_selectCommand == 6)
+ cmdGoto(pScript);
+ else
+ pScript += 2;
+}
+
void Scripts::CMDNULL(const byte *&pScript) { }
void Scripts::CMDPRINT(const byte *&pScript) { }
void Scripts::CMDRETPOS(const byte *&pScript) { }
void Scripts::CMDANIM(const byte *&pScript) { }
-void Scripts::CMDSETFLAG(const byte *&pScript) { }
-void Scripts::CMDCHECKFLAG(const byte *&pScript) { }
+
+void Scripts::cmdSetFlag(const byte *&pScript) {
+ int flagNum = *pScript++;
+ byte flagVal = *pScript++;
+ assert(flagNum < 100);
+ _vm->_flags[flagNum] = flagVal;
+}
+
+void Scripts::CMDCHECKFLAG(const byte *&pScript) {
+ int flagNum = READ_LE_UINT16(pScript);
+ int flagVal = READ_LE_UINT16(pScript + 2);
+ pScript += 4;
+ assert(flagNum < 100);
+
+ if (_vm->_flags[flagNum] == (flagVal & 0xff))
+ cmdGoto(pScript);
+ else
+ pScript += 2;
+}
void Scripts::cmdGoto(const byte *&pScript) {
_sequence = READ_LE_UINT16(pScript);
diff --git a/engines/access/scripts.h b/engines/access/scripts.h
index fc75e9e9ab..5e733dbd47 100644
--- a/engines/access/scripts.h
+++ b/engines/access/scripts.h
@@ -38,17 +38,17 @@ protected:
virtual void executeCommand(int commandIndex, const byte *&pScript);
void CMDENDOBJECT(const byte *&pScript);
- void CMDJUMPLOOK(const byte *&pScript);
- void CMDJUMPHELP(const byte *&pScript);
- void CMDJUMPGET(const byte *&pScript);
- void CMDJUMPMOVE(const byte *&pScript);
- void CMDJUMPUSE(const byte *&pScript);
- void CMDJUMPTALK(const byte *&pScript);
+ void cmdJumpLook(const byte *&pScript);
+ void cmdJumpHelp(const byte *&pScript);
+ void cmdJumpGet(const byte *&pScript);
+ void cmdJumpMove(const byte *&pScript);
+ void cmdJumpUse(const byte *&pScript);
+ void cmdJumpTalk(const byte *&pScript);
void CMDNULL(const byte *&pScript);
void CMDPRINT(const byte *&pScript);
void CMDRETPOS(const byte *&pScript);
void CMDANIM(const byte *&pScript);
- void CMDSETFLAG(const byte *&pScript);
+ void cmdSetFlag(const byte *&pScript);
void CMDCHECKFLAG(const byte *&pScript);
/**