Minor changes

This commit is contained in:
Christian Semmler 2024-01-24 11:36:07 -05:00
parent 3b159eab86
commit 13f61c7971
5 changed files with 44 additions and 27 deletions

View File

@ -98,13 +98,16 @@ LegoResult LegoImage::Read(LegoStorage* p_storage, LegoU32 p_square)
if ((result = p_storage->Read(m_bits, m_width * m_height)) != SUCCESS) { if ((result = p_storage->Read(m_bits, m_width * m_height)) != SUCCESS) {
return result; return result;
} }
if (p_square && m_width != m_height) { if (p_square && m_width != m_height) {
LegoU8* newBits; LegoU8* newBits;
if (m_height < m_width) { if (m_height < m_width) {
LegoU32 aspect = m_width / m_height; LegoU32 aspect = m_width / m_height;
newBits = new LegoU8[m_width * m_width]; newBits = new LegoU8[m_width * m_width];
LegoU8* src = m_bits; LegoU8* src = m_bits;
LegoU8* dst = newBits; LegoU8* dst = newBits;
for (LegoU32 row = 0; row < m_height; row++) { for (LegoU32 row = 0; row < m_height; row++) {
for (LegoU32 dup = aspect; dup; dup--) { for (LegoU32 dup = aspect; dup; dup--) {
memcpy(dst, src, m_width); memcpy(dst, src, m_width);
@ -112,6 +115,7 @@ LegoResult LegoImage::Read(LegoStorage* p_storage, LegoU32 p_square)
} }
src += m_width; src += m_width;
} }
m_height = m_width; m_height = m_width;
} }
else { else {
@ -119,20 +123,25 @@ LegoResult LegoImage::Read(LegoStorage* p_storage, LegoU32 p_square)
newBits = new LegoU8[m_height * m_height]; newBits = new LegoU8[m_height * m_height];
LegoU8* src = m_bits; LegoU8* src = m_bits;
LegoU8* dst = newBits; LegoU8* dst = newBits;
for (LegoU32 row = 0; row < m_height; row++) { for (LegoU32 row = 0; row < m_height; row++) {
for (LegoU32 col = 0; col < m_width; col++) { for (LegoU32 col = 0; col < m_width; col++) {
for (LegoU32 dup = aspect; dup; dup--) { for (LegoU32 dup = aspect; dup; dup--) {
*dst = *src; *dst = *src;
dst++; dst++;
} }
src++; src++;
} }
} }
m_width = m_height; m_width = m_height;
} }
delete m_bits; delete m_bits;
m_bits = newBits; m_bits = newBits;
} }
return SUCCESS; return SUCCESS;
} }

View File

