diff options
-rw-r--r-- | engines/voyeur/files.cpp | 49 | ||||
-rw-r--r-- | engines/voyeur/files.h | 12 | ||||
-rw-r--r-- | engines/voyeur/voyeur.cpp | 1 | ||||
-rw-r--r-- | engines/voyeur/voyeur.h | 9 | ||||
-rw-r--r-- | engines/voyeur/voyeur_game.cpp | 57 |
5 files changed, 68 insertions, 60 deletions
diff --git a/engines/voyeur/files.cpp b/engines/voyeur/files.cpp index f9fce61f8d..84f0df81ef 100644 --- a/engines/voyeur/files.cpp +++ b/engines/voyeur/files.cpp @@ -1307,10 +1307,57 @@ VInitCyclResource::VInitCyclResource(BoltFilesState &state, const byte *src) { /*------------------------------------------------------------------------*/ -ThreadResource::ThreadResource(BoltFilesState &state, const byte *src) { +int ThreadResource::_stampFlags = 0; +int ThreadResource::_useCount[8]; + +ThreadResource::ThreadResource(BoltFilesState &state, const byte *src): + _vm(state._vm) { _flags = READ_LE_UINT16(&src[8]); } +bool ThreadResource::loadAStack(int idx) { + if (_stampFlags & 1) { + unloadAStack(_controlIndex); + if (!_useCount[idx]) { + BoltEntry &boltEntry = _vm->_stampLibPtr->boltEntry(_vm->_controlPtr->_memberIds[idx]); + if (!boltEntry._data) + return false; + + _vm->_controlPtr->_entries[idx] = boltEntry._data; + } + + ++_useCount[idx]; + } + + _ctlPtr = _vm->_controlPtr->_entries[idx]; + return true; +} + +void ThreadResource::unloadAStack(int idx) { + if ((_stampFlags & 1) && _useCount[idx]) { + if (--_useCount[idx] == 0) { + _vm->_stampLibPtr->freeBoltMember(_vm->_controlPtr->_memberIds[idx]); + } + } +} + +void ThreadResource::doState() { + warning("TODO: stm_doState"); +} + +void ThreadResource::unloadAllStacks(VoyeurEngine *vm) { + if (_stampFlags & 1) { + for (int i = 0; i < 8; ++i) { + if (_useCount[i]) + vm->_stampLibPtr->freeBoltMember(vm->_controlPtr->_memberIds[i]); + } + } +} + +void ThreadResource::initUseCount() { + Common::fill(&_useCount[0], &_useCount[8], 0); +} + /*------------------------------------------------------------------------*/ PtrResource::PtrResource(BoltFilesState &state, const byte *src) { diff --git a/engines/voyeur/files.h b/engines/voyeur/files.h index 7ea7dead91..3ce9d4c2f6 100644 --- a/engines/voyeur/files.h +++ b/engines/voyeur/files.h @@ -414,6 +414,14 @@ public: class ThreadResource { public: + static int _stampFlags; + static int _useCount[8]; + + static void initUseCount(); + static void unloadAllStacks(VoyeurEngine *vm); +public: + VoyeurEngine *_vm; + int _field0; int _controlIndex; int _field4, _field6; @@ -424,6 +432,10 @@ public: public: ThreadResource(BoltFilesState &state, const byte *src); virtual ~ThreadResource() {} + + bool loadAStack(int idx); + void unloadAStack(int idx); + void doState(); }; } // End of namespace Voyeur diff --git a/engines/voyeur/voyeur.cpp b/engines/voyeur/voyeur.cpp index 000012c899..7312728c24 100644 --- a/engines/voyeur/voyeur.cpp +++ b/engines/voyeur/voyeur.cpp @@ -41,7 +41,6 @@ VoyeurEngine::VoyeurEngine(OSystem *syst, const VoyeurGameDescription *gameDesc) _bVoy = NULL; _iForceDeath = -1; _controlPtr = NULL; - _stampFlags = 0; initialiseManagers(); } diff --git a/engines/voyeur/voyeur.h b/engines/voyeur/voyeur.h index 549a335416..772343b00a 100644 --- a/engines/voyeur/voyeur.h +++ b/engines/voyeur/voyeur.h @@ -84,12 +84,7 @@ private: void playStamp(); void initStamp(); void closeStamp(); - void initUseCount(); - void initThreadStruct(ThreadResource *thread, int v1, int idx); - bool stm_loadAStack(ThreadResource *thread, int idx); - void stm_unloadAStack(int idx); - void stm_unloadAllStacks(); - void stm_doState(ThreadResource *thread); + void initThreadStruct(ThreadResource *thread, int idx, int v3); protected: // Engine APIs virtual Common::Error run(); @@ -108,8 +103,6 @@ public: ControlResource *_controlPtr; byte *_stampData; BoltGroup *_stackGroupPtr; - int _stampFlags; - int _stm_useCount[8]; public: VoyeurEngine(OSystem *syst, const VoyeurGameDescription *gameDesc); virtual ~VoyeurEngine(); diff --git a/engines/voyeur/voyeur_game.cpp b/engines/voyeur/voyeur_game.cpp index ee7ef66c6d..adaff87672 100644 --- a/engines/voyeur/voyeur_game.cpp +++ b/engines/voyeur/voyeur_game.cpp @@ -65,72 +65,29 @@ void VoyeurEngine::playStamp() { } void VoyeurEngine::initStamp() { - _stampFlags &= ~1; + ThreadResource::_stampFlags &= ~1; _stackGroupPtr = _controlGroupPtr; if (!_controlPtr->_entries[0]) error("No control entries"); - initUseCount(); + ThreadResource::initUseCount(); } void VoyeurEngine::closeStamp() { - stm_unloadAllStacks(); + ThreadResource::unloadAllStacks(this); } -void VoyeurEngine::initUseCount() { - Common::fill(&_stm_useCount[0], &_stm_useCount[8], 0); -} - -void VoyeurEngine::initThreadStruct(ThreadResource *thread, int v1, int idx) { +void VoyeurEngine::initThreadStruct(ThreadResource *thread, int idx, int v3) { thread->_controlIndex = -1; - if (stm_loadAStack(thread, idx)) { + if (thread->loadAStack(idx)) { thread->_field4 = thread->_field6 = -1; - thread->_field0 = idx; + thread->_field0 = v3; thread->_field3A = -1; thread->_field3E = -1; - stm_doState(thread); - } -} - -bool VoyeurEngine::stm_loadAStack(ThreadResource *thread, int idx) { - if (_stampFlags & 1) { - stm_unloadAStack(thread->_controlIndex); - if (!_stm_useCount[idx]) { - BoltEntry &boltEntry = _stampLibPtr->boltEntry(_controlPtr->_memberIds[idx]); - if (!boltEntry._data) - return false; - - _controlPtr->_entries[idx] = boltEntry._data; - } - - ++_stm_useCount[idx]; - } - - thread->_ctlPtr = _controlPtr->_entries[idx]; - return true; -} - -void VoyeurEngine::stm_unloadAStack(int idx) { - if ((_stampFlags & 1) && _stm_useCount[idx]) { - if (--_stm_useCount[idx] == 0) { - _stampLibPtr->freeBoltMember(_controlPtr->_memberIds[idx]); - } - } -} - -void VoyeurEngine::stm_unloadAllStacks() { - if (_stampFlags & 1) { - for (int i = 0; i < 8; ++i) { - if (_stm_useCount[i]) - _stampLibPtr->freeBoltMember(_controlPtr->_memberIds[i]); - } + thread->doState(); } } -void VoyeurEngine::stm_doState(ThreadResource *thread) { - warning("TODO: stm_doState"); -} - } // End of namespace Voyeur |