mirror of
https://github.com/zeldaret/ph
synced 2026-05-23 15:01:37 -04:00
more progress & cleanup structs
This commit is contained in:
@@ -1,12 +1,11 @@
|
||||
#include "Message/MessageManager.hpp"
|
||||
|
||||
extern s32 func_02036824(void);
|
||||
extern unk32 func_ov000_020d7f18(u32*, unk32);
|
||||
extern unk32 func_ov000_020d77e4(u32*, unk32);
|
||||
extern unk32 func_02037628(u8*);
|
||||
extern THUMB unk32 func_0202ab48(void);
|
||||
extern ARM void func_02038b40(Struct_027E0C68_unk_28*);
|
||||
extern ARM unk32 func_0203de14(Struct_027E0C68_unk_28*, unk32);
|
||||
extern ARM void func_02038b40(UnkStruct_027E0C68_UnkSubClass1*);
|
||||
extern ARM unk32 func_0203de14(UnkStruct_027E0C68_UnkSubClass1*, unk32);
|
||||
|
||||
// see Actor.cpp
|
||||
struct UnkStruct2 {
|
||||
@@ -18,12 +17,64 @@ extern UnkStruct2 data_027e077c;
|
||||
extern u32 data_ov000_020eec9c[];
|
||||
extern u8 data_02056be4[];
|
||||
|
||||
ARM bool UnkStruct_027E0C68::func_02036808(void) {
|
||||
return this->unk_28[2]->unk_15[0x2E] > 0;
|
||||
}
|
||||
|
||||
ARM bool UnkStruct_027E0C68::func_02036824(void) {
|
||||
switch (data_027e077c.mUnk_0) {
|
||||
case 0x01:
|
||||
case 0x37:
|
||||
case 0x3B:
|
||||
return true;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
ARM bool UnkStruct_027E0C68::func_02036850(void) {
|
||||
bool ret = false;
|
||||
u8 value;
|
||||
u32 val = data_027e077c.mUnk_0;
|
||||
|
||||
value = data_02056be4[val];
|
||||
|
||||
if (!(value & 2)) {
|
||||
ret = value & 1;
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
ARM void UnkStruct_027E0C68::func_02036888(UnkStruct_027E0C68_UnkSubClass2* param_2) {
|
||||
if ((param_2->unk_18 & 0xFFFF0000) != 0x1000000) {
|
||||
UnkStruct_027E0C68_UnkSubClass1* iVar1 = this->func_020366c4();
|
||||
|
||||
if (iVar1->unk_5C <= 0) {
|
||||
param_2->vfunc_10();
|
||||
} else {
|
||||
param_2->vfunc_0C(this->func_020366c4());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
ARM bool UnkStruct_027E0C68::func_020368f4(unk32 param_2) {
|
||||
if (this->unk_24 != 0) {
|
||||
return false;
|
||||
}
|
||||
|
||||
this->unk_24 = param_2;
|
||||
return true;
|
||||
}
|
||||
|
||||
ARM void UnkStruct_027E0C68::func_02036c50(unk32 param_2) {
|
||||
s32 i;
|
||||
|
||||
for (i = 0; i < ARRAY_LEN(this->unk_28); i++) {
|
||||
if (this->unk_28[i] != NULL && func_0203de14(this->unk_28[i], param_2) != 0) {
|
||||
this->unk_28[i]->unk_00->unk_28(this->unk_28[i]);
|
||||
this->unk_28[i]->vfunc_28();
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -32,41 +83,40 @@ ARM void UnkStruct_027E0C68::func_02036ca4(unk32 param_2) {
|
||||
s32 i;
|
||||
|
||||
for (i = 0; i < ARRAY_LEN(this->unk_28); i++) {
|
||||
Struct_027E0C68_unk_28* pSVar1 = this->unk_28[i];
|
||||
UnkStruct_027E0C68_UnkSubClass1* pSVar1 = this->unk_28[i];
|
||||
|
||||
if (pSVar1 != NULL) {
|
||||
pSVar1->unk_00->unk_3C(pSVar1, param_2);
|
||||
pSVar1->vfunc_3C(param_2);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// non-matching
|
||||
ARM s32 UnkStruct_027E0C68::func_02036ce4(Struct_027E0C68_unk_18* param_2, unk32 param_3) {
|
||||
ARM s32 UnkStruct_027E0C68::func_02036ce4(UnkStruct_027E0C68_UnkSubClass2* param_2, unk32 param_3) {
|
||||
if (param_3 == 0) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (func_020373ec(this->pGroups, param_3) != -1) {
|
||||
param_2->unk_00->unk_08();
|
||||
param_2->vfunc_08();
|
||||
return 1;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
// non-matching
|
||||
ARM unk32 UnkStruct_027E0C68::func_02036d30(unk32 param_2) {
|
||||
if (this->unk_20 == 0 || this->unk_20 == param_2) {
|
||||
this->unk_20 = param_2;
|
||||
return 1;
|
||||
ARM unk32 UnkStruct_027E0C68::func_02036d30(u32* param_2) {
|
||||
if (this->unk_20 != NULL && this->unk_20 != param_2) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
return 0;
|
||||
this->unk_20 = param_2;
|
||||
return 1;
|
||||
}
|
||||
|
||||
ARM unk32 UnkStruct_027E0C68::func_02036d4c(unk32 param_2) {
|
||||
ARM unk32 UnkStruct_027E0C68::func_02036d4c(u32* param_2) {
|
||||
if (this->unk_20 == param_2) {
|
||||
this->unk_20 = 0;
|
||||
this->unk_20 = NULL;
|
||||
return 1;
|
||||
}
|
||||
|
||||
@@ -85,11 +135,11 @@ ARM void UnkStruct_027E0C68::func_02036d6c(void) {
|
||||
}
|
||||
|
||||
// non-matching
|
||||
ARM Struct_027E0C68_unk_28* UnkStruct_027E0C68::func_02036da8(u32 param_2, s32* param_3) {
|
||||
ARM UnkStruct_027E0C68_UnkSubClass1* UnkStruct_027E0C68::func_02036da8(u32 param_2, s32* param_3) {
|
||||
EntryINF1 *pEVar1;
|
||||
EntryINF1 *pEVar2;
|
||||
u8* puVar3;
|
||||
Struct_027E0C68_unk_28 *pSVar4;
|
||||
UnkStruct_027E0C68_UnkSubClass1 *pSVar4;
|
||||
BMGGroups *pBVar5;
|
||||
bool bVar6;
|
||||
u8 iStack_38;
|
||||
@@ -127,7 +177,7 @@ ARM Struct_027E0C68_unk_28* UnkStruct_027E0C68::func_02036da8(u32 param_2, s32*
|
||||
pBVar5 = this->pGroups;
|
||||
pEVar2 = func_02037258(&pBVar5->entries[param_2 >> 0x10], param_2 & 0xFFFF);
|
||||
|
||||
pSVar4->unk_00->unk_50(pSVar4, pEVar1, (int)&((pBVar5->entries[param_2 >> 0x10].pDAT1)->base).tag + (pEVar2->offset & 0xfffffffe), &iStack_38);
|
||||
pSVar4->vfunc_50(pEVar1, (int)&((pBVar5->entries[param_2 >> 0x10].pDAT1)->base).tag + (pEVar2->offset & 0xfffffffe), &iStack_38);
|
||||
|
||||
func_ov000_020d77e4(data_ov000_020eec9c, 0x1C);
|
||||
return pSVar4;
|
||||
@@ -138,7 +188,7 @@ ARM Struct_027E0C68_unk_28* UnkStruct_027E0C68::func_02036da8(u32 param_2, s32*
|
||||
|
||||
// non-matching
|
||||
ARM void UnkStruct_027E0C68::func_02036edc(u32 param_2, u8 param_3) {
|
||||
Struct_027E0C68_unk_28 *pSVar1;
|
||||
UnkStruct_027E0C68_UnkSubClass1 *pSVar1;
|
||||
u8 auStack_28[24];
|
||||
u8 local_13;
|
||||
|
||||
@@ -161,12 +211,12 @@ ARM void UnkStruct_027E0C68::func_02036edc(u32 param_2, u8 param_3) {
|
||||
}
|
||||
|
||||
// non-matching
|
||||
ARM Struct_027E0C68_unk_28* UnkStruct_027E0C68::func_02036f68(u32 param_2, u8* param_3) {
|
||||
ARM UnkStruct_027E0C68_UnkSubClass1* UnkStruct_027E0C68::func_02036f68(u32 param_2, u8* param_3) {
|
||||
EntryINF1 *pEVar1;
|
||||
Struct_027E0C68_unk_28 *pSVar2;
|
||||
UnkStruct_027E0C68_UnkSubClass1 *pSVar2;
|
||||
EntryINF1 *pEVar3;
|
||||
int iVar4;
|
||||
Struct_027E0C68_unk_28 *pSVar5;
|
||||
UnkStruct_027E0C68_UnkSubClass1 *pSVar5;
|
||||
BMGGroups *pBVar6;
|
||||
|
||||
pEVar1 = func_02037258(&this->pGroups->entries[param_2 >> 0x10], param_2 & 0xffff);
|
||||
@@ -183,12 +233,12 @@ ARM Struct_027E0C68_unk_28* UnkStruct_027E0C68::func_02036f68(u32 param_2, u8* p
|
||||
pSVar2 = this->unk_28[1];
|
||||
}
|
||||
|
||||
pSVar5[0x16].unk_04 = pSVar2;
|
||||
pSVar5[0x41].unk_08 = this->unk_28[5];
|
||||
pSVar5[0x16].unk_04 = (unk32*)pSVar2;
|
||||
pSVar5[0x41].unk_08 = (unk32*)this->unk_28[5];
|
||||
pBVar6 = this->pGroups;
|
||||
pEVar3 = func_02037258(&pBVar6->entries[param_2 >> 0x10], param_2 & 0xffff);
|
||||
|
||||
pSVar5->unk_00->unk_50(pSVar5, pEVar1, (int)&((pBVar6->entries[param_2 >> 0x10].pDAT1)->base).tag + (pEVar3->offset & 0xfffffffe), param_3);
|
||||
pSVar5->vfunc_50(pEVar1, (int)&((pBVar6->entries[param_2 >> 0x10].pDAT1)->base).tag + (pEVar3->offset & 0xfffffffe), param_3);
|
||||
|
||||
if (func_ov000_020d7f18(data_ov000_020eec9c, 0x19) == 0 && func_ov000_020d7f18(data_ov000_020eec9c, 0x18) == 0 &&
|
||||
func_ov000_020d7f18(data_ov000_020eec9c, 0x34) == 0 && func_ov000_020d7f18(data_ov000_020eec9c, 0x35) == 0 &&
|
||||
@@ -200,14 +250,14 @@ ARM Struct_027E0C68_unk_28* UnkStruct_027E0C68::func_02036f68(u32 param_2, u8* p
|
||||
return pSVar5;
|
||||
}
|
||||
|
||||
ARM Struct_027E0C68_unk_18* UnkStruct_027E0C68::func_020370d0(unk32 param_2, unk32 param_3) {
|
||||
ARM UnkStruct_027E0C68_UnkSubClass2* UnkStruct_027E0C68::func_020370d0(unk32 param_2, unk32 param_3) {
|
||||
return this->func_020370e8(param_2, -1, -1, param_3);
|
||||
}
|
||||
|
||||
ARM Struct_027E0C68_unk_18* UnkStruct_027E0C68::func_020370e8(unk32 param_2, unk16 param_3, unk16 param_4, unk32 param_5) {
|
||||
Struct_027E0C68_unk_18* puVar2;
|
||||
ARM UnkStruct_027E0C68_UnkSubClass2* UnkStruct_027E0C68::func_020370e8(unk32 param_2, unk16 param_3, unk16 param_4, unk32 param_5) {
|
||||
UnkStruct_027E0C68_UnkSubClass2* puVar2;
|
||||
|
||||
if (func_02036824() != 0) {
|
||||
if (this->func_02036824() != 0) {
|
||||
puVar2 = this->unk_18;
|
||||
} else {
|
||||
if (this->func_02036850() != 0) {
|
||||
@@ -228,24 +278,24 @@ ARM Struct_027E0C68_unk_18* UnkStruct_027E0C68::func_020370e8(unk32 param_2, unk
|
||||
return NULL;
|
||||
}
|
||||
|
||||
ARM void UnkStruct_027E0C68::func_02037158(Struct_027E0C68_unk_28* param_2) {
|
||||
Struct_027E0C68_unk_28* pSVar1;
|
||||
ARM void UnkStruct_027E0C68::func_02037158(UnkStruct_027E0C68_UnkSubClass1* param_2) {
|
||||
UnkStruct_027E0C68_UnkSubClass1* pSVar1;
|
||||
|
||||
pSVar1 = this->func_02037178(param_2);
|
||||
|
||||
if (pSVar1 != NULL) {
|
||||
pSVar1->unk_00->unk_58(pSVar1);
|
||||
pSVar1->vfunc_58();
|
||||
}
|
||||
}
|
||||
|
||||
ARM Struct_027E0C68_unk_28* UnkStruct_027E0C68::func_02037178(Struct_027E0C68_unk_28* param_2) {
|
||||
Struct_027E0C68_unk_28* piVar1;
|
||||
ARM UnkStruct_027E0C68_UnkSubClass1* UnkStruct_027E0C68::func_02037178(UnkStruct_027E0C68_UnkSubClass1* param_2) {
|
||||
UnkStruct_027E0C68_UnkSubClass1* piVar1;
|
||||
s32 iVar2;
|
||||
|
||||
for (iVar2 = 0; iVar2 < ARRAY_LEN(this->unk_28); iVar2++) {
|
||||
piVar1 = this->unk_28[iVar2];
|
||||
|
||||
if (piVar1 != NULL && piVar1->unk_08 == param_2) {
|
||||
if (piVar1 != NULL && piVar1->unk_08 == (unk32*)param_2) {
|
||||
return piVar1;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user