mirror of
https://github.com/isledecomp/isle.git
synced 2025-10-23 00:14:22 +00:00
MxDiskStreamController vtable (#197)
* mxdiskstreamcontroller vtable + MxStreamController::vtable0x20
* stub MxDiskStreamController::Open
* MxDiskStreamProvider
* MxNextActionDataStart
* Revert "MxNextActionDataStart"
This reverts commit 41e8cfa2f1
.
* Match MxStreamController::vtable0x20
---------
Co-authored-by: Christian Semmler <mail@csemmler.com>
This commit is contained in:
@@ -16,6 +16,52 @@ MxDiskStreamController::~MxDiskStreamController()
|
|||||||
MxResult MxDiskStreamController::Tickle()
|
MxResult MxDiskStreamController::Tickle()
|
||||||
{
|
{
|
||||||
// TODO
|
// TODO
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100c7790 STUB
|
||||||
|
MxResult MxDiskStreamController::Open(const char *p_filename)
|
||||||
|
{
|
||||||
|
// TODO
|
||||||
|
return FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100c7880
|
||||||
|
MxResult MxDiskStreamController::vtable0x18(undefined4 p_unknown, undefined4 p_unknown2)
|
||||||
|
{
|
||||||
|
return SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100c7ff0 STUB
|
||||||
|
MxResult MxDiskStreamController::vtable0x20(MxDSAction* p_action)
|
||||||
|
{
|
||||||
|
// TODO
|
||||||
|
return FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100c8160 STUB
|
||||||
|
MxResult MxDiskStreamController::vtable0x24(undefined4 p_unknown)
|
||||||
|
{
|
||||||
|
// TODO
|
||||||
|
return FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100c7ac0 STUB
|
||||||
|
MxResult MxDiskStreamController::vtable0x28()
|
||||||
|
{
|
||||||
|
// TODO
|
||||||
|
return FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100c7c00 STUB
|
||||||
|
MxResult MxDiskStreamController::vtable0x30(undefined4 p_unknown)
|
||||||
|
{
|
||||||
|
// TODO
|
||||||
|
return FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100c7960
|
||||||
|
MxResult MxDiskStreamController::vtable0x34(undefined4 p_unknown)
|
||||||
|
{
|
||||||
|
return FAILURE;
|
||||||
|
}
|
||||||
|
@@ -15,6 +15,13 @@ public:
|
|||||||
virtual ~MxDiskStreamController() override;
|
virtual ~MxDiskStreamController() override;
|
||||||
|
|
||||||
virtual MxResult Tickle() override; // vtable+0x8
|
virtual MxResult Tickle() override; // vtable+0x8
|
||||||
|
virtual MxResult Open(const char *p_filename) override; // vtable+0x14
|
||||||
|
virtual MxResult vtable0x18(undefined4 p_unknown, undefined4 p_unknown2) override; //vtable+0x18
|
||||||
|
virtual MxResult vtable0x20(MxDSAction* p_action) override; //vtable+0x20
|
||||||
|
virtual MxResult vtable0x24(undefined4 p_unknown) override; //vtable+0x24
|
||||||
|
virtual MxResult vtable0x28() override; //vtable+0x28
|
||||||
|
virtual MxResult vtable0x30(undefined4 p_unknown) override; //vtable+0x30
|
||||||
|
virtual MxResult vtable0x34(undefined4 p_unknown); //vtable+0x34
|
||||||
|
|
||||||
// OFFSET: LEGO1 0x100c7360
|
// OFFSET: LEGO1 0x100c7360
|
||||||
inline virtual const char *ClassName() const override // vtable+0x0c
|
inline virtual const char *ClassName() const override // vtable+0x0c
|
||||||
|
@@ -45,4 +45,41 @@ MxResult MxDiskStreamProvider::WaitForWorkToComplete()
|
|||||||
void MxDiskStreamProvider::PerformWork()
|
void MxDiskStreamProvider::PerformWork()
|
||||||
{
|
{
|
||||||
// TODO
|
// TODO
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100d13d0 STUB
|
||||||
|
MxResult MxDiskStreamProvider::SetResourceToGet(void* p_resource)
|
||||||
|
{
|
||||||
|
// TODO
|
||||||
|
return FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100d1e90
|
||||||
|
MxU32 MxDiskStreamProvider::GetFileSize()
|
||||||
|
{
|
||||||
|
return m_pFile->GetBufferSize();
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100d1ea0
|
||||||
|
MxU32 MxDiskStreamProvider::GetStreamBuffersNum()
|
||||||
|
{
|
||||||
|
return m_pFile->GetStreamBuffersNum();
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100d15e0 STUB
|
||||||
|
void MxDiskStreamProvider::vtable0x20(undefined4 p_unknown1)
|
||||||
|
{
|
||||||
|
// TODO
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100d1eb0
|
||||||
|
MxU32 MxDiskStreamProvider::GetLengthInDWords()
|
||||||
|
{
|
||||||
|
return m_pFile->GetLengthInDWords();
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100d1ec0
|
||||||
|
MxU32* MxDiskStreamProvider::GetBufferForDWords()
|
||||||
|
{
|
||||||
|
return m_pFile->GetBuffer();
|
||||||
|
}
|
||||||
|
@@ -49,6 +49,13 @@ public:
|
|||||||
|
|
||||||
void PerformWork();
|
void PerformWork();
|
||||||
|
|
||||||
|
virtual MxResult SetResourceToGet(void* p_resource) override; //vtable+0x14
|
||||||
|
virtual MxU32 GetFileSize() override; //vtable+0x18
|
||||||
|
virtual MxU32 GetStreamBuffersNum() override; //vtable+0x1c
|
||||||
|
virtual void vtable0x20(undefined4 p_unknown1) override; //vtable+0x20
|
||||||
|
virtual MxU32 GetLengthInDWords() override; //vtable+0x24
|
||||||
|
virtual MxU32* GetBufferForDWords()override; //vtable+0x28
|
||||||
|
|
||||||
private:
|
private:
|
||||||
MxDiskStreamProviderThread m_thread; // 0x10
|
MxDiskStreamProviderThread m_thread; // 0x10
|
||||||
MxSemaphore m_busySemaphore; // 0x2c
|
MxSemaphore m_busySemaphore; // 0x2c
|
||||||
|
@@ -81,7 +81,7 @@ MxLong MxDSFile::ReadChunks()
|
|||||||
}
|
}
|
||||||
MxULong* pLengthInDWords = &m_lengthInDWords;
|
MxULong* pLengthInDWords = &m_lengthInDWords;
|
||||||
m_io.Read(pLengthInDWords, 4);
|
m_io.Read(pLengthInDWords, 4);
|
||||||
m_pBuffer = malloc(*pLengthInDWords * 4);
|
m_pBuffer = new MxU32[*pLengthInDWords];
|
||||||
m_io.Read(m_pBuffer, *pLengthInDWords * 4);
|
m_io.Read(m_pBuffer, *pLengthInDWords * 4);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@@ -120,7 +120,7 @@ MxLong MxDSFile::Close()
|
|||||||
if (m_lengthInDWords != 0)
|
if (m_lengthInDWords != 0)
|
||||||
{
|
{
|
||||||
m_lengthInDWords = 0;
|
m_lengthInDWords = 0;
|
||||||
free(m_pBuffer);
|
delete[] m_pBuffer;
|
||||||
m_pBuffer = NULL;
|
m_pBuffer = NULL;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
|
@@ -14,7 +14,7 @@ MxLong MxDSSource::GetLengthInDWords()
|
|||||||
}
|
}
|
||||||
|
|
||||||
// OFFSET: LEGO1 0x100c0000
|
// OFFSET: LEGO1 0x100c0000
|
||||||
void *MxDSSource::GetBuffer()
|
MxU32 *MxDSSource::GetBuffer()
|
||||||
{
|
{
|
||||||
return m_pBuffer;
|
return m_pBuffer;
|
||||||
}
|
}
|
@@ -34,11 +34,11 @@ public:
|
|||||||
virtual MxULong GetBufferSize() = 0;
|
virtual MxULong GetBufferSize() = 0;
|
||||||
virtual MxULong GetStreamBuffersNum() = 0;
|
virtual MxULong GetStreamBuffersNum() = 0;
|
||||||
virtual MxLong GetLengthInDWords();
|
virtual MxLong GetLengthInDWords();
|
||||||
virtual void* GetBuffer(); // 0x34
|
virtual MxU32* GetBuffer(); // 0x34
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
MxULong m_lengthInDWords;
|
MxULong m_lengthInDWords;
|
||||||
void* m_pBuffer;
|
MxU32* m_pBuffer;
|
||||||
MxLong m_position;
|
MxLong m_position;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@@ -41,7 +41,7 @@ MxU32 MxRAMStreamProvider::GetFileSize()
|
|||||||
}
|
}
|
||||||
|
|
||||||
// OFFSET: LEGO1 0x100d0940
|
// OFFSET: LEGO1 0x100d0940
|
||||||
MxU32 MxRAMStreamProvider::vtable0x1C()
|
MxU32 MxRAMStreamProvider::GetStreamBuffersNum()
|
||||||
{
|
{
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
@@ -53,7 +53,7 @@ MxU32 MxRAMStreamProvider::GetLengthInDWords()
|
|||||||
}
|
}
|
||||||
|
|
||||||
// OFFSET: LEGO1 0x100d0960
|
// OFFSET: LEGO1 0x100d0960
|
||||||
void* MxRAMStreamProvider::GetBufferForDWords()
|
MxU32* MxRAMStreamProvider::GetBufferForDWords()
|
||||||
{
|
{
|
||||||
return m_bufferForDWords;
|
return m_bufferForDWords;
|
||||||
}
|
}
|
||||||
|
@@ -9,19 +9,19 @@ class MxRAMStreamProvider : public MxStreamProvider
|
|||||||
public:
|
public:
|
||||||
MxRAMStreamProvider();
|
MxRAMStreamProvider();
|
||||||
virtual ~MxRAMStreamProvider() override;
|
virtual ~MxRAMStreamProvider() override;
|
||||||
|
|
||||||
virtual MxResult SetResourceToGet(void* p_resource) override; //vtable+0x14
|
virtual MxResult SetResourceToGet(void* p_resource) override; //vtable+0x14
|
||||||
virtual MxU32 GetFileSize() override; //vtable+0x18
|
virtual MxU32 GetFileSize() override; //vtable+0x18
|
||||||
virtual MxU32 vtable0x1C() override; //vtable+0x1c
|
virtual MxU32 GetStreamBuffersNum() override; //vtable+0x1c
|
||||||
virtual MxU32 GetLengthInDWords() override; //vtable+0x24
|
virtual MxU32 GetLengthInDWords() override; //vtable+0x24
|
||||||
virtual void* GetBufferForDWords() override; //vtable+0x28
|
virtual MxU32* GetBufferForDWords() override; //vtable+0x28
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
MxU32 m_bufferSize;
|
MxU32 m_bufferSize;
|
||||||
MxU32 m_fileSize;
|
MxU32 m_fileSize;
|
||||||
void* m_pBufferOfFileSize;
|
void* m_pBufferOfFileSize;
|
||||||
MxU32 m_lengthInDWords;
|
MxU32 m_lengthInDWords;
|
||||||
void* m_bufferForDWords;
|
MxU32* m_bufferForDWords;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // MXRAMSTREAMPROVIDER_H
|
#endif // MXRAMSTREAMPROVIDER_H
|
||||||
|
@@ -45,11 +45,26 @@ MxResult MxStreamController::vtable0x1C(undefined4 p_unknown, undefined4 p_unkno
|
|||||||
return FAILURE;
|
return FAILURE;
|
||||||
}
|
}
|
||||||
|
|
||||||
// OFFSET: LEGO1 0x100c1690 STUB
|
// OFFSET: LEGO1 0x100c1690
|
||||||
MxResult MxStreamController::vtable0x20(MxDSAction* p_action)
|
MxResult MxStreamController::vtable0x20(MxDSAction* p_action)
|
||||||
{
|
{
|
||||||
// TODO STUB
|
MxAutoLocker locker(&m_criticalSection);
|
||||||
return FAILURE;
|
|
||||||
|
MxResult result;
|
||||||
|
MxU32 offset = 0;
|
||||||
|
|
||||||
|
MxS32 objectId = p_action->GetObjectId();
|
||||||
|
MxStreamProvider *provider = m_provider;
|
||||||
|
|
||||||
|
if ((MxS32) provider->GetLengthInDWords() > objectId)
|
||||||
|
offset = provider->GetBufferForDWords()[objectId];
|
||||||
|
|
||||||
|
if (offset)
|
||||||
|
result = vtable0x2c(p_action, offset);
|
||||||
|
else
|
||||||
|
result = FAILURE;
|
||||||
|
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
// OFFSET: LEGO1 0x100c1740 STUB
|
// OFFSET: LEGO1 0x100c1740 STUB
|
||||||
@@ -66,7 +81,7 @@ MxResult MxStreamController::vtable0x28()
|
|||||||
}
|
}
|
||||||
|
|
||||||
// OFFSET: LEGO1 0x100c1c10 STUB
|
// OFFSET: LEGO1 0x100c1c10 STUB
|
||||||
MxResult MxStreamController::vtable0x2c(undefined4 p_unknown1, undefined4 p_unknow2)
|
MxResult MxStreamController::vtable0x2c(MxDSAction* p_action, MxU32 p_bufferval)
|
||||||
{
|
{
|
||||||
return FAILURE;
|
return FAILURE;
|
||||||
}
|
}
|
||||||
|
@@ -7,6 +7,7 @@
|
|||||||
#include "mxcore.h"
|
#include "mxcore.h"
|
||||||
#include "mxdsobject.h"
|
#include "mxdsobject.h"
|
||||||
#include "mxdsaction.h"
|
#include "mxdsaction.h"
|
||||||
|
#include "mxstreamprovider.h"
|
||||||
|
|
||||||
// VTABLE 0x100dc968
|
// VTABLE 0x100dc968
|
||||||
// SIZE 0x64
|
// SIZE 0x64
|
||||||
@@ -36,7 +37,7 @@ public:
|
|||||||
virtual MxResult vtable0x20(MxDSAction* p_action); //vtable+0x20
|
virtual MxResult vtable0x20(MxDSAction* p_action); //vtable+0x20
|
||||||
virtual MxResult vtable0x24(undefined4 p_unknown); //vtable+0x24
|
virtual MxResult vtable0x24(undefined4 p_unknown); //vtable+0x24
|
||||||
virtual MxResult vtable0x28(); //vtable+0x28
|
virtual MxResult vtable0x28(); //vtable+0x28
|
||||||
virtual MxResult vtable0x2c(undefined4 p_unknown1, undefined4 p_unknow2); //vtable+0x2c
|
virtual MxResult vtable0x2c(MxDSAction* p_action, MxU32 p_bufferval); //vtable+0x2c
|
||||||
virtual MxResult vtable0x30(undefined4 p_unknown); //vtable+0x30
|
virtual MxResult vtable0x30(undefined4 p_unknown); //vtable+0x30
|
||||||
|
|
||||||
MxBool FUN_100c20d0(MxDSObject &p_obj);
|
MxBool FUN_100c20d0(MxDSObject &p_obj);
|
||||||
@@ -45,7 +46,7 @@ public:
|
|||||||
protected:
|
protected:
|
||||||
MxCriticalSection m_criticalSection;
|
MxCriticalSection m_criticalSection;
|
||||||
MxAtomId atom;
|
MxAtomId atom;
|
||||||
undefined4 m_unk28; // MxStreamProvider*
|
MxStreamProvider* m_provider; // MxStreamProvider*
|
||||||
undefined4 m_unk2c;
|
undefined4 m_unk2c;
|
||||||
undefined m_unk30[0x34];
|
undefined m_unk30[0x34];
|
||||||
};
|
};
|
||||||
|
@@ -26,10 +26,10 @@ public:
|
|||||||
|
|
||||||
virtual MxResult SetResourceToGet(void* p_resource); //vtable+0x14
|
virtual MxResult SetResourceToGet(void* p_resource); //vtable+0x14
|
||||||
virtual MxU32 GetFileSize() = 0; //vtable+0x18
|
virtual MxU32 GetFileSize() = 0; //vtable+0x18
|
||||||
virtual MxU32 vtable0x1C() = 0; //vtable+0x1c
|
virtual MxU32 GetStreamBuffersNum() = 0; //vtable+0x1c
|
||||||
virtual void vtable0x20(undefined4 p_unknown1); //vtable+0x20
|
virtual void vtable0x20(undefined4 p_unknown1); //vtable+0x20
|
||||||
virtual MxU32 GetLengthInDWords() = 0; //vtable+0x24
|
virtual MxU32 GetLengthInDWords() = 0; //vtable+0x24
|
||||||
virtual void* GetBufferForDWords() = 0; //vtable+0x28
|
virtual MxU32* GetBufferForDWords() = 0; //vtable+0x28
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void *m_pLookup;
|
void *m_pLookup;
|
||||||
|
Reference in New Issue
Block a user