2007-05-30 21:56:52 +00:00
|
|
|
/* ScummVM - Graphic Adventure Engine
|
|
|
|
*
|
|
|
|
* ScummVM is the legal property of its developers, whose names
|
|
|
|
* are too numerous to list here. Please refer to the COPYRIGHT
|
|
|
|
* file distributed with this source distribution.
|
2003-09-11 10:32:15 +00:00
|
|
|
*
|
2021-12-26 18:47:58 +01:00
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
2014-02-18 02:34:24 +01:00
|
|
|
*
|
2003-09-11 10:32:15 +00:00
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
2014-02-18 02:34:24 +01:00
|
|
|
*
|
2003-09-11 10:32:15 +00:00
|
|
|
* You should have received a copy of the GNU General Public License
|
2021-12-26 18:47:58 +01:00
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
2003-09-11 10:32:15 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2007-02-19 17:48:19 +00:00
|
|
|
#ifndef SCUMM_SCRIPT_H
|
|
|
|
#define SCUMM_SCRIPT_H
|
2003-09-11 10:32:15 +00:00
|
|
|
|
2009-04-16 09:26:37 +00:00
|
|
|
#include "common/func.h"
|
2003-09-11 10:32:15 +00:00
|
|
|
|
2003-10-03 18:33:57 +00:00
|
|
|
namespace Scumm {
|
2003-09-11 10:32:15 +00:00
|
|
|
|
2009-04-16 09:26:37 +00:00
|
|
|
typedef Common::Functor0<void> Opcode;
|
|
|
|
|
|
|
|
struct OpcodeEntry : Common::NonCopyable {
|
|
|
|
Opcode *proc;
|
2011-05-17 15:50:11 +02:00
|
|
|
#ifndef REDUCE_MEMORY_USAGE
|
2009-04-16 09:26:37 +00:00
|
|
|
const char *desc;
|
2011-05-17 15:50:11 +02:00
|
|
|
#endif
|
2009-04-16 09:26:37 +00:00
|
|
|
|
2011-05-17 15:50:11 +02:00
|
|
|
#ifndef REDUCE_MEMORY_USAGE
|
2009-04-16 09:26:37 +00:00
|
|
|
OpcodeEntry() : proc(0), desc(0) {}
|
2011-05-17 15:50:11 +02:00
|
|
|
#else
|
|
|
|
OpcodeEntry() : proc(0) {}
|
|
|
|
#endif
|
2009-04-16 09:26:37 +00:00
|
|
|
~OpcodeEntry() {
|
|
|
|
setProc(0, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
void setProc(Opcode *p, const char *d) {
|
|
|
|
if (proc != p) {
|
|
|
|
delete proc;
|
|
|
|
proc = p;
|
|
|
|
}
|
2011-05-17 15:50:11 +02:00
|
|
|
#ifndef REDUCE_MEMORY_USAGE
|
2009-04-16 09:26:37 +00:00
|
|
|
desc = d;
|
2011-05-17 15:50:11 +02:00
|
|
|
#endif
|
2009-04-16 09:26:37 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
// This is to help devices with small memory (PDA, smartphones, ...)
|
|
|
|
// to save abit of memory used by opcode names in the Scumm engine.
|
|
|
|
#ifndef REDUCE_MEMORY_USAGE
|
|
|
|
# define _OPCODE(ver, x) setProc(new Common::Functor0Mem<void, ver>(this, &ver::x), #x)
|
|
|
|
#else
|
|
|
|
# define _OPCODE(ver, x) setProc(new Common::Functor0Mem<void, ver>(this, &ver::x), "")
|
|
|
|
#endif
|
|
|
|
|
2005-10-21 22:49:59 +00:00
|
|
|
/**
|
|
|
|
* The number of script slots, which determines the maximal number
|
SCUMM: Use correct array size when calling initializeLocals()
The initializeLocals() function assumes that it can copy 25
elements when being provided an array of values. But this array
was frequently a lot smaller than that. I've introduced a constant
for the number of locals (though VirtualMachineState has one more
for some reason), and fixed the array sizes in a number of places.
CID 1003951, 1003952, 1003953, 1003955, 1003956, 1003959, 1003960,
1003961, 1003963, 100394, 1003965
2013-04-30 22:26:51 +02:00
|
|
|
* of concurrently running scripts, and the number of local variables
|
|
|
|
* in a script.
|
|
|
|
* WARNING: Do NOT changes these values unless you really have to, as
|
2005-10-21 22:49:59 +00:00
|
|
|
* this will break savegame compatibility if done carelessly. If you
|
SCUMM: Use correct array size when calling initializeLocals()
The initializeLocals() function assumes that it can copy 25
elements when being provided an array of values. But this array
was frequently a lot smaller than that. I've introduced a constant
for the number of locals (though VirtualMachineState has one more
for some reason), and fixed the array sizes in a number of places.
CID 1003951, 1003952, 1003953, 1003955, 1003956, 1003959, 1003960,
1003961, 1003963, 100394, 1003965
2013-04-30 22:26:51 +02:00
|
|
|
* have to change them, make sure you update saveload.cpp accordingly!
|
2005-10-21 22:49:59 +00:00
|
|
|
*/
|
2003-09-11 10:32:15 +00:00
|
|
|
enum {
|
SCUMM: Use correct array size when calling initializeLocals()
The initializeLocals() function assumes that it can copy 25
elements when being provided an array of values. But this array
was frequently a lot smaller than that. I've introduced a constant
for the number of locals (though VirtualMachineState has one more
for some reason), and fixed the array sizes in a number of places.
CID 1003951, 1003952, 1003953, 1003955, 1003956, 1003959, 1003960,
1003961, 1003963, 100394, 1003965
2013-04-30 22:26:51 +02:00
|
|
|
NUM_SCRIPT_SLOT = 80,
|
2013-05-01 07:47:56 +02:00
|
|
|
NUM_SCRIPT_LOCAL = 25
|
2003-09-11 10:32:15 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/* Script status type (slot.status) */
|
|
|
|
enum {
|
|
|
|
ssDead = 0,
|
|
|
|
ssPaused = 1,
|
|
|
|
ssRunning = 2
|
|
|
|
};
|
|
|
|
|
|
|
|
struct ScriptSlot {
|
|
|
|
uint32 offs;
|
|
|
|
int32 delay;
|
|
|
|
uint16 number;
|
|
|
|
uint16 delayFrameCount;
|
|
|
|
bool freezeResistant, recursive;
|
|
|
|
bool didexec;
|
|
|
|
byte status;
|
|
|
|
byte where;
|
|
|
|
byte freezeCount;
|
|
|
|
byte cutsceneOverride;
|
2005-02-28 13:23:10 +00:00
|
|
|
byte cycle;
|
2003-09-11 10:32:15 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
struct NestedScript {
|
|
|
|
uint16 number;
|
|
|
|
uint8 where;
|
|
|
|
uint8 slot;
|
|
|
|
};
|
|
|
|
|
2011-04-05 11:13:08 +02:00
|
|
|
enum {
|
|
|
|
/**
|
|
|
|
* The maximal number of cutscenes that can be active
|
|
|
|
* in parallel (i.e. nested).
|
|
|
|
*/
|
|
|
|
kMaxCutsceneNum = 5,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The maximal 'nesting' level for scripts.
|
|
|
|
*/
|
|
|
|
kMaxScriptNesting = 15
|
|
|
|
};
|
|
|
|
|
2003-09-11 10:32:15 +00:00
|
|
|
struct VirtualMachineState {
|
2011-04-05 11:13:08 +02:00
|
|
|
uint32 cutScenePtr[kMaxCutsceneNum];
|
|
|
|
byte cutSceneScript[kMaxCutsceneNum];
|
|
|
|
int16 cutSceneData[kMaxCutsceneNum];
|
2003-09-11 10:32:15 +00:00
|
|
|
int16 cutSceneScriptIndex;
|
|
|
|
byte cutSceneStackPointer;
|
|
|
|
ScriptSlot slot[NUM_SCRIPT_SLOT];
|
SCUMM: Use correct array size when calling initializeLocals()
The initializeLocals() function assumes that it can copy 25
elements when being provided an array of values. But this array
was frequently a lot smaller than that. I've introduced a constant
for the number of locals (though VirtualMachineState has one more
for some reason), and fixed the array sizes in a number of places.
CID 1003951, 1003952, 1003953, 1003955, 1003956, 1003959, 1003960,
1003961, 1003963, 100394, 1003965
2013-04-30 22:26:51 +02:00
|
|
|
// Why does localvar have space for one extra local variable?
|
2013-05-01 07:47:56 +02:00
|
|
|
int32 localvar[NUM_SCRIPT_SLOT][NUM_SCRIPT_LOCAL + 1];
|
2003-09-11 10:32:15 +00:00
|
|
|
|
2011-04-05 11:13:08 +02:00
|
|
|
NestedScript nest[kMaxScriptNesting];
|
2003-09-11 10:32:15 +00:00
|
|
|
byte numNestedScripts;
|
|
|
|
};
|
|
|
|
|
2003-10-03 18:33:57 +00:00
|
|
|
} // End of namespace Scumm
|
2003-09-11 10:32:15 +00:00
|
|
|
|
|
|
|
#endif
|