mirror of
https://github.com/isledecomp/isle.git
synced 2024-11-22 23:57:54 -05:00
MxStream provider and controller vtables (#191)
* MxStreamProvider and MxRamStreamProvider vtable * Update mxramstreamprovider.h * Match IsA * Fixes, improvements --------- Co-authored-by: Christian Semmler <mail@csemmler.com>
This commit is contained in:
parent
3ac0c5d86c
commit
d82649c6f0
11 changed files with 181 additions and 12 deletions
|
@ -154,6 +154,7 @@ add_library(lego1 SHARED
|
||||||
LEGO1/mxpresenter.cpp
|
LEGO1/mxpresenter.cpp
|
||||||
LEGO1/mxpresenterlist.cpp
|
LEGO1/mxpresenterlist.cpp
|
||||||
LEGO1/mxramstreamcontroller.cpp
|
LEGO1/mxramstreamcontroller.cpp
|
||||||
|
LEGO1/mxramstreamprovider.cpp
|
||||||
LEGO1/mxscheduler.cpp
|
LEGO1/mxscheduler.cpp
|
||||||
LEGO1/mxsemaphore.cpp
|
LEGO1/mxsemaphore.cpp
|
||||||
LEGO1/mxsmkpresenter.cpp
|
LEGO1/mxsmkpresenter.cpp
|
||||||
|
@ -162,6 +163,7 @@ add_library(lego1 SHARED
|
||||||
LEGO1/mxstillpresenter.cpp
|
LEGO1/mxstillpresenter.cpp
|
||||||
LEGO1/mxstreamcontroller.cpp
|
LEGO1/mxstreamcontroller.cpp
|
||||||
LEGO1/mxstreamer.cpp
|
LEGO1/mxstreamer.cpp
|
||||||
|
LEGO1/mxstreamprovider.cpp
|
||||||
LEGO1/mxstring.cpp
|
LEGO1/mxstring.cpp
|
||||||
LEGO1/mxstringlist.cpp
|
LEGO1/mxstringlist.cpp
|
||||||
LEGO1/mxthread.cpp
|
LEGO1/mxthread.cpp
|
||||||
|
|
|
@ -734,7 +734,7 @@ inline void IsleApp::Tick(BOOL sleepIfNotNextFrame)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
ds.SetAtomId(stream->atom);
|
ds.SetAtomId(stream->GetAtom());
|
||||||
ds.SetUnknown24(-1);
|
ds.SetUnknown24(-1);
|
||||||
ds.SetObjectId(0);
|
ds.SetObjectId(0);
|
||||||
VideoManager()->EnableFullScreenMovie(TRUE, TRUE);
|
VideoManager()->EnableFullScreenMovie(TRUE, TRUE);
|
||||||
|
@ -743,7 +743,7 @@ inline void IsleApp::Tick(BOOL sleepIfNotNextFrame)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
ds.SetAtomId(stream->atom);
|
ds.SetAtomId(stream->GetAtom());
|
||||||
ds.SetUnknown24(-1);
|
ds.SetUnknown24(-1);
|
||||||
ds.SetObjectId(0);
|
ds.SetObjectId(0);
|
||||||
if (Start(&ds) != SUCCESS) {
|
if (Start(&ds) != SUCCESS) {
|
||||||
|
|
|
@ -1,3 +1,25 @@
|
||||||
#include "mxramstreamcontroller.h"
|
#include "mxramstreamcontroller.h"
|
||||||
|
#include "mxramstreamprovider.h"
|
||||||
|
|
||||||
DECOMP_SIZE_ASSERT(MxRAMStreamController, 0x98);
|
DECOMP_SIZE_ASSERT(MxRAMStreamController, 0x98);
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100c6110 STUB
|
||||||
|
MxResult MxRAMStreamController::Open(const char *p_filename)
|
||||||
|
{
|
||||||
|
// TODO STUB
|
||||||
|
return FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100c6210 STUB
|
||||||
|
MxResult MxRAMStreamController::vtable0x20(MxDSAction* p_action)
|
||||||
|
{
|
||||||
|
// TODO STUB
|
||||||
|
return FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100c6320 STUB
|
||||||
|
MxResult MxRAMStreamController::vtable0x24(undefined4 p_unknown)
|
||||||
|
{
|
||||||
|
// TODO STUB
|
||||||
|
return FAILURE;
|
||||||
|
}
|
||||||
|
|
|
@ -11,6 +11,23 @@ class MxRAMStreamController : public MxStreamController
|
||||||
public:
|
public:
|
||||||
inline MxRAMStreamController() {}
|
inline MxRAMStreamController() {}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100b9430
|
||||||
|
inline virtual const char *ClassName() const override // vtable+0xc
|
||||||
|
{
|
||||||
|
// 0x10102130
|
||||||
|
return "MxRAMStreamController";
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100b9440
|
||||||
|
inline virtual MxBool IsA(const char *name) const override // vtable+0x10
|
||||||
|
{
|
||||||
|
return !strcmp(name, MxRAMStreamController::ClassName()) || !strcmp(name, MxStreamController::ClassName()) || MxCore::IsA(name);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual MxResult Open(const char *p_filename) override;
|
||||||
|
virtual MxResult vtable0x20(MxDSAction* p_action) override;
|
||||||
|
virtual MxResult vtable0x24(undefined4 p_unknown) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
MxDSBuffer m_buffer;
|
MxDSBuffer m_buffer;
|
||||||
|
|
||||||
|
|
59
LEGO1/mxramstreamprovider.cpp
Normal file
59
LEGO1/mxramstreamprovider.cpp
Normal file
|
@ -0,0 +1,59 @@
|
||||||
|
#include "mxramstreamprovider.h"
|
||||||
|
#include "decomp.h"
|
||||||
|
|
||||||
|
DECOMP_SIZE_ASSERT(MxRAMStreamProvider, 0x24);
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100d0730
|
||||||
|
MxRAMStreamProvider::MxRAMStreamProvider()
|
||||||
|
{
|
||||||
|
m_bufferSize = 0;
|
||||||
|
m_fileSize = 0;
|
||||||
|
m_pBufferOfFileSize = NULL;
|
||||||
|
m_lengthInDWords = 0;
|
||||||
|
m_bufferForDWords = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100d0a50
|
||||||
|
MxRAMStreamProvider::~MxRAMStreamProvider()
|
||||||
|
{
|
||||||
|
m_bufferSize = 0;
|
||||||
|
m_fileSize = 0;
|
||||||
|
|
||||||
|
free(m_pBufferOfFileSize);
|
||||||
|
m_pBufferOfFileSize = NULL;
|
||||||
|
|
||||||
|
m_lengthInDWords = 0;
|
||||||
|
|
||||||
|
free(m_bufferForDWords);
|
||||||
|
m_bufferForDWords = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100d0ae0 STUB
|
||||||
|
MxResult MxRAMStreamProvider::SetResourceToGet(void* p_resource)
|
||||||
|
{
|
||||||
|
return FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100d0930
|
||||||
|
MxU32 MxRAMStreamProvider::GetFileSize()
|
||||||
|
{
|
||||||
|
return m_fileSize;
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100d0940
|
||||||
|
MxU32 MxRAMStreamProvider::vtable0x1C()
|
||||||
|
{
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100d0950
|
||||||
|
MxU32 MxRAMStreamProvider::GetLengthInDWords()
|
||||||
|
{
|
||||||
|
return m_lengthInDWords;
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100d0960
|
||||||
|
void* MxRAMStreamProvider::GetBufferForDWords()
|
||||||
|
{
|
||||||
|
return m_bufferForDWords;
|
||||||
|
}
|
|
@ -6,7 +6,22 @@
|
||||||
// VTABLE 0x100dd0d0
|
// VTABLE 0x100dd0d0
|
||||||
class MxRAMStreamProvider : public MxStreamProvider
|
class MxRAMStreamProvider : public MxStreamProvider
|
||||||
{
|
{
|
||||||
|
public:
|
||||||
|
MxRAMStreamProvider();
|
||||||
|
virtual ~MxRAMStreamProvider() override;
|
||||||
|
|
||||||
|
virtual MxResult SetResourceToGet(void* p_resource) override; //vtable+0x14
|
||||||
|
virtual MxU32 GetFileSize() override; //vtable+0x18
|
||||||
|
virtual MxU32 vtable0x1C() override; //vtable+0x1c
|
||||||
|
virtual MxU32 GetLengthInDWords() override; //vtable+0x24
|
||||||
|
virtual void* GetBufferForDWords() override; //vtable+0x28
|
||||||
|
|
||||||
|
protected:
|
||||||
|
MxU32 m_bufferSize;
|
||||||
|
MxU32 m_fileSize;
|
||||||
|
void* m_pBufferOfFileSize;
|
||||||
|
MxU32 m_lengthInDWords;
|
||||||
|
void* m_bufferForDWords;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // MXRAMSTREAMPROVIDER_H
|
#endif // MXRAMSTREAMPROVIDER_H
|
||||||
|
|
|
@ -46,8 +46,33 @@ MxResult MxStreamController::vtable0x1C(undefined4 p_unknown, undefined4 p_unkno
|
||||||
}
|
}
|
||||||
|
|
||||||
// OFFSET: LEGO1 0x100c1690 STUB
|
// OFFSET: LEGO1 0x100c1690 STUB
|
||||||
MxResult MxStreamController::vtable0x20(MxDSAction* action)
|
MxResult MxStreamController::vtable0x20(MxDSAction* p_action)
|
||||||
{
|
{
|
||||||
// TODO STUB
|
// TODO STUB
|
||||||
return FAILURE;
|
return FAILURE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100c1740 STUB
|
||||||
|
MxResult MxStreamController::vtable0x24(undefined4 p_unknown)
|
||||||
|
{
|
||||||
|
// TODO STUB
|
||||||
|
return FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100b9420
|
||||||
|
MxResult MxStreamController::vtable0x28()
|
||||||
|
{
|
||||||
|
return SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100c1c10 STUB
|
||||||
|
MxResult MxStreamController::vtable0x2c(undefined4 p_unknown1, undefined4 p_unknow2)
|
||||||
|
{
|
||||||
|
return FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100c1ce0 STUB
|
||||||
|
MxResult MxStreamController::vtable0x30(undefined4 p_unknown)
|
||||||
|
{
|
||||||
|
return FAILURE;
|
||||||
|
}
|
||||||
|
|
|
@ -33,14 +33,20 @@ class MxStreamController : public MxCore
|
||||||
virtual MxResult Open(const char *p_filename); // vtable+0x14
|
virtual MxResult Open(const char *p_filename); // vtable+0x14
|
||||||
virtual MxResult vtable0x18(undefined4 p_unknown, undefined4 p_unknown2); //vtable+0x18
|
virtual MxResult vtable0x18(undefined4 p_unknown, undefined4 p_unknown2); //vtable+0x18
|
||||||
virtual MxResult vtable0x1C(undefined4 p_unknown, undefined4 p_unknown2); //vtable+0x1c
|
virtual MxResult vtable0x1C(undefined4 p_unknown, undefined4 p_unknown2); //vtable+0x1c
|
||||||
virtual MxResult vtable0x20(MxDSAction* action); //vtable+0x20
|
virtual MxResult vtable0x20(MxDSAction* p_action); //vtable+0x20
|
||||||
|
virtual MxResult vtable0x24(undefined4 p_unknown); //vtable+0x24
|
||||||
|
virtual MxResult vtable0x28(); //vtable+0x28
|
||||||
|
virtual MxResult vtable0x2c(undefined4 p_unknown1, undefined4 p_unknow2); //vtable+0x2c
|
||||||
|
virtual MxResult vtable0x30(undefined4 p_unknown); //vtable+0x30
|
||||||
|
|
||||||
MxBool FUN_100c20d0(MxDSObject &p_obj);
|
MxBool FUN_100c20d0(MxDSObject &p_obj);
|
||||||
|
|
||||||
|
inline MxAtomId &GetAtom() { return atom; };
|
||||||
|
protected:
|
||||||
MxCriticalSection m_criticalSection;
|
MxCriticalSection m_criticalSection;
|
||||||
MxAtomId atom;
|
MxAtomId atom;
|
||||||
int m_unk28;
|
undefined4 m_unk28; // MxStreamProvider*
|
||||||
int m_unk2c;
|
undefined4 m_unk2c;
|
||||||
undefined m_unk30[0x34];
|
undefined m_unk30[0x34];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -80,7 +80,7 @@ MxLong MxStreamer::Close(const char *p)
|
||||||
for (list<MxStreamController *>::iterator it = m_openStreams.begin(); it != m_openStreams.end(); it++) {
|
for (list<MxStreamController *>::iterator it = m_openStreams.begin(); it != m_openStreams.end(); it++) {
|
||||||
MxStreamController *c = *it;
|
MxStreamController *c = *it;
|
||||||
|
|
||||||
if (!p || !strcmp(p, c->atom.GetInternal())) {
|
if (!p || !strcmp(p, c->GetAtom().GetInternal())) {
|
||||||
m_openStreams.erase(it);
|
m_openStreams.erase(it);
|
||||||
|
|
||||||
if (!c->FUN_100c20d0(ds)) {
|
if (!c->FUN_100c20d0(ds)) {
|
||||||
|
@ -109,7 +109,7 @@ MxStreamController *MxStreamer::GetOpenStream(const char *p_name)
|
||||||
{
|
{
|
||||||
for (list<MxStreamController *>::iterator it = m_openStreams.begin(); it != m_openStreams.end(); it++) {
|
for (list<MxStreamController *>::iterator it = m_openStreams.begin(); it != m_openStreams.end(); it++) {
|
||||||
MxStreamController *c = *it;
|
MxStreamController *c = *it;
|
||||||
MxAtomId &atom = c->atom;
|
MxAtomId &atom = c->GetAtom();
|
||||||
if (p_name) {
|
if (p_name) {
|
||||||
if (!strcmp(atom.GetInternal(), p_name)) {
|
if (!strcmp(atom.GetInternal(), p_name)) {
|
||||||
return *it;
|
return *it;
|
||||||
|
|
17
LEGO1/mxstreamprovider.cpp
Normal file
17
LEGO1/mxstreamprovider.cpp
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
#include "decomp.h"
|
||||||
|
#include "mxstreamprovider.h"
|
||||||
|
|
||||||
|
DECOMP_SIZE_ASSERT(MxStreamProvider, 0x10);
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100d07c0
|
||||||
|
MxResult MxStreamProvider::SetResourceToGet(void* p_resource)
|
||||||
|
{
|
||||||
|
m_pLookup = p_resource;
|
||||||
|
return SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100d07d0
|
||||||
|
void MxStreamProvider::vtable0x20(undefined4 p_unknown1)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
|
@ -1,17 +1,16 @@
|
||||||
#ifndef MXSTREAMPROVIDER_H
|
#ifndef MXSTREAMPROVIDER_H
|
||||||
#define MXSTREAMPROVIDER_H
|
#define MXSTREAMPROVIDER_H
|
||||||
|
|
||||||
|
#include "decomp.h"
|
||||||
#include "mxcore.h"
|
#include "mxcore.h"
|
||||||
#include "mxdsfile.h"
|
#include "mxdsfile.h"
|
||||||
|
|
||||||
// VTABLE 0x100dd100
|
// VTABLE 0x100dd100
|
||||||
|
// SIZE 0x10
|
||||||
class MxStreamProvider : public MxCore
|
class MxStreamProvider : public MxCore
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
inline MxStreamProvider() {
|
inline MxStreamProvider() : m_pLookup(NULL), m_pFile(NULL) {}
|
||||||
this->m_pLookup = NULL;
|
|
||||||
this->m_pFile = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
// OFFSET: LEGO1 0x100d07e0
|
// OFFSET: LEGO1 0x100d07e0
|
||||||
inline virtual const char *ClassName() const override // vtable+0x0c
|
inline virtual const char *ClassName() const override // vtable+0x0c
|
||||||
|
@ -25,6 +24,13 @@ class MxStreamProvider : public MxCore
|
||||||
return !strcmp(name, MxStreamProvider::ClassName()) || MxCore::IsA(name);
|
return !strcmp(name, MxStreamProvider::ClassName()) || MxCore::IsA(name);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
virtual MxResult SetResourceToGet(void* p_resource); //vtable+0x14
|
||||||
|
virtual MxU32 GetFileSize() = 0; //vtable+0x18
|
||||||
|
virtual MxU32 vtable0x1C() = 0; //vtable+0x1c
|
||||||
|
virtual void vtable0x20(undefined4 p_unknown1); //vtable+0x20
|
||||||
|
virtual MxU32 GetLengthInDWords() = 0; //vtable+0x24
|
||||||
|
virtual void* GetBufferForDWords() = 0; //vtable+0x28
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void *m_pLookup;
|
void *m_pLookup;
|
||||||
MxDSFile* m_pFile;
|
MxDSFile* m_pFile;
|
||||||
|
|
Loading…
Reference in a new issue