diff options
author | Alyssa Milburn | 2011-07-16 00:57:50 +0200 |
---|---|---|
committer | Alyssa Milburn | 2011-07-16 00:57:50 +0200 |
commit | 70ae2c74e04ac84503cfe9c1a555495700d55e68 (patch) | |
tree | 937e99240814217d2ffea632062501b2dbc59e39 /engines | |
parent | 28d4aaf095e4f3979d1f6dc75b53d73f412e83a0 (diff) | |
download | scummvm-rg350-70ae2c74e04ac84503cfe9c1a555495700d55e68.tar.gz scummvm-rg350-70ae2c74e04ac84503cfe9c1a555495700d55e68.tar.bz2 scummvm-rg350-70ae2c74e04ac84503cfe9c1a555495700d55e68.zip |
COMPOSER: Handle loading/unloading pages properly.
Diffstat (limited to 'engines')
-rw-r--r-- | engines/composer/composer.cpp | 51 | ||||
-rw-r--r-- | engines/composer/composer.h | 10 |
2 files changed, 55 insertions, 6 deletions
diff --git a/engines/composer/composer.cpp b/engines/composer/composer.cpp index acd1d33e65..6228292676 100644 --- a/engines/composer/composer.cpp +++ b/engines/composer/composer.cpp @@ -542,6 +542,14 @@ Common::Error ComposerEngine::run() { uint frameTime = 1000 / fps; uint32 lastDrawTime = 0; while (!shouldQuit()) { + for (uint i = 0; i < _pendingPageChanges.size(); i++) { + if (_pendingPageChanges[i]._remove) + unloadLibrary(_pendingPageChanges[i]._pageId); + else + loadLibrary(_pendingPageChanges[i]._pageId); + } + _pendingPageChanges.clear(); + uint32 thisTime = _system->getMillis(); for (uint i = 0; i < _queuedScripts.size(); i++) { QueuedScript &script = _queuedScripts[i]; @@ -683,6 +691,37 @@ void ComposerEngine::loadLibrary(uint id) { runEvent(3, id, 0, 0); } +void ComposerEngine::unloadLibrary(uint id) { + for (Common::List<Library>::iterator i = _libraries.begin(); i != _libraries.end(); i++) { + if (i->_id != id) + continue; + + for (Common::List<Animation *>::iterator j = _anims.begin(); j != _anims.end(); j++) { + delete *j; + } + _anims.clear(); + for (Common::List<Pipe *>::iterator j = _pipes.begin(); j != _pipes.end(); j++) { + delete *j; + } + _pipes.clear(); + + for (Common::List<Sprite>::iterator j = _sprites.begin(); j != _sprites.end(); j++) { + j->surface.free(); + } + _sprites.clear(); + + for (uint j = 0; j < _queuedScripts.size(); j++) { + _queuedScripts[j]._count = 0; + _queuedScripts[j]._scriptId = 0; + } + + _libraries.erase(i); + return; + } + + error("tried to unload library %d, which isn't loaded", id); +} + bool ComposerEngine::hasResource(uint32 tag, uint16 id) { for (Common::List<Library>::iterator i = _libraries.begin(); i != _libraries.end(); i++) if (i->_archive->hasResource(tag, id)) @@ -912,17 +951,17 @@ int16 ComposerEngine::scriptFuncCall(uint16 id, int16 param1, int16 param2, int1 warning("ignoring kFuncDeactivateButton(%d)", param1); return 1; case kFuncNewPage: - // TODO - warning("ignoring kFuncNewPage(%d, %d)", param1, param2); + debug(3, "kFuncNewPage(%d, %d)", param1, param2); + _pendingPageChanges.push_back(PendingPageChange(param1, true)); + _pendingPageChanges.push_back(PendingPageChange(param2, false)); return 1; case kFuncLoadPage: - // TODO debug(3, "kFuncLoadPage(%d)", param1); - loadLibrary(param1); + _pendingPageChanges.push_back(PendingPageChange(param1, false)); return 1; case kFuncUnloadPage: - // TODO - warning("ignoring kFuncUnloadPage(%d)", param1); + debug(3, "ignoring kFuncUnloadPage(%d)", param1); + _pendingPageChanges.push_back(PendingPageChange(param1, true)); return 1; case kFuncSetPalette: // TODO: return 0 if not disabling (0) and doesn't exist diff --git a/engines/composer/composer.h b/engines/composer/composer.h index a90eb61459..eba51759a2 100644 --- a/engines/composer/composer.h +++ b/engines/composer/composer.h @@ -139,6 +139,14 @@ struct QueuedScript { uint16 _scriptId; }; +struct PendingPageChange { + PendingPageChange() { } + PendingPageChange(uint16 id, bool remove) : _pageId(id), _remove(remove) { } + + uint16 _pageId; + bool _remove; +}; + class ComposerEngine : public Engine { protected: Common::Error run(); @@ -168,6 +176,7 @@ private: uint _directoriesToStrip; Common::ConfigFile _bookIni; Common::List<Library> _libraries; + Common::Array<PendingPageChange> _pendingPageChanges; Common::Array<uint16> _stack; Common::Array<uint16> _vars; @@ -179,6 +188,7 @@ private: Common::String getStringFromConfig(const Common::String §ion, const Common::String &key); Common::String getFilename(const Common::String §ion, uint id); void loadLibrary(uint id); + void unloadLibrary(uint id); bool hasResource(uint32 tag, uint16 id); Common::SeekableReadStream *getResource(uint32 tag, uint16 id); |