diff --git a/progress/progress_core2.svg b/progress/progress_core2.svg index 00cf48df..69fd841f 100644 --- a/progress/progress_core2.svg +++ b/progress/progress_core2.svg @@ -9,7 +9,7 @@ - + @@ -17,7 +17,7 @@ core2 - 81.4658% - 81.4658% + 81.7157% + 81.7157% \ No newline at end of file diff --git a/progress/progress_total.svg b/progress/progress_total.svg index a62a3e43..0bd33c51 100644 --- a/progress/progress_total.svg +++ b/progress/progress_total.svg @@ -9,7 +9,7 @@ - + @@ -17,7 +17,7 @@ Banjo-Kazooie (us.v10) - 84.3482% - 84.3482% + 84.4916% + 84.4916% \ No newline at end of file diff --git a/src/core2/code_A4D00.c b/src/core2/code_A4D00.c index d2018d38..c293a11f 100644 --- a/src/core2/code_A4D00.c +++ b/src/core2/code_A4D00.c @@ -3,16 +3,30 @@ #include "variables.h" #include "structs.h" - extern s32 func_80320DB0(f32[3], f32, f32[3], u32); +extern void func_80320ED8(ActorMarker *, f32, s32); extern f32 func_8033229C(ActorMarker *marker); +extern f32 func_80309B24(f32 [3]); + +typedef bool (*method_core2_A4D00_0)(Actor *, f32[3], s32, s32); + +/* .data */ +method_core2_A4D00_0 D_8036E5D0[][6]; + +/* .rodata */ +extern f64 D_80378E70; +extern f64 D_80378E78; +extern f64 D_80378E80; +extern f64 D_80378E88; +extern f32 D_80378E90; /* .bss */ -s32 D_803833D0; +Prop *D_803833D0; + f32 D_803833D8[3]; /* .code */ -bool func_8032BC90(Actor *actor, s32 arg1, s32 arg2, s32 arg3) { +bool func_8032BC90(Actor *actor, f32 arg1[3], s32 arg2, s32 arg3) { f32 sp44[3]; bool sp40; s32 phi_v0; @@ -35,30 +49,192 @@ void func_8032BD64(f32 arg0[3]){ ml_vec3f_copy(arg0, D_803833D8); } +bool func_8032BD88(Actor *arg0, f32 arg1[3], s32 arg2, s32 arg3); #pragma GLOBAL_ASM("asm/nonmatchings/core2/code_A4D00/func_8032BD88.s") -#pragma GLOBAL_ASM("asm/nonmatchings/core2/code_A4D00/func_8032C280.s") +bool func_8032C280(Actor *arg0, f32 arg1[3], s32 arg2, s32 arg3) { + if ((arg0->unk10_25 != 0) && !func_80307390(arg0->unk10_25 - 1, arg0->unk10_18 - 1)) { + return FALSE; + } + return func_8032BD88(arg0, arg1, arg2, arg3); +} -#pragma GLOBAL_ASM("asm/nonmatchings/core2/code_A4D00/func_8032C2F0.s") +bool func_8032C2F0(Actor *arg0, f32 arg1[3], s32 arg2, s32 arg3) { + f32 sp6C[3]; + f32 sp60[3]; + f32 sp20[4][4]; -#pragma GLOBAL_ASM("asm/nonmatchings/core2/code_A4D00/func_8032C404.s") + sp6C[0] = arg0->unk28; + sp6C[1] = 0.0f; + sp6C[2] = 0.0f; + guRotateRPYF(sp20[0], arg0->roll, 90.0f - arg0->yaw, arg0->pitch); + sp60[0] = (sp20[0][0]*sp6C[0]) + (sp20[0][1]*sp6C[1]) + (sp20[0][2]*sp6C[2]); + sp60[1] = (sp20[1][0]*sp6C[0]) + (sp20[1][1]*sp6C[1]) + (sp20[1][2]*sp6C[2]); + sp60[2] = (sp20[2][0]*sp6C[0]) + (sp20[2][1]*sp6C[1]) + (sp20[2][2]*sp6C[2]); + arg0->position[0] += sp60[0]; + arg0->position[1] += sp60[1]; + arg0->position[2] += sp60[2]; + return FALSE; +} -#pragma GLOBAL_ASM("asm/nonmatchings/core2/code_A4D00/func_8032C4AC.s") +bool func_8032C404(Actor *arg0, f32 arg1[3], s32 arg2, s32 arg3) { + f32 sp1C[3]; -#pragma GLOBAL_ASM("asm/nonmatchings/core2/code_A4D00/func_8032C660.s") + sp1C[0] = arg0->unk28; + sp1C[1] = 0.0f; + sp1C[2] = 0.0f; + ml_vec3f_yaw_rotate_copy(sp1C, sp1C, arg0->yaw - D_80378E88); + arg0->position[0] += sp1C[0]; + arg0->position[1] += sp1C[1]; + arg0->position[2] += sp1C[2]; + return FALSE; +} -#pragma GLOBAL_ASM("asm/nonmatchings/core2/code_A4D00/func_8032C6E0.s") +bool func_8032C4AC(Actor *arg0, f32 arg1[3], s32 arg2, s32 arg3) { + f32 sp4C[3]; + f32 sp40[3]; + f32 sp34[3]; + f32 sp30; -#pragma GLOBAL_ASM("asm/nonmatchings/core2/code_A4D00/func_8032C79C.s") + if (arg0->unk138_8) { + arg0->position[1] = func_80309724(arg0->position); + } + else{ + sp30 = func_8033229C(arg0->marker) / 3.0; + sp4C[0] = arg0->position[0]; + sp4C[1] = arg0->position[1]; + sp4C[2] = arg0->position[2]; + sp4C[1] += sp30; + sp40[0] = arg0->position[0]; + sp40[1] = arg0->position[1]; + sp40[2] = arg0->position[2]; + sp40[1] += arg0->unk170; + arg0->unk170 = (-sp30 < time_getDelta() * (arg0->unk170 * 40.0)) ? time_getDelta() * (arg0->unk170 * 40.0) + : -sp30; + if (func_80309B48(sp4C, sp40, sp34, 0x5E0000)) { + arg0->unk170 = -10.0f; + arg0->position[0] = sp40[0]; + arg0->position[1] = sp40[1]; + arg0->position[2] = sp40[2]; + } else { + arg0->position[1] = (arg0->position[1] + arg0->unk170 < D_80378E90) ? D_80378E90 : arg0->position[1] + arg0->unk170; + } + } + return FALSE; +} -#pragma GLOBAL_ASM("asm/nonmatchings/core2/code_A4D00/func_8032C850.s") +bool func_8032C660(Actor *arg0, f32 arg1[3], s32 arg2, s32 arg3) { + f32 temp_f12; + f32 temp_f2; -#pragma GLOBAL_ASM("asm/nonmatchings/core2/code_A4D00/func_8032C99C.s") + temp_f2 = func_80309B24(arg0->position) - 130.0f; + arg0->position[1] = (temp_f2 > arg0->position[1]) ? arg0->position[1] : temp_f2; + return (temp_f2 == arg0->position[1]); +} -#pragma GLOBAL_ASM("asm/nonmatchings/core2/code_A4D00/func_8032C9C0.s") -#pragma GLOBAL_ASM("asm/nonmatchings/core2/code_A4D00/func_8032C9E0.s") +bool func_8032C6E0(Actor *actor, f32 arg1[3], s32 arg2, s32 arg3) { + s32 temp_v0; + u32 temp_v1; -#pragma GLOBAL_ASM("asm/nonmatchings/core2/code_A4D00/func_8032CA40.s") + temp_v0 = func_80309D58(actor->position, actor->unk10_18); + if (actor->unk10_18 == 0) { + actor->unk10_18 = temp_v0; + } + if ((temp_v0 == 0) && (actor->unk10_18 != 0)) { + actor->position[0] = arg1[0]; + actor->position[1] = arg1[1]; + actor->position[2] = arg1[2]; + return TRUE; + } + return FALSE; +} -#pragma GLOBAL_ASM("asm/nonmatchings/core2/code_A4D00/func_8032CA80.s") +bool func_8032C79C(Actor *arg0, f32 arg1[3], s32 arg2, s32 arg3) { + s32 temp_v0; + + if (arg0->unk10_25 != 0) { + temp_v0 = func_80307258(arg0->position, arg0->unk10_25 - 1, arg0->unk10_18 - 1); + if (temp_v0 == -1) { + arg0->position[0] = arg1[0]; + arg0->position[1] = arg1[1]; + arg0->position[2] = arg1[2]; + return TRUE; + } + arg0->unk10_18 = temp_v0 + 1; + return FALSE; + } + return func_8032C6E0(arg0, arg1, arg2, arg3); +} + +bool func_8032C850(Actor *actor, f32 arg1[3], s32 arg2, s32 arg3, bool nonactor) { + Prop *var_v1; + f32 temp_f0; + s32 stored_collidability; + + temp_f0 = func_8033229C(actor->marker); + stored_collidability = actor->marker->collidable; + D_803833D0 = NULL; + actor->marker->collidable = TRUE; + func_80320ED8(actor->marker, temp_f0 / 2, 2); + actor->marker->collidable = stored_collidability; + for(var_v1 = func_8032F528(); var_v1 != NULL; var_v1 = func_8032F528()) { + if (nonactor || (var_v1->markerFlag && (var_v1->actorProp.marker->unk14_20 == actor->marker->unk14_20))) { + D_803833D0 = var_v1; + actor->position[0] = (f32) arg1[0]; + actor->position[1] = (f32) arg1[1]; + actor->position[2] = (f32) arg1[2]; + while (func_8032F528() != NULL) {} + return TRUE; + } + } + return FALSE; +} + +bool func_8032C99C(Actor *actor, f32 arg1[3], s32 arg2, s32 arg3){ + return func_8032C850(actor, arg1, arg2, arg3, 1); +} + + +bool func_8032C9C0(Actor *actor, f32 arg1[3], s32 arg2, s32 arg3){ + return func_8032C850(actor, arg1, arg2, arg3, 0); +} + +void func_8032C9E0(f32 arg0[3]) { + if (D_803833D0 != NULL) { + arg0[0] = (f32) D_803833D0->unk4[0]; + arg0[1] = (f32) D_803833D0->unk4[1]; + arg0[2] = (f32) D_803833D0->unk4[2]; + } +} + +bool func_8032CA40(Actor *actor, f32 arg1[3], s32 arg2, s32 arg3){ + bool var_v1 = (arg3 & 8) ? TRUE : FALSE; + if(var_v1){ + actor->position[0] = arg1[0]; + actor->position[1] = arg1[1]; + actor->position[2] = arg1[2]; + } + return var_v1; +} + +s32 func_8032CA80(Actor *actor, s32 arg1) { + s32 temp_v0_2; + s32 var_s0; + s32 var_s1; + f32 sp40[3]; + + sp40[0] = actor->position[0]; + sp40[1] = actor->position[1]; + sp40[2] = actor->position[2]; + var_s1 = 0; + for(var_s0 = 0; var_s0 < 6; var_s0++){ + if(D_8036E5D0[arg1][var_s0] != NULL){ + temp_v0_2 = D_8036E5D0[arg1][var_s0](actor, sp40, arg1, var_s1); + if (temp_v0_2 != 0) { + var_s1 |= temp_v0_2 << var_s0; + } + } + } + return var_s1; +}