mirror of
https://github.com/isledecomp/isle.git
synced 2024-11-22 15:48:09 -05:00
Match MxDSFile scalar ddtor, add annotations (#523)
This commit is contained in:
parent
83e116defc
commit
f0ea8850c4
4 changed files with 32 additions and 19 deletions
|
@ -419,6 +419,8 @@ if (ISLE_BUILD_APP)
|
||||||
ISLE/define.cpp
|
ISLE/define.cpp
|
||||||
)
|
)
|
||||||
|
|
||||||
|
target_compile_definitions(isle PRIVATE ISLE_APP)
|
||||||
|
|
||||||
# Use internal DirectX 5 if required
|
# Use internal DirectX 5 if required
|
||||||
target_link_libraries(isle PRIVATE $<$<BOOL:${ISLE_USE_DX5}>:DirectX5::DirectX5>)
|
target_link_libraries(isle PRIVATE $<$<BOOL:${ISLE_USE_DX5}>:DirectX5::DirectX5>)
|
||||||
|
|
||||||
|
|
|
@ -9,10 +9,19 @@
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
|
|
||||||
// VTABLE: LEGO1 0x100dc890
|
// VTABLE: LEGO1 0x100dc890
|
||||||
|
// SIZE 0x7c
|
||||||
class MxDSFile : public MxDSSource {
|
class MxDSFile : public MxDSSource {
|
||||||
public:
|
public:
|
||||||
MxDSFile(const char* p_filename, MxULong p_skipReadingChunks);
|
MxDSFile(const char* p_filename, MxULong p_skipReadingChunks);
|
||||||
~MxDSFile() override; // vtable+0x00
|
|
||||||
|
#ifdef ISLE_APP
|
||||||
|
~MxDSFile() override { Close(); }
|
||||||
|
#else
|
||||||
|
// We have to explicitly use dllexport, otherwise this function cannot be exported,
|
||||||
|
// since it is inlined everywhere in LEGO1.DLL
|
||||||
|
// FUNCTION: LEGO1 0x100bfed0
|
||||||
|
__declspec(dllexport) ~MxDSFile() override { Close(); }
|
||||||
|
#endif
|
||||||
|
|
||||||
// FUNCTION: LEGO1 0x100c0120
|
// FUNCTION: LEGO1 0x100c0120
|
||||||
inline const char* ClassName() const override // vtable+0x0c
|
inline const char* ClassName() const override // vtable+0x0c
|
||||||
|
@ -41,25 +50,27 @@ class MxDSFile : public MxDSSource {
|
||||||
// SYNTHETIC: LEGO1 0x100c01e0
|
// SYNTHETIC: LEGO1 0x100c01e0
|
||||||
// MxDSFile::`scalar deleting destructor'
|
// MxDSFile::`scalar deleting destructor'
|
||||||
|
|
||||||
private:
|
// SIZE 0x0c
|
||||||
MxLong ReadChunks();
|
|
||||||
struct ChunkHeader {
|
struct ChunkHeader {
|
||||||
ChunkHeader() : m_majorVersion(0), m_minorVersion(0), m_bufferSize(0), m_streamBuffersNum(0) {}
|
ChunkHeader() : m_majorVersion(0), m_minorVersion(0), m_bufferSize(0), m_streamBuffersNum(0) {}
|
||||||
|
|
||||||
MxU16 m_majorVersion;
|
MxU16 m_majorVersion; // 0x00
|
||||||
MxU16 m_minorVersion;
|
MxU16 m_minorVersion; // 0x02
|
||||||
MxULong m_bufferSize;
|
MxULong m_bufferSize; // 0x04
|
||||||
MxS16 m_streamBuffersNum;
|
MxS16 m_streamBuffersNum; // 0x08
|
||||||
MxS16 m_reserved;
|
MxS16 m_reserved; // 0x0a
|
||||||
};
|
};
|
||||||
|
|
||||||
MxString m_filename;
|
private:
|
||||||
MXIOINFO m_io;
|
MxLong ReadChunks();
|
||||||
ChunkHeader m_header;
|
|
||||||
|
MxString m_filename; // 0x14
|
||||||
|
MXIOINFO m_io; // 0x24
|
||||||
|
ChunkHeader m_header; // 0x6c
|
||||||
|
|
||||||
// If false, read chunks immediately on open, otherwise
|
// If false, read chunks immediately on open, otherwise
|
||||||
// skip reading chunks until ReadChunks is explicitly called.
|
// skip reading chunks until ReadChunks is explicitly called.
|
||||||
MxULong m_skipReadingChunks;
|
MxULong m_skipReadingChunks; // 0x78
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // MXDSFILE_H
|
#endif // MXDSFILE_H
|
||||||
|
|
|
@ -9,6 +9,7 @@
|
||||||
#include <mmsystem.h>
|
#include <mmsystem.h>
|
||||||
// clang-format on
|
// clang-format on
|
||||||
|
|
||||||
|
// SIZE 0x48
|
||||||
class MXIOINFO {
|
class MXIOINFO {
|
||||||
public:
|
public:
|
||||||
MXIOINFO();
|
MXIOINFO();
|
||||||
|
|
|
@ -1,15 +1,14 @@
|
||||||
#include "mxdsfile.h"
|
#include "mxdsfile.h"
|
||||||
|
|
||||||
|
#include "decomp.h"
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
#define SI_MAJOR_VERSION 2
|
#define SI_MAJOR_VERSION 2
|
||||||
#define SI_MINOR_VERSION 2
|
#define SI_MINOR_VERSION 2
|
||||||
|
|
||||||
// FUNCTION: LEGO1 0x100bfed0
|
DECOMP_SIZE_ASSERT(MxDSFile::ChunkHeader, 0x0c)
|
||||||
MxDSFile::~MxDSFile()
|
DECOMP_SIZE_ASSERT(MxDSFile, 0x7c)
|
||||||
{
|
|
||||||
Close();
|
|
||||||
}
|
|
||||||
|
|
||||||
// FUNCTION: LEGO1 0x100cc4b0
|
// FUNCTION: LEGO1 0x100cc4b0
|
||||||
MxDSFile::MxDSFile(const char* p_filename, MxULong p_skipReadingChunks)
|
MxDSFile::MxDSFile(const char* p_filename, MxULong p_skipReadingChunks)
|
||||||
|
@ -37,10 +36,10 @@ MxLong MxDSFile::Open(MxULong p_uStyle)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (longResult != 0) {
|
if (longResult != 0) {
|
||||||
Close(); // vtable + 0x18
|
Close();
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
Seek(0, 0); // vtable + 0x24
|
Seek(0, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
return longResult;
|
return longResult;
|
||||||
|
|
Loading…
Reference in a new issue