Match MxDSFile scalar ddtor, add annotations (#523)

This commit is contained in:
Christian Semmler 2024-02-03 11:33:22 -05:00 committed by GitHub
parent 83e116defc
commit f0ea8850c4
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
4 changed files with 32 additions and 19 deletions

View file

@ -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>)

View file

@ -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

View file

@ -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();

View file

@ -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;