@ -5,6 +5,7 @@
class LegoStorage; class LegoStorage;
// SIZE 0x3
class LegoPaletteEntry { class LegoPaletteEntry {
public: public:
LegoPaletteEntry(); LegoPaletteEntry();
@ -19,11 +20,12 @@ class LegoPaletteEntry {
LegoResult Write(LegoStorage* p_storage); LegoResult Write(LegoStorage* p_storage);
protected: protected:
LegoU8 m_red; LegoU8 m_red; // 0x00
LegoU8 m_green; LegoU8 m_green; // 0x01
LegoU8 m_blue; LegoU8 m_blue; // 0x02
}; };
// 0x310
class LegoImage { class LegoImage {
public: public:
LegoImage(); LegoImage();
@ -42,11 +44,11 @@ class LegoImage {
LegoResult Write(LegoStorage* p_storage); LegoResult Write(LegoStorage* p_storage);
protected: protected:
LegoU32 m_width; LegoU32 m_width; // 0x00
LegoU32 m_height; LegoU32 m_height; // 0x04
LegoU32 m_count; LegoU32 m_count; // 0x08
LegoPaletteEntry m_palette[256]; LegoPaletteEntry m_palette[256]; // 0x0c
LegoU8* m_bits; LegoU8* m_bits; // 0x30c
}; };
#endif // __LEGOIMAGE_H #endif // __LEGOIMAGE_H

View File

@ -7,7 +7,7 @@
DECOMP_SIZE_ASSERT(LegoStorage, 0x8); DECOMP_SIZE_ASSERT(LegoStorage, 0x8);
DECOMP_SIZE_ASSERT(LegoMemory, 0x10); DECOMP_SIZE_ASSERT(LegoMemory, 0x10);
DECOMP_SIZE_ASSERT(LegoFile, 0xC); DECOMP_SIZE_ASSERT(LegoFile, 0xc);
// FUNCTION: LEGO1 0x10099080 // FUNCTION: LEGO1 0x10099080
LegoMemory::LegoMemory(void* p_buffer) : LegoStorage() LegoMemory::LegoMemory(void* p_buffer) : LegoStorage()
@ -105,12 +105,12 @@ LegoResult LegoFile::Open(const char* p_name, LegoU32 p_mode)
char mode[4]; char mode[4];
mode[0] = '\0'; mode[0] = '\0';
if (p_mode & c_read) { if (p_mode & c_read) {
m_mode = LEGOSTREAM_MODE_READ; m_mode = c_read;
strcat(mode, "r"); strcat(mode, "r");
} }
if (p_mode & c_write) { if (p_mode & c_write) {
if (m_mode != LEGOSTREAM_MODE_READ) if (m_mode != c_read)
m_mode = LEGOSTREAM_MODE_WRITE; m_mode = c_write;
strcat(mode, "w"); strcat(mode, "w");
} }
if ((p_mode & c_text) != 0) if ((p_mode & c_text) != 0)
@ -130,6 +130,7 @@ LegoResult LegoMemory::GetPosition(LegoU32& p_position)
p_position = m_position; p_position = m_position;
return SUCCESS; return SUCCESS;
} }
// FUNCTION: LEGO1 0x100994b0 // FUNCTION: LEGO1 0x100994b0
LegoResult LegoMemory::SetPosition(LegoU32 p_position) LegoResult LegoMemory::SetPosition(LegoU32 p_position)
{ {

View File

@ -6,33 +6,41 @@
#include <stdio.h> #include <stdio.h>
#define LEGOSTREAM_MODE_READ 1
#define LEGOSTREAM_MODE_WRITE 2
// VTABLE: LEGO1 0x100d7d80 // VTABLE: LEGO1 0x100d7d80
// SIZE 0x08
class LegoStorage { class LegoStorage {
public: public:
enum OpenFlags {
c_read = 1,
c_write = 2,
c_text = 4
};
LegoStorage() : m_mode(0) {} LegoStorage() : m_mode(0) {}
// FUNCTION: LEGO1 0x10045ad0 // FUNCTION: LEGO1 0x10045ad0
virtual ~LegoStorage(){}; virtual ~LegoStorage(){};
virtual LegoResult Read(void* p_buffer, LegoU32 p_size) = 0; virtual LegoResult Read(void* p_buffer, LegoU32 p_size) = 0;
virtual LegoResult Write(const void* p_buffer, LegoU32 p_size) = 0; virtual LegoResult Write(const void* p_buffer, LegoU32 p_size) = 0;
virtual LegoResult GetPosition(LegoU32& p_position) = 0; virtual LegoResult GetPosition(LegoU32& p_position) = 0;
virtual LegoResult SetPosition(LegoU32 p_position) = 0; virtual LegoResult SetPosition(LegoU32 p_position) = 0;
// FUNCTION: LEGO1 0x10045ae0 // FUNCTION: LEGO1 0x10045ae0
virtual LegoBool IsWriteMode() { return m_mode == LEGOSTREAM_MODE_WRITE; } virtual LegoBool IsWriteMode() { return m_mode == c_read; }
// FUNCTION: LEGO1 0x10045af0 // FUNCTION: LEGO1 0x10045af0
virtual LegoBool IsReadMode() { return m_mode == LEGOSTREAM_MODE_READ; } virtual LegoBool IsReadMode() { return m_mode == c_write; }
// SYNTHETIC: LEGO1 0x10045b00 // SYNTHETIC: LEGO1 0x10045b00
// LegoStorage::`scalar deleting destructor' // LegoStorage::`scalar deleting destructor'
protected: protected:
LegoU8 m_mode; LegoU8 m_mode; // 0x04
}; };
// VTABLE: LEGO1 0x100db710 // VTABLE: LEGO1 0x100db710
// SIZE 0x10
class LegoMemory : public LegoStorage { class LegoMemory : public LegoStorage {
public: public:
LegoMemory(void* p_buffer); LegoMemory(void* p_buffer);
@ -45,18 +53,14 @@ class LegoMemory : public LegoStorage {
// LegoMemory::`scalar deleting destructor' // LegoMemory::`scalar deleting destructor'
protected: protected:
LegoU8* m_buffer; LegoU8* m_buffer; // 0x04
LegoU32 m_position; LegoU32 m_position; // 0x08
}; };
// VTABLE: LEGO1 0x100db730 // VTABLE: LEGO1 0x100db730
// SIZE 0x0c
class LegoFile : public LegoStorage { class LegoFile : public LegoStorage {
public: public:
enum OpenFlags {
c_read = 1,
c_write = 2,
c_text = 4
};
LegoFile(); LegoFile();
virtual ~LegoFile(); virtual ~LegoFile();
virtual LegoResult Read(void* p_buffer, LegoU32 p_size); virtual LegoResult Read(void* p_buffer, LegoU32 p_size);
@ -82,7 +86,7 @@ class LegoFile : public LegoStorage {
// LegoFile::`scalar deleting destructor' // LegoFile::`scalar deleting destructor'
protected: protected:
FILE* m_file; FILE* m_file; // 0x08
}; };
#endif // __LEGOSTORAGE_H #endif // __LEGOSTORAGE_H

View File

@ -6,6 +6,7 @@
class LegoImage; class LegoImage;
class LegoStorage; class LegoStorage;
// SIZE 0x04
class LegoTexture { class LegoTexture {
public: public:
LegoTexture(); LegoTexture();
@ -16,7 +17,7 @@ class LegoTexture {
LegoResult Write(LegoStorage* p_storage); LegoResult Write(LegoStorage* p_storage);
protected: protected:
LegoImage* m_image; LegoImage* m_image; // 0x00
}; };
#endif // __LEGOTEXTURE_H #endif // __LEGOTEXTURE_H