mirror of
https://github.com/isledecomp/isle.git
synced 2026-01-12 11:11:16 +00:00
100% Match of MxDSFile
* ...almost, MxDSFile::Open is still not quite matching but all of the other methods are 100% matching. * Turns out that most of the virtual methods and some of the members are actually on the MxDSSource base class, which I've pulled out as part of this. * In order to implement the methods I added the MXIOINFO class, which seems to be a thin wrapper around the MMIOINFO windows structure. We can tell this because MMIOINFO::~MMIOINFO was included in the DLL exports, and calls down to a function which deconstructs something looking exactly like MMIOINFO.
This commit is contained in:
parent
64d2b9e02b
commit
92135cf15a
@ -1,6 +1,139 @@
|
||||
#include "mxdsfile.h"
|
||||
|
||||
#include "stdio.h"
|
||||
|
||||
#define SI_MAJOR_VERSION 2
|
||||
#define SI_MINOR_VERSION 2
|
||||
|
||||
// OFFSET: LEGO1 0x100bffd0
|
||||
void MxDSSource::SomethingWhichCallsRead(void* pUnknownObject)
|
||||
{
|
||||
// TODO: Calls read, reading into a buffer somewhere in pUnknownObject.
|
||||
Read(NULL, 0);
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100bfff0
|
||||
long MxDSSource::GetLengthInDWords()
|
||||
{
|
||||
return m_lengthInDWords;
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100cc4b0
|
||||
MxDSFile::MxDSFile(const char *filename, unsigned long skipReadingChunks)
|
||||
{
|
||||
m_filename = filename;
|
||||
m_skipReadingChunks = skipReadingChunks;
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100bfed0
|
||||
MxDSFile::~MxDSFile()
|
||||
{
|
||||
Close();
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100cc590
|
||||
long MxDSFile::Open(unsigned long uStyle)
|
||||
{
|
||||
// No idea what's stopping this one matching, but I'm pretty
|
||||
// confident it has the correct behavior.
|
||||
memset(&m_io, 0, sizeof(MXIOINFO));
|
||||
if (m_io.Open(m_filename.Data(), uStyle) != 0) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
m_io.SetBuffer(NULL, 0);
|
||||
m_position = 0;
|
||||
|
||||
long longResult = 1;
|
||||
if (m_skipReadingChunks == 0)
|
||||
{
|
||||
longResult = ReadChunks();
|
||||
}
|
||||
if (longResult != 0)
|
||||
{
|
||||
Close(); // vtable + 0x18
|
||||
return longResult;
|
||||
}
|
||||
Seek(0, 0); // vtable + 0x24
|
||||
return 0;
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100cc780
|
||||
long MxDSFile::Read(unsigned char *pch, unsigned long cch)
|
||||
{
|
||||
if (m_io.Read((char*)pch, cch) != cch)
|
||||
return -1;
|
||||
|
||||
m_position += cch;
|
||||
return 0;
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100cc620
|
||||
long MxDSFile::ReadChunks()
|
||||
{
|
||||
_MMCKINFO topChunk;
|
||||
_MMCKINFO childChunk;
|
||||
char tempBuffer[80];
|
||||
|
||||
topChunk.fccType = 0x494e4d4f;
|
||||
if (m_io.Descend(&topChunk, NULL, MMIO_FINDRIFF) != 0) {
|
||||
return -1;
|
||||
}
|
||||
childChunk.ckid = 0x6448784d;
|
||||
if (m_io.Descend(&childChunk, &topChunk, 0) != 0) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
m_io.Read((char*)&m_header, 0xc);
|
||||
if ((m_header.majorVersion == SI_MAJOR_VERSION) && (m_header.minorVersion == SI_MINOR_VERSION))
|
||||
{
|
||||
childChunk.ckid = 0x664f784d;
|
||||
if (m_io.Descend(&childChunk, &topChunk, 0) != 0) {
|
||||
return -1;
|
||||
}
|
||||
unsigned long* pLengthInDWords = &m_lengthInDWords;
|
||||
m_io.Read((char *)pLengthInDWords, 4);
|
||||
m_pBuffer = malloc(*pLengthInDWords * 4);
|
||||
m_io.Read((char*)m_pBuffer, *pLengthInDWords * 4);
|
||||
return 0;
|
||||
}
|
||||
else
|
||||
{
|
||||
sprintf(tempBuffer, "Wrong SI file version. %d.%d expected.", SI_MAJOR_VERSION, SI_MINOR_VERSION);
|
||||
MessageBoxA(NULL, tempBuffer, NULL, 0x10);
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100cc7b0
|
||||
long MxDSFile::Seek(long lOffset, int iOrigin)
|
||||
{
|
||||
return (m_position = m_io.Seek(lOffset, iOrigin)) == 0xFFFFFFFF ? -1 : 0;
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100cc7e0
|
||||
unsigned long MxDSFile::GetBufferSize()
|
||||
{
|
||||
return this->m_buffersize;
|
||||
return m_header.bufferSize;
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100cc7f0
|
||||
unsigned long MxDSFile::GetStreamBuffersNum()
|
||||
{
|
||||
return m_header.streamBuffersNum;
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100cc740
|
||||
long MxDSFile::Close()
|
||||
{
|
||||
m_io.Close(0);
|
||||
m_position = -1;
|
||||
memset(&m_header, 0, sizeof(m_header));
|
||||
if (m_lengthInDWords != 0)
|
||||
{
|
||||
m_lengthInDWords = 0;
|
||||
free(m_pBuffer);
|
||||
m_pBuffer = NULL;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
@ -1,20 +1,46 @@
|
||||
#ifndef MXDSFILE_H
|
||||
#define MXDSFILE_H
|
||||
|
||||
class MxDSFile
|
||||
#include "mxcore.h"
|
||||
#include "mxstring.h"
|
||||
#include "mxioinfo.h"
|
||||
#include "mxdssource.h"
|
||||
class MxDSFile : public MxDSSource
|
||||
{
|
||||
public:
|
||||
__declspec(dllexport) MxDSFile(const char *,unsigned long);
|
||||
__declspec(dllexport) virtual ~MxDSFile();
|
||||
__declspec(dllexport) virtual long Close();
|
||||
__declspec(dllexport) virtual unsigned long GetBufferSize();
|
||||
__declspec(dllexport) virtual unsigned long GetStreamBuffersNum();
|
||||
__declspec(dllexport) virtual long Open(unsigned long);
|
||||
__declspec(dllexport) virtual long Read(unsigned char *,unsigned long);
|
||||
__declspec(dllexport) virtual long Seek(long,int);
|
||||
__declspec(dllexport) MxDSFile(const char *filename, unsigned long skipReadingChunks);
|
||||
__declspec(dllexport) ~MxDSFile();
|
||||
__declspec(dllexport) long Open(unsigned long);
|
||||
__declspec(dllexport) long Close();
|
||||
__declspec(dllexport) long Read(unsigned char *,unsigned long);
|
||||
__declspec(dllexport) long Seek(long,int);
|
||||
__declspec(dllexport) unsigned long GetBufferSize();
|
||||
__declspec(dllexport) unsigned long GetStreamBuffersNum();
|
||||
|
||||
private:
|
||||
char m_unknown[0x70];
|
||||
unsigned long m_buffersize;
|
||||
long ReadChunks();
|
||||
struct ChunkHeader {
|
||||
ChunkHeader()
|
||||
: majorVersion(0)
|
||||
, minorVersion(0)
|
||||
, bufferSize(0)
|
||||
, streamBuffersNum(0)
|
||||
{}
|
||||
|
||||
unsigned short majorVersion;
|
||||
unsigned short minorVersion;
|
||||
unsigned long bufferSize;
|
||||
short streamBuffersNum;
|
||||
short reserved;
|
||||
};
|
||||
|
||||
MxString m_filename;
|
||||
MXIOINFO m_io;
|
||||
ChunkHeader m_header;
|
||||
|
||||
// If false, read chunks immediately on open, otherwise
|
||||
// skip reading chunks until ReadChunks is explicitly called.
|
||||
unsigned long m_skipReadingChunks;
|
||||
};
|
||||
|
||||
#endif // MXDSFILE_H
|
||||
|
||||
30
LEGO1/mxdssource.h
Normal file
30
LEGO1/mxdssource.h
Normal file
@ -0,0 +1,30 @@
|
||||
#ifndef MXDSSOURCE_H
|
||||
#define MXDSSOURCE_H
|
||||
|
||||
#include "mxcore.h"
|
||||
|
||||
class MxDSSource : public MxCore
|
||||
{
|
||||
public:
|
||||
MxDSSource()
|
||||
: m_lengthInDWords(0)
|
||||
, m_pBuffer(0)
|
||||
, m_position(-1)
|
||||
{}
|
||||
|
||||
virtual long Open(unsigned long) = 0;
|
||||
virtual long Close() = 0;
|
||||
virtual void SomethingWhichCallsRead(void* pUnknownObject);
|
||||
virtual long Read(unsigned char *, unsigned long) = 0;
|
||||
virtual long Seek(long, int) = 0;
|
||||
virtual unsigned long GetBufferSize() = 0;
|
||||
virtual unsigned long GetStreamBuffersNum() = 0;
|
||||
virtual long GetLengthInDWords();
|
||||
|
||||
protected:
|
||||
unsigned long m_lengthInDWords;
|
||||
void* m_pBuffer;
|
||||
long m_position;
|
||||
};
|
||||
|
||||
#endif // MXDSSOURCE_H
|
||||
49
LEGO1/mxioinfo.cpp
Normal file
49
LEGO1/mxioinfo.cpp
Normal file
@ -0,0 +1,49 @@
|
||||
#include "mxioinfo.h"
|
||||
|
||||
// OFFSET: LEGO1 0x100cc800
|
||||
MXIOINFO::MXIOINFO()
|
||||
{
|
||||
memset(&m_info, 0, sizeof(MMIOINFO));
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100cc820
|
||||
MXIOINFO::~MXIOINFO()
|
||||
{
|
||||
m_info.cchBuffer = 0;
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100cc830
|
||||
unsigned short MXIOINFO::Open(const char *filename, DWORD fdwOpen)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100cc8e0
|
||||
void MXIOINFO::Close(long arg)
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100cc930
|
||||
unsigned long MXIOINFO::Read(HPSTR pch, LONG cch)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100cca00
|
||||
LONG MXIOINFO::Seek(LONG lOffset, int iOrigin)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100ccbc0
|
||||
void MXIOINFO::SetBuffer(LPSTR pchBuffer, LONG cchBuffer)
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
// OFFSET: LEGO1 0x100cce60
|
||||
unsigned short MXIOINFO::Descend(LPMMCKINFO pmmcki, const MMCKINFO *pmmckiParent, UINT fuDescend)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
@ -1,10 +1,22 @@
|
||||
#ifndef MXIOINFO_H
|
||||
#define MXIOINFO_H
|
||||
|
||||
#include "windows.h"
|
||||
#include "mmsystem.h"
|
||||
class MXIOINFO
|
||||
{
|
||||
public:
|
||||
MXIOINFO();
|
||||
__declspec(dllexport) ~MXIOINFO();
|
||||
|
||||
unsigned short Open(const char *filename, DWORD fdwOpen);
|
||||
void Close(long arg);
|
||||
LONG Seek(LONG lOffset, int iOrigin);
|
||||
unsigned long Read(HPSTR pch, LONG cch);
|
||||
void SetBuffer(LPSTR pchBuffer, LONG cchBuffer);
|
||||
unsigned short Descend(LPMMCKINFO pmmcki, const MMCKINFO *pmmckiParent, UINT fuDescend);
|
||||
|
||||
MMIOINFO m_info;
|
||||
};
|
||||
|
||||
#endif // MXIOINFO_H
|
||||
|
||||
@ -16,6 +16,8 @@ class MxString : public MxCore
|
||||
void ToLowerCase();
|
||||
const MxString &operator=(MxString *);
|
||||
|
||||
inline const char *Data() const { return m_data; }
|
||||
|
||||
private:
|
||||
char *m_data;
|
||||
unsigned short m_length;
|
||||
|
||||
41
isle.mak
41
isle.mak
@ -61,7 +61,9 @@ CLEAN :
|
||||
-@erase "$(INTDIR)\mxautolocker.obj"
|
||||
-@erase "$(INTDIR)\mxcore.obj"
|
||||
-@erase "$(INTDIR)\mxcriticalsection.obj"
|
||||
-@erase "$(INTDIR)\mxdsfile.obj"
|
||||
-@erase "$(INTDIR)\mxdsobject.obj"
|
||||
-@erase "$(INTDIR)\mxioinfo.obj"
|
||||
-@erase "$(INTDIR)\mxomni.obj"
|
||||
-@erase "$(INTDIR)\mxomnicreateflags.obj"
|
||||
-@erase "$(INTDIR)\mxomnicreateparam.obj"
|
||||
@ -138,7 +140,9 @@ LINK32_OBJS= \
|
||||
"$(INTDIR)\mxautolocker.obj" \
|
||||
"$(INTDIR)\mxcore.obj" \
|
||||
"$(INTDIR)\mxcriticalsection.obj" \
|
||||
"$(INTDIR)\mxdsfile.obj" \
|
||||
"$(INTDIR)\mxdsobject.obj" \
|
||||
"$(INTDIR)\mxioinfo.obj" \
|
||||
"$(INTDIR)\mxomni.obj" \
|
||||
"$(INTDIR)\mxomnicreateflags.obj" \
|
||||
"$(INTDIR)\mxomnicreateparam.obj" \
|
||||
@ -181,7 +185,9 @@ CLEAN :
|
||||
-@erase "$(INTDIR)\mxautolocker.obj"
|
||||
-@erase "$(INTDIR)\mxcore.obj"
|
||||
-@erase "$(INTDIR)\mxcriticalsection.obj"
|
||||
-@erase "$(INTDIR)\mxdsfile.obj"
|
||||
-@erase "$(INTDIR)\mxdsobject.obj"
|
||||
-@erase "$(INTDIR)\mxioinfo.obj"
|
||||
-@erase "$(INTDIR)\mxomni.obj"
|
||||
-@erase "$(INTDIR)\mxomnicreateflags.obj"
|
||||
-@erase "$(INTDIR)\mxomnicreateparam.obj"
|
||||
@ -260,7 +266,9 @@ LINK32_OBJS= \
|
||||
"$(INTDIR)\mxautolocker.obj" \
|
||||
"$(INTDIR)\mxcore.obj" \
|
||||
"$(INTDIR)\mxcriticalsection.obj" \
|
||||
"$(INTDIR)\mxdsfile.obj" \
|
||||
"$(INTDIR)\mxdsobject.obj" \
|
||||
"$(INTDIR)\mxioinfo.obj" \
|
||||
"$(INTDIR)\mxomni.obj" \
|
||||
"$(INTDIR)\mxomnicreateflags.obj" \
|
||||
"$(INTDIR)\mxomnicreateparam.obj" \
|
||||
@ -885,6 +893,32 @@ DEP_CPP_MXPAL=\
|
||||
$(CPP) $(CPP_PROJ) $(SOURCE)
|
||||
|
||||
|
||||
# End Source File
|
||||
################################################################################
|
||||
# Begin Source File
|
||||
|
||||
SOURCE=.\LEGO1\mxioinfo.cpp
|
||||
DEP_CPP_MXIOI=\
|
||||
".\LEGO1\mxioinfo.h"\
|
||||
|
||||
|
||||
"$(INTDIR)\mxioinfo.obj" : $(SOURCE) $(DEP_CPP_MXIOI) "$(INTDIR)"
|
||||
$(CPP) $(CPP_PROJ) $(SOURCE)
|
||||
|
||||
|
||||
# End Source File
|
||||
################################################################################
|
||||
# Begin Source File
|
||||
|
||||
SOURCE=.\LEGO1\mxdsfile.cpp
|
||||
DEP_CPP_MXDSF=\
|
||||
".\LEGO1\mxdsfile.h"\
|
||||
|
||||
|
||||
"$(INTDIR)\mxdsfile.obj" : $(SOURCE) $(DEP_CPP_MXDSF) "$(INTDIR)"
|
||||
$(CPP) $(CPP_PROJ) $(SOURCE)
|
||||
|
||||
|
||||
# End Source File
|
||||
# End Target
|
||||
################################################################################
|
||||
@ -982,21 +1016,28 @@ SOURCE=.\ISLE\main.cpp
|
||||
DEP_CPP_MAIN_=\
|
||||
".\ISLE\define.h"\
|
||||
".\ISLE\isle.h"\
|
||||
".\ISLE\res\resource.h"\
|
||||
".\LEGO1\lego3dmanager.h"\
|
||||
".\LEGO1\lego3dview.h"\
|
||||
".\LEGO1\legoanimationmanager.h"\
|
||||
".\LEGO1\legobuildingmanager.h"\
|
||||
".\LEGO1\legoentity.h"\
|
||||
".\LEGO1\legogamestate.h"\
|
||||
".\LEGO1\legoinc.h"\
|
||||
".\LEGO1\legoinputmanager.h"\
|
||||
".\LEGO1\legomodelpresenter.h"\
|
||||
".\LEGO1\legonavcontroller.h"\
|
||||
".\LEGO1\legoomni.h"\
|
||||
".\LEGO1\legopartpresenter.h"\
|
||||
".\LEGO1\legoroi.h"\
|
||||
".\LEGO1\legovideomanager.h"\
|
||||
".\LEGO1\legoworldpresenter.h"\
|
||||
".\LEGO1\mxatomid.h"\
|
||||
".\LEGO1\mxbackgroundaudiomanager.h"\
|
||||
".\LEGO1\mxbool.h"\
|
||||
".\LEGO1\mxcore.h"\
|
||||
".\LEGO1\mxcriticalsection.h"\
|
||||
".\LEGO1\mxdirectdraw.h"\
|
||||
".\LEGO1\mxdsaction.h"\
|
||||
".\LEGO1\mxdsfile.h"\
|
||||
".\LEGO1\mxdsobject.h"\
|
||||
|
||||
Loading…
Reference in New Issue
Block a user