Enable some multiple-inheritance vtables (#821)

This commit is contained in:
MS 2024-04-19 16:23:36 -04:00 committed by GitHub
parent d5dd8db46e
commit 2ce9ff06fc
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
8 changed files with 112 additions and 53 deletions

View file

@ -3,16 +3,22 @@
#include "legoanimactor.h" #include "legoanimactor.h"
/* // VTABLE: LEGO1 0x100d6078 LegoPathActor
VTABLE: LEGO1 0x100d6078 LegoPathActor // VTABLE: LEGO1 0x100d6148 LegoAnimActor
VTABLE: LEGO1 0x100d6148 LegoAnimActor
*/
// SIZE 0x1a8 // SIZE 0x1a8
class Act2Actor : public LegoAnimActor { class Act2Actor : public LegoAnimActor {
public: public:
Act2Actor(); Act2Actor();
// SYNTHETIC: LEGO1 0x1001a090 void SetROI(LegoROI* p_roi, MxBool p_bool1, MxBool p_bool2) override; // vtable+0x24
void SetWorldSpeed(MxFloat p_worldSpeed) override; // vtable+0x30
MxS32 VTable0x68(Vector3&, Vector3&, Vector3&) override; // vtable+0x68
void VTable0x70(float p_und) override; // vtable+0x70
MxResult VTable0x94(LegoPathActor*, MxBool) override; // vtable+0x94
MxResult WaitForAnimation() override; // vtable+0x9c
MxS32 VTable0xa0() override; // vtable+0xa0
// SYNTHETIC: LEGO1 0x1001a0a0
// Act2Actor::`scalar deleting destructor' // Act2Actor::`scalar deleting destructor'
private: private:

View file

@ -3,22 +3,26 @@
#include "legoanimactor.h" #include "legoanimactor.h"
/* // VTABLE: LEGO1 0x100d7668 LegoPathActor
VTABLE: LEGO1 0x100d7668 LegoPathActor // VTABLE: LEGO1 0x100d7738 LegoAnimActor
VTABLE: LEGO1 0x100d7738 LegoAnimActor
*/
// SIZE 0x178 // SIZE 0x178
class Act3Actor : public LegoAnimActor { class Act3Actor : public LegoAnimActor {
public: public:
Act3Actor(); Act3Actor();
// FUNCTION: LEGO1 0x100433b0 // FUNCTION: LEGO1 0x100431b0
inline const char* ClassName() const override inline const char* ClassName() const override // vtable+0x0c
{ {
// STRING: LEGO1 0x100f03ac // STRING: LEGO1 0x100f03ac
return "Act3Actor"; return "Act3Actor";
} }
MxU32 VTable0x90(float, Matrix4&) override; // vtable+0x90
MxResult VTable0x94(LegoPathActor*, MxBool) override; // vtable+0x94
// SYNTHETIC: LEGO1 0x10043330
// Act3Actor::`scalar deleting destructor'
private: private:
undefined4 m_unk0x1c; // 0x1c undefined4 m_unk0x1c; // 0x1c
}; };

View file

@ -3,36 +3,27 @@
#include "legoanimactor.h" #include "legoanimactor.h"
/* // VTABLE: LEGO1 0x100d7920 LegoPathActor
VTABLE: LEGO1 0x100d7920 LegoPathActor // VTABLE: LEGO1 0x100d79f0 LegoAnimActor
VTABLE: LEGO1 0x100d79f0 LegoAnimActor
*/
// SIZE 0x1a8 // SIZE 0x1a8
class Act3Shark : public LegoAnimActor { class Act3Shark : public LegoAnimActor {
public: public:
Act3Shark(); Act3Shark();
// FUNCTION: LEGO1 0x100430c0 // FUNCTION: LEGO1 0x100430d0
inline const char* ClassName() const override // vtable+0x0c inline const char* ClassName() const override // vtable+0x0c
{ {
// STRING: LEGO1 0x100f03a0 // STRING: LEGO1 0x100f03a0
return "Act3Shark"; return "Act3Shark";
} }
// FUNCTION: LEGO1 0x1001a130 void ParseAction(char*) override; // vtable+0x20
inline MxBool IsA(const char* p_name) const override // vtable+0x10 void VTable0x70(float p_float) override; // vtable+0x70
{
return !strcmp(p_name, Act3Shark::ClassName()) || LegoAnimActor::IsA(p_name);
}
void ParseAction(char*) override; // vtable+0x20 // LegoAnimActor vtable
void SetWorldSpeed(MxFloat p_worldSpeed) override; // vtable+0x30 virtual MxResult FUN_10042ce0(void*); // vtable+0x10
void VTable0x70(float p_float) override; // vtable+0x70
void VTable0x74(Matrix4& p_transform) override; // vtable+0x74
virtual MxResult FUN_10042ce0(void*); // SYNTHETIC: LEGO1 0x10043030
// SYNTHETIC: LEGO1 0x10043020
// Act3Shark::`scalar deleting destructor' // Act3Shark::`scalar deleting destructor'
private: private:
@ -43,4 +34,9 @@ class Act3Shark : public LegoAnimActor {
Mx3DPointFloat m_unk0x3c; // 0x3c Mx3DPointFloat m_unk0x3c; // 0x3c
}; };
// STUB: LEGO1 0x10042c90
// List<void *>::~List<void *>
// TODO: Update once type is known.
// STUB to resolve diff in scalar dtor and not create a new one.
#endif // ACT3SHARK_H #endif // ACT3SHARK_H

View file

@ -4,24 +4,23 @@
#include "legoanimactor.h" #include "legoanimactor.h"
#include "mxtypes.h" #include "mxtypes.h"
/* // VTABLE: LEGO1 0x100d6790 LegoPathActor
VTABLE: LEGO1 0x100d6790 LegoPathActor // VTABLE: LEGO1 0x100d6860 LegoAnimActor
VTABLE: LEGO1 0x100d6860 LegoAnimActor
*/
// SIZE 0x174 // SIZE 0x174
class BumpBouy : public LegoAnimActor { class BumpBouy : public LegoAnimActor {
public: public:
BumpBouy(); BumpBouy();
~BumpBouy() override;
MxLong Notify(MxParam& p_param) override; // vtable+0x04 MxLong Notify(MxParam& p_param) override; // vtable+0x04
// FUNCTION: LEGO1 0x10027510 // FUNCTION: LEGO1 0x100274f0
inline const char* ClassName() const override // vtable+0x0c inline const char* ClassName() const override // vtable+0x0c
{ {
// STRING: LEGO1 0x100f0394 // STRING: LEGO1 0x100f0394
return "BumpBouy"; return "BumpBouy";
} }
// FUNCTION: LEGO1 0x10027500 // FUNCTION: LEGO1 0x10027510
inline MxBool IsA(const char* p_name) const override // vtable+0x10 inline MxBool IsA(const char* p_name) const override // vtable+0x10
{ {
return !strcmp(p_name, BumpBouy::ClassName()) || LegoAnimActor::IsA(p_name); return !strcmp(p_name, BumpBouy::ClassName()) || LegoAnimActor::IsA(p_name);

View file

@ -2,12 +2,6 @@
DECOMP_SIZE_ASSERT(Act3Shark, 0x1a8) DECOMP_SIZE_ASSERT(Act3Shark, 0x1a8)
// STUB: LEGO1 0x1001a1c0
void Act3Shark::VTable0x74(Matrix4& p_transform)
{
// TODO
}
// STUB: LEGO1 0x10042ab0 // STUB: LEGO1 0x10042ab0
Act3Shark::Act3Shark() Act3Shark::Act3Shark()
{ {
@ -21,20 +15,14 @@ MxResult Act3Shark::FUN_10042ce0(void*)
return SUCCESS; return SUCCESS;
} }
// STUB: LEGO1 0x100430e0 // STUB: LEGO1 0x10042d40
void Act3Shark::ParseAction(char*)
{
// TODO
}
// STUB: LEGO1 0x100430f0
void Act3Shark::SetWorldSpeed(MxFloat p_worldSpeed)
{
// TODO
}
// STUB: LEGO1 0x10043100
void Act3Shark::VTable0x70(float p_float) void Act3Shark::VTable0x70(float p_float)
{ {
// TODO // TODO
} }
// STUB: LEGO1 0x10042f30
void Act3Shark::ParseAction(char*)
{
// TODO
}

View file

@ -7,3 +7,49 @@ Act2Actor::Act2Actor()
{ {
// TODO // TODO
} }
// STUB: LEGO1 0x10018940
void Act2Actor::SetROI(LegoROI* p_roi, MxBool p_bool1, MxBool p_bool2)
{
// TODO
}
// STUB: LEGO1 0x100189f0
MxResult Act2Actor::VTable0x94(LegoPathActor*, MxBool)
{
// TODO
return SUCCESS;
}
// STUB: LEGO1 0x10018a20
MxResult Act2Actor::WaitForAnimation()
{
// TODO
return SUCCESS;
}
// STUB: LEGO1 0x10018c30
void Act2Actor::VTable0x70(float p_und)
{
// TODO
}
// STUB: LEGO1 0x10019280
void Act2Actor::SetWorldSpeed(MxFloat p_worldSpeed)
{
// TODO
}
// STUB: LEGO1 0x100195a0
MxS32 Act2Actor::VTable0xa0()
{
// TODO
return 0;
}
// STUB: LEGO1 0x1001a180
MxS32 Act2Actor::VTable0x68(Vector3&, Vector3&, Vector3&)
{
// TODO
return 0;
}

View file

@ -7,3 +7,17 @@ Act3Actor::Act3Actor()
{ {
m_unk0x1c = 0; m_unk0x1c = 0;
} }
// STUB: LEGO1 0x1003fb70
MxU32 Act3Actor::VTable0x90(float, Matrix4&)
{
// TODO
return FALSE;
}
// STUB: LEGO1 0x1003fd90
MxResult Act3Actor::VTable0x94(LegoPathActor*, MxBool)
{
// TODO
return 0;
}

View file

@ -7,6 +7,12 @@ BumpBouy::BumpBouy()
{ {
} }
// STUB: LEGO1 0x10027360
BumpBouy::~BumpBouy()
{
// TODO
}
// STUB: LEGO1 0x10027400 // STUB: LEGO1 0x10027400
MxLong BumpBouy::Notify(MxParam& p_param) MxLong BumpBouy::Notify(MxParam& p_param)
{ {