diff options
author | Nicola Mettifogo | 2008-05-09 01:35:43 +0000 |
---|---|---|
committer | Nicola Mettifogo | 2008-05-09 01:35:43 +0000 |
commit | 1d025957caad81aef5504b8e505b835ce106cf1b (patch) | |
tree | 9c30c5ca606fb96edcc568655464ab488f88542e /engines | |
parent | bdadf34f16cc0f271151e6e7f0438bf5ed48df8d (diff) | |
download | scummvm-rg350-1d025957caad81aef5504b8e505b835ce106cf1b.tar.gz scummvm-rg350-1d025957caad81aef5504b8e505b835ce106cf1b.tar.bz2 scummvm-rg350-1d025957caad81aef5504b8e505b835ce106cf1b.zip |
Moved location parsing out of the engines, to LocationParser_ns and LocationParser_br.
svn-id: r31958
Diffstat (limited to 'engines')
-rw-r--r-- | engines/parallaction/callables_ns.cpp | 4 | ||||
-rw-r--r-- | engines/parallaction/exec_ns.cpp | 2 | ||||
-rw-r--r-- | engines/parallaction/parallaction.cpp | 3 | ||||
-rw-r--r-- | engines/parallaction/parallaction.h | 166 | ||||
-rw-r--r-- | engines/parallaction/parallaction_br.cpp | 24 | ||||
-rw-r--r-- | engines/parallaction/parallaction_ns.cpp | 32 | ||||
-rw-r--r-- | engines/parallaction/parser.h | 203 | ||||
-rw-r--r-- | engines/parallaction/parser_br.cpp | 372 | ||||
-rw-r--r-- | engines/parallaction/parser_ns.cpp | 411 | ||||
-rw-r--r-- | engines/parallaction/staticres.cpp | 265 |
10 files changed, 790 insertions, 692 deletions
diff --git a/engines/parallaction/callables_ns.cpp b/engines/parallaction/callables_ns.cpp index c9a547d75b..d5defda8cf 100644 --- a/engines/parallaction/callables_ns.cpp +++ b/engines/parallaction/callables_ns.cpp @@ -422,8 +422,8 @@ void Parallaction_ns::_c_testResult(void *parm) { parseLocation("common"); uint id[2]; - id[0] = _gfx->createLabel(_menuFont, _slideText[0], 1); - id[1] = _gfx->createLabel(_menuFont, _slideText[1], 1); + id[0] = _gfx->createLabel(_menuFont, _location._slideText[0], 1); + id[1] = _gfx->createLabel(_menuFont, _location._slideText[1], 1); _gfx->showLabel(id[0], CENTER_LABEL_HORIZONTAL, 38); _gfx->showLabel(id[1], CENTER_LABEL_HORIZONTAL, 58); diff --git a/engines/parallaction/exec_ns.cpp b/engines/parallaction/exec_ns.cpp index 385e49b78d..b1889daa21 100644 --- a/engines/parallaction/exec_ns.cpp +++ b/engines/parallaction/exec_ns.cpp @@ -446,7 +446,7 @@ void Parallaction::runCommands(CommandList& list, ZonePtr z) { if ((cmd->_flagsOn & v8) != cmd->_flagsOn) continue; if ((cmd->_flagsOff & ~v8) != cmd->_flagsOff) continue; - debugC(3, kDebugExec, "runCommands[%i]: %s (on: %x, off: %x)", cmd->_id, _commandsNamesRes[cmd->_id-1], cmd->_flagsOn, cmd->_flagsOff); +// debugC(3, kDebugExec, "runCommands[%i]: %s (on: %x, off: %x)", cmd->_id, _commandsNamesRes[cmd->_id-1], cmd->_flagsOn, cmd->_flagsOff); _cmdRunCtxt.z = z; _cmdRunCtxt.cmd = cmd; diff --git a/engines/parallaction/parallaction.cpp b/engines/parallaction/parallaction.cpp index 649f21ae96..3907098b0f 100644 --- a/engines/parallaction/parallaction.cpp +++ b/engines/parallaction/parallaction.cpp @@ -89,13 +89,10 @@ Parallaction::Parallaction(OSystem *syst, const PARALLACTIONGameDescription *gam Parallaction::~Parallaction() { delete _debugger; - delete _locationParser; delete _globalTable; delete _callableNames; delete _localFlagNames; - delete _zoneTypeNames; - delete _zoneFlagNames; freeLocation(); diff --git a/engines/parallaction/parallaction.h b/engines/parallaction/parallaction.h index 19ce437410..b32278bfaa 100644 --- a/engines/parallaction/parallaction.h +++ b/engines/parallaction/parallaction.h @@ -151,7 +151,6 @@ extern char _password[8]; extern uint16 _score; extern uint16 _language; extern uint32 _engineFlags; -#define MAX_FORWARDS 50 extern char _saveData1[]; extern uint32 _commandFlags; extern const char *_dinoName; @@ -194,6 +193,7 @@ struct Location { // NS specific WalkNodeList _walkNodes; + char _slideText[2][MAX_TOKEN_LEN]; // BRA specific int _zeta0; @@ -247,10 +247,6 @@ public: -#define DECLARE_UNQUALIFIED_ZONE_PARSER(sig) void locZoneParse_##sig() -#define DECLARE_UNQUALIFIED_ANIM_PARSER(sig) void locAnimParse_##sig() -#define DECLARE_UNQUALIFIED_COMMAND_PARSER(sig) void cmdParse_##sig() -#define DECLARE_UNQUALIFIED_LOCATION_PARSER(sig) void locParse_##sig() #define DECLARE_UNQUALIFIED_INSTRUCTION_PARSER(sig) void instParse_##sig() #define DECLARE_UNQUALIFIED_COMMAND_OPCODE(op) void cmdOp_##op() @@ -331,13 +327,9 @@ public: Table *_globalTable; Table *_objectsNames; - Table *_zoneTypeNames; - Table *_zoneFlagNames; Table *_callableNames; Table *_localFlagNames; - Parser *_locationParser; - public: int getGameType() const; uint32 getFeatures() const; @@ -472,9 +464,9 @@ public: void beep(); public: - const char **_zoneFlagNamesRes; - const char **_zoneTypeNamesRes; - const char **_commandsNamesRes; +// const char **_zoneFlagNamesRes; +// const char **_zoneTypeNamesRes; +// const char **_commandsNamesRes; const char **_callableNamesRes; const char **_instructionNamesRes; @@ -558,8 +550,11 @@ public: bool loadGame(); bool saveGame(); + void switchBackground(const char* background, const char* mask); private: + LocationParser_ns *_locationParser; + void initFonts(); void freeFonts(); void renameOldSavefiles(); @@ -586,6 +581,7 @@ private: void initResources(); void initCursors(); + void initParsers(); static byte _mouseArrow[256]; Frames *_mouseComposedArrow; @@ -600,7 +596,6 @@ private: ZonePtr _moveSarcZone0; ZonePtr _moveSarcZone1; uint16 num_foglie; - char _slideText[2][MAX_TOKEN_LEN]; int16 _introSarcData1; uint16 _introSarcData2; // sarcophagus stuff to be saved uint16 _introSarcData3; // sarcophagus stuff to be saved @@ -649,112 +644,9 @@ protected: void walk(); void drawAnimations(); - - // location parser - OpcodeSet _locationParsers; - OpcodeSet _locationZoneParsers; - OpcodeSet _locationAnimParsers; - OpcodeSet _commandParsers; - Table *_commandsNames; - Table *_locationStmt; - Table *_locationZoneStmt; - Table *_locationAnimStmt; - - struct LocationParserContext { - bool end; - - const char *filename; - Script *script; - ZonePtr z; - AnimationPtr a; - int nextToken; - CommandList *list; - bool endcommands; - CommandPtr cmd; - - // BRA specific - int numZones; - char *bgName; - char *maskName; - char *pathName; - } _locParseCtxt; - - void warning_unexpected(); - - DECLARE_UNQUALIFIED_LOCATION_PARSER(endlocation); - DECLARE_UNQUALIFIED_LOCATION_PARSER(location); - DECLARE_UNQUALIFIED_LOCATION_PARSER(disk); - DECLARE_UNQUALIFIED_LOCATION_PARSER(nodes); - DECLARE_UNQUALIFIED_LOCATION_PARSER(zone); - DECLARE_UNQUALIFIED_LOCATION_PARSER(animation); - DECLARE_UNQUALIFIED_LOCATION_PARSER(localflags); - DECLARE_UNQUALIFIED_LOCATION_PARSER(commands); - DECLARE_UNQUALIFIED_LOCATION_PARSER(acommands); - DECLARE_UNQUALIFIED_LOCATION_PARSER(flags); - DECLARE_UNQUALIFIED_LOCATION_PARSER(comment); - DECLARE_UNQUALIFIED_LOCATION_PARSER(endcomment); - DECLARE_UNQUALIFIED_LOCATION_PARSER(sound); - DECLARE_UNQUALIFIED_LOCATION_PARSER(music); - DECLARE_UNQUALIFIED_ZONE_PARSER(limits); - DECLARE_UNQUALIFIED_ZONE_PARSER(moveto); - DECLARE_UNQUALIFIED_ZONE_PARSER(type); - DECLARE_UNQUALIFIED_ZONE_PARSER(commands); - DECLARE_UNQUALIFIED_ZONE_PARSER(label); - DECLARE_UNQUALIFIED_ZONE_PARSER(flags); - DECLARE_UNQUALIFIED_ZONE_PARSER(endzone); - DECLARE_UNQUALIFIED_ZONE_PARSER(null); - DECLARE_UNQUALIFIED_ANIM_PARSER(script); - DECLARE_UNQUALIFIED_ANIM_PARSER(commands); - DECLARE_UNQUALIFIED_ANIM_PARSER(type); - DECLARE_UNQUALIFIED_ANIM_PARSER(label); - DECLARE_UNQUALIFIED_ANIM_PARSER(flags); - DECLARE_UNQUALIFIED_ANIM_PARSER(file); - DECLARE_UNQUALIFIED_ANIM_PARSER(position); - DECLARE_UNQUALIFIED_ANIM_PARSER(moveto); - DECLARE_UNQUALIFIED_ANIM_PARSER(endanimation); - DECLARE_UNQUALIFIED_COMMAND_PARSER(flags); - DECLARE_UNQUALIFIED_COMMAND_PARSER(animation); - DECLARE_UNQUALIFIED_COMMAND_PARSER(zone); - DECLARE_UNQUALIFIED_COMMAND_PARSER(location); - DECLARE_UNQUALIFIED_COMMAND_PARSER(drop); - DECLARE_UNQUALIFIED_COMMAND_PARSER(call); - DECLARE_UNQUALIFIED_COMMAND_PARSER(simple); - DECLARE_UNQUALIFIED_COMMAND_PARSER(move); - DECLARE_UNQUALIFIED_COMMAND_PARSER(endcommands); - - virtual void parseGetData(Script &script, ZonePtr z); - virtual void parseExamineData(Script &script, ZonePtr z); - virtual void parseDoorData(Script &script, ZonePtr z); - virtual void parseMergeData(Script &script, ZonePtr z); - virtual void parseHearData(Script &script, ZonePtr z); - virtual void parseSpeakData(Script &script, ZonePtr z); - void parseLocation(const char *filename); - char *parseComment(Script &script); - char *parseDialogueString(Script &script); - Dialogue *parseDialogue(Script &script); - void resolveDialogueForwards(Dialogue *dialogue, uint numQuestions, Table &forwards); - Answer *parseAnswer(Script &script); - Question *parseQuestion(Script &script); - - void parseZone(Script &script, ZoneList &list, char *name); - void parseZoneTypeBlock(Script &script, ZonePtr z); - void parseWalkNodes(Script& script, WalkNodeList &list); - void parseAnimation(Script &script, AnimationList &list, char *name); - void parseCommands(Script &script, CommandList&); - void parseCommandFlags(); - void saveCommandForward(const char *name, CommandPtr cmd); - void resolveCommandForwards(); - void createCommand(uint id); - void addCommand(); void initOpcodes(); - void initParsers(); - struct CommandForwardReference { - char name[20]; - CommandPtr cmd; - } _forwardedCommands[MAX_FORWARDS]; - uint _numForwardedCommands; // program parser OpcodeSet _instructionParsers; @@ -837,7 +729,6 @@ protected: uint16 guiSelectGame(); int guiGetSelectedBlock(const Common::Point &p); - void switchBackground(const char* background, const char* mask); void showSlide(const char *name); }; @@ -863,7 +754,6 @@ public: public: Table *_countersNames; - Table *_audioCommandsNames; const char **_audioCommandsNamesRes; int _part; @@ -881,6 +771,8 @@ public: uint32 _zoneFlags[NUM_LOCATIONS][NUM_ZONES]; private: + LocationParser_br *_locationParser; + void initResources(); void initFonts(); void freeFonts(); @@ -925,37 +817,6 @@ private: const Callable *_callables; - DECLARE_UNQUALIFIED_LOCATION_PARSER(location); - DECLARE_UNQUALIFIED_LOCATION_PARSER(zone); - DECLARE_UNQUALIFIED_LOCATION_PARSER(animation); - DECLARE_UNQUALIFIED_LOCATION_PARSER(localflags); - DECLARE_UNQUALIFIED_LOCATION_PARSER(flags); - DECLARE_UNQUALIFIED_LOCATION_PARSER(comment); - DECLARE_UNQUALIFIED_LOCATION_PARSER(endcomment); - DECLARE_UNQUALIFIED_LOCATION_PARSER(sound); - DECLARE_UNQUALIFIED_LOCATION_PARSER(music); - DECLARE_UNQUALIFIED_LOCATION_PARSER(redundant); - DECLARE_UNQUALIFIED_LOCATION_PARSER(ifchar); - DECLARE_UNQUALIFIED_LOCATION_PARSER(character); - DECLARE_UNQUALIFIED_LOCATION_PARSER(mask); - DECLARE_UNQUALIFIED_LOCATION_PARSER(path); - DECLARE_UNQUALIFIED_LOCATION_PARSER(escape); - DECLARE_UNQUALIFIED_LOCATION_PARSER(zeta); - DECLARE_UNQUALIFIED_LOCATION_PARSER(null); - DECLARE_UNQUALIFIED_COMMAND_PARSER(ifchar); - DECLARE_UNQUALIFIED_COMMAND_PARSER(endif); - DECLARE_UNQUALIFIED_COMMAND_PARSER(location); - DECLARE_UNQUALIFIED_COMMAND_PARSER(toggle); - DECLARE_UNQUALIFIED_COMMAND_PARSER(string); - DECLARE_UNQUALIFIED_COMMAND_PARSER(math); - DECLARE_UNQUALIFIED_COMMAND_PARSER(test); - DECLARE_UNQUALIFIED_COMMAND_PARSER(music); - DECLARE_UNQUALIFIED_COMMAND_PARSER(zeta); - DECLARE_UNQUALIFIED_COMMAND_PARSER(swap); - DECLARE_UNQUALIFIED_COMMAND_PARSER(give); - DECLARE_UNQUALIFIED_COMMAND_PARSER(text); - DECLARE_UNQUALIFIED_COMMAND_PARSER(unary); - void parseLocation(const char* name); DECLARE_UNQUALIFIED_INSTRUCTION_PARSER(zone); @@ -1003,13 +864,6 @@ private: DECLARE_UNQUALIFIED_COMMAND_OPCODE(ret); DECLARE_UNQUALIFIED_COMMAND_OPCODE(onsave); DECLARE_UNQUALIFIED_COMMAND_OPCODE(offsave); - DECLARE_UNQUALIFIED_ZONE_PARSER(limits); - DECLARE_UNQUALIFIED_ZONE_PARSER(moveto); - DECLARE_UNQUALIFIED_ZONE_PARSER(type); - DECLARE_UNQUALIFIED_ANIM_PARSER(file); - DECLARE_UNQUALIFIED_ANIM_PARSER(position); - DECLARE_UNQUALIFIED_ANIM_PARSER(moveto); - DECLARE_UNQUALIFIED_ANIM_PARSER(endanimation); DECLARE_UNQUALIFIED_INSTRUCTION_OPCODE(on); DECLARE_UNQUALIFIED_INSTRUCTION_OPCODE(off); diff --git a/engines/parallaction/parallaction_br.cpp b/engines/parallaction/parallaction_br.cpp index 29e9fe6d70..118fe195d0 100644 --- a/engines/parallaction/parallaction_br.cpp +++ b/engines/parallaction/parallaction_br.cpp @@ -233,6 +233,30 @@ void Parallaction_br::changeLocation(char *location) { _engineFlags &= ~kEngineChangeLocation; } + +// FIXME: Parallaction_br::parseLocation() is now a verbatim copy of the same routine from Parallaction_ns. +void Parallaction_br::parseLocation(const char *filename) { + debugC(1, kDebugParser, "parseLocation('%s')", filename); + + allocateLocationSlot(filename); + Script *script = _disk->loadLocation(filename); + + _locationParser->parse(script); + delete script; + + // this loads animation scripts + AnimationList::iterator it = _vm->_location._animations.begin(); + for ( ; it != _vm->_location._animations.end(); it++) { + if ((*it)->_scriptName) { + loadProgram(*it, (*it)->_scriptName); + } + } + + debugC(1, kDebugParser, "parseLocation('%s') done", filename); + return; +} + + void Parallaction_br::changeCharacter(const char *name) { } diff --git a/engines/parallaction/parallaction_ns.cpp b/engines/parallaction/parallaction_ns.cpp index 7a476f7d24..071fa262a8 100644 --- a/engines/parallaction/parallaction_ns.cpp +++ b/engines/parallaction/parallaction_ns.cpp @@ -155,9 +155,7 @@ Parallaction_ns::~Parallaction_ns() { delete _mouseComposedArrow; - delete _commandsNames; delete _instructionNames; - delete _locationStmt; _location._animations.remove(_char._ani); @@ -315,7 +313,7 @@ void Parallaction_ns::changeLocation(char *location) { if (locname.hasSlide()) { showSlide(locname.slide()); - uint id = _gfx->createLabel(_menuFont, _slideText[0], 1); + uint id = _gfx->createLabel(_menuFont, _location._slideText[0], 1); _gfx->showLabel(id, CENTER_LABEL_HORIZONTAL, 14); waitUntilLeftClick(); _gfx->freeLabels(); @@ -367,6 +365,34 @@ void Parallaction_ns::changeLocation(char *location) { } +void Parallaction_ns::parseLocation(const char *filename) { + debugC(1, kDebugParser, "parseLocation('%s')", filename); + + allocateLocationSlot(filename); + Script *script = _disk->loadLocation(filename); + + // TODO: the following two lines are specific to Nippon Safes + // and should be moved into something like 'initializeParsing()' + _vm->_location._hasSound = false; + + _locationParser->parse(script); + + delete script; + + // this loads animation scripts + AnimationList::iterator it = _vm->_location._animations.begin(); + for ( ; it != _vm->_location._animations.end(); it++) { + if ((*it)->_scriptName) { + loadProgram(*it, (*it)->_scriptName); + } + } + + debugC(1, kDebugParser, "parseLocation('%s') done", filename); + return; +} + + + void Parallaction_ns::changeCharacter(const char *name) { debugC(1, kDebugExec, "changeCharacter(%s)", name); diff --git a/engines/parallaction/parser.h b/engines/parallaction/parser.h index d29a6c7e73..a62d883ccc 100644 --- a/engines/parallaction/parser.h +++ b/engines/parallaction/parser.h @@ -28,6 +28,7 @@ #include "common/stream.h" #include "parallaction/objects.h" +#include "parallaction/walk.h" namespace Parallaction { @@ -112,8 +113,207 @@ protected: Script *_script; }; +#define DECLARE_UNQUALIFIED_ZONE_PARSER(sig) void locZoneParse_##sig() +#define DECLARE_UNQUALIFIED_ANIM_PARSER(sig) void locAnimParse_##sig() +#define DECLARE_UNQUALIFIED_COMMAND_PARSER(sig) void cmdParse_##sig() +#define DECLARE_UNQUALIFIED_LOCATION_PARSER(sig) void locParse_##sig() +#define MAX_FORWARDS 50 +class Parallaction_ns; +class Parallaction_br; + +class LocationParser_ns { + +protected: + Parallaction_ns* _vm; + Parser *parser; + + Table *_zoneTypeNames; + Table *_zoneFlagNames; + + // location parser + OpcodeSet _locationParsers; + OpcodeSet _locationZoneParsers; + OpcodeSet _locationAnimParsers; + OpcodeSet _commandParsers; + Table *_commandsNames; + Table *_locationStmt; + Table *_locationZoneStmt; + Table *_locationAnimStmt; + + struct LocationParserContext { + bool end; + + const char *filename; + Script *script; + ZonePtr z; + AnimationPtr a; + int nextToken; + CommandList *list; + bool endcommands; + CommandPtr cmd; + + // BRA specific + int numZones; + char *bgName; + char *maskName; + char *pathName; + } _locParseCtxt; + + void warning_unexpected(); + + DECLARE_UNQUALIFIED_LOCATION_PARSER(endlocation); + DECLARE_UNQUALIFIED_LOCATION_PARSER(location); + DECLARE_UNQUALIFIED_LOCATION_PARSER(disk); + DECLARE_UNQUALIFIED_LOCATION_PARSER(nodes); + DECLARE_UNQUALIFIED_LOCATION_PARSER(zone); + DECLARE_UNQUALIFIED_LOCATION_PARSER(animation); + DECLARE_UNQUALIFIED_LOCATION_PARSER(localflags); + DECLARE_UNQUALIFIED_LOCATION_PARSER(commands); + DECLARE_UNQUALIFIED_LOCATION_PARSER(acommands); + DECLARE_UNQUALIFIED_LOCATION_PARSER(flags); + DECLARE_UNQUALIFIED_LOCATION_PARSER(comment); + DECLARE_UNQUALIFIED_LOCATION_PARSER(endcomment); + DECLARE_UNQUALIFIED_LOCATION_PARSER(sound); + DECLARE_UNQUALIFIED_LOCATION_PARSER(music); + DECLARE_UNQUALIFIED_ZONE_PARSER(limits); + DECLARE_UNQUALIFIED_ZONE_PARSER(moveto); + DECLARE_UNQUALIFIED_ZONE_PARSER(type); + DECLARE_UNQUALIFIED_ZONE_PARSER(commands); + DECLARE_UNQUALIFIED_ZONE_PARSER(label); + DECLARE_UNQUALIFIED_ZONE_PARSER(flags); + DECLARE_UNQUALIFIED_ZONE_PARSER(endzone); + DECLARE_UNQUALIFIED_ZONE_PARSER(null); + DECLARE_UNQUALIFIED_ANIM_PARSER(script); + DECLARE_UNQUALIFIED_ANIM_PARSER(commands); + DECLARE_UNQUALIFIED_ANIM_PARSER(type); + DECLARE_UNQUALIFIED_ANIM_PARSER(label); + DECLARE_UNQUALIFIED_ANIM_PARSER(flags); + DECLARE_UNQUALIFIED_ANIM_PARSER(file); + DECLARE_UNQUALIFIED_ANIM_PARSER(position); + DECLARE_UNQUALIFIED_ANIM_PARSER(moveto); + DECLARE_UNQUALIFIED_ANIM_PARSER(endanimation); + DECLARE_UNQUALIFIED_COMMAND_PARSER(flags); + DECLARE_UNQUALIFIED_COMMAND_PARSER(animation); + DECLARE_UNQUALIFIED_COMMAND_PARSER(zone); + DECLARE_UNQUALIFIED_COMMAND_PARSER(location); + DECLARE_UNQUALIFIED_COMMAND_PARSER(drop); + DECLARE_UNQUALIFIED_COMMAND_PARSER(call); + DECLARE_UNQUALIFIED_COMMAND_PARSER(simple); + DECLARE_UNQUALIFIED_COMMAND_PARSER(move); + DECLARE_UNQUALIFIED_COMMAND_PARSER(endcommands); + + virtual void parseGetData(Script &script, ZonePtr z); + virtual void parseExamineData(Script &script, ZonePtr z); + virtual void parseDoorData(Script &script, ZonePtr z); + virtual void parseMergeData(Script &script, ZonePtr z); + virtual void parseHearData(Script &script, ZonePtr z); + virtual void parseSpeakData(Script &script, ZonePtr z); + + char *parseComment(Script &script); + char *parseDialogueString(Script &script); + Dialogue *parseDialogue(Script &script); + void resolveDialogueForwards(Dialogue *dialogue, uint numQuestions, Table &forwards); + Answer *parseAnswer(Script &script); + Question *parseQuestion(Script &script); + + void parseZone(Script &script, ZoneList &list, char *name); + void parseZoneTypeBlock(Script &script, ZonePtr z); + void parseWalkNodes(Script& script, WalkNodeList &list); + void parseAnimation(Script &script, AnimationList &list, char *name); + void parseCommands(Script &script, CommandList&); + void parseCommandFlags(); + void saveCommandForward(const char *name, CommandPtr cmd); + void resolveCommandForwards(); + void createCommand(uint id); + void addCommand(); + void initParsers(); + + struct CommandForwardReference { + char name[20]; + CommandPtr cmd; + } _forwardedCommands[MAX_FORWARDS]; + uint _numForwardedCommands; + + void init(); + +public: + LocationParser_ns(Parallaction_ns *vm) : _vm(vm) { + init(); + } + + virtual ~LocationParser_ns() { + delete _commandsNames; + delete _locationStmt; + delete _zoneTypeNames; + delete _zoneFlagNames; + } + + void parse(Script *script); + +}; + +class LocationParser_br : public LocationParser_ns { + +protected: + Table *_audioCommandsNames; + + Parallaction_br* _vm; + + DECLARE_UNQUALIFIED_LOCATION_PARSER(location); + DECLARE_UNQUALIFIED_LOCATION_PARSER(zone); + DECLARE_UNQUALIFIED_LOCATION_PARSER(animation); + DECLARE_UNQUALIFIED_LOCATION_PARSER(localflags); + DECLARE_UNQUALIFIED_LOCATION_PARSER(flags); + DECLARE_UNQUALIFIED_LOCATION_PARSER(comment); + DECLARE_UNQUALIFIED_LOCATION_PARSER(endcomment); + DECLARE_UNQUALIFIED_LOCATION_PARSER(sound); + DECLARE_UNQUALIFIED_LOCATION_PARSER(music); + DECLARE_UNQUALIFIED_LOCATION_PARSER(redundant); + DECLARE_UNQUALIFIED_LOCATION_PARSER(ifchar); + DECLARE_UNQUALIFIED_LOCATION_PARSER(character); + DECLARE_UNQUALIFIED_LOCATION_PARSER(mask); + DECLARE_UNQUALIFIED_LOCATION_PARSER(path); + DECLARE_UNQUALIFIED_LOCATION_PARSER(escape); + DECLARE_UNQUALIFIED_LOCATION_PARSER(zeta); + DECLARE_UNQUALIFIED_LOCATION_PARSER(null); + DECLARE_UNQUALIFIED_COMMAND_PARSER(ifchar); + DECLARE_UNQUALIFIED_COMMAND_PARSER(endif); + DECLARE_UNQUALIFIED_COMMAND_PARSER(location); + DECLARE_UNQUALIFIED_COMMAND_PARSER(toggle); + DECLARE_UNQUALIFIED_COMMAND_PARSER(string); + DECLARE_UNQUALIFIED_COMMAND_PARSER(math); + DECLARE_UNQUALIFIED_COMMAND_PARSER(test); + DECLARE_UNQUALIFIED_COMMAND_PARSER(music); + DECLARE_UNQUALIFIED_COMMAND_PARSER(zeta); + DECLARE_UNQUALIFIED_COMMAND_PARSER(swap); + DECLARE_UNQUALIFIED_COMMAND_PARSER(give); + DECLARE_UNQUALIFIED_COMMAND_PARSER(text); + DECLARE_UNQUALIFIED_COMMAND_PARSER(unary); + DECLARE_UNQUALIFIED_ZONE_PARSER(limits); + DECLARE_UNQUALIFIED_ZONE_PARSER(moveto); + DECLARE_UNQUALIFIED_ZONE_PARSER(type); + DECLARE_UNQUALIFIED_ANIM_PARSER(file); + DECLARE_UNQUALIFIED_ANIM_PARSER(position); + DECLARE_UNQUALIFIED_ANIM_PARSER(moveto); + DECLARE_UNQUALIFIED_ANIM_PARSER(endanimation); + + void init(); + +public: + LocationParser_br(Parallaction_br *vm) : LocationParser_ns((Parallaction_ns*)vm), _vm(vm) { + init(); + } + + virtual ~LocationParser_br() { + delete _commandsNames; + delete _locationStmt; + } + + void parse(Script *script); + +}; } // namespace Parallaction @@ -121,3 +321,6 @@ protected: #endif + + + diff --git a/engines/parallaction/parser_br.cpp b/engines/parallaction/parser_br.cpp index 2544267382..612a53759b 100644 --- a/engines/parallaction/parser_br.cpp +++ b/engines/parallaction/parser_br.cpp @@ -104,17 +104,167 @@ namespace Parallaction { #define INST_ENDIF 30 #define INST_STOP 31 -#define DECLARE_ZONE_PARSER(sig) void Parallaction_br::locZoneParse_##sig() -#define DECLARE_ANIM_PARSER(sig) void Parallaction_br::locAnimParse_##sig() -#define DECLARE_COMMAND_PARSER(sig) void Parallaction_br::cmdParse_##sig() +const char *_zoneTypeNamesRes_br[] = { + "examine", + "door", + "get", + "merge", + "taste", + "hear", + "feel", + "speak", + "none", + "trap", + "you", + "command", + "path", + "box" +}; + +const char *_zoneFlagNamesRes_br[] = { + "closed", + "active", + "remove", + "acting", + "locked", + "fixed", + "noname", + "nomasked", + "looping", + "added", + "character", + "nowalk", + "yourself", + "scaled", + "selfuse" +}; + +const char *_commandsNamesRes_br[] = { + "set", + "clear", + "start", + "speak", + "get", + "location", + "open", + "close", + "on", + "off", + "call", + "toggle", + "drop", + "quit", + "move", + "stop", + "character", + "followme", + "onmouse", + "offmouse", + "add", + "leave", + "inc", + "dec", + "test", + "dummy", + "dummy", + "let", + "music", + "fix", + "unfix", + "zeta", + "scroll", + "swap", + "give", + "text", + "part", + "dummy", + "return", + "onsave", + "offsave", + "endcommands", + "ifchar", + "endif" +}; + + +const char *_audioCommandsNamesRes_br[] = { + "play", + "stop", + "pause", + "channel_level", + "fadein", + "fadeout", + "volume", + " ", + "faderate", + " ", + " ", + " ", + " ", + " ", + " ", + " ", + "loop" +}; + +const char *_locationStmtRes_br[] = { + "character", + "endlocation", + "ifchar", + "endif", + "location", + "mask", + "path", + "disk", + "localflags", + "commands", + "escape", + "acommands", + "flags", + "comment", + "endcomment", + "zone", + "animation", + "zeta", + "music", + "sound" +}; + +const char *_locationZoneStmtRes_br[] = { + "endzone", + "limits", + "moveto", + "type", + "commands", + "label", + "flags" +}; + +const char *_locationAnimStmtRes_br[] = { + "endanimation", + "endzone", + "script", + "commands", + "type", + "label", + "flags", + "file", + "position", + "moveto" +}; + + +#define DECLARE_ZONE_PARSER(sig) void LocationParser_br::locZoneParse_##sig() +#define DECLARE_ANIM_PARSER(sig) void LocationParser_br::locAnimParse_##sig() +#define DECLARE_COMMAND_PARSER(sig) void LocationParser_br::cmdParse_##sig() #define DECLARE_INSTRUCTION_PARSER(sig) void Parallaction_br::instParse_##sig() -#define DECLARE_LOCATION_PARSER(sig) void Parallaction_br::locParse_##sig() +#define DECLARE_LOCATION_PARSER(sig) void LocationParser_br::locParse_##sig() DECLARE_LOCATION_PARSER(location) { debugC(7, kDebugParser, "LOCATION_PARSER(location) "); - strcpy(_location._name, _tokens[1]); + strcpy(_vm->_location._name, _tokens[1]); _locParseCtxt.bgName = strdup(_tokens[1]); bool flip = false; @@ -130,14 +280,14 @@ DECLARE_LOCATION_PARSER(location) { // TODO: handle background horizontal flip (via a context parameter) if (_tokens[nextToken][0] != '\0') { - _char._ani->_left = atoi(_tokens[nextToken]); + _vm->_char._ani->_left = atoi(_tokens[nextToken]); nextToken++; - _char._ani->_top = atoi(_tokens[nextToken]); + _vm->_char._ani->_top = atoi(_tokens[nextToken]); nextToken++; } if (_tokens[nextToken][0] != '\0') { - _char._ani->_frame = atoi(_tokens[nextToken]); + _vm->_char._ani->_frame = atoi(_tokens[nextToken]); } } @@ -146,14 +296,14 @@ DECLARE_LOCATION_PARSER(location) { DECLARE_LOCATION_PARSER(zone) { debugC(7, kDebugParser, "LOCATION_PARSER(zone) "); - parseZone(*_locParseCtxt.script, _location._zones, _tokens[1]); + parseZone(*_locParseCtxt.script, _vm->_location._zones, _tokens[1]); _locParseCtxt.z->_index = _locParseCtxt.numZones++; - if (getLocationFlags() & kFlagsVisited) { - _locParseCtxt.z->_flags = _zoneFlags[_currentLocationIndex][_locParseCtxt.z->_index]; + if (_vm->getLocationFlags() & kFlagsVisited) { + _locParseCtxt.z->_flags = _vm->_zoneFlags[_vm->_currentLocationIndex][_locParseCtxt.z->_index]; } else { - _zoneFlags[_currentLocationIndex][_locParseCtxt.z->_index] = _locParseCtxt.z->_flags; + _vm->_zoneFlags[_vm->_currentLocationIndex][_locParseCtxt.z->_index] = _locParseCtxt.z->_flags; } } @@ -162,14 +312,14 @@ DECLARE_LOCATION_PARSER(zone) { DECLARE_LOCATION_PARSER(animation) { debugC(7, kDebugParser, "LOCATION_PARSER(animation) "); - parseAnimation(*_locParseCtxt.script, _location._animations, _tokens[1]); + parseAnimation(*_locParseCtxt.script, _vm->_location._animations, _tokens[1]); _locParseCtxt.a->_index = _locParseCtxt.numZones++; - if (getLocationFlags() & kFlagsVisited) { - _locParseCtxt.a->_flags = _zoneFlags[_currentLocationIndex][_locParseCtxt.a->_index]; + if (_vm->getLocationFlags() & kFlagsVisited) { + _locParseCtxt.a->_flags = _vm->_zoneFlags[_vm->_currentLocationIndex][_locParseCtxt.a->_index]; } else { - _zoneFlags[_currentLocationIndex][_locParseCtxt.a->_index] = _locParseCtxt.a->_flags; + _vm->_zoneFlags[_vm->_currentLocationIndex][_locParseCtxt.a->_index] = _locParseCtxt.a->_flags; } } @@ -180,7 +330,7 @@ DECLARE_LOCATION_PARSER(localflags) { int _si = 1; while (_tokens[_si][0] != '\0') { - _localFlagNames->addData(_tokens[_si]); + _vm->_localFlagNames->addData(_tokens[_si]); _si++; } } @@ -189,14 +339,14 @@ DECLARE_LOCATION_PARSER(localflags) { DECLARE_LOCATION_PARSER(flags) { debugC(7, kDebugParser, "LOCATION_PARSER(flags) "); - if ((getLocationFlags() & kFlagsVisited) == 0) { + if ((_vm->getLocationFlags() & kFlagsVisited) == 0) { // only for 1st visit - clearLocationFlags(kFlagsAll); + _vm->clearLocationFlags(kFlagsAll); int _si = 1; do { - byte _al = _localFlagNames->lookup(_tokens[_si]); - setLocationFlags(1 << (_al - 1)); + byte _al = _vm->_localFlagNames->lookup(_tokens[_si]); + _vm->setLocationFlags(1 << (_al - 1)); _si++; if (scumm_stricmp(_tokens[_si], "|")) break; @@ -209,14 +359,14 @@ DECLARE_LOCATION_PARSER(flags) { DECLARE_LOCATION_PARSER(comment) { debugC(7, kDebugParser, "LOCATION_PARSER(comment) "); - _location._comment = parseComment(*_locParseCtxt.script); + _vm->_location._comment = parseComment(*_locParseCtxt.script); } DECLARE_LOCATION_PARSER(endcomment) { debugC(7, kDebugParser, "LOCATION_PARSER(endcomment) "); - _location._endComment = parseComment(*_locParseCtxt.script); + _vm->_location._endComment = parseComment(*_locParseCtxt.script); } @@ -265,9 +415,9 @@ DECLARE_LOCATION_PARSER(mask) { debugC(7, kDebugParser, "LOCATION_PARSER(mask) "); _locParseCtxt.maskName = strdup(_tokens[1]); - _gfx->_backgroundInfo.layers[0] = atoi(_tokens[2]); - _gfx->_backgroundInfo.layers[1] = atoi(_tokens[3]); - _gfx->_backgroundInfo.layers[2] = atoi(_tokens[4]); + _vm->_gfx->_backgroundInfo.layers[0] = atoi(_tokens[2]); + _vm->_gfx->_backgroundInfo.layers[1] = atoi(_tokens[3]); + _vm->_gfx->_backgroundInfo.layers[2] = atoi(_tokens[4]); } @@ -281,27 +431,27 @@ DECLARE_LOCATION_PARSER(path) { DECLARE_LOCATION_PARSER(escape) { debugC(7, kDebugParser, "LOCATION_PARSER(escape) "); - parseCommands(*_locParseCtxt.script, _location._escapeCommands); + parseCommands(*_locParseCtxt.script, _vm->_location._escapeCommands); } DECLARE_LOCATION_PARSER(zeta) { debugC(7, kDebugParser, "LOCATION_PARSER(zeta) "); - _location._zeta0 = atoi(_tokens[1]); - _location._zeta1 = atoi(_tokens[2]); + _vm->_location._zeta0 = atoi(_tokens[1]); + _vm->_location._zeta1 = atoi(_tokens[2]); if (_tokens[3][0] != '\0') { - _location._zeta2 = atoi(_tokens[1]); + _vm->_location._zeta2 = atoi(_tokens[1]); } else { - _location._zeta2 = 50; + _vm->_location._zeta2 = 50; } } DECLARE_COMMAND_PARSER(ifchar) { debugC(7, kDebugParser, "COMMAND_PARSER(ifchar) "); - if (!scumm_stricmp(_char.getName(), _tokens[1])) + if (!scumm_stricmp(_vm->_char.getName(), _tokens[1])) _locParseCtxt.script->skip("endif"); } @@ -316,7 +466,7 @@ DECLARE_COMMAND_PARSER(endif) { DECLARE_COMMAND_PARSER(location) { debugC(7, kDebugParser, "COMMAND_PARSER(location) "); - createCommand(_locationParser->_lookup); + createCommand(parser->_lookup); _locParseCtxt.cmd->u._string = strdup(_tokens[1]); _locParseCtxt.nextToken++; @@ -345,7 +495,7 @@ DECLARE_COMMAND_PARSER(location) { DECLARE_COMMAND_PARSER(string) { debugC(7, kDebugParser, "COMMAND_PARSER(string) "); - createCommand(_locationParser->_lookup); + createCommand(parser->_lookup); _locParseCtxt.cmd->u._string = strdup(_tokens[1]); _locParseCtxt.nextToken++; @@ -357,9 +507,9 @@ DECLARE_COMMAND_PARSER(string) { DECLARE_COMMAND_PARSER(math) { debugC(7, kDebugParser, "COMMAND_PARSER(math) "); - createCommand(_locationParser->_lookup); + createCommand(parser->_lookup); - _locParseCtxt.cmd->u._lvalue = _countersNames->lookup(_tokens[1]); + _locParseCtxt.cmd->u._lvalue = _vm->_countersNames->lookup(_tokens[1]); _locParseCtxt.nextToken++; _locParseCtxt.cmd->u._rvalue = atoi(_tokens[2]); _locParseCtxt.nextToken++; @@ -372,9 +522,9 @@ DECLARE_COMMAND_PARSER(math) { DECLARE_COMMAND_PARSER(test) { debugC(7, kDebugParser, "COMMAND_PARSER(test) "); - createCommand(_locationParser->_lookup); + createCommand(parser->_lookup); - uint counter = _countersNames->lookup(_tokens[1]); + uint counter = _vm->_countersNames->lookup(_tokens[1]); _locParseCtxt.nextToken++; if (counter == Table::notFound) { @@ -405,7 +555,7 @@ DECLARE_COMMAND_PARSER(test) { DECLARE_COMMAND_PARSER(music) { debugC(7, kDebugParser, "COMMAND_PARSER(music) "); - createCommand(_locationParser->_lookup); + createCommand(parser->_lookup); _locParseCtxt.cmd->u._musicCommand = _audioCommandsNames->lookup(_tokens[1]); _locParseCtxt.nextToken++; @@ -423,7 +573,7 @@ DECLARE_COMMAND_PARSER(music) { DECLARE_COMMAND_PARSER(zeta) { debugC(7, kDebugParser, "COMMAND_PARSER(zeta) "); - createCommand(_locationParser->_lookup); + createCommand(parser->_lookup); _locParseCtxt.cmd->u._zeta0 = atoi(_tokens[1]); _locParseCtxt.nextToken++; @@ -445,7 +595,7 @@ DECLARE_COMMAND_PARSER(zeta) { DECLARE_COMMAND_PARSER(give) { debugC(7, kDebugParser, "COMMAND_PARSER(give) "); - createCommand(_locationParser->_lookup); + createCommand(parser->_lookup); _locParseCtxt.cmd->u._object = 4 + atoi(_tokens[1]); _locParseCtxt.nextToken++; @@ -471,7 +621,7 @@ DECLARE_COMMAND_PARSER(give) { DECLARE_COMMAND_PARSER(text) { debugC(7, kDebugParser, "COMMAND_PARSER(text) "); - createCommand(_locationParser->_lookup); + createCommand(parser->_lookup); if (isdigit(_tokens[1][1])) { _locParseCtxt.cmd->u._zeta0 = atoi(_tokens[1]); @@ -497,7 +647,7 @@ DECLARE_COMMAND_PARSER(text) { DECLARE_COMMAND_PARSER(unary) { debugC(7, kDebugParser, "COMMAND_PARSER(unary) "); - createCommand(_locationParser->_lookup); + createCommand(parser->_lookup); _locParseCtxt.cmd->u._rvalue = atoi(_tokens[1]); _locParseCtxt.nextToken++; @@ -512,7 +662,7 @@ DECLARE_ZONE_PARSER(limits) { if (isalpha(_tokens[1][1])) { _locParseCtxt.z->_flags |= kFlagsAnimLinked; - _locParseCtxt.z->_linkedAnim = findAnimation(_tokens[1]); + _locParseCtxt.z->_linkedAnim = _vm->findAnimation(_tokens[1]); _locParseCtxt.z->_linkedName = strdup(_tokens[1]); } else { _locParseCtxt.z->_left = atoi(_tokens[1]); @@ -536,7 +686,7 @@ DECLARE_ZONE_PARSER(type) { debugC(7, kDebugParser, "ZONE_PARSER(type) "); if (_tokens[2][0] != '\0') { - _locParseCtxt.z->_type = (4 + _objectsNames->lookup(_tokens[2])) << 16; + _locParseCtxt.z->_type = (4 + _vm->_objectsNames->lookup(_tokens[2])) << 16; } int16 _si = _zoneTypeNames->lookup(_tokens[1]); if (_si != Table::notFound) { @@ -548,14 +698,14 @@ DECLARE_ZONE_PARSER(type) { // } } - _locationParser->popTables(); + parser->popTables(); } DECLARE_ANIM_PARSER(file) { debugC(7, kDebugParser, "ANIM_PARSER(file) "); - _locParseCtxt.a->gfxobj = _gfx->loadAnim(_tokens[1]); + _locParseCtxt.a->gfxobj = _vm->_gfx->loadAnim(_tokens[1]); } @@ -592,7 +742,7 @@ DECLARE_ANIM_PARSER(endanimation) { _locParseCtxt.a->_flags |= 0x1000000; - _locationParser->popTables(); + parser->popTables(); } @@ -749,58 +899,31 @@ void Parallaction_br::parseRValue(ScriptVar &v, const char *str) { } -typedef OpcodeImpl<Parallaction_br> OpcodeV2; -#define INSTRUCTION_PARSER(sig) OpcodeV2(this, &Parallaction_br::instParse_##sig) -#define ZONE_PARSER(sig) OpcodeV2(this, &Parallaction_br::locZoneParse_##sig) -#define ANIM_PARSER(sig) OpcodeV2(this, &Parallaction_br::locAnimParse_##sig) -#define LOCATION_PARSER(sig) OpcodeV2(this, &Parallaction_br::locParse_##sig) -#define COMMAND_PARSER(sig) OpcodeV2(this, &Parallaction_br::cmdParse_##sig) +typedef OpcodeImpl<LocationParser_br> OpcodeV2; +#define ZONE_PARSER(sig) OpcodeV2(this, &LocationParser_br::locZoneParse_##sig) +#define ANIM_PARSER(sig) OpcodeV2(this, &LocationParser_br::locAnimParse_##sig) +#define LOCATION_PARSER(sig) OpcodeV2(this, &LocationParser_br::locParse_##sig) +#define COMMAND_PARSER(sig) OpcodeV2(this, &LocationParser_br::cmdParse_##sig) +#define WARNING_PARSER(sig) OpcodeV2(this, &LocationParser_br::warning_##sig) -#define WARNING_PARSER(sig) OpcodeV2(this, &Parallaction_br::warning_##sig) +typedef OpcodeImpl<Parallaction_br> OpcodeV3; +#define INSTRUCTION_PARSER(sig) OpcodeV3(this, &Parallaction_br::instParse_##sig) -void Parallaction_br::initParsers() { - _locationParser = new Parser; +void LocationParser_br::init() { - static const OpcodeV2 op0[] = { - INSTRUCTION_PARSER(defLocal), // invalid opcode -> local definition - INSTRUCTION_PARSER(zone), // on - INSTRUCTION_PARSER(zone), // off - INSTRUCTION_PARSER(x), - INSTRUCTION_PARSER(y), - INSTRUCTION_PARSER(z), - INSTRUCTION_PARSER(f), - INSTRUCTION_PARSER(loop), - INSTRUCTION_PARSER(null), // endloop - INSTRUCTION_PARSER(null), // show - INSTRUCTION_PARSER(inc), - INSTRUCTION_PARSER(inc), // dec - INSTRUCTION_PARSER(set), - INSTRUCTION_PARSER(put), - INSTRUCTION_PARSER(call), - INSTRUCTION_PARSER(null), // wait - INSTRUCTION_PARSER(zone), // start - INSTRUCTION_PARSER(zone), // process - INSTRUCTION_PARSER(move), - INSTRUCTION_PARSER(color), - INSTRUCTION_PARSER(zone), // sound - INSTRUCTION_PARSER(mask), - INSTRUCTION_PARSER(print), - INSTRUCTION_PARSER(text), - INSTRUCTION_PARSER(inc), // mul - INSTRUCTION_PARSER(inc), // div - INSTRUCTION_PARSER(if_op), - INSTRUCTION_PARSER(null), - INSTRUCTION_PARSER(null), - INSTRUCTION_PARSER(endif), - INSTRUCTION_PARSER(zone), // stop - INSTRUCTION_PARSER(endscript) - }; + parser = new Parser; + + _zoneFlagNames = new Table(ARRAYSIZE(_zoneFlagNamesRes_br), _zoneFlagNamesRes_br); + _zoneTypeNames = new Table(ARRAYSIZE(_zoneTypeNamesRes_br), _zoneTypeNamesRes_br); + _commandsNames = new Table(ARRAYSIZE(_commandsNamesRes_br), _commandsNamesRes_br); + _audioCommandsNames = new Table(ARRAYSIZE(_audioCommandsNamesRes_br), _audioCommandsNamesRes_br); + _locationStmt = new Table(ARRAYSIZE(_locationStmtRes_br), _locationStmtRes_br); + _locationZoneStmt = new Table(ARRAYSIZE(_locationZoneStmtRes_br), _locationZoneStmtRes_br); + _locationAnimStmt = new Table(ARRAYSIZE(_locationAnimStmtRes_br), _locationAnimStmtRes_br); - uint i; - for (i = 0; i < ARRAYSIZE(op0); i++) - _instructionParsers.push_back(&op0[i]); + int i; static const OpcodeV2 op2[] = { WARNING_PARSER(unexpected), @@ -910,31 +1033,70 @@ void Parallaction_br::initParsers() { for (i = 0; i < ARRAYSIZE(op6); i++) _locationAnimParsers.push_back(&op6[i]); + } -void Parallaction_br::parseLocation(const char* filename) { +void Parallaction_br::initParsers() { + + _locationParser = new LocationParser_br(this); + + static const OpcodeV3 op0[] = { + INSTRUCTION_PARSER(defLocal), // invalid opcode -> local definition + INSTRUCTION_PARSER(zone), // on + INSTRUCTION_PARSER(zone), // off + INSTRUCTION_PARSER(x), + INSTRUCTION_PARSER(y), + INSTRUCTION_PARSER(z), + INSTRUCTION_PARSER(f), + INSTRUCTION_PARSER(loop), + INSTRUCTION_PARSER(null), // endloop + INSTRUCTION_PARSER(null), // show + INSTRUCTION_PARSER(inc), + INSTRUCTION_PARSER(inc), // dec + INSTRUCTION_PARSER(set), + INSTRUCTION_PARSER(put), + INSTRUCTION_PARSER(call), + INSTRUCTION_PARSER(null), // wait + INSTRUCTION_PARSER(zone), // start + INSTRUCTION_PARSER(zone), // process + INSTRUCTION_PARSER(move), + INSTRUCTION_PARSER(color), + INSTRUCTION_PARSER(zone), // sound + INSTRUCTION_PARSER(mask), + INSTRUCTION_PARSER(print), + INSTRUCTION_PARSER(text), + INSTRUCTION_PARSER(inc), // mul + INSTRUCTION_PARSER(inc), // div + INSTRUCTION_PARSER(if_op), + INSTRUCTION_PARSER(null), + INSTRUCTION_PARSER(null), + INSTRUCTION_PARSER(endif), + INSTRUCTION_PARSER(zone), // stop + INSTRUCTION_PARSER(endscript) + }; + + uint i; + for (i = 0; i < ARRAYSIZE(op0); i++) + _instructionParsers.push_back(&op0[i]); + +} + +void LocationParser_br::parse(Script *script) { _locParseCtxt.numZones = 0; _locParseCtxt.bgName = 0; _locParseCtxt.maskName = 0; _locParseCtxt.pathName = 0; - Super::parseLocation(filename); + LocationParser_ns::parse(script); - _gfx->setBackground(kBackgroundLocation, _locParseCtxt.bgName, _locParseCtxt.maskName, _locParseCtxt.pathName); - _pathBuffer = &_gfx->_backgroundInfo.path; + _vm->_gfx->setBackground(kBackgroundLocation, _locParseCtxt.bgName, _locParseCtxt.maskName, _locParseCtxt.pathName); + _vm->_pathBuffer = &_vm->_gfx->_backgroundInfo.path; free(_locParseCtxt.bgName); free(_locParseCtxt.maskName); free(_locParseCtxt.pathName); -// drawZones(); - - return; } - - - - } // namespace Parallaction diff --git a/engines/parallaction/parser_ns.cpp b/engines/parallaction/parser_ns.cpp index b8b36a0885..29c356b8af 100644 --- a/engines/parallaction/parser_ns.cpp +++ b/engines/parallaction/parser_ns.cpp @@ -67,14 +67,106 @@ namespace Parallaction { #define INST_END 19 -#define DECLARE_ZONE_PARSER(sig) void Parallaction_ns::locZoneParse_##sig() -#define DECLARE_ANIM_PARSER(sig) void Parallaction_ns::locAnimParse_##sig() -#define DECLARE_COMMAND_PARSER(sig) void Parallaction_ns::cmdParse_##sig() +const char *_zoneFlagNamesRes_ns[] = { + "closed", + "active", + "remove", + "acting", + "locked", + "fixed", + "noname", + "nomasked", + "looping", + "added", + "character", + "nowalk" +}; + +const char *_zoneTypeNamesRes_ns[] = { + "examine", + "door", + "get", + "merge", + "taste", + "hear", + "feel", + "speak", + "none", + "trap", + "yourself", + "Command" +}; + +const char *_commandsNamesRes_ns[] = { + "set", + "clear", + "start", + "speak", + "get", + "location", + "open", + "close", + "on", + "off", + "call", + "toggle", + "drop", + "quit", + "move", + "stop", + "endcommands", + "endzone" +}; + +const char *_locationStmtRes_ns[] = { + "endlocation", + "location", + "disk", + "nodes", + "zone", + "animation", + "localflags", + "commands", + "acommands", + "flags", + "comment", + "endcomment", + "sound", + "music" +}; + +const char *_locationZoneStmtRes_ns[] = { + "limits", + "moveto", + "type", + "commands", + "label", + "flags", + "endzone" +}; + +const char *_locationAnimStmtRes_ns[] = { + "script", + "commands", + "type", + "label", + "flags", + "file", + "position", + "moveto", + "endanimation" +}; + + +#define DECLARE_ZONE_PARSER(sig) void LocationParser_ns::locZoneParse_##sig() +#define DECLARE_ANIM_PARSER(sig) void LocationParser_ns::locAnimParse_##sig() +#define DECLARE_COMMAND_PARSER(sig) void LocationParser_ns::cmdParse_##sig() +#define DECLARE_LOCATION_PARSER(sig) void LocationParser_ns::locParse_##sig() + #define DECLARE_INSTRUCTION_PARSER(sig) void Parallaction_ns::instParse_##sig() -#define DECLARE_LOCATION_PARSER(sig) void Parallaction_ns::locParse_##sig() -void Parallaction_ns::warning_unexpected() { +void LocationParser_ns::warning_unexpected() { debugC(1, kDebugParser, "unexpected keyword '%s' in line %i", _tokens[0], _locParseCtxt.script->getLine()); } @@ -97,7 +189,7 @@ DECLARE_ANIM_PARSER(type) { debugC(7, kDebugParser, "ANIM_PARSER(type) "); if (_tokens[2][0] != '\0') { - _locParseCtxt.a->_type = ((4 + _objectsNames->lookup(_tokens[2])) << 16) & 0xFFFF0000; + _locParseCtxt.a->_type = ((4 + _vm->_objectsNames->lookup(_tokens[2])) << 16) & 0xFFFF0000; } int16 _si = _zoneTypeNames->lookup(_tokens[1]); if (_si != Table::notFound) { @@ -112,14 +204,14 @@ DECLARE_ANIM_PARSER(type) { _locParseCtxt.a->_flags |= 0x1000000; - _locationParser->popTables(); + parser->popTables(); } DECLARE_ANIM_PARSER(label) { debugC(7, kDebugParser, "ANIM_PARSER(label) "); - _locParseCtxt.a->_label = _gfx->renderFloatingLabel(_labelFont, _tokens[1]); + _locParseCtxt.a->_label = _vm->_gfx->renderFloatingLabel(_vm->_labelFont, _tokens[1]); } @@ -146,7 +238,7 @@ DECLARE_ANIM_PARSER(file) { strcat(vC8, "tras"); } } - _locParseCtxt.a->gfxobj = _gfx->loadAnim(vC8); + _locParseCtxt.a->gfxobj = _vm->_gfx->loadAnim(vC8); } @@ -176,10 +268,10 @@ DECLARE_ANIM_PARSER(endanimation) { _locParseCtxt.a->_flags |= 0x1000000; - _locationParser->popTables(); + parser->popTables(); } -void Parallaction_ns::parseAnimation(Script& script, AnimationList &list, char *name) { +void LocationParser_ns::parseAnimation(Script& script, AnimationList &list, char *name) { debugC(5, kDebugParser, "parseAnimation(name: %s)", name); AnimationPtr a(new Animation); @@ -191,7 +283,7 @@ void Parallaction_ns::parseAnimation(Script& script, AnimationList &list, char * _locParseCtxt.a = a; _locParseCtxt.script = &script; - _locationParser->pushTables(&_locationAnimParsers, _locationAnimStmt); + parser->pushTables(&_locationAnimParsers, _locationAnimStmt); } void Parallaction_ns::parseInstruction(ProgramPtr program) { @@ -239,7 +331,7 @@ void Parallaction_ns::loadProgram(AnimationPtr a, const char *filename) { delete script; - _location._programs.push_back(program); + _vm->_location._programs.push_back(program); debugC(1, kDebugParser, "loadProgram() done"); @@ -469,11 +561,11 @@ void Parallaction_ns::parseLValue(ScriptVar &v, const char *str) { DECLARE_COMMAND_PARSER(flags) { debugC(7, kDebugParser, "COMMAND_PARSER(flags) "); - createCommand(_locationParser->_lookup); + createCommand(parser->_lookup); - if (_globalTable->lookup(_tokens[1]) == Table::notFound) { + if (_vm->_globalTable->lookup(_tokens[1]) == Table::notFound) { do { - char _al = _localFlagNames->lookup(_tokens[_locParseCtxt.nextToken]); + char _al = _vm->_localFlagNames->lookup(_tokens[_locParseCtxt.nextToken]); _locParseCtxt.nextToken++; _locParseCtxt.cmd->u._flags |= 1 << (_al - 1); } while (!scumm_stricmp(_tokens[_locParseCtxt.nextToken++], "|")); @@ -481,7 +573,7 @@ DECLARE_COMMAND_PARSER(flags) { } else { _locParseCtxt.cmd->u._flags |= kFlagsGlobal; do { - char _al = _globalTable->lookup(_tokens[1]); + char _al = _vm->_globalTable->lookup(_tokens[1]); _locParseCtxt.nextToken++; _locParseCtxt.cmd->u._flags |= 1 << (_al - 1); } while (!scumm_stricmp(_tokens[_locParseCtxt.nextToken++], "|")); @@ -496,9 +588,9 @@ DECLARE_COMMAND_PARSER(flags) { DECLARE_COMMAND_PARSER(zone) { debugC(7, kDebugParser, "COMMAND_PARSER(zone) "); - createCommand(_locationParser->_lookup); + createCommand(parser->_lookup); - _locParseCtxt.cmd->u._zone = findZone(_tokens[_locParseCtxt.nextToken]); + _locParseCtxt.cmd->u._zone = _vm->findZone(_tokens[_locParseCtxt.nextToken]); if (!_locParseCtxt.cmd->u._zone) { saveCommandForward(_tokens[_locParseCtxt.nextToken], _locParseCtxt.cmd); } @@ -512,7 +604,7 @@ DECLARE_COMMAND_PARSER(zone) { DECLARE_COMMAND_PARSER(location) { debugC(7, kDebugParser, "COMMAND_PARSER(location) "); - createCommand(_locationParser->_lookup); + createCommand(parser->_lookup); _locParseCtxt.cmd->u._string = strdup(_tokens[_locParseCtxt.nextToken]); _locParseCtxt.nextToken++; @@ -525,9 +617,9 @@ DECLARE_COMMAND_PARSER(location) { DECLARE_COMMAND_PARSER(drop) { debugC(7, kDebugParser, "COMMAND_PARSER(drop) "); - createCommand(_locationParser->_lookup); + createCommand(parser->_lookup); - _locParseCtxt.cmd->u._object = 4 + _objectsNames->lookup(_tokens[_locParseCtxt.nextToken]); + _locParseCtxt.cmd->u._object = 4 + _vm->_objectsNames->lookup(_tokens[_locParseCtxt.nextToken]); _locParseCtxt.nextToken++; parseCommandFlags(); @@ -538,9 +630,9 @@ DECLARE_COMMAND_PARSER(drop) { DECLARE_COMMAND_PARSER(call) { debugC(7, kDebugParser, "COMMAND_PARSER(call) "); - createCommand(_locationParser->_lookup); + createCommand(parser->_lookup); - _locParseCtxt.cmd->u._callable = _callableNames->lookup(_tokens[_locParseCtxt.nextToken]) - 1; + _locParseCtxt.cmd->u._callable = _vm->_callableNames->lookup(_tokens[_locParseCtxt.nextToken]) - 1; _locParseCtxt.nextToken++; parseCommandFlags(); @@ -551,7 +643,7 @@ DECLARE_COMMAND_PARSER(call) { DECLARE_COMMAND_PARSER(simple) { debugC(7, kDebugParser, "COMMAND_PARSER(simple) "); - createCommand(_locationParser->_lookup); + createCommand(parser->_lookup); addCommand(); } @@ -559,7 +651,7 @@ DECLARE_COMMAND_PARSER(simple) { DECLARE_COMMAND_PARSER(move) { debugC(7, kDebugParser, "COMMAND_PARSER(move) "); - createCommand(_locationParser->_lookup); + createCommand(parser->_lookup); _locParseCtxt.cmd->u._move.x = atoi(_tokens[_locParseCtxt.nextToken]); _locParseCtxt.nextToken++; @@ -573,13 +665,13 @@ DECLARE_COMMAND_PARSER(move) { DECLARE_COMMAND_PARSER(endcommands) { debugC(7, kDebugParser, "COMMAND_PARSER(endcommands) "); - _locationParser->popTables(); + parser->popTables(); // temporary trick to handle dialogue commands _locParseCtxt.endcommands = true; } -void Parallaction_ns::parseCommandFlags() { +void LocationParser_ns::parseCommandFlags() { int _si = _locParseCtxt.nextToken; CommandPtr cmd = _locParseCtxt.cmd; @@ -595,11 +687,11 @@ void Parallaction_ns::parseCommandFlags() { cmd->_flagsOn |= kFlagsEnter; } else if (!scumm_strnicmp(_tokens[_si], "no", 2)) { - byte _al = _localFlagNames->lookup(&_tokens[_si][2]); + byte _al = _vm->_localFlagNames->lookup(&_tokens[_si][2]); assert(_al != Table::notFound); cmd->_flagsOff |= 1 << (_al - 1); } else { - byte _al = _localFlagNames->lookup(_tokens[_si]); + byte _al = _vm->_localFlagNames->lookup(_tokens[_si]); assert(_al != Table::notFound); cmd->_flagsOn |= 1 << (_al - 1); } @@ -622,11 +714,11 @@ void Parallaction_ns::parseCommandFlags() { cmd->_flagsOn |= kFlagsEnter; } else if (!scumm_strnicmp(_tokens[_si], "no", 2)) { - byte _al = _globalTable->lookup(&_tokens[_si][2]); + byte _al = _vm->_globalTable->lookup(&_tokens[_si][2]); assert(_al != Table::notFound); cmd->_flagsOff |= 1 << (_al - 1); } else { - byte _al = _globalTable->lookup(_tokens[_si]); + byte _al = _vm->_globalTable->lookup(_tokens[_si]); assert(_al != Table::notFound); cmd->_flagsOn |= 1 << (_al - 1); } @@ -641,11 +733,11 @@ void Parallaction_ns::parseCommandFlags() { } -void Parallaction_ns::addCommand() { +void LocationParser_ns::addCommand() { _locParseCtxt.list->push_front(_locParseCtxt.cmd); // NOTE: command lists are written backwards in scripts } -void Parallaction_ns::createCommand(uint id) { +void LocationParser_ns::createCommand(uint id) { _locParseCtxt.nextToken = 1; _locParseCtxt.cmd = CommandPtr(new Command); @@ -653,7 +745,7 @@ void Parallaction_ns::createCommand(uint id) { } -void Parallaction_ns::saveCommandForward(const char *name, CommandPtr cmd) { +void LocationParser_ns::saveCommandForward(const char *name, CommandPtr cmd) { assert(_numForwardedCommands < MAX_FORWARDS); strcpy(_forwardedCommands[_numForwardedCommands].name, name); @@ -662,9 +754,9 @@ void Parallaction_ns::saveCommandForward(const char *name, CommandPtr cmd) { _numForwardedCommands++; } -void Parallaction_ns::resolveCommandForwards() { +void LocationParser_ns::resolveCommandForwards() { for (uint i = 0; i < _numForwardedCommands; i++) { - _forwardedCommands[i].cmd->u._zone = findZone(_forwardedCommands[i].name); + _forwardedCommands[i].cmd->u._zone = _vm->findZone(_forwardedCommands[i].name); if (_forwardedCommands[i].cmd->u._zone == 0) { warning("Cannot find zone '%s' into current location script. This may be a bug in the original scripts.\n", _forwardedCommands[i].name); } @@ -672,17 +764,17 @@ void Parallaction_ns::resolveCommandForwards() { _numForwardedCommands = 0; } -void Parallaction_ns::parseCommands(Script &script, CommandList& list) { +void LocationParser_ns::parseCommands(Script &script, CommandList& list) { debugC(5, kDebugParser, "parseCommands()"); _locParseCtxt.list = &list; _locParseCtxt.endcommands = false; _locParseCtxt.script = &script; - _locationParser->pushTables(&_commandParsers, _commandsNames); + parser->pushTables(&_commandParsers, _commandsNames); } -Dialogue *Parallaction_ns::parseDialogue(Script &script) { +Dialogue *LocationParser_ns::parseDialogue(Script &script) { debugC(7, kDebugParser, "parseDialogue()"); uint16 numQuestions = 0; @@ -711,7 +803,7 @@ Dialogue *Parallaction_ns::parseDialogue(Script &script) { return dialogue; } -Question *Parallaction_ns::parseQuestion(Script &script) { +Question *LocationParser_ns::parseQuestion(Script &script) { Question *question = new Question; assert(question); @@ -732,7 +824,7 @@ Question *Parallaction_ns::parseQuestion(Script &script) { return question; } -Answer *Parallaction_ns::parseAnswer(Script &script) { +Answer *LocationParser_ns::parseAnswer(Script &script) { Answer *answer = new Answer; assert(answer); @@ -744,11 +836,11 @@ Answer *Parallaction_ns::parseAnswer(Script &script) { if (!scumm_stricmp(_tokens[1], "global")) { token = 2; - flagNames = _globalTable; + flagNames = _vm->_globalTable; answer->_yesFlags |= kFlagsGlobal; } else { token = 1; - flagNames = _localFlagNames; + flagNames = _vm->_localFlagNames; } do { @@ -779,7 +871,7 @@ Answer *Parallaction_ns::parseAnswer(Script &script) { parseCommands(script, answer->_commands); _locParseCtxt.endcommands = false; do { - _locationParser->parseStatement(); + parser->parseStatement(); } while (!_locParseCtxt.endcommands); script.readLineToken(true); @@ -788,7 +880,7 @@ Answer *Parallaction_ns::parseAnswer(Script &script) { return answer; } -void Parallaction_ns::resolveDialogueForwards(Dialogue *dialogue, uint numQuestions, Table &forwards) { +void LocationParser_ns::resolveDialogueForwards(Dialogue *dialogue, uint numQuestions, Table &forwards) { for (uint16 i = 0; i < numQuestions; i++) { Question *question = dialogue->_questions[i]; @@ -811,7 +903,7 @@ void Parallaction_ns::resolveDialogueForwards(Dialogue *dialogue, uint numQuesti } -char *Parallaction_ns::parseDialogueString(Script &script) { +char *LocationParser_ns::parseDialogueString(Script &script) { char vC8[200]; char *vD0 = NULL; @@ -851,16 +943,16 @@ DECLARE_LOCATION_PARSER(location) { mask++; } - strcpy(_location._name, _tokens[1]); - switchBackground(_location._name, mask); + strcpy(_vm->_location._name, _tokens[1]); + _vm->switchBackground(_vm->_location._name, mask); if (_tokens[2][0] != '\0') { - _char._ani->_left = atoi(_tokens[2]); - _char._ani->_top = atoi(_tokens[3]); + _vm->_char._ani->_left = atoi(_tokens[2]); + _vm->_char._ani->_top = atoi(_tokens[3]); } if (_tokens[4][0] != '\0') { - _char._ani->_frame = atoi(_tokens[4]); + _vm->_char._ani->_frame = atoi(_tokens[4]); } } @@ -868,28 +960,28 @@ DECLARE_LOCATION_PARSER(location) { DECLARE_LOCATION_PARSER(disk) { debugC(7, kDebugParser, "LOCATION_PARSER(disk) "); - _disk->selectArchive(_tokens[1]); + _vm->_disk->selectArchive(_tokens[1]); } DECLARE_LOCATION_PARSER(nodes) { debugC(7, kDebugParser, "LOCATION_PARSER(nodes) "); - parseWalkNodes(*_locParseCtxt.script, _location._walkNodes); + parseWalkNodes(*_locParseCtxt.script, _vm->_location._walkNodes); } DECLARE_LOCATION_PARSER(zone) { debugC(7, kDebugParser, "LOCATION_PARSER(zone) "); - parseZone(*_locParseCtxt.script, _location._zones, _tokens[1]); + parseZone(*_locParseCtxt.script, _vm->_location._zones, _tokens[1]); } DECLARE_LOCATION_PARSER(animation) { debugC(7, kDebugParser, "LOCATION_PARSER(animation) "); - parseAnimation(*_locParseCtxt.script, _location._animations, _tokens[1]); + parseAnimation(*_locParseCtxt.script, _vm->_location._animations, _tokens[1]); } @@ -898,7 +990,7 @@ DECLARE_LOCATION_PARSER(localflags) { int _si = 1; while (_tokens[_si][0] != '\0') { - _localFlagNames->addData(_tokens[_si]); + _vm->_localFlagNames->addData(_tokens[_si]); _si++; } } @@ -907,28 +999,28 @@ DECLARE_LOCATION_PARSER(localflags) { DECLARE_LOCATION_PARSER(commands) { debugC(7, kDebugParser, "LOCATION_PARSER(commands) "); - parseCommands(*_locParseCtxt.script, _location._commands); + parseCommands(*_locParseCtxt.script, _vm->_location._commands); } DECLARE_LOCATION_PARSER(acommands) { debugC(7, kDebugParser, "LOCATION_PARSER(acommands) "); - parseCommands(*_locParseCtxt.script, _location._aCommands); + parseCommands(*_locParseCtxt.script, _vm->_location._aCommands); } DECLARE_LOCATION_PARSER(flags) { debugC(7, kDebugParser, "LOCATION_PARSER(flags) "); - if ((getLocationFlags() & kFlagsVisited) == 0) { + if ((_vm->getLocationFlags() & kFlagsVisited) == 0) { // only for 1st visit - clearLocationFlags(kFlagsAll); + _vm->clearLocationFlags(kFlagsAll); int _si = 1; do { - byte _al = _localFlagNames->lookup(_tokens[_si]); - setLocationFlags(1 << (_al - 1)); + byte _al = _vm->_localFlagNames->lookup(_tokens[_si]); + _vm->setLocationFlags(1 << (_al - 1)); _si++; if (scumm_stricmp(_tokens[_si], "|")) break; @@ -941,23 +1033,23 @@ DECLARE_LOCATION_PARSER(flags) { DECLARE_LOCATION_PARSER(comment) { debugC(7, kDebugParser, "LOCATION_PARSER(comment) "); - _location._comment = parseComment(*_locParseCtxt.script); + _vm->_location._comment = parseComment(*_locParseCtxt.script); } DECLARE_LOCATION_PARSER(endcomment) { debugC(7, kDebugParser, "LOCATION_PARSER(endcomment) "); - _location._endComment = parseComment(*_locParseCtxt.script); + _vm->_location._endComment = parseComment(*_locParseCtxt.script); } DECLARE_LOCATION_PARSER(sound) { debugC(7, kDebugParser, "LOCATION_PARSER(sound) "); - if (getPlatform() == Common::kPlatformAmiga) { - strcpy(_location._soundFile, _tokens[1]); - _location._hasSound = true; + if (_vm->getPlatform() == Common::kPlatformAmiga) { + strcpy(_vm->_location._soundFile, _tokens[1]); + _vm->_location._hasSound = true; } } @@ -965,55 +1057,30 @@ DECLARE_LOCATION_PARSER(sound) { DECLARE_LOCATION_PARSER(music) { debugC(7, kDebugParser, "LOCATION_PARSER(music) "); - if (getPlatform() == Common::kPlatformAmiga) - _soundMan->setMusicFile(_tokens[1]); + if (_vm->getPlatform() == Common::kPlatformAmiga) + _vm->_soundMan->setMusicFile(_tokens[1]); } - -void Parallaction_ns::parseLocation(const char *filename) { - debugC(1, kDebugParser, "parseLocation('%s')", filename); - - allocateLocationSlot(filename); -// printf("got location slot #%i for %s\n", _currentLocationIndex, filename); +void LocationParser_ns::parse(Script *script) { _numForwardedCommands = 0; - Script *script = _disk->loadLocation(filename); - _locationParser->bind(script); - - // TODO: the following two lines are specific to Nippon Safes - // and should be moved into something like 'initializeParsing()' - _location._hasSound = false; - _locParseCtxt.end = false; _locParseCtxt.script = script; - _locParseCtxt.filename = filename; + _locParseCtxt.filename = 0;//filename; - _locationParser->pushTables(&_locationParsers, _locationStmt); + parser->bind(script); + parser->pushTables(&_locationParsers, _locationStmt); do { - _locationParser->parseStatement(); + parser->parseStatement(); } while (!_locParseCtxt.end); - _locationParser->popTables(); - _locationParser->unbind(); - - delete script; + parser->popTables(); + parser->unbind(); resolveCommandForwards(); - - // this loads animation scripts - AnimationList::iterator it = _location._animations.begin(); - for ( ; it != _location._animations.end(); it++) { - if ((*it)->_scriptName) { - loadProgram(*it, (*it)->_scriptName); - } - } - - debugC(1, kDebugParser, "parseLocation('%s') done", filename); - return; } - -void Parallaction_ns::parseWalkNodes(Script& script, WalkNodeList &list) { +void LocationParser_ns::parseWalkNodes(Script& script, WalkNodeList &list) { debugC(5, kDebugParser, "parseWalkNodes()"); script.readLineToken(true); @@ -1039,46 +1106,29 @@ void Parallaction_ns::parseWalkNodes(Script& script, WalkNodeList &list) { typedef OpcodeImpl<Parallaction_ns> OpcodeV1; #define INSTRUCTION_PARSER(sig) OpcodeV1(this, &Parallaction_ns::instParse_##sig) -#define ZONE_PARSER(sig) OpcodeV1(this, &Parallaction_ns::locZoneParse_##sig) -#define ANIM_PARSER(sig) OpcodeV1(this, &Parallaction_ns::locAnimParse_##sig) -#define LOCATION_PARSER(sig) OpcodeV1(this, &Parallaction_ns::locParse_##sig) -#define COMMAND_PARSER(sig) OpcodeV1(this, &Parallaction_ns::cmdParse_##sig) -#define WARNING_PARSER(sig) OpcodeV1(this, &Parallaction_br::warning_##sig) +typedef OpcodeImpl<LocationParser_ns> OpcodeV2; +#define ZONE_PARSER(sig) OpcodeV2(this, &LocationParser_ns::locZoneParse_##sig) +#define ANIM_PARSER(sig) OpcodeV2(this, &LocationParser_ns::locAnimParse_##sig) +#define LOCATION_PARSER(sig) OpcodeV2(this, &LocationParser_ns::locParse_##sig) +#define COMMAND_PARSER(sig) OpcodeV2(this, &LocationParser_ns::cmdParse_##sig) -void Parallaction_ns::initParsers() { +#define WARNING_PARSER(sig) OpcodeV2(this, &LocationParser_br::warning_##sig) - _locationParser = new Parser; +void LocationParser_ns::init() { - static const OpcodeV1 op0[] = { - INSTRUCTION_PARSER(defLocal), // invalid opcode -> local definition - INSTRUCTION_PARSER(animation), // on - INSTRUCTION_PARSER(animation), // off - INSTRUCTION_PARSER(x), - INSTRUCTION_PARSER(y), - INSTRUCTION_PARSER(z), - INSTRUCTION_PARSER(f), - INSTRUCTION_PARSER(loop), - INSTRUCTION_PARSER(null), // endloop - INSTRUCTION_PARSER(null), // show - INSTRUCTION_PARSER(inc), - INSTRUCTION_PARSER(inc), // dec - INSTRUCTION_PARSER(set), - INSTRUCTION_PARSER(put), - INSTRUCTION_PARSER(call), - INSTRUCTION_PARSER(null), // wait - INSTRUCTION_PARSER(animation), // start - INSTRUCTION_PARSER(sound), - INSTRUCTION_PARSER(move), - INSTRUCTION_PARSER(endscript) - }; + parser = new Parser; - uint i; - for (i = 0; i < ARRAYSIZE(op0); i++) - _instructionParsers.push_back(&op0[i]); + _zoneFlagNames = new Table(ARRAYSIZE(_zoneFlagNamesRes_ns), _zoneFlagNamesRes_ns); + _zoneTypeNames = new Table(ARRAYSIZE(_zoneTypeNamesRes_ns), _zoneTypeNamesRes_ns); + _commandsNames = new Table(ARRAYSIZE(_commandsNamesRes_ns), _commandsNamesRes_ns); + _locationStmt = new Table(ARRAYSIZE(_locationStmtRes_ns), _locationStmtRes_ns); + _locationZoneStmt = new Table(ARRAYSIZE(_locationZoneStmtRes_ns), _locationZoneStmtRes_ns); + _locationAnimStmt = new Table(ARRAYSIZE(_locationAnimStmtRes_ns), _locationAnimStmtRes_ns); + uint i; - static const OpcodeV1 op2[] = { + static const OpcodeV2 op2[] = { WARNING_PARSER(unexpected), COMMAND_PARSER(flags), // set COMMAND_PARSER(flags), // clear @@ -1104,7 +1154,7 @@ void Parallaction_ns::initParsers() { _commandParsers.push_back(&op2[i]); - static const OpcodeV1 op4[] = { + static const OpcodeV2 op4[] = { WARNING_PARSER(unexpected), LOCATION_PARSER(endlocation), LOCATION_PARSER(location), @@ -1125,7 +1175,7 @@ void Parallaction_ns::initParsers() { for (i = 0; i < ARRAYSIZE(op4); i++) _locationParsers.push_back(&op4[i]); - static const OpcodeV1 op5[] = { + static const OpcodeV2 op5[] = { WARNING_PARSER(unexpected), ZONE_PARSER(limits), ZONE_PARSER(moveto), @@ -1139,7 +1189,7 @@ void Parallaction_ns::initParsers() { for (i = 0; i < ARRAYSIZE(op5); i++) _locationZoneParsers.push_back(&op5[i]); - static const OpcodeV1 op6[] = { + static const OpcodeV2 op6[] = { WARNING_PARSER(unexpected), ANIM_PARSER(script), ANIM_PARSER(commands), @@ -1155,13 +1205,46 @@ void Parallaction_ns::initParsers() { for (i = 0; i < ARRAYSIZE(op6); i++) _locationAnimParsers.push_back(&op6[i]); + +} + +void Parallaction_ns::initParsers() { + + _locationParser = new LocationParser_ns(this); + + static const OpcodeV1 op0[] = { + INSTRUCTION_PARSER(defLocal), // invalid opcode -> local definition + INSTRUCTION_PARSER(animation), // on + INSTRUCTION_PARSER(animation), // off + INSTRUCTION_PARSER(x), + INSTRUCTION_PARSER(y), + INSTRUCTION_PARSER(z), + INSTRUCTION_PARSER(f), + INSTRUCTION_PARSER(loop), + INSTRUCTION_PARSER(null), // endloop + INSTRUCTION_PARSER(null), // show + INSTRUCTION_PARSER(inc), + INSTRUCTION_PARSER(inc), // dec + INSTRUCTION_PARSER(set), + INSTRUCTION_PARSER(put), + INSTRUCTION_PARSER(call), + INSTRUCTION_PARSER(null), // wait + INSTRUCTION_PARSER(animation), // start + INSTRUCTION_PARSER(sound), + INSTRUCTION_PARSER(move), + INSTRUCTION_PARSER(endscript) + }; + + for (uint i = 0; i < ARRAYSIZE(op0); i++) + _instructionParsers.push_back(&op0[i]); + } // // a comment can appear both at location and Zone levels // comments are displayed into rectangles on the screen // -char *Parallaction_ns::parseComment(Script &script) { +char *LocationParser_ns::parseComment(Script &script) { char _tmp_comment[1000] = "\0"; char *v194; @@ -1192,7 +1275,7 @@ DECLARE_ZONE_PARSER(null) { DECLARE_ZONE_PARSER(endzone) { debugC(7, kDebugParser, "ZONE_PARSER(endzone) "); - _locationParser->popTables(); + parser->popTables(); } DECLARE_ZONE_PARSER(limits) { @@ -1217,7 +1300,7 @@ DECLARE_ZONE_PARSER(type) { debugC(7, kDebugParser, "ZONE_PARSER(type) "); if (_tokens[2][0] != '\0') { - _locParseCtxt.z->_type = (4 + _objectsNames->lookup(_tokens[2])) << 16; + _locParseCtxt.z->_type = (4 + _vm->_objectsNames->lookup(_tokens[2])) << 16; } int16 _si = _zoneTypeNames->lookup(_tokens[1]); if (_si != Table::notFound) { @@ -1225,7 +1308,7 @@ DECLARE_ZONE_PARSER(type) { parseZoneTypeBlock(*_locParseCtxt.script, _locParseCtxt.z); } - _locationParser->popTables(); + parser->popTables(); } @@ -1240,7 +1323,7 @@ DECLARE_ZONE_PARSER(label) { debugC(7, kDebugParser, "ZONE_PARSER(label) "); // printf("label: %s", _tokens[1]); - _locParseCtxt.z->_label = _gfx->renderFloatingLabel(_labelFont, _tokens[1]); + _locParseCtxt.z->_label = _vm->_gfx->renderFloatingLabel(_vm->_labelFont, _tokens[1]); } @@ -1256,10 +1339,10 @@ DECLARE_ZONE_PARSER(flags) { } while (!scumm_stricmp(_tokens[_si++], "|")); } -void Parallaction_ns::parseZone(Script &script, ZoneList &list, char *name) { +void LocationParser_ns::parseZone(Script &script, ZoneList &list, char *name) { debugC(5, kDebugParser, "parseZone(name: %s)", name); - if (findZone(name)) { + if (_vm->findZone(name)) { script.skip("endzone"); return; } @@ -1273,7 +1356,7 @@ void Parallaction_ns::parseZone(Script &script, ZoneList &list, char *name) { list.push_front(z); - _locationParser->pushTables(&_locationZoneParsers, _locationZoneStmt); + parser->pushTables(&_locationZoneParsers, _locationZoneStmt); return; } @@ -1281,7 +1364,7 @@ void Parallaction_ns::parseZone(Script &script, ZoneList &list, char *name) { -void Parallaction_ns::parseGetData(Script &script, ZonePtr z) { +void LocationParser_ns::parseGetData(Script &script, ZonePtr z) { GetData *data = new GetData; @@ -1291,17 +1374,17 @@ void Parallaction_ns::parseGetData(Script &script, ZonePtr z) { bool visible = (z->_flags & kFlagsRemove) == 0; - GfxObj *obj = _gfx->loadGet(_tokens[1]); + GfxObj *obj = _vm->_gfx->loadGet(_tokens[1]); obj->frame = 0; obj->x = z->_left; obj->y = z->_top; - _gfx->showGfxObj(obj, visible); + _vm->_gfx->showGfxObj(obj, visible); data->gfxobj = obj; } if (!scumm_stricmp(_tokens[0], "icon")) { - data->_icon = 4 + _objectsNames->lookup(_tokens[1]); + data->_icon = 4 + _vm->_objectsNames->lookup(_tokens[1]); } script.readLineToken(true); @@ -1312,7 +1395,7 @@ void Parallaction_ns::parseGetData(Script &script, ZonePtr z) { } -void Parallaction_ns::parseExamineData(Script &script, ZonePtr z) { +void LocationParser_ns::parseExamineData(Script &script, ZonePtr z) { ExamineData *data = new ExamineData; @@ -1333,16 +1416,16 @@ void Parallaction_ns::parseExamineData(Script &script, ZonePtr z) { } -void Parallaction_ns::parseDoorData(Script &script, ZonePtr z) { +void LocationParser_ns::parseDoorData(Script &script, ZonePtr z) { DoorData *data = new DoorData; do { if (!scumm_stricmp(_tokens[0], "slidetext")) { - strcpy(_slideText[0], _tokens[1]); + strcpy(_vm->_location._slideText[0], _tokens[1]); // printf("%s\t", _slideText[0]); - strcpy(_slideText[1], _tokens[2]); + strcpy(_vm->_location._slideText[1], _tokens[2]); } if (!scumm_stricmp(_tokens[0], "location")) { @@ -1354,11 +1437,11 @@ void Parallaction_ns::parseDoorData(Script &script, ZonePtr z) { uint16 frame = (z->_flags & kFlagsClosed ? 0 : 1); - GfxObj *obj = _gfx->loadDoor(_tokens[1]); + GfxObj *obj = _vm->_gfx->loadDoor(_tokens[1]); obj->frame = frame; obj->x = z->_left; obj->y = z->_top; - _gfx->showGfxObj(obj, true); + _vm->_gfx->showGfxObj(obj, true); data->gfxobj = obj; } @@ -1377,20 +1460,20 @@ void Parallaction_ns::parseDoorData(Script &script, ZonePtr z) { } -void Parallaction_ns::parseMergeData(Script &script, ZonePtr z) { +void LocationParser_ns::parseMergeData(Script &script, ZonePtr z) { MergeData *data = new MergeData; do { if (!scumm_stricmp(_tokens[0], "obj1")) { - data->_obj1 = 4 + _objectsNames->lookup(_tokens[1]); + data->_obj1 = 4 + _vm->_objectsNames->lookup(_tokens[1]); } if (!scumm_stricmp(_tokens[0], "obj2")) { - data->_obj2 = 4 + _objectsNames->lookup(_tokens[1]); + data->_obj2 = 4 + _vm->_objectsNames->lookup(_tokens[1]); } if (!scumm_stricmp(_tokens[0], "newobj")) { - data->_obj3 = 4 + _objectsNames->lookup(_tokens[1]); + data->_obj3 = 4 + _vm->_objectsNames->lookup(_tokens[1]); } script.readLineToken(true); @@ -1400,7 +1483,7 @@ void Parallaction_ns::parseMergeData(Script &script, ZonePtr z) { } -void Parallaction_ns::parseHearData(Script &script, ZonePtr z) { +void LocationParser_ns::parseHearData(Script &script, ZonePtr z) { HearData *data = new HearData; @@ -1421,7 +1504,7 @@ void Parallaction_ns::parseHearData(Script &script, ZonePtr z) { } -void Parallaction_ns::parseSpeakData(Script &script, ZonePtr z) { +void LocationParser_ns::parseSpeakData(Script &script, ZonePtr z) { SpeakData *data = new SpeakData; @@ -1442,7 +1525,7 @@ void Parallaction_ns::parseSpeakData(Script &script, ZonePtr z) { } -void Parallaction_ns::parseZoneTypeBlock(Script &script, ZonePtr z) { +void LocationParser_ns::parseZoneTypeBlock(Script &script, ZonePtr z) { debugC(7, kDebugParser, "parseZoneTypeBlock(name: %s, type: %x)", z->_name, z->_type); switch (z->_type & 0xFFFF) { diff --git a/engines/parallaction/staticres.cpp b/engines/parallaction/staticres.cpp index 53d370a0a8..3c2051795d 100644 --- a/engines/parallaction/staticres.cpp +++ b/engines/parallaction/staticres.cpp @@ -216,58 +216,6 @@ byte _amigaTopazFont[2600] = { }; - -const char *_zoneFlagNamesRes_ns[] = { - "closed", - "active", - "remove", - "acting", - "locked", - "fixed", - "noname", - "nomasked", - "looping", - "added", - "character", - "nowalk" -}; - -const char *_zoneTypeNamesRes_ns[] = { - "examine", - "door", - "get", - "merge", - "taste", - "hear", - "feel", - "speak", - "none", - "trap", - "yourself", - "Command" -}; - -const char *_commandsNamesRes_ns[] = { - "set", - "clear", - "start", - "speak", - "get", - "location", - "open", - "close", - "on", - "off", - "call", - "toggle", - "drop", - "quit", - "move", - "stop", - "endcommands", - "endzone" -}; - const char *_instructionNamesRes_ns[] = { "on", "off", @@ -318,80 +266,6 @@ const char *_callableNamesRes_ns[] = { "TestResult" }; -const char *_locationStmtRes_ns[] = { - "endlocation", - "location", - "disk", - "nodes", - "zone", - "animation", - "localflags", - "commands", - "acommands", - "flags", - "comment", - "endcomment", - "sound", - "music" -}; - -const char *_locationZoneStmtRes_ns[] = { - "limits", - "moveto", - "type", - "commands", - "label", - "flags", - "endzone" -}; - -const char *_locationAnimStmtRes_ns[] = { - "script", - "commands", - "type", - "label", - "flags", - "file", - "position", - "moveto", - "endanimation" -}; - -const char *_zoneTypeNamesRes_br[] = { - "examine", - "door", - "get", - "merge", - "taste", - "hear", - "feel", - "speak", - "none", - "trap", - "you", - "command", - "path", - "box" -}; - -const char *_zoneFlagNamesRes_br[] = { - "closed", - "active", - "remove", - "acting", - "locked", - "fixed", - "noname", - "nomasked", - "looping", - "added", - "character", - "nowalk", - "yourself", - "scaled", - "selfuse" -}; - const char *_instructionNamesRes_br[] = { "on", "off", @@ -426,52 +300,6 @@ const char *_instructionNamesRes_br[] = { "endscript" }; -const char *_commandsNamesRes_br[] = { - "set", - "clear", - "start", - "speak", - "get", - "location", - "open", - "close", - "on", - "off", - "call", - "toggle", - "drop", - "quit", - "move", - "stop", - "character", - "followme", - "onmouse", - "offmouse", - "add", - "leave", - "inc", - "dec", - "test", - "dummy", - "dummy", - "let", - "music", - "fix", - "unfix", - "zeta", - "scroll", - "swap", - "give", - "text", - "part", - "dummy", - "return", - "onsave", - "offsave", - "endcommands", - "ifchar", - "endif" -}; const char *_callableNamesRes_br[] = { "blufade", @@ -482,72 +310,6 @@ const char *_callableNamesRes_br[] = { "password" }; -const char *_audioCommandsNamesRes_br[] = { - "play", - "stop", - "pause", - "channel_level", - "fadein", - "fadeout", - "volume", - " ", - "faderate", - " ", - " ", - " ", - " ", - " ", - " ", - " ", - "loop" -}; - -const char *_locationStmtRes_br[] = { - "character", - "endlocation", - "ifchar", - "endif", - "location", - "mask", - "path", - "disk", - "localflags", - "commands", - "escape", - "acommands", - "flags", - "comment", - "endcomment", - "zone", - "animation", - "zeta", - "music", - "sound" -}; - -const char *_locationZoneStmtRes_br[] = { - "endzone", - "limits", - "moveto", - "type", - "commands", - "label", - "flags" -}; - -const char *_locationAnimStmtRes_br[] = { - "endanimation", - "endzone", - "script", - "commands", - "type", - "label", - "flags", - "file", - "position", - "moveto" -}; - const char *_dinoName = "dino"; const char *_donnaName = "donna"; const char *_doughName = "dough"; @@ -629,20 +391,14 @@ const Parallaction_br::Callable Parallaction_br::_dosCallables[] = { void Parallaction_ns::initResources() { - _zoneFlagNamesRes = _zoneFlagNamesRes_ns; - _zoneTypeNamesRes = _zoneTypeNamesRes_ns; - _commandsNamesRes = _commandsNamesRes_ns; +// _zoneFlagNamesRes = _zoneFlagNamesRes_ns; +// _zoneTypeNamesRes = _zoneTypeNamesRes_ns; +// _commandsNamesRes = _commandsNamesRes_ns; _callableNamesRes = _callableNamesRes_ns; _instructionNamesRes = _instructionNamesRes_ns; _callableNames = new Table(ARRAYSIZE(_callableNamesRes_ns), _callableNamesRes_ns); _instructionNames = new Table(ARRAYSIZE(_instructionNamesRes_ns), _instructionNamesRes_ns); - _zoneFlagNames = new Table(ARRAYSIZE(_zoneFlagNamesRes_ns), _zoneFlagNamesRes_ns); - _zoneTypeNames = new Table(ARRAYSIZE(_zoneTypeNamesRes_ns), _zoneTypeNamesRes_ns); - _commandsNames = new Table(ARRAYSIZE(_commandsNamesRes_ns), _commandsNamesRes_ns); - _locationStmt = new Table(ARRAYSIZE(_locationStmtRes_ns), _locationStmtRes_ns); - _locationZoneStmt = new Table(ARRAYSIZE(_locationZoneStmtRes_ns), _locationZoneStmtRes_ns); - _locationAnimStmt = new Table(ARRAYSIZE(_locationAnimStmtRes_ns), _locationAnimStmtRes_ns); _localFlagNames = new FixedTable(NUM_LOCATIONS, 1); _localFlagNames->addData("visited"); @@ -657,22 +413,15 @@ void Parallaction_ns::initResources() { void Parallaction_br::initResources() { - _zoneFlagNamesRes = _zoneFlagNamesRes_br; - _zoneTypeNamesRes = _zoneTypeNamesRes_br; - _commandsNamesRes = _commandsNamesRes_br; +// _zoneFlagNamesRes = _zoneFlagNamesRes_br; +// _zoneTypeNamesRes = _zoneTypeNamesRes_br; +// _commandsNamesRes = _commandsNamesRes_br; _callableNamesRes = _callableNamesRes_br; _instructionNamesRes = _instructionNamesRes_br; - _audioCommandsNamesRes = _audioCommandsNamesRes_br; +// _audioCommandsNamesRes = _audioCommandsNamesRes_br; _callableNames = new Table(ARRAYSIZE(_callableNamesRes_br), _callableNamesRes_br); _instructionNames = new Table(ARRAYSIZE(_instructionNamesRes_br), _instructionNamesRes_br); - _zoneFlagNames = new Table(ARRAYSIZE(_zoneFlagNamesRes_br), _zoneFlagNamesRes_br); - _zoneTypeNames = new Table(ARRAYSIZE(_zoneTypeNamesRes_br), _zoneTypeNamesRes_br); - _commandsNames = new Table(ARRAYSIZE(_commandsNamesRes_br), _commandsNamesRes_br); - _audioCommandsNames = new Table(ARRAYSIZE(_audioCommandsNamesRes_br), _audioCommandsNamesRes_br); - _locationStmt = new Table(ARRAYSIZE(_locationStmtRes_br), _locationStmtRes_br); - _locationZoneStmt = new Table(ARRAYSIZE(_locationZoneStmtRes_br), _locationZoneStmtRes_br); - _locationAnimStmt = new Table(ARRAYSIZE(_locationAnimStmtRes_br), _locationAnimStmtRes_br); _localFlagNames = new FixedTable(NUM_LOCATIONS, 2); _localFlagNames->addData("visited"); |