From a10d749a9549957aaf89d6217e5f5ad85cdfaf73 Mon Sep 17 00:00:00 2001 From: M0liusX Date: Fri, 5 Apr 2024 15:53:50 -0500 Subject: [PATCH] decomp more for w02|dice --- src/REL/w02Dll/dice.c | 120 ++++++++++++++++++++++++++++++++++++++++-- 1 file changed, 115 insertions(+), 5 deletions(-) diff --git a/src/REL/w02Dll/dice.c b/src/REL/w02Dll/dice.c index 81df6305..b178bda7 100644 --- a/src/REL/w02Dll/dice.c +++ b/src/REL/w02Dll/dice.c @@ -3,25 +3,34 @@ /* DATA */ extern char lbl_1_data_2A8[0x12]; extern char lbl_1_data_2BA[0x0D]; +extern char lbl_1_data_2C8[0x10]; /* RODATA*/ extern f32 lbl_1_rodata_38; extern f32 lbl_1_rodata_3C; +extern f32 lbl_1_rodata_40; +extern f32 lbl_1_rodata_44; +extern f32 lbl_1_rodata_48; +extern f32 lbl_1_rodata_4C; /* STRUCTS*/ typedef struct { /* 0x00 */ s16 unk00; - /* 0x02 */ u8 unk02[0x0A]; + /* 0x02 */ s16 unk02; + /* 0x04 */ s32 unk04; + /* 0x08 */ u8 unk08[0x04]; /* 0x0C */ Vec unk0C; - /* 0x18 */ u8 unk18[0xA]; + /* 0x18 */ s16 unk18; + /* 0x1A */ s16 unk1A; + /* 0x1C */ u8 unk1C[0x6]; /* 0x22 */ s16 unk22; - /* 0x24 */ u8 unk24[0x4]; + /* 0x24 */ f32 unk24; /* 0x28 */ s16 unk28; /* 0x2A */ u8 unk2A[0x2]; /* 0x2C */ Process* unk2C; /* 0x30 */ s16 unk30[3]; /* 0x36 */ s16 unk36[3]; - /* 0x3C */ s32 unk3C[3]; + /* 0x3C */ omObjData* unk3C[3]; /* 0x48 */ s16 unk48[3]; /* 0x4E */ u8 unk4E[0x2]; /* 0x50 */ s32 unk50[3]; @@ -32,17 +41,37 @@ typedef struct { /* 0x88 */ s32 unk88[3]; /* 0x94 */ s16 unk94; /* 0x96 */ s16 unk96; - /* 0x98 */ s32 unk98; + /* 0x98 */ f32 unk98; /* 0x9C */ s16 unk9C; } unkW02Dice; +typedef struct { + union { +/* 0x00 */ struct { + u8 unk7 : 1; + u8 unk6 : 1; + u8 unk3 : 3; + u8 unk1 : 2; + u8 unk0 : 1; + }; + u8 unk00; + }; +/* 0x01 */ u8 unk01; +/* 0x02 */ u8 unk02; +/* 0x03 */ u8 unk03; +/* 0x04 */ u16 unk04; +} unkW02DiceBitfields; + /* EXTERN FUNCTIONS */ void fn_1_13D0(void); void fn_1_1574(unkW02Dice*); /* extern */ void fn_1_1794(unkW02Dice*); /* extern */ +void fn_1_1850(omObjData*); /* extern */ +void fn_1_2030(unkW02Dice*); /* extern */ void fn_1_2220(unkW02Dice*); /* extern */ s32 fn_1_233C(unkW02Dice*); /* extern */ void fn_1_23B4(unkW02Dice*, s32 i); /* extern */ +void fn_1_272C(unkW02Dice*); /* extern */ /* LOCAL FUNCTIONS */ void fn_1_1254(unkW02Dice* arg0) { @@ -115,4 +144,85 @@ void fn_1_13D0(void) { while (TRUE) { HuPrcVSleep(); } +} + +void fn_1_1518(unkW02Dice* arg0) { + OSReport(lbl_1_data_2C8); + if (arg0->unk2C) { + HuPrcKill(arg0->unk2C); + } + fn_1_2030(arg0); + fn_1_272C(arg0); +} + +void fn_1_1574(unkW02Dice* arg0) { + Vec sp8; + f32 temp_f0; + omObjData* temp_r3; + s32 temp_r28; + unkW02DiceBitfields* temp_r29; + + temp_r28 = arg0->unk96; + arg0->unk30[temp_r28] = BoardModelCreate(arg0->unk04, NULL, 0); + arg0->unk98 = lbl_1_rodata_40 + BoardRandMod(arg0->unk1A); + BoardModelMotionStart(arg0->unk30[temp_r28], 0, 0x40000001U); + BoardModelMotionSpeedSet(arg0->unk30[temp_r28], lbl_1_rodata_44); + BoardModelMotionTimeSet(arg0->unk30[temp_r28], arg0->unk98); + temp_r3 = omAddObjEx(boardObjMan, 0x102, 0U, 0U, -1, fn_1_1850); + temp_r29 = (unkW02DiceBitfields*) temp_r3->work; + + temp_r29->unk7 = 0; + temp_r29->unk6 = 0; + temp_r29->unk3 = 0; + temp_r29->unk1 = temp_r28; + + temp_r29->unk04 = 0; + temp_r29->unk01 = 3; + temp_r29->unk02 = 0; + temp_r3->unk10 = arg0; + arg0->unk3C[temp_r28] = temp_r3; + sp8 = arg0->unk0C; + sp8.y += (lbl_1_rodata_48 * arg0->unk24); + temp_r3->trans.x = sp8.x; + temp_r3->trans.y = sp8.y; + temp_r3->trans.z = sp8.z; + temp_r3->scale.x = lbl_1_rodata_44; + temp_r3->scale.y = lbl_1_rodata_44; + temp_r3->scale.z = lbl_1_rodata_44; + sp8.z += lbl_1_rodata_4C; + HuAudFXPlay(0x302); +} + +void fn_1_1794(unkW02Dice* arg0) { + unkW02DiceBitfields* temp_r30; + + temp_r30 = (unkW02DiceBitfields*) arg0->unk3C[arg0->unk96]->work; + while (temp_r30->unk3 != 1) { + HuPrcVSleep(); + } +} + +s32 fn_1_17F4(unkW02Dice* arg0) { + unkW02DiceBitfields* temp; + if ( arg0->unk96 < 0) { + return 0; + } + temp = (unkW02DiceBitfields*) arg0->unk3C[arg0->unk96]->work; + if (temp->unk3 != 1) { + return 0; + } + return 1; +} + +void fn_1_1F94(unkW02Dice* arg0, s32 arg1) { + if (arg0->unk30[arg1] != -1) { + BoardModelKill(arg0->unk30[arg1]); + arg0->unk30[arg1] = -1; + } + + if (arg0->unk48[arg1] != -1) { + Hu3DParManKill(arg0->unk48[arg1]); + arg0->unk48[arg1] = -1; + + } } \ No newline at end of file