aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--engines/voyeur/files.cpp66
-rw-r--r--engines/voyeur/files.h3
2 files changed, 68 insertions, 1 deletions
diff --git a/engines/voyeur/files.cpp b/engines/voyeur/files.cpp
index 5b7e475640..c5838637c8 100644
--- a/engines/voyeur/files.cpp
+++ b/engines/voyeur/files.cpp
@@ -1387,7 +1387,21 @@ byte *ThreadResource::getDataOffset() {
}
void ThreadResource::getButtonsText() {
- warning("TODO: stm_getButtonsText");
+ int idx = 0;
+
+ for (const byte *p = _field4A; *p != 0x49; p = getNextRecord(p)) {
+ if (*p == 0xC0) {
+ ++p;
+ if (*p++ & 0x80) {
+ assert(idx < 7);
+ _field8E[idx] = getRecordOffset(p);
+ p += 4;
+ }
+
+ ++idx;
+ _field8E[idx] = NULL;
+ }
+ }
}
void ThreadResource::unloadAllStacks(VoyeurEngine *vm) {
@@ -1403,6 +1417,56 @@ void ThreadResource::initUseCount() {
Common::fill(&_useCount[0], &_useCount[8], 0);
}
+const byte *ThreadResource::getRecordOffset(const byte *p) {
+ uint32 recSize = READ_LE_UINT32(p) + READ_LE_UINT32(p + 6);
+ return _ctlPtr + recSize;
+}
+
+const byte *ThreadResource::getNextRecord(const byte *p) {
+ byte v = *p++;
+
+ switch (v) {
+ case 2:
+ case 4:
+ case 6:
+ case 8:
+ case 10:
+ return p + 8;
+ case 1:
+ case 3:
+ case 5:
+ case 7:
+ case 9:
+ case 11:
+ case 21:
+ case 22:
+ case 25:
+ case 26:
+ return p + 5;
+ case 17:
+ case 23:
+ case 24:
+ case 27:
+ case 28:
+ return p + 2;
+ case 19:
+ case 41:
+ return p + 6;
+ case 18:
+ case 51:
+ case 52:
+ return p + 1;
+ case 74:
+ return p + 4;
+ case 192:
+ if (*p * 0x80)
+ p += 4;
+ return p + 2;
+ default:
+ return p;
+ }
+}
+
/*------------------------------------------------------------------------*/
PtrResource::PtrResource(BoltFilesState &state, const byte *src) {
diff --git a/engines/voyeur/files.h b/engines/voyeur/files.h
index 1beb091a19..13023f80fb 100644
--- a/engines/voyeur/files.h
+++ b/engines/voyeur/files.h
@@ -424,6 +424,8 @@ private:
bool getStateInfo();
byte *getDataOffset();
void getButtonsText();
+ const byte *getRecordOffset(const byte *p);
+ const byte *getNextRecord(const byte *p);
public:
VoyeurEngine *_vm;
@@ -439,6 +441,7 @@ public:
int _field44;
uint32 _field46;
byte *_field4A;
+ const byte *_field8E[8];
byte *_ctlPtr;
byte *_field28E;