mirror of https://github.com/PrimeDecomp/prime.git
Match and link CDecalDescription, nearly match CWeaponDescription
This commit is contained in:
parent
6e006bdcbd
commit
181f0435d2
|
@ -2,6 +2,18 @@
|
||||||
|
|
||||||
.section .text, "ax"
|
.section .text, "ax"
|
||||||
|
|
||||||
|
.global __ct__Q217CDecalDescription10SQuadDescrFv
|
||||||
|
__ct__Q217CDecalDescription10SQuadDescrFv:
|
||||||
|
/* 802B5CC0 002B2C20 38 00 00 00 */ li r0, 0
|
||||||
|
/* 802B5CC4 002B2C24 90 03 00 00 */ stw r0, 0(r3)
|
||||||
|
/* 802B5CC8 002B2C28 90 03 00 04 */ stw r0, 4(r3)
|
||||||
|
/* 802B5CCC 002B2C2C 90 03 00 08 */ stw r0, 8(r3)
|
||||||
|
/* 802B5CD0 002B2C30 90 03 00 0C */ stw r0, 0xc(r3)
|
||||||
|
/* 802B5CD4 002B2C34 90 03 00 10 */ stw r0, 0x10(r3)
|
||||||
|
/* 802B5CD8 002B2C38 90 03 00 14 */ stw r0, 0x14(r3)
|
||||||
|
/* 802B5CDC 002B2C3C 98 03 00 18 */ stb r0, 0x18(r3)
|
||||||
|
/* 802B5CE0 002B2C40 4E 80 00 20 */ blr
|
||||||
|
|
||||||
.global __ct__17CDecalDescriptionFv
|
.global __ct__17CDecalDescriptionFv
|
||||||
__ct__17CDecalDescriptionFv:
|
__ct__17CDecalDescriptionFv:
|
||||||
/* 802B5CE4 002B2C44 94 21 FF F0 */ stwu r1, -0x10(r1)
|
/* 802B5CE4 002B2C44 94 21 FF F0 */ stwu r1, -0x10(r1)
|
||||||
|
@ -9,9 +21,9 @@ __ct__17CDecalDescriptionFv:
|
||||||
/* 802B5CEC 002B2C4C 90 01 00 14 */ stw r0, 0x14(r1)
|
/* 802B5CEC 002B2C4C 90 01 00 14 */ stw r0, 0x14(r1)
|
||||||
/* 802B5CF0 002B2C50 93 E1 00 0C */ stw r31, 0xc(r1)
|
/* 802B5CF0 002B2C50 93 E1 00 0C */ stw r31, 0xc(r1)
|
||||||
/* 802B5CF4 002B2C54 7C 7F 1B 78 */ mr r31, r3
|
/* 802B5CF4 002B2C54 7C 7F 1B 78 */ mr r31, r3
|
||||||
/* 802B5CF8 002B2C58 4B FF FF C9 */ bl sub_802b5cc0
|
/* 802B5CF8 002B2C58 4B FF FF C9 */ bl __ct__Q217CDecalDescription10SQuadDescrFv
|
||||||
/* 802B5CFC 002B2C5C 38 7F 00 1C */ addi r3, r31, 0x1c
|
/* 802B5CFC 002B2C5C 38 7F 00 1C */ addi r3, r31, 0x1c
|
||||||
/* 802B5D00 002B2C60 4B FF FF C1 */ bl sub_802b5cc0
|
/* 802B5D00 002B2C60 4B FF FF C1 */ bl __ct__Q217CDecalDescription10SQuadDescrFv
|
||||||
/* 802B5D04 002B2C64 38 80 00 00 */ li r4, 0
|
/* 802B5D04 002B2C64 38 80 00 00 */ li r4, 0
|
||||||
/* 802B5D08 002B2C68 7F E3 FB 78 */ mr r3, r31
|
/* 802B5D08 002B2C68 7F E3 FB 78 */ mr r3, r31
|
||||||
/* 802B5D0C 002B2C6C 98 9F 00 44 */ stb r4, 0x44(r31)
|
/* 802B5D0C 002B2C6C 98 9F 00 44 */ stb r4, 0x44(r31)
|
||||||
|
|
|
@ -314,15 +314,3 @@ __ct__18CWeaponDescriptionFv:
|
||||||
/* 802B5CB4 002B2C14 90 A3 00 AC */ stw r5, 0xac(r3)
|
/* 802B5CB4 002B2C14 90 A3 00 AC */ stw r5, 0xac(r3)
|
||||||
/* 802B5CB8 002B2C18 90 A3 00 B0 */ stw r5, 0xb0(r3)
|
/* 802B5CB8 002B2C18 90 A3 00 B0 */ stw r5, 0xb0(r3)
|
||||||
/* 802B5CBC 002B2C1C 4E 80 00 20 */ blr
|
/* 802B5CBC 002B2C1C 4E 80 00 20 */ blr
|
||||||
|
|
||||||
.global sub_802b5cc0
|
|
||||||
sub_802b5cc0:
|
|
||||||
/* 802B5CC0 002B2C20 38 00 00 00 */ li r0, 0
|
|
||||||
/* 802B5CC4 002B2C24 90 03 00 00 */ stw r0, 0(r3)
|
|
||||||
/* 802B5CC8 002B2C28 90 03 00 04 */ stw r0, 4(r3)
|
|
||||||
/* 802B5CCC 002B2C2C 90 03 00 08 */ stw r0, 8(r3)
|
|
||||||
/* 802B5CD0 002B2C30 90 03 00 0C */ stw r0, 0xc(r3)
|
|
||||||
/* 802B5CD4 002B2C34 90 03 00 10 */ stw r0, 0x10(r3)
|
|
||||||
/* 802B5CD8 002B2C38 90 03 00 14 */ stw r0, 0x14(r3)
|
|
||||||
/* 802B5CDC 002B2C3C 98 03 00 18 */ stb r0, 0x18(r3)
|
|
||||||
/* 802B5CE0 002B2C40 4E 80 00 20 */ blr
|
|
||||||
|
|
|
@ -426,7 +426,7 @@ LIBS = [
|
||||||
"Weapons/CDecalDataFactory",
|
"Weapons/CDecalDataFactory",
|
||||||
["Weapons/CDecal", False],
|
["Weapons/CDecal", False],
|
||||||
"Weapons/CWeaponDescription",
|
"Weapons/CWeaponDescription",
|
||||||
"Weapons/CDecalDescription",
|
["Weapons/CDecalDescription", True],
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
|
|
@ -13,8 +13,11 @@ public:
|
||||||
rstl::single_ptr< CColorElement > x10_CLR;
|
rstl::single_ptr< CColorElement > x10_CLR;
|
||||||
rstl::single_ptr< CUVElement > x14_TEX;
|
rstl::single_ptr< CUVElement > x14_TEX;
|
||||||
bool x18_ADD;
|
bool x18_ADD;
|
||||||
|
SQuadDescr();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
CDecalDescription();
|
||||||
|
|
||||||
// private:
|
// private:
|
||||||
SQuadDescr x0_quad1;
|
SQuadDescr x0_quad1;
|
||||||
SQuadDescr x1c_quad2;
|
SQuadDescr x1c_quad2;
|
||||||
|
|
|
@ -1,23 +1,58 @@
|
||||||
#ifndef _CWEAPONDESCRIPTION
|
#ifndef _CWEAPONDESCRIPTION
|
||||||
#define _CWEAPONDESCRIPTION
|
#define _CWEAPONDESCRIPTION
|
||||||
|
|
||||||
#include "Kyoto/Particles/CVectorElement.hpp"
|
|
||||||
#include "Kyoto/Particles/CModVectorElement.hpp"
|
#include "Kyoto/Particles/CModVectorElement.hpp"
|
||||||
|
#include "Kyoto/Particles/CVectorElement.hpp"
|
||||||
|
|
||||||
|
#include "rstl/optional_object.hpp"
|
||||||
#include "rstl/single_ptr.hpp"
|
#include "rstl/single_ptr.hpp"
|
||||||
|
|
||||||
|
class CModel;
|
||||||
|
class CElectricDescription;
|
||||||
|
class CSwooshDescription;
|
||||||
|
class CGenDescription;
|
||||||
|
class CCollisionResponseData;
|
||||||
|
|
||||||
class CWeaponDescription {
|
class CWeaponDescription {
|
||||||
public:
|
public:
|
||||||
rstl::single_ptr<CVectorElement> x0_IORN;
|
typedef rstl::optional_object< TCachedToken< CModel > > TParticleModel;
|
||||||
rstl::single_ptr<CVectorElement> x4_IVEC;
|
typedef rstl::optional_object< TCachedToken< CGenDescription > > TChildGeneratorDesc;
|
||||||
rstl::single_ptr<CVectorElement> x8_PSOV;
|
typedef rstl::optional_object< TCachedToken< CSwooshDescription > > TSwooshGeneratorDesc;
|
||||||
rstl::single_ptr<CModVectorElement> xc_PSVM;
|
typedef rstl::optional_object< TCachedToken< CCollisionResponseData > > TCollisionResponseDesc;
|
||||||
|
|
||||||
|
CWeaponDescription();
|
||||||
|
~CWeaponDescription();
|
||||||
|
rstl::single_ptr< CVectorElement > x0_IORN;
|
||||||
|
rstl::single_ptr< CVectorElement > x4_IVEC;
|
||||||
|
rstl::single_ptr< CVectorElement > x8_PSOV;
|
||||||
|
rstl::single_ptr< CModVectorElement > xc_PSVM;
|
||||||
bool x10_VMD2;
|
bool x10_VMD2;
|
||||||
rstl::single_ptr<CIntElement> x14_PSLT;
|
rstl::single_ptr< CIntElement > x14_PSLT;
|
||||||
rstl::single_ptr<CVectorElement> x18_PSCL;
|
rstl::single_ptr< CVectorElement > x18_PSCL;
|
||||||
rstl::single_ptr<CColorElement> x1c_PCOL;
|
rstl::single_ptr< CColorElement > x1c_PCOL;
|
||||||
rstl::single_ptr<CVectorElement> x20_POFS;
|
rstl::single_ptr< CVectorElement > x20_POFS;
|
||||||
rstl::single_ptr<CVectorElement> x24_OFST;
|
rstl::single_ptr< CVectorElement > x24_OFST;
|
||||||
|
bool x28_APSO;
|
||||||
|
bool x29_HOMG;
|
||||||
|
bool x2a_AP11;
|
||||||
|
bool x2b_AP21;
|
||||||
|
bool x2c_AS11;
|
||||||
|
bool x2d_AS12;
|
||||||
|
bool x2e_AS13;
|
||||||
|
rstl::single_ptr< CRealElement > x30_TRAT;
|
||||||
|
TChildGeneratorDesc x34_APSM;
|
||||||
|
TChildGeneratorDesc x44_APS2;
|
||||||
|
TSwooshGeneratorDesc x54_ASW1;
|
||||||
|
TSwooshGeneratorDesc x64_ASW2;
|
||||||
|
TSwooshGeneratorDesc x74_ASW3;
|
||||||
|
TParticleModel x84_OHEF;
|
||||||
|
TCollisionResponseDesc x94_COLR;
|
||||||
|
bool xa4_EWTR;
|
||||||
|
bool xa5_LWTR;
|
||||||
|
bool xa6_SWTR;
|
||||||
|
int xa8_PJFX;
|
||||||
|
rstl::single_ptr< CRealElement > xac_RNGE;
|
||||||
|
rstl::single_ptr< CRealElement > xb0_FOFF;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // _CWEAPONDESCRIPTION
|
#endif // _CWEAPONDESCRIPTION
|
||||||
|
|
|
@ -379,7 +379,7 @@ WEAPONS :=\
|
||||||
$(BUILD_DIR)/asm/Weapons/CDecalDataFactory.o\
|
$(BUILD_DIR)/asm/Weapons/CDecalDataFactory.o\
|
||||||
$(BUILD_DIR)/asm/Weapons/CDecal.o\
|
$(BUILD_DIR)/asm/Weapons/CDecal.o\
|
||||||
$(BUILD_DIR)/asm/Weapons/CWeaponDescription.o\
|
$(BUILD_DIR)/asm/Weapons/CWeaponDescription.o\
|
||||||
$(BUILD_DIR)/asm/Weapons/CDecalDescription.o\
|
$(BUILD_DIR)/src/Weapons/CDecalDescription.o\
|
||||||
|
|
||||||
METARENDER :=\
|
METARENDER :=\
|
||||||
$(BUILD_DIR)/asm/MetaRender/CCubeRenderer.o\
|
$(BUILD_DIR)/asm/MetaRender/CCubeRenderer.o\
|
||||||
|
|
|
@ -0,0 +1,10 @@
|
||||||
|
#include "Weapons/CDecalDescription.hpp"
|
||||||
|
|
||||||
|
CDecalDescription::CDecalDescription()
|
||||||
|
: x5c_24_DMAB(false)
|
||||||
|
, x5c_25_DMOO(false) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
CDecalDescription::SQuadDescr::SQuadDescr()
|
||||||
|
: x18_ADD(false) {}
|
|
@ -0,0 +1,17 @@
|
||||||
|
#include "Weapons/CWeaponDescription.hpp"
|
||||||
|
#include "Kyoto/Alloc/CMemory.hpp"
|
||||||
|
|
||||||
|
CWeaponDescription::CWeaponDescription()
|
||||||
|
: x10_VMD2(false)
|
||||||
|
, x28_APSO(false)
|
||||||
|
, x2a_AP11(false)
|
||||||
|
, x2b_AP21(false)
|
||||||
|
, x2c_AS11(false)
|
||||||
|
, x2d_AS12(false)
|
||||||
|
, x2e_AS13(false)
|
||||||
|
, xa4_EWTR(true)
|
||||||
|
, xa5_LWTR(true)
|
||||||
|
, xa6_SWTR(true)
|
||||||
|
, xa8_PJFX(-1) {}
|
||||||
|
|
||||||
|
CWeaponDescription::~CWeaponDescription() {}
|
Loading…
Reference in New Issue