mirror of
https://github.com/isledecomp/isle.git
synced 2025-10-23 08:24:16 +00:00
Beta matching MxDSMediaAction (#882)
This commit is contained in:
@@ -8,36 +8,45 @@ DECOMP_SIZE_ASSERT(MxDSMediaAction, 0xb8)
|
||||
// FUNCTION: BETA10 0x1015c760
|
||||
MxDSMediaAction::MxDSMediaAction()
|
||||
{
|
||||
this->m_mediaSrcPath = NULL;
|
||||
this->m_unk0x9c.m_unk0x00 = 0;
|
||||
this->m_unk0x9c.m_unk0x04 = 0;
|
||||
this->m_framesPerSecond = 0;
|
||||
this->m_mediaFormat = 0;
|
||||
this->m_paletteManagement = 1;
|
||||
this->m_unk0xb4 = -1;
|
||||
this->m_sustainTime = 0;
|
||||
this->SetType(e_mediaAction);
|
||||
m_type = e_mediaAction;
|
||||
m_mediaSrcPath = NULL;
|
||||
m_unk0x9c.SetUnk0x00(0);
|
||||
m_unk0x9c.SetUnk0x04(0);
|
||||
m_framesPerSecond = 0;
|
||||
m_mediaFormat = 0;
|
||||
m_unk0xb4 = -1;
|
||||
m_paletteManagement = 1;
|
||||
m_sustainTime = 0;
|
||||
}
|
||||
|
||||
// FUNCTION: LEGO1 0x100c8cf0
|
||||
// FUNCTION: BETA10 0x1015c846
|
||||
MxDSMediaAction::~MxDSMediaAction()
|
||||
{
|
||||
delete[] this->m_mediaSrcPath;
|
||||
delete[] m_mediaSrcPath;
|
||||
}
|
||||
|
||||
// FUNCTION: LEGO1 0x100c8d60
|
||||
// FUNCTION: BETA10 0x1015c8cc
|
||||
void MxDSMediaAction::CopyFrom(MxDSMediaAction& p_dsMediaAction)
|
||||
{
|
||||
CopyMediaSrcPath(p_dsMediaAction.m_mediaSrcPath);
|
||||
|
||||
this->m_unk0x9c = p_dsMediaAction.m_unk0x9c;
|
||||
this->m_framesPerSecond = p_dsMediaAction.m_framesPerSecond;
|
||||
this->m_mediaFormat = p_dsMediaAction.m_mediaFormat;
|
||||
this->m_paletteManagement = p_dsMediaAction.m_paletteManagement;
|
||||
this->m_sustainTime = p_dsMediaAction.m_sustainTime;
|
||||
m_unk0x9c = p_dsMediaAction.m_unk0x9c;
|
||||
m_framesPerSecond = p_dsMediaAction.m_framesPerSecond;
|
||||
m_mediaFormat = p_dsMediaAction.m_mediaFormat;
|
||||
m_paletteManagement = p_dsMediaAction.m_paletteManagement;
|
||||
m_sustainTime = p_dsMediaAction.m_sustainTime;
|
||||
}
|
||||
|
||||
// FUNCTION: BETA10 0x1015c959
|
||||
MxDSMediaAction::MxDSMediaAction(MxDSMediaAction& p_dsMediaAction) : MxDSAction(p_dsMediaAction)
|
||||
{
|
||||
CopyFrom(p_dsMediaAction);
|
||||
}
|
||||
|
||||
// FUNCTION: LEGO1 0x100c8dc0
|
||||
// FUNCTION: BETA10 0x1015c9da
|
||||
MxDSMediaAction& MxDSMediaAction::operator=(MxDSMediaAction& p_dsMediaAction)
|
||||
{
|
||||
if (this == &p_dsMediaAction) {
|
||||
@@ -45,11 +54,12 @@ MxDSMediaAction& MxDSMediaAction::operator=(MxDSMediaAction& p_dsMediaAction)
|
||||
}
|
||||
|
||||
MxDSAction::operator=(p_dsMediaAction);
|
||||
this->CopyFrom(p_dsMediaAction);
|
||||
CopyFrom(p_dsMediaAction);
|
||||
return *this;
|
||||
}
|
||||
|
||||
// FUNCTION: LEGO1 0x100c8df0
|
||||
// FUNCTION: BETA10 0x1015ca21
|
||||
MxDSAction* MxDSMediaAction::Clone()
|
||||
{
|
||||
MxDSMediaAction* clone = new MxDSMediaAction();
|
||||
@@ -62,58 +72,73 @@ MxDSAction* MxDSMediaAction::Clone()
|
||||
}
|
||||
|
||||
// FUNCTION: LEGO1 0x100c8e80
|
||||
// FUNCTION: BETA10 0x1015cacb
|
||||
void MxDSMediaAction::CopyMediaSrcPath(const char* p_mediaSrcPath)
|
||||
{
|
||||
if (this->m_mediaSrcPath == p_mediaSrcPath) {
|
||||
if (m_mediaSrcPath == p_mediaSrcPath) {
|
||||
return;
|
||||
}
|
||||
|
||||
delete[] this->m_mediaSrcPath;
|
||||
delete[] m_mediaSrcPath;
|
||||
|
||||
if (p_mediaSrcPath) {
|
||||
this->m_mediaSrcPath = new char[strlen(p_mediaSrcPath) + 1];
|
||||
if (this->m_mediaSrcPath) {
|
||||
strcpy(this->m_mediaSrcPath, p_mediaSrcPath);
|
||||
m_mediaSrcPath = new char[strlen(p_mediaSrcPath) + 1];
|
||||
if (m_mediaSrcPath) {
|
||||
strcpy(m_mediaSrcPath, p_mediaSrcPath);
|
||||
}
|
||||
}
|
||||
else {
|
||||
this->m_mediaSrcPath = NULL;
|
||||
m_mediaSrcPath = NULL;
|
||||
}
|
||||
}
|
||||
|
||||
// FUNCTION: LEGO1 0x100c8f00
|
||||
// FUNCTION: BETA10 0x1015cbf5
|
||||
undefined4 MxDSMediaAction::VTable0x14()
|
||||
{
|
||||
return MxDSAction::VTable0x14();
|
||||
}
|
||||
|
||||
// FUNCTION: LEGO1 0x100c8f10
|
||||
// FUNCTION: BETA10 0x1015cc13
|
||||
MxU32 MxDSMediaAction::GetSizeOnDisk()
|
||||
{
|
||||
MxU32 totalSizeOnDisk = MxDSAction::GetSizeOnDisk();
|
||||
|
||||
if (this->m_mediaSrcPath) {
|
||||
totalSizeOnDisk += strlen(this->m_mediaSrcPath) + 1;
|
||||
if (m_mediaSrcPath) {
|
||||
totalSizeOnDisk += strlen(m_mediaSrcPath) + 1;
|
||||
}
|
||||
else {
|
||||
totalSizeOnDisk++;
|
||||
}
|
||||
|
||||
totalSizeOnDisk += 24;
|
||||
this->m_sizeOnDisk = totalSizeOnDisk - MxDSAction::GetSizeOnDisk();
|
||||
totalSizeOnDisk += sizeof(m_unk0x9c.m_unk0x00);
|
||||
totalSizeOnDisk += sizeof(m_unk0x9c.m_unk0x04);
|
||||
totalSizeOnDisk += sizeof(m_framesPerSecond);
|
||||
totalSizeOnDisk += sizeof(m_mediaFormat);
|
||||
totalSizeOnDisk += sizeof(m_paletteManagement);
|
||||
totalSizeOnDisk += sizeof(m_sustainTime);
|
||||
|
||||
m_sizeOnDisk = totalSizeOnDisk - MxDSAction::GetSizeOnDisk();
|
||||
return totalSizeOnDisk;
|
||||
}
|
||||
|
||||
// FUNCTION: LEGO1 0x100c8f60
|
||||
// FUNCTION: BETA10 0x1015cc93
|
||||
void MxDSMediaAction::Deserialize(MxU8*& p_source, MxS16 p_unk0x24)
|
||||
{
|
||||
MxDSAction::Deserialize(p_source, p_unk0x24);
|
||||
|
||||
GetString(p_source, this->m_mediaSrcPath, this, &MxDSMediaAction::CopyMediaSrcPath);
|
||||
GetScalar(p_source, this->m_unk0x9c.m_unk0x00);
|
||||
GetScalar(p_source, this->m_unk0x9c.m_unk0x04);
|
||||
GetScalar(p_source, this->m_framesPerSecond);
|
||||
GetScalar(p_source, this->m_mediaFormat);
|
||||
GetScalar(p_source, this->m_paletteManagement);
|
||||
GetScalar(p_source, this->m_sustainTime);
|
||||
CopyMediaSrcPath((char*) p_source);
|
||||
p_source += strlen(m_mediaSrcPath) + 1;
|
||||
|
||||
// clang-format off
|
||||
m_unk0x9c.SetUnk0x00(*(MxU32*) p_source); p_source += sizeof(m_unk0x9c.m_unk0x00);
|
||||
m_unk0x9c.SetUnk0x04(*(MxU32*) p_source); p_source += sizeof(m_unk0x9c.m_unk0x04);
|
||||
|
||||
m_framesPerSecond = *(MxS32*) p_source; p_source += sizeof(m_framesPerSecond);
|
||||
m_mediaFormat = *(MxS32*) p_source; p_source += sizeof(m_mediaFormat);
|
||||
m_paletteManagement = *(MxS32*) p_source; p_source += sizeof(m_paletteManagement);
|
||||
m_sustainTime = *(MxS32*) p_source; p_source += sizeof(m_sustainTime);
|
||||
// clang-format on
|
||||
}
|
||||
|
Reference in New Issue
Block a user