#include #include #include "types.h" #include "functions.h" #include "variables.h" #include "kart_attributes.h" #include "code_8008C1D0.h" #include "code_80027D00.h" #include UNUSED void func_unnamed(void) { } UNUSED void func_8008C1D8(UNUSED s32 arg0) { } UNUSED void func_8008C1E0(UNUSED s32 arg0, UNUSED s32 arg1) { arg1 = 4; } UNUSED void func_unnamed1(UNUSED s32 arg0) { } UNUSED void func_unnamed2(UNUSED s32 arg0) { } UNUSED void func_unnamed3(void) { } UNUSED void func_8008C204(void) { } UNUSED void func_unnamed4(void) { } UNUSED void func_8008C214(void) { } UNUSED void func_unnamed5(void) { } UNUSED void func_unnamed6(void) { } UNUSED void func_unnamed7(void) { } UNUSED void func_unnamed8(void) { } UNUSED void func_8008C23C(void) { } UNUSED void func_unnamed9(void) { } UNUSED void func_unnamed10(void) { } UNUSED void func_unnamed11(void) { } UNUSED void func_unnamed12(void) { } UNUSED void func_unnamed13(void) { } UNUSED void func_unnamed14(void) { } UNUSED void func_unnamed15(void) { } UNUSED void func_unnamed16(void) { } UNUSED void func_unnamed17(void) { } UNUSED void func_unnamed18(void) { } UNUSED void func_unnamed19(void) { } UNUSED void func_unnamed20(void) { } UNUSED void func_unnamed21(void) { } UNUSED void func_unnamed22(UNUSED s32 arg0, UNUSED s32 arg1) { arg1 = 4; } UNUSED void func_unnamed23(void) { } UNUSED void func_unnamed24(void) { } UNUSED void func_unnamed25(void) { } UNUSED void func_unnamed26(void) { } UNUSED void func_unnamed27(void) { } UNUSED void func_unnamed28(void) { } UNUSED void func_unnamed29(void) { } UNUSED void func_unnamed30(void) { } UNUSED void func_unnamed31(void) { } UNUSED void func_unnamed32(void) { } UNUSED void func_unnamed33(void) { } void func_8008C310(Player *player) { if ((player->unk_00C & 2) || (player->unk_00C & 4) || ((player->unk_00C << 9) < 0) || (player->unk_00C & 0x1000000)) { player->unk_0B6 = ((u16)player->unk_0B6 | 0x1000); } } UNUSED void func_unnamed34(void) { } void func_8008C354(Player *player, s8 arg1) { if ((player->unk_0BC & 0x400) == 0x400) { func_8008C6D0(player, arg1); } if (((player->unk_0BC & 0x80) == 0x80) || (player->unk_0BC & 0x40) == 0x40) { func_8008C8C4(player, arg1); } if ((player->unk_0BC & 0x800) == 0x800) { func_8008D0E4(player, arg1); } if ((player->unk_044 & 0x4000) != 0) { func_8008D3B0(player, arg1); } if ((player->unk_0BC & 0x2000) == 0x2000) { func_8008D554(player); } if ((player->unk_0BC & 0x80000) == 0x80000) { func_8008D760(player); } if ((player->unk_0BC & 0x800000) == 0x800000) { func_8008D97C(player); } if ((player->unk_0BC & 0x1000000) == 0x1000000) { func_8008E884(player, arg1); } if ((player->unk_0BC & 0x2000000) == 0x2000000) { func_8008EC34(player, arg1); } if ((player->unk_0BC & 0x100000) == 0x100000) { func_8008EEC4(player); } if ((player->unk_0BC & 4) == 4) { func_8008F0E8(player); } if ((player->unk_0BC & 0x4000) == 0x4000) { func_8008F3E0(player); } if ((player->unk_0BC & 0x10000) == 0x10000) { func_8008F5A4(player, arg1); } if ((player->unk_0BC & 0x10000000) == 0x10000000) { func_8008FEDC(player, arg1); } player->unk_044 = (s16) (player->unk_044 & 0xFFFE); player->unk_0BC = (s32) (player->unk_0BC & ~0x20); } void func_8008C528(Player *player, s8 arg1) { UNUSED s32 sp24; s32 temp_v1; func_8008C354(player, arg1); func_8008C310(player); temp_v1 = player->characterId; player->unk_0C2 = 0; player->kartHopJerk = D_800E37B0[temp_v1]; player->kartHopAcceleration = 0.0f; player->kartHopVelocity = D_800E3790[temp_v1]; player->unk_0A8 = 0; player->unk_0BC = player->unk_0BC | 0x400; player->unk_0BC = player->unk_0BC & ~0x10; player->unk_0C0 = 0; player->unk_236 = 2; player->unk_042 = 0; if (((player->unk_000 & PLAYER_HUMAN) == PLAYER_HUMAN) && ((player->unk_000 & PLAYER_INVISIBLE_OR_BOMB) != PLAYER_INVISIBLE_OR_BOMB)) { func_800C90F4(arg1, (temp_v1 * 0x10) + 0x29008005); func_800C9060(arg1, 0x19009005); } else { func_800098FC(arg1, player); } player->unk_00C = (s32) (player->unk_00C & ~4); } void func_8008C62C(Player *player, s8 arg1) { func_80031F48(player, 5.0f); player->unk_0A8 += (s16)0xA0; player->unk_042 += (s16)0x71C; if (player->unk_0A8 >= 0x2000) { player->unk_0A8 = 0; player->unk_236 = (s16) (player->unk_236 - 1); if (player->unk_236 == 0) { player->unk_0A8 = 0x2000; func_8008C6D0(player, arg1); if (gModeSelection == BATTLE) { func_8006B8B4(player, arg1); } } } } void func_8008C6D0(Player *player, s8 arg1) { player->unk_206 = 0; player->unk_0C4 = 0; player->unk_0BC = (s32) (player->unk_0BC & ~0x400); player->unk_0A8 = 0; player->unk_0C0 = 0; player->unk_07C = 0; player->unk_236 = 0; player->unk_078 = 0; player->unk_09C = 0.0f; D_80165190[0][arg1] = 1; D_80165190[1][arg1] = 1; D_80165190[2][arg1] = 1; D_80165190[3][arg1] = 1; player->unk_042 = 0; } void func_8008C73C(Player *player, s8 arg1) { func_8008C354(player, arg1); if (((player->unk_0BC & 0x80) != 0x80) && ((player->unk_0BC & 0x40) != 0x40)) { player->unk_0BC &= ~0x10; if ((player->unk_0C0 / 182) >= 0) { player->unk_0BC |= 0x40; } else { player->unk_0BC |= 0x80; } player->unk_0B6 |= 0x80; player->unk_0C0 = 0; player->unk_07C = 0; player->unk_078 = 0; player->unk_0AE = player->unk_02E; player->unk_0B2 = 2; D_80165190[0][arg1] = 1; D_80165190[1][arg1] = 1; D_80165190[2][arg1] = 1; D_80165190[3][arg1] = 1; D_80165280[arg1] = player->unk_09C; D_80165480[arg1] = 0; D_80165460[arg1] = 0; D_80165440[arg1] = 0; D_80165420[arg1] = 0; D_8018D920[arg1] = 0; if (((player->unk_000 & 0x4000) == 0x4000) && ((player->unk_000 & 0x100) != 0x100)) { func_800C90F4(arg1, (player->characterId * 0x10) + 0x29008003); } else { func_800098FC(arg1, player); } } } void func_8008C8C4(Player* player, s8 arg1) { player->unk_0BC &= ~0x80; player->unk_0BC &= ~0x40; player->unk_0A8 = 0; player->unk_02E = player->unk_0AE; player->unk_07C = 0; player->unk_0C0 = 0; player->unk_0BC &= ~0x800; D_80165190[0][arg1] = 1; D_80165190[1][arg1] = 1; D_80165190[2][arg1] = 1; D_80165190[3][arg1] = 1; player->unk_046 &= 0xFFBF; if ((D_80165460[arg1] == 1) && ((player->unk_000 & 0x4000) == 0x4000)) { player->unk_09C = (f32) (player->unk_09C + 100.0f); } if ((gModeSelection == VERSUS) && ((player->unk_000 & 0x1000) == 0x1000) && (D_800DC51C == 0) && ((player->unk_0CA & 2) == 0) && (gPlayerPositions[arg1] != 0)) { player->unk_00C = (s32) (player->unk_00C | 0x400000); } } #ifdef MIPS_TO_C //generated by mips_to_c commit bd0364fa19633bd6201f8007e2d0a7ed87825909 ? func_80031F48(void *, ?); /* extern */ ? func_8006B8B4(void *, s8, ? *); /* extern */ ? func_8008C8C4(void *, s8); /* extern */ extern ? D_80165460; extern ? D_80165480; extern ? D_8018D920; extern s32 gModeSelection; static ? D_800E6F60; /* unable to generate initializer; const */ void func_8008C9EC(void *arg0, s8 arg1) { ? sp30; s16 *temp_a0; s16 *temp_a0_2; s16 *temp_v0; s16 *temp_v0_2; s16 temp_t7; s16 temp_t8; s16 temp_v1; s16 temp_v1_2; s32 temp_t7_2; sp30.unk0 = D_800E6F60.unk0; sp30.unk4 = D_800E6F60.unk4; sp30.unk8 = D_800E6F60.unk8; arg0->unk206 = 0; arg0->unkC4 = 0; if ((arg0->unk46 & 0x40) == 0x40) { func_80031F48(0x42C80000); } else { if ((arg0->unk0 & 0x4000) == 0x4000) { func_80031F48(arg0, 0x3F800000); } else { func_80031F48(arg0, 0x40800000); } if ((arg0->unk0 & 0x4000) == 0) { func_80031F48(arg0, 0x41F00000); } } if ((arg0->unkBC & 0x80) == 0x80) { temp_a0 = &sp30 + (arg0->unkB2 * 2); arg0->unk2E = arg0->unk2E - *temp_a0; temp_v0 = (arg1 * 2) + &D_8018D920; temp_t7 = *temp_v0 - *temp_a0; *temp_v0 = temp_t7; temp_v1 = arg0->unkB2; if (((temp_t7 & 0xFFFF) / (0x10000 / (0x168 / (*(&sp30 + (temp_v1 * 2)) / 182)))) == 0) { arg0->unkB2 = temp_v1 - 1; if (arg0->unkB2 <= 0) { if (gModeSelection == BATTLE) { func_8006B8B4(arg0, arg1, &sp30); } func_8008C8C4(arg0, arg1); } } } else { temp_a0_2 = (arg0->unkB2 * 2) + &sp30; arg0->unk2E = arg0->unk2E + *temp_a0_2; temp_v0_2 = (arg1 * 2) + &D_8018D920; temp_t8 = *temp_v0_2 - *temp_a0_2; *temp_v0_2 = temp_t8; temp_v1_2 = arg0->unkB2; if (((temp_t8 & 0xFFFF) / (0x10000 / (0x168 / ((sp + (temp_v1_2 * 2))->unk30 / 182)))) == 0) { arg0->unkB2 = temp_v1_2 - 1; if (arg0->unkB2 <= 0) { func_8008C8C4(arg0, arg1); if (gModeSelection == BATTLE) { func_8006B8B4(arg0, arg1); } } } } temp_t7_2 = arg1 * 4; if ((*(&D_80165460 + temp_t7_2) == 1) && ((arg0->unk0 & 0x4000) == 0x4000)) { *(&D_80165480 + temp_t7_2) = 0x78; if (arg0->unk9C <= 90.0f) { arg0->unk9C = 90.0f; } } } #else GLOBAL_ASM("asm/non_matchings/code_8008C1D0/func_8008C9EC.s") #endif void func_8008CDC0(Player* player, s8 arg1) { func_8008C354(player, arg1); player->unk_00C &= ~1; player->unk_0B4 = 0; player->unk_0B8 = 3.0f; player->unk_0AC = 1; player->unk_0BC &= ~0x10; if (((player->unk_07C >> 0x10) >= 0x14) || ((player->unk_07C >> 0x10) < -0x13) || (((player->unk_094 / 18.0f) * 216.0f) <= 30.0f) || ((player->unk_0BC & 8) != 0) || (((player->unk_000 & 0x4000) == 0) && ((player->unk_0BC & 0x1000) == 0))) { func_8008C73C(player, arg1); } else { player->unk_0BC |= 0x800; } } #ifdef MIPS_TO_C //generated by mips_to_c commit bd0364fa19633bd6201f8007e2d0a7ed87825909 ? func_8008C73C(void *, s8, s16, s16); /* extern */ ? func_800C90F4(u8, s32, s16, s16); /* extern */ void func_8008CEB0(void *arg0, s8 arg1) { f32 sp2C; s16 sp2A; s16 sp28; s16 sp26; f32 temp_f0; f32 temp_f0_2; s16 temp_a3; s16 temp_a3_2; s16 temp_lo; s16 temp_v1; s32 temp_f16; s32 temp_v0; s32 temp_v0_2; s16 phi_a2; s16 phi_a3; s32 phi_a2_2; s16 phi_a2_3; f32 phi_f0; s16 phi_v1; temp_v1 = arg0->unkB4 + 1; temp_f0 = arg0->unkB8; temp_a3 = arg0->unkAC; temp_f16 = (temp_v1 * temp_f0) - (0.2 * (temp_v1 * temp_v1)); phi_a2 = temp_f16; phi_a3 = temp_a3; phi_f0 = temp_f0; phi_v1 = temp_v1; if ((temp_v1 != 0) && (temp_f16 < 0)) { temp_v0 = arg0->unkBC; temp_a3_2 = temp_a3 * -1; temp_f0_2 = temp_f0 * 0.8; phi_a3 = temp_a3_2; phi_f0 = temp_f0_2; phi_v1 = 0; if ((temp_v0 & 1) == 1) { arg0->unkBC = temp_v0 | 0x40000; } if (temp_f0_2 <= 1.0f) { temp_v0_2 = arg0->unkBC & ~0x800; arg0->unkBC = temp_v0_2; if ((temp_v0_2 & 0x40000) != 0x40000) { sp2A = 0; sp26 = temp_f16; sp28 = temp_a3_2; sp2C = temp_f0_2; func_8008C73C(arg0, arg1, temp_f16, temp_a3_2); goto block_9; } arg0->unkB6 = arg0->unkB6 | 0x20; arg0->unkBC = temp_v0_2 & 0xFFFBFFFF; if ((arg0->unk0 & 0x4000) == 0x4000) { sp2C = temp_f0_2; sp28 = temp_a3_2; sp26 = temp_f16; sp2A = 0; func_800C90F4(arg1, (arg0->unk254 * 0x10) + 0x29008008, temp_f16, temp_a3_2); block_9: phi_a2 = temp_f16; phi_a3 = temp_a3 * -1; phi_f0 = sp2C; phi_v1 = 0; } } } temp_lo = phi_a2 * phi_a3; phi_a2_2 = temp_lo; if ((temp_lo <= 0) && (phi_a3 == 1)) { phi_a2_2 = 0; } phi_a2_3 = phi_a2_2; if ((phi_a2_2 >= 0) && (phi_a3 == -1)) { phi_a2_3 = 0; } arg0->unk78 = arg0->unk78 + (phi_a2_3 * 0x12); arg0->unkB8 = phi_f0; arg0->unkB4 = phi_v1; arg0->unkAC = phi_a3; if ((arg0->unkBC & 8) != 0) { func_8008C73C(arg0, arg1, phi_a2_3, phi_a3); arg0->unkBC = arg0->unkBC & ~0x800; } } #else GLOBAL_ASM("asm/non_matchings/code_8008C1D0/func_8008CEB0.s") #endif void func_8008D0E4(Player* player, UNUSED s8 arg1) { player->unk_0BC &= ~0x800; } void func_8008D0FC(Player *player, s8 arg1) { func_8008C354(player, arg1); player->unk_00C &= ~0x80; player->unk_0B4 = 0; player->unk_0B8 = 2.0f; player->unk_0AC = 1; player->unk_0BC &= ~0x10; player->unk_044 |= 0x4000; } #ifdef MIPS_TO_C //generated by mips_to_c commit bd0364fa19633bd6201f8007e2d0a7ed87825909 ? func_8008C73C(void *, s8, s16, s16); /* extern */ ? func_800C90F4(u8, s32, s16, s16); /* extern */ void func_8008D170(void *arg0, s8 arg1) { f32 sp2C; s16 sp2A; s16 sp28; s16 sp26; f32 temp_f0; f32 temp_f0_2; s16 temp_a3; s16 temp_a3_2; s16 temp_lo; s16 temp_v1; s32 temp_f16; s32 temp_v0; s32 temp_v0_2; s16 phi_a2; s16 phi_a3; s32 phi_a2_2; s16 phi_a2_3; f32 phi_f0; s16 phi_v1; temp_v1 = arg0->unkB4 + 1; temp_f0 = arg0->unkB8; temp_a3 = arg0->unkAC; temp_f16 = (temp_v1 * temp_f0) - (0.1 * (temp_v1 * temp_v1)); phi_a2 = temp_f16; phi_a3 = temp_a3; phi_f0 = temp_f0; phi_v1 = temp_v1; if ((temp_v1 != 0) && (temp_f16 < 0)) { temp_v0 = arg0->unkBC; temp_a3_2 = temp_a3 * -1; temp_f0_2 = temp_f0 * 0.9; phi_a3 = temp_a3_2; phi_f0 = temp_f0_2; phi_v1 = 0; if (((temp_v0 & 1) == 1) || ((arg0->unk44 & 0x20) == 0)) { arg0->unkBC = temp_v0 | 0x40000; } if (temp_f0_2 <= 1.3) { temp_v0_2 = arg0->unkBC; arg0->unk44 = arg0->unk44 & 0xBFFF; if ((temp_v0_2 & 0x40000) != 0x40000) { sp2A = 0; sp26 = temp_f16; sp28 = temp_a3_2; sp2C = temp_f0_2; func_8008C73C(arg0, arg1, temp_f16, temp_a3_2); goto block_10; } arg0->unkB6 = arg0->unkB6 | 0x20; arg0->unkBC = temp_v0_2 & 0xFFFBFFFF; if ((arg0->unk0 & 0x4000) == 0x4000) { sp2C = temp_f0_2; sp28 = temp_a3_2; sp26 = temp_f16; sp2A = 0; func_800C90F4(arg1, (arg0->unk254 * 0x10) + 0x29008008, temp_f16, temp_a3_2); block_10: phi_a2 = temp_f16; phi_a3 = temp_a3 * -1; phi_f0 = sp2C; phi_v1 = 0; } } } temp_lo = phi_a2 * phi_a3; phi_a2_2 = temp_lo; if ((temp_lo <= 0) && (phi_a3 == 1)) { phi_a2_2 = 0; } phi_a2_3 = phi_a2_2; if ((phi_a2_2 >= 0) && (phi_a3 == -1)) { phi_a2_3 = 0; } arg0->unk78 = arg0->unk78 + (phi_a2_3 * 0x14); arg0->unkB8 = phi_f0; arg0->unkB4 = phi_v1; arg0->unkAC = phi_a3; if ((arg0->unkBC & 8) != 0) { func_8008C73C(arg0, arg1, phi_a2_3, phi_a3); arg0->unk44 = arg0->unk44 & 0xBFFF; } } #else GLOBAL_ASM("asm/non_matchings/code_8008C1D0/func_8008D170.s") #endif void func_8008D3B0(Player* player, UNUSED s8 arg1) { player->unk_044 &= 0xBFFF; } void func_8008D3C4(Player* player, s8 arg1) { func_8008C354(player, arg1); player->unk_0BC |= 0x2000; player->unk_00C &= ~0x200; player->unk_DB4 = 0; player->unk_DBC = 8.0f; if (D_8015F890 != 1) { if (((player->unk_000 & 0x4000) == 0x4000) && ((player->unk_000 & 0x100) != 0x100)) { func_800C9250(arg1); func_800C9060(arg1, 0x1900A40B); } } else { if (player == gPlayerOne) { func_800C9250(arg1); func_800C9060(arg1, 0x1900A40B); } } player->boostTimer = 0x50; } void func_8008D4B4(Player* player) { player->unk_09C = (f32) player->unk_214; if ( player->boostTimer > 0) { --player->boostTimer; } if (player->boostTimer != 0) { move_f32_towards(&player->boostPower, 400.0f, 0.5f); } else { move_f32_towards(&player->boostPower, 0.0f, 0.1f); } if (player->boostPower <= 1.0f) { player->unk_0BC &= ~0x2000; } } void func_8008D554(Player* player) { player->unk_0BC &= ~0x2000; player->boostPower = 0.0f; } void func_8008D570(Player *player, s8 arg1) { func_8008C354(player, arg1); player->unk_0AE = player->unk_02E; player->unk_0BC |= 0x80000; player->unk_0BC &= ~0x10; player->unk_00C &= ~0x1000; player->kartHopJerk = D_800E3730[player->characterId]; player->kartHopAcceleration = 0.0f; player->kartHopVelocity = (f32) D_800E3710[player->characterId]; player->unk_0B2 = 1; player->unk_0C0 = 0; player->unk_07C = 0; player->unk_078 = 0; D_8018D920[arg1] = 0; if (((player->unk_000 & 0x4000) == 0x4000) && ((player->unk_000 & 0x100) != 0x100)) { func_800C9060(arg1, 0x19008002); } if (((player->unk_000 & 0x4000) == 0x4000) && ((player->unk_000 & 0x100) != 0x100)) { func_800C90F4(arg1, (player->characterId * 0x10) + 0x2900800C); } } void func_8008D698(Player* player, s8 arg1) { s16 temp; if (player->unk_0B2 == 0) { player->unk_02E = player->unk_0AE; temp = 0; } else { player->unk_02E -= 1820; D_8018D920[arg1] -= 1820; temp = ((u16) D_8018D920[arg1] / 1820); } if (temp == 0) { --player->unk_0B2; if (player->unk_0B2 <= 0) { player->unk_0B2 = 0; } if ((player->unk_0B2 == 0) && ((player->unk_0BC & 8) != 8)) { func_8008D760(player); } } } void func_8008D760(Player* player) { player->unk_0A8 = 0; player->unk_07C = 0; player->unk_0C0 = 0; player->unk_02E = player->unk_0AE; player->unk_0BC &= 0xFFF7FFFF; player->unk_100 = gKartGravityTable[player->characterId]; player->unk_000 &= 0xFF7F; } void func_8008D7B0(Player* player, s8 arg1) { func_8008C354(player, arg1); player->unk_0AE = player->unk_02E; player->unk_0BC |= 0x800000; player->unk_0BC &= ~0x10; player->unk_00C &= 0xFFFDFFFF; player->kartHopJerk = D_800E3770[player->characterId]; player->kartHopAcceleration = 0.0f; player->kartHopVelocity = D_800E3750[player->characterId]; D_8018D920[arg1] = 0; player->unk_0B2 = 4; player->unk_0C0 = 0; player->unk_07C = 0; player->unk_078 = 0; if (((player->unk_000 & 0x4000) == 0x4000) && ((player->unk_000 & 0x100) != 0x100)) { func_800C90F4(arg1, (player->characterId * 0x10) + 0x29008003); } } void func_8008D8B4(Player* player, s8 arg1) { s16 temp; if (player->unk_0B2 == 0) { player->unk_02E = player->unk_0AE; temp = 0; } else { player->unk_02E -= 1820; D_8018D920[arg1] -= 1820; temp = ((u16) (D_8018D920[arg1]) / 1820); } if (temp == 0) { --player->unk_0B2; if (player->unk_0B2 <= 0) { player->unk_0B2 = 0; } if ((player->unk_0B2 == 0) && ((player->unk_0BC & 8) != 8)) { func_8008D97C(player); } } } void func_8008D97C(Player *player) { player->unk_0A8 = 0; player->unk_07C = 0; player->unk_0C0 = 0; player->unk_02E = player->unk_0AE; player->unk_0BC &= 0xFF7FFFFF; player->unk_100 = gKartGravityTable[player->characterId]; } void func_8008D9C0(Player* player) { player->unk_DA0 += 8.0f; if (player->unk_DA0 >= 140.0f) { player->unk_DA0 = 140.0f; } if (player->unk_D98 == 1) { player->unk_D9C += player->unk_DA0; if (D_800EF568 <= player->unk_D9C) { player->unk_DA0 = 10.0f; player->unk_D98 *= -1; } } if (player->unk_D98 == -1) { player->unk_D9C -= player->unk_DA0; if (player->unk_D9C <= D_800EF56C) { player->unk_DA0 = 10.0f; player->unk_D98 *= -1; } } } void func_8008DABC(Player *player, s8 arg1) { func_8008C354(player, arg1); if ((player->unk_0BC & 0x4000000) == 0) { player->unk_DB6 = 0; player->unk_238 = 0; player->unk_DC4 = 4.5f; D_8018D990[arg1] = 0; player->unk_0BC &= ~0x08000010; D_80165190[0][arg1] = 1; D_80165190[1][arg1] = 1; D_80165190[2][arg1] = 1; D_80165190[3][arg1] = 1; player->unk_D98 = 1; player->unk_D9C = 0.0f; player->unk_DA0 = 65.0f; if ((player->unk_00C & 0x100) != 0) { player->unk_046 |= 0x80; } if (((player->unk_000 & 0x4000) != 0) && ((player->unk_0BC & 0x04000000) == 0)) { func_800C90F4(arg1, (player->characterId * 0x10) + 0x29008005); } player->unk_0BC |= 0x04000000; if (((player->unk_000) & 0x1000) != 0) { func_800098FC(arg1, player); } } } void func_8008DC08(Player* player, s8 arg1) { player->unk_0C2 = 0; player->unk_0A8 = 0; player->unk_07C = 0; player->unk_0C0 = 0; player->unk_08C = 0.0f; player->unk_09C = 0.0f; if ((player->unk_110.unk44 >= 600.0f) || ((player->unk_0BC & 0x1000) != 0)) { D_8018D990[arg1] = 3; } // placed block on same line to match switch (D_8018D990[arg1]) { case 0: player->unk_DC4 = 4.5f; if (player->unk_238 < 0x3D) { ++player->unk_238; } if ((player->unk_046 & 0x80) != 0) { if ((player->unk_00C & 0x100) == 0) { D_8018D990[arg1] = 1; player->unk_238 = 0; if ((player->unk_000 & 0x4000) != 0) { func_800C9060(arg1, 0x1901904B); break; } } } else { ++player->unk_238; if (player->unk_238 >= 0x1E) { D_8018D990[arg1] = 1; player->unk_238 = 0; if ((player->unk_000 & 0x4000) != 0) { func_800C9060(arg1, 0x1901904B); break; } } break; } break; case 1: player->unk_DC4 = 4.5f; player->pos[1] += D_800EF570; ++player->unk_238; if ((player->unk_046 & 0x80) != 0) { if (player->unk_238 >= 0x32) { D_8018D990[arg1] = 2; player->unk_238 = 0; player->unk_046 &= 0xFF7F; } } else if (player->unk_238 >= 0x50) { D_8018D990[arg1] = 2; player->unk_238 = 0; } player->unk_DA0 += 6.0f; if (player->unk_DA0 >= 90.0f) { player->unk_DA0 = 90.0f; } player->unk_D9C += player->unk_DA0; if (D_800EF578 <= player->unk_D9C) { player->unk_DA0 = 0.0f; break; } break; case 2: ++player->unk_238; if (player->unk_238 >= 0x259) { D_8018D990[arg1] = 3; player->unk_238 = 0; } if (player->unk_110.unk44 >= 600.0f) { D_8018D990[arg1] = 3; } player->unk_DC4 = 4.5f; player->pos[1] -= D_800EF580; if ((player->unk_0BC & 8) != 8) { D_8018D990[arg1] = 3; player->unk_238 = 0; } func_8008D9C0(player); break; case 3: player->unk_DC4 = 3.0f; player->unk_0BC &= ~0x04000000; player->unk_DB6 = 0; player->unk_0BC |= 0x08000000; player->unk_224 = 1.0f; player->boundingBoxSize = gKartBoundingBoxSizeTable[player->characterId]; D_80165190[0][arg1] = 1; D_80165190[1][arg1] = 1; D_80165190[2][arg1] = 1; D_80165190[3][arg1] = 1; if ((player->unk_000 & 0x4000) != 0) { func_800C90F4(arg1, (player->characterId * 0x10) + 0x29008008); } break; } } void func_8008DF98(Player* player, s8 arg1) { func_8008C354(player, arg1); player->unk_00C &= ~0x4000; player->unk_0BC |= 0x40020000; player->unk_0BC &= ~0x10; player->unk_08C *= D_800EF588; player->unk_0B0 = 0; player->unk_224 = 1.0f; D_8018D930[arg1] = gCourseTimer; player->unk_0AE = player->unk_02E; player->unk_0B2 = 2; player->unk_0C0 = 0; player->unk_07C = 0; player->unk_078 = 0; D_80165190[0][arg1] = 1; D_80165190[1][arg1] = 1; D_80165190[2][arg1] = 1; D_80165190[3][arg1] = 1; D_8018D920[arg1] = 0; if (((player->unk_000 & 0x4000) == 0x4000) && ((player->unk_000 & 0x100) != 0x100)) { func_800C90F4(arg1, (player->characterId * 0x10) + 0x29008003); } else { func_800098FC(arg1, player); } if (gModeSelection == BATTLE) { func_8006B8B4(player, arg1); } } #ifdef MIPS_TO_C //generated by mips_to_c commit bd0364fa19633bd6201f8007e2d0a7ed87825909 ? move_f32_towards(void *, f32, ?); /* extern */ ? func_80031F48(void *, ?, s8); /* extern */ ? func_8008DABC(void *, s8, s8); /* extern */ ? func_8008E3C0(s8, s8, s8); /* extern */ ? func_800C90F4(s32, s32, s8); /* extern */ extern ? D_80165190; extern ? D_8018D920; extern ? gKartBoundingBoxSizeTable; void func_8008E118(void *arg0, s8 arg1) { s16 *temp_v0_3; s16 temp_t0; s32 temp_a0; s32 temp_v0; s8 temp_a2; s8 temp_t1; void *temp_v0_2; void *temp_v0_4; s8 phi_a2; temp_v0 = arg0->unkBC; temp_a2 = arg1; phi_a2 = temp_a2; if (((temp_v0 & 0x8000) == 0x8000) && ((temp_v0 & 0x4000000) != 0x4000000)) { arg0->unkBC = temp_v0 & 0xFFFDFFFF; arg0->unkA8 = 0; arg0->unk7C = 0; arg0->unkC0 = 0; temp_t1 = arg1; arg0->unk2E = arg0->unkAE; arg1 = arg1; func_8008E3C0(temp_t1, temp_a2); temp_v0_2 = (arg1 * 2) + &D_80165190; temp_v0_2->unk0 = 1; temp_v0_2->unk10 = 1; temp_v0_2->unk20 = 1; temp_v0_2->unk30 = 1; func_8008DABC(arg0, arg1, arg1); return; } temp_a0 = temp_a2 * 2; if ((temp_v0 & 0x20000) == 0x20000) { arg0->unk2E = arg0->unk2E - 0x5B0; temp_v0_3 = temp_a0 + &D_8018D920; temp_t0 = *temp_v0_3 - 0x5B0; *temp_v0_3 = temp_t0; if (((temp_t0 & 0xFFFF) / 1456) == 0) { arg0->unkB2 = arg0->unkB2 - 1; if (arg0->unkB2 <= 0) { arg0->unkA8 = 0; arg0->unkBC = arg0->unkBC & 0xFFFDFFFF; arg0->unk7C = 0; arg0->unkC0 = 0; temp_v0_4 = temp_a0 + &D_80165190; arg0->unk2E = arg0->unkAE; temp_v0_4->unk0 = 1; temp_v0_4->unk10 = 1; temp_v0_4->unk20 = 1; temp_v0_4->unk30 = 1; } } func_80031F48(arg0, 0x3F800000, temp_a2); return; } arg0->unkB0 = arg0->unkB0 + 1; arg0->unk8C = arg0->unk8C * 0.6; if ((arg0->unkB0 == 1) && ((arg0->unk0 & 0x4000) != 0)) { arg1 = temp_a2; func_800C90F4(temp_a2 & 0xFF, (arg0->unk254 * 0x10) + 0x29008005, temp_a2); phi_a2 = arg1; } if ((arg0->unkB0 >= 0) && (arg0->unkB0 < 0x1CC)) { move_f32_towards(arg0 + 0x224, 0.7f, 0x3DCCCCCD); move_f32_towards(arg0 + 0x70, *(&gKartBoundingBoxSizeTable + (arg0->unk254 * 4)) * 0.9, 0x3DCCCCCD); return; } arg1 = phi_a2; func_8008E3C0(arg0, phi_a2, phi_a2); if ((arg0->unk0 & 0x4000) != 0) { func_800C90F4(arg1 & 0xFF, (arg0->unk254 * 0x10) + 0x29008008, arg1); } } #else GLOBAL_ASM("asm/non_matchings/code_8008C1D0/func_8008E118.s") #endif void func_8008E3C0(Player* player, UNUSED s8 arg1) { move_f32_towards(&player->unk_224, 1.0f, 0.1f); move_f32_towards(&player->boundingBoxSize, gKartBoundingBoxSizeTable[player->characterId], 0.1f); player->unk_0BC &= ~0x40000000; player->unk_224 = 1.0f; player->boundingBoxSize = gKartBoundingBoxSizeTable[player->characterId]; player->unk_DC4 = 3.0f; player->unk_DB6 = 0; player->unk_0BC |= 0x08000000; if ((player->unk_0BC & 0x20000) == 0x20000) { player->unk_02E = player->unk_0AE; } player->unk_0BC &= ~0x20000; } void func_8008E4A4(Player* player, s8 arg1) { player->unk_206 = 0; player->unk_0C4 = 0; player->unk_0C0 = 0; player->unk_07C = 0; player->unk_0C2 = 0xF; player->unk_042 += 0xAAA; player->unk_08C = 0.0f; player->unk_09C = 0.0f; player->unk_034[0] = 0.0f; player->unk_034[2] = 0.0f; player->unk_0BC &= ~0xC0; if ((player->unk_0BC & 8) != 8) { ++player->unk_0E0; } if (player->unk_0E0 == 3) { player->unk_0BC &= ~0x01000000; player->unk_0A8 = 0; player->unk_236 = 0; D_80165190[0][arg1] = 1; D_80165190[1][arg1] = 1; D_80165190[2][arg1] = 1; D_80165190[3][arg1] = 1; player->unk_042 = 0; player->unk_000 &= ~0x80; if ((D_80165460[arg1] == 1) && ((player->unk_000 & 0x4000) == 0x4000)) { player->unk_09C += 100.0f; } if (gModeSelection == 3) { func_8006B8B4(player, arg1); } } else { player->unk_0A8 += 0x80; if (player->unk_0A8 >= 0x2000) { player->unk_0A8 = 0; --player->unk_236; if (player->unk_236 == 0) { player->unk_0BC &= ~0x01000000; player->unk_236 = 0; D_80165190[0][arg1] = 1; D_80165190[1][arg1] = 1; D_80165190[2][arg1] = 1; D_80165190[3][arg1] = 1; player->unk_042 = 0; if (gModeSelection == 3) { func_8006B8B4(player, arg1); } if ((D_80165460[arg1] == 1) && ((player->unk_000 & 0x4000) == 0x4000)) { player->unk_09C += 100.0f; } player->unk_000 &= ~0x80; } } } } void func_8008E6C0(Player *player, s8 arg1) { func_8008C354(player, arg1); func_8008C310(player); player->unk_0A8 = 0; player->unk_0BC |= 0x01000000; player->unk_0BC &= ~0x10; player->kartHopJerk = 0.0f; player->kartHopAcceleration = 0.0f; player->kartHopVelocity = 0.0f; player->kartHopJerk = D_800E3730[player->characterId]; player->kartHopVelocity = D_800E3710[player->characterId]; player->unk_236 = 4; player->unk_042 = 0; player->unk_0E0 = 0; if (((player->unk_000 & 0x4000) == 0x4000) && ((player->unk_000 & 0x100) != 0x100)) { if (((gModeSelection == 2) && ((player->unk_000 & 0x1000) != 0)) && (D_800DC51C == 0)) { func_800CA24C(arg1); } if (1) { } func_800C90F4(arg1, (player->characterId * 0x10) + 0x29008005); if (((gModeSelection == 2) && ((player->unk_000 & 0x1000) != 0)) && (D_800DC51C == 0)) { func_800CA24C(arg1); } func_800C9060(arg1, 0x19009005); } else { func_800098FC(arg1, player); } player->unk_00C &= ~0x00480000; player->unk_0B6 |= 0x40; D_80165480[arg1] = 0; D_80165460[arg1] = 0; D_80165440[arg1] = 0; D_80165420[arg1] = 0; } void func_8008E884(Player* player, s8 arg1) { player->unk_0BC &= ~0x01000000; player->unk_0A8 = 0; player->unk_236 = 0; D_80165190[0][arg1] = 1; D_80165190[1][arg1] = 1; D_80165190[2][arg1] = 1; D_80165190[3][arg1] = 1; player->unk_042 = 0; } void func_8008E8D8(Player *player, s8 arg1) { player->unk_206 = 0; player->unk_0C4 = 0; player->unk_0C0 = 0; player->unk_07C = 0; player->unk_0C2 = 0xF; player->unk_042 += 0xAAA; player->unk_08C /= 2; player->unk_09C = 0.0f; player->unk_0BC &= ~0xC0; if ((player->unk_0BC & 8) != 8) { ++player->unk_0E0; } if (player->unk_0E0 == 4) { player->unk_0BC &= ~0x02000000; player->unk_0A8 = 0; player->unk_236 = 0; D_80165190[3][arg1] = 1; D_80165190[0][arg1] = 1; D_80165190[1][arg1] = 1; D_80165190[2][arg1] = 1; player->unk_042 = 0; if ((D_80165460[arg1] == 1) && ((player->unk_000 & 0x4000) == 0x4000)) { player->unk_09C += 100.0f; } if (gModeSelection == BATTLE) { func_8006B8B4(player, arg1); } } else { player->unk_0A8 = (s16)(player->unk_0A8 + 0x90); if (((s32)player->unk_0A8) >= 0x2000) { player->unk_0A8 = 0; --player->unk_236; if (player->unk_236 == 0) { player->unk_0BC &= ~0x02000000; player->unk_236 = 0; D_80165190[0][arg1] = 1; D_80165190[1][arg1] = 1; D_80165190[2][arg1] = 1; D_80165190[3][arg1] = 1; player->unk_042 = 0; if ((D_80165460[arg1] == 1) && ((player->unk_000 & 0x4000) == 0x4000)) { player->unk_09C += 100.0f; } if (gModeSelection == BATTLE) { func_8006B8B4(player, arg1); } } } } } void func_8008EAE0(Player* player, s8 arg1) { func_8008C354(player, arg1); func_8008C310(player); player->unk_0A8 = 0; player->unk_0BC &= ~0x10; player->kartHopJerk = 0.0f; player->kartHopAcceleration = 0.0f; player->kartHopVelocity = 0.0f; player->kartHopJerk = D_800E3730[player->characterId]; player->kartHopVelocity = D_800E3710[player->characterId]; player->unk_236 = 4; player->unk_042 = 0; player->unk_0E0 = 0; if (((player->unk_000 & 0x4000) == 0x4000) && ((player->unk_000 & 0x100) != 0x100)) { func_800C90F4(arg1, (player->characterId * 0x10) + 0x29008005); func_800C9060(arg1, 0x19009005); } else { func_800098FC(arg1, player); } player->unk_0BC |= 0x02000000; player->unk_0B6 |= 0x40; player->unk_00C &= ~0x01000002; D_80165480[arg1] = 0; D_80165460[arg1] = 0; D_80165440[arg1] = 0; D_80165420[arg1] = 0; } void func_8008EC34(Player* player, s8 arg1) { player->unk_0BC &= ~0x02000000; player->unk_0A8 = 0; player->unk_236 = 0; D_80165190[0][arg1] = 1; D_80165190[1][arg1] = 1; D_80165190[2][arg1] = 1; D_80165190[3][arg1] = 1; player->unk_042 = 0; } void func_8008EC88(Player* player, s8 arg1) { func_8008C354(player, arg1); player->unk_0BC |= 0x100000; player->unk_00C &= ~0x00800000; player->unk_DB4 = 0; player->unk_DBC = 8.0f; if (D_8015F890 != 1) { if (((player->unk_000 & 0x4000) == 0x4000) && ((player->unk_000 & 0x100) == 0)) { func_800C90F4(arg1, (player->characterId * 0x10) + 0x29008001); func_800C9060(arg1, 0x1900A40B); } } else if (player == gPlayerOne) { func_800C90F4(arg1, (player->characterId * 0x10) + 0x29008001); func_800C9060(arg1, 0x1900A40B); } player->unk_044 &= ~0x1; player->unk_0BC &= ~0x20; } void func_8008EDC0(Player* player) { f64 temp_f0; player->unk_09C = player->unk_214; if ((u16) player->unk_256 > 0) { player->unk_09C = 0.0f; } if ((*((u16*)&player->unk_0F8) != 0xFE) && ((player->unk_0BC & 8) != 8)) { move_f32_towards(&player->boostPower, 0, 1.0f); } else { move_f32_towards(&player->boostPower, 400.0f, 0.01f); } if (player->boostPower <= 1.0f) { player->unk_0BC &= ~0x00100000; player->boostPower = 0.0f; if (player->unk_0C2 >= 0x33) { temp_f0 = D_800EF5A0; player->unk_09C = (player->unk_09C * temp_f0); player->unk_08C = (player->unk_08C * temp_f0); } } } void func_8008EEC4(Player* player) { player->unk_0BC &= ~0x00100000; player->boostPower = 0.0f; } void func_8008EEE4(Player* player, s8 arg1) { func_8008C354(player, arg1); player->unk_0BC |= 0x4; player->unk_00C &= ~0x8000; if (D_8015F890 != 1) { if (((player->unk_000 & 0x4000) == 0x4000) && ((player->unk_000 & 0x100) == 0)) { func_800C90F4(arg1, (player->characterId * 0x10) + 0x29008001); func_800C9060(arg1, 0x1900A40B); } } else if (player == gPlayerOne) { func_800C90F4(arg1, (player->characterId * 0x10) + 0x29008001); func_800C9060(arg1, 0x1900A40B); } player->unk_044 &= ~0x1; player->unk_0BC &= ~0x20; } void func_8008F008(Player* player) { player->unk_09C = D_800E261C[0][player->characterId]; if ( ( *((u16*) player->unk_0F8) != 0xFC) && ((player->unk_0BC & 8) != 8)) { move_f32_towards(&player->boostPower, 0, 1.0f); } else { move_f32_towards(&player->boostPower, 300.0f, 0.1f); } if (player->boostPower <= 1.0f) { player->unk_0BC &= ~0x4; player->boostPower = 0.0f; player->unk_09C /= 2; player->unk_08C /= 2; } } void func_8008F0E8(Player* player) { player->unk_0BC &= ~4; player->boostPower = 0.0f; } void func_8008F104(Player* player, s8 arg1) { func_8008C354(player, arg1); player->unk_0AE = player->unk_02E; player->unk_0B2 = 2; player->unk_0C0 = 0; player->unk_07C = 0; player->unk_0BC |= 0x4000; player->unk_078 = 0; D_8018D920[arg1] = -0x8000; if (((player->unk_000 & 0x4000) == 0x4000) && ((player->unk_000 & 0x100) != 0x100)) { func_800C90F4(arg1, (player->characterId * 0x10) + 0x29008003); } } void func_8008F1B8(Player* player, s8 arg1) { s16 temp; player->unk_08C = (player->unk_210 * D_800EF5A8); if (player->unk_0B2 < 0) { if ((player->unk_044 & 0x80) == 0x80) { player->unk_02E += 182; D_8018D920[arg1] += 182; temp = ((u16) D_8018D920[arg1] / 182); if (temp == 180) { player->unk_0BC &= ~0x4000; player->unk_000 &= ~0x80; player->unk_09C /= 3.0f; } } else { player->unk_02E -= 182; D_8018D920[arg1] -= 182; temp = ((u16) D_8018D920[arg1] / 182); if (temp == 180) { player->unk_0BC &= ~0x4000; player->unk_000 &= ~0x80; player->unk_09C /= 3.0f; } } } else { if ((player->unk_0B2 & 1) != 0) { player->unk_02E -= 364; D_8018D920[arg1] -= 364; temp = ((u16) D_8018D920[arg1] / 364); if (temp < 71) { --player->unk_0B2; } player->unk_044 |= 0x80; player->unk_044 &= ~0x40; return; } player->unk_02E += 364; D_8018D920[arg1] += 364; temp = ((u16) D_8018D920[arg1] / 364); if (temp >= 110) { --player->unk_0B2; } player->unk_044 |= 0x40; player->unk_044 &= ~0x80; } } void func_8008F3E0(Player* player) { player->unk_0BC &= ~0x4000; } void func_8008F3F4(Player* player, UNUSED s8 arg1) { player->unk_0A8 += 0x80; player->unk_042 += 0x71C; player->unk_07C = 0; player->unk_09C = 0.0f; player->unk_08C /= 2; if (player->unk_0A8 >= 0x2000) { player->unk_0A8 = 0; --player->unk_236; if (player->unk_236 == 0) { player->unk_0BC &= ~0x00010000; func_80090778(player); func_80090868(player); } } } void func_8008F494(Player* player, s8 arg1) { if ((((player->unk_0BC & 0x80) != 0) || ((player->unk_0BC & 0x40) != 0) || ((player->unk_0BC << 7) < 0) || ((player->unk_0BC << 6) < 0) || ((player->unk_0BC & 0x400) != 0)) && (gModeSelection == 3)) { player->unk_044 |= 0x8000; } func_8008C354(player, arg1); func_8008F86C(player, arg1); player->unk_0A8 = 0; player->unk_0BC |= 0x10000; player->unk_0BC &= ~0x10; player->unk_236 = 0x1E; player->unk_042 = 0; if (((player->unk_000 & 0x4000) != 0) && ((player->unk_000 & 0x100) == 0) && ((player->unk_0CA & 2) == 0) && ((player->unk_0DE & 1) == 0) && ((player->unk_0DE & 2) == 0)) { func_800C90F4(arg1, (player->characterId * 0x10) + 0x29008004); } } void func_8008F5A4(Player* player, s8 arg1) { if ((player->unk_044 & 0x8000) != 0) { func_8006B8B4(player, arg1); player->unk_044 &= ~0x8000; } player->unk_206 = 0; player->unk_0C4 = 0; player->unk_0BC &= ~0x10000; player->unk_0A8 = 0; player->unk_0C0 = 0; player->unk_07C = 0; player->unk_236 = 0; player->unk_078 = 0; player->unk_09C = 0.0f; D_80165190[0][arg1] = 1; D_80165190[1][arg1] = 1; D_80165190[2][arg1] = 1; D_80165190[3][arg1] = 1; player->unk_042 = 0; } void func_8008F650(Player* player, s8 arg1) { if (((s32) gCourseTimer - D_8018D930[arg1]) >= 9) { D_8018D900[arg1] = 1; if (((player->unk_000 & 0x4000) == 0x4000) && ((player->unk_000 & 0x100) != 0x100)) { if (D_8018D900[arg1] == 1) { func_800CA730(arg1); D_8018D900[arg1] = 0; } } else if (D_8018D900[arg1] == 1) { func_800CAACC((u8)arg1); D_8018D900[arg1] = 0; } } if (((s32) gCourseTimer - D_8018D930[arg1]) >= 0xA) { player->unk_0BC &= ~0x200; } } void func_8008F778(Player* player, s8 arg1) { func_8008C354(player, arg1); player->unk_0BC |= 0x200; player->unk_00C &= ~0x2000; D_8018D930[arg1] = gCourseTimer; D_8018D900[arg1] = 1; if (((player->unk_000 & 0x4000) == 0x4000) && ((player->unk_000 & 0x100) != 0x100)) { if (D_8018D900[arg1] == 1) { func_800CA59C(arg1); D_8018D900[arg1] = 2; } } else if (D_8018D900[arg1] == 1) { func_800CA984(arg1); D_8018D900[arg1] = 2; } } void func_8008F86C(Player* player, s8 arg1) { player->unk_0BC &= ~0x200; if (((player->unk_000 & 0x4000) == 0x4000) && ((player->unk_000 & 0x100) != 0x100)) { func_800CA730(arg1); return; } func_800CAACC(arg1); } void func_8008F8DC(Player* arg0, s8 arg1) { s32 tmp; tmp = ((s32) gCourseTimer) - D_8018D950[arg1]; if (tmp < 7) { arg0->unk_0C6 -= 2; if (arg0->unk_0C6 < 0x61) { arg0->unk_0C6 = 0x60; } D_8018D970[arg1] -= 2; if (D_8018D970[arg1] <= 0) { D_8018D970[arg1] = 0; } } else { arg0->unk_0C6 += 4; if (arg0->unk_0C6 >= 0xF0) { arg0->unk_0C6 = 0xFF; D_8018D970[arg1] = 0xFF; arg0->unk_0BC &= ~0x80000000; if ((arg0->unk_000 & 0x4000) != 0) { func_800CB064(arg1); } } D_8018D970[arg1] += 8; if (D_8018D970[arg1] >= 0xF0) { D_8018D970[arg1] = 0xFF; arg0->unk_0C6 = 0xFF; arg0->unk_0BC &= ~0x80000000; if ((arg0->unk_000 & 0x4000) != 0) { func_800CB064(arg1); } } } } void func_8008FA38(Player* player, s8 arg1) { s16 temp_v1; if ((player->unk_000 & 0x4000) != 0) { player->unk_044 |= 0x200; for (temp_v1 = 0; temp_v1 < 10; ++temp_v1) { player->unk_258[temp_v1].unk_01C = 0; player->unk_258[temp_v1].unk_01E = 0; player->unk_258[temp_v1].unk_012 = 0; } } func_8008C354(player, arg1); player->unk_0BC |= 0x80000000; player->unk_00C &= ~0x800; D_8018D950[arg1] = gCourseTimer; D_8018D970[arg1] = 0xFF; if ((player->unk_000 & 0x4000) != 0) { func_800CAFC0(arg1); } } void func_8008FB30(Player* arg0, s8 arg1) { arg0->unk_0C6 += 8; if (arg0->unk_0C6 >= 0xF0) { arg0->unk_0C6 = 0xFF; D_8018D970[arg1] = 0xFF; arg0->unk_0BC &= ~0x80000000; if ((arg0->unk_000 & 0x4000) != 0) { func_800CB064(arg1); } } D_8018D970[arg1] += 0x10; if (D_8018D970[arg1] >= 0xE0) { D_8018D970[arg1] = 0xFF; arg0->unk_0C6 = 0xFF; arg0->unk_0BC &= ~0x80000000; if ((arg0->unk_000 & 0x4000) != 0) { func_800CB064(arg1); } } } void func_8008FC1C(Player* player) { s32 playerIndex; if ((player->unk_000 & 0x40) != 0) { playerIndex = get_player_index_for_player(player); player->unk_000 = 0x7000; func_80056A94(playerIndex, player); } } void func_8008FC64(Player* player, s8 arg1) { player->unk_0C6 -= 4; if (player->unk_0C6 < 5) { player->unk_0C6 = 0; player->unk_00C &= 0xFBFFFFFF; player->unk_00C |= 0x08000000; player->unk_000 |= 0x40; func_8008FDA8(player, arg1); func_800569F4(arg1); } } void func_8008FCDC(Player* player, s8 arg1) { player->unk_0C6 += 2; if (player->unk_0C6 >= 0xF0) { player->unk_0C6 = 0xFF; player->unk_00C &= ~0x08000000; } func_80056A40(arg1, (u32) player->unk_0C6); } void func_8008FD4C(Player* player, UNUSED s8 arg1) { s16 temp_v0; player->unk_00C |= 0x04000000; player->unk_044 |= 0x200; for (temp_v0 = 0; temp_v0 < 10; ++temp_v0) { player->unk_258[temp_v0].unk_01C = 0; player->unk_258[temp_v0].unk_01E = 0; player->unk_258[temp_v0].unk_012 = 0; } } void func_8008FDA8(Player* player, UNUSED s8 arg1) { s16 temp_v0; player->unk_044 |= 0x200; for (temp_v0 = 0; temp_v0 < 10; ++temp_v0) { player->unk_258[temp_v0].unk_01C = 0; player->unk_258[temp_v0].unk_01E = 0; player->unk_258[temp_v0].unk_012 = 0; } } void func_8008FDF4(Player* player, UNUSED s8 arg1) { func_8008C354(player, arg1); player->unk_0BC &= ~0x10; player->kartHopJerk = D_800E37F0[player->characterId]; player->kartHopAcceleration = 0.0f; player->kartHopVelocity = D_800E37D0[player->characterId]; player->unk_00C &= ~0x00100000; player->unk_0BC |= 0x10000000; } void func_8008FE84(Player* player, UNUSED s8 arg1) { player->unk_0BC &= ~0x10; if ((player->unk_0BC & 8) != 8) { player->unk_0BC &= ~0x10000000; player->unk_09C /= 2; player->unk_08C /= 2; } } void func_8008FEDC(Player* player, UNUSED s8 arg1) { player->unk_0BC &= ~0x10000000; player->kartHopJerk = 0.0f; player->kartHopVelocity = 0.0f; player->kartHopAcceleration = 0.0f; } #ifdef NEEDS_RODATA void func_8008FF08(Player *player, s8 arg1) { s8 arg1Copy; arg1Copy = arg1; switch (gCurrentCourseId) { case COURSE_BOWSER_CASTLE: if ((((s16)D_80164438[arg1Copy]) >= 0x235) && (((s16)D_80164438[arg1Copy]) < 0x247)) { player->unk_220 = 0x214U; break; } if ((((s16)D_80164438[arg1Copy]) >= 0x267) && (((s16)D_80164438[arg1Copy]) < 0x277)) { player->unk_220 = 0x25BU; break; } player->unk_220 = D_80164438[arg1Copy]; if (player->unk_220 < 0) { player->unk_220 = D_801645C8 + player->unk_220; break; } break; case COURSE_BANSHEE_BOARDWALK: if ((((s16)D_80164438[arg1Copy]) >= 0x12C) && (((s16)D_80164438[arg1Copy]) < 0x13C)) { player->unk_220 = 0x12CU; break; } player->unk_220 = D_80164438[arg1Copy]; if (player->unk_220 < 0) { player->unk_220 = D_801645C8 + player->unk_220; break; } break; case COURSE_YOSHI_VALLEY: case COURSE_RAINBOW_ROAD: player->unk_220 = D_80165320[arg1Copy]; break; case COURSE_FRAPPE_SNOWLAND: if ((((s16)D_80164438[arg1Copy]) >= 0xF0) && (((s16)D_80164438[arg1Copy]) < 0x105)) { player->unk_220 = 0xF0U; break; } player->unk_220 = D_80165320[arg1Copy]; if (player->unk_220 < 0) { player->unk_220 = D_801645C8 + player->unk_220; break; } break; case COURSE_ROYAL_RACEWAY: if ((((s16)D_80164438[arg1Copy]) >= 0x258) && (((s16)D_80164438[arg1Copy]) < 0x2A4)) { player->unk_220 = 0x258U; break; } player->unk_220 = D_80165320[arg1Copy]; if (player->unk_220 < 0) { player->unk_220 = D_801645C8 + player->unk_220; break; } break; case COURSE_DK_JUNGLE: if ((((s16)D_80164438[arg1Copy]) >= 0xB9) && (((s16)D_80164438[arg1Copy]) < 0x119)) { player->unk_220 = 0xB9U; break; } player->unk_220 = D_80164438[arg1Copy]; if (player->unk_220 < 0) { player->unk_220 = D_801645C8 + player->unk_220; break; } break; case COURSE_BLOCK_FORT: case COURSE_SKYSCRAPER: case COURSE_DOUBLE_DECK: case COURSE_BIG_DONUT: player->unk_220 = 0U; break; default: player->unk_220 = D_80164438[arg1Copy]; if (player->unk_220 < 0) { player->unk_220 = D_801645C8 + player->unk_220; break; } break; } } #else GLOBAL_ASM("asm/non_matchings/code_8008C1D0/func_8008FF08.s") #endif #ifdef MIPS_TO_C //generated by mips_to_c commit bd0364fa19633bd6201f8007e2d0a7ed87825909 extern s32 D_80164550; extern u16 D_801645C8; extern ? D_80165310; static s16 gCurrentCourseId; /* type too large by 2; unable to generate initializer */ static ? D_800E6F6C; /* unable to generate initializer; const */ static ? D_800E6F7C; /* unable to generate initializer; const */ static ? D_800E6F8C; /* unable to generate initializer; const */ static ? D_800E6F9C; /* unable to generate initializer; const */ static ? D_800E6FAC; /* unable to generate initializer; const */ static ? D_800E6FBC; /* unable to generate initializer; const */ static ? D_800E6FCC; /* unable to generate initializer; const */ static ? D_800E6FDC; /* unable to generate initializer; const */ static ? D_800E6FEC; /* unable to generate initializer; const */ static ? D_800E6FFC; /* unable to generate initializer; const */ static ? D_800E700C; /* unable to generate initializer; const */ static ? D_800E701C; /* unable to generate initializer; const */ static ? D_800E702C; /* unable to generate initializer; const */ static ? D_800E703C; /* unable to generate initializer; const */ static ? D_800E704C; /* unable to generate initializer; const */ static ? D_800E705C; /* unable to generate initializer; const */ void func_80090178(void *arg0, s8 arg1, void *arg2, void *arg3) { ? spF8; ? spE8; ? spD8; ? spC8; ? spB8; ? spA8; ? sp98; ? sp88; ? sp78; ? sp68; ? sp58; ? sp48; ? sp38; ? sp28; ? sp18; ? sp8; s16 temp_t9; s32 temp_a0; s32 temp_a0_2; s32 temp_a0_3; s32 temp_a0_4; u16 *temp_t0; u16 temp_t1; void *temp_v1; void *temp_v1_2; void *temp_v1_3; void *temp_v1_4; f32 phi_f10; spF8.unk0 = D_800E6F6C.unk0; spF8.unk4 = D_800E6F6C.unk4; spF8.unk8 = D_800E6F6C.unk8; spF8.unkC = D_800E6F6C.unkC; spE8.unk0 = D_800E6F7C.unk0; spE8.unk4 = D_800E6F7C.unk4; spE8.unk8 = D_800E6F7C.unk8; spE8.unkC = D_800E6F7C.unkC; spD8.unk0 = D_800E6F8C.unk0; spD8.unk4 = D_800E6F8C.unk4; spD8.unk8 = D_800E6F8C.unk8; spD8.unkC = D_800E6F8C.unkC; spC8.unk0 = D_800E6F9C.unk0; spC8.unk4 = D_800E6F9C.unk4; spC8.unk8 = D_800E6F9C.unk8; spC8.unkC = D_800E6F9C.unkC; spB8.unk0 = D_800E6FAC.unk0; spB8.unk4 = D_800E6FAC.unk4; spB8.unk8 = D_800E6FAC.unk8; spB8.unkC = D_800E6FAC.unkC; spA8.unk0 = D_800E6FBC.unk0; spA8.unk4 = D_800E6FBC.unk4; spA8.unk8 = D_800E6FBC.unk8; spA8.unkC = D_800E6FBC.unkC; sp98.unk0 = D_800E6FCC.unk0; sp98.unk4 = D_800E6FCC.unk4; sp98.unk8 = D_800E6FCC.unk8; sp98.unkC = D_800E6FCC.unkC; sp88.unk0 = D_800E6FDC.unk0; sp88.unk4 = D_800E6FDC.unk4; sp88.unk8 = D_800E6FDC.unk8; sp88.unkC = D_800E6FDC.unkC; sp78.unk4 = D_800E6FEC.unk4; sp78.unk0 = D_800E6FEC.unk0; sp78.unk8 = D_800E6FEC.unk8; sp78.unkC = D_800E6FEC.unkC; sp68.unk0 = D_800E6FFC.unk0; sp68.unk4 = D_800E6FFC.unk4; sp68.unkC = D_800E6FFC.unkC; sp68.unk8 = D_800E6FFC.unk8; sp58.unk0 = D_800E700C.unk0; sp58.unk4 = D_800E700C.unk4; sp58.unkC = D_800E700C.unkC; sp58.unk8 = D_800E700C.unk8; sp48.unk0 = D_800E701C.unk0; sp48.unk4 = D_800E701C.unk4; sp48.unkC = D_800E701C.unkC; sp48.unk8 = D_800E701C.unk8; sp38.unk0 = D_800E702C.unk0; sp38.unk4 = D_800E702C.unk4; sp38.unkC = D_800E702C.unkC; sp38.unk8 = D_800E702C.unk8; sp28.unk0 = D_800E703C.unk0; sp28.unk4 = D_800E703C.unk4; sp28.unkC = D_800E703C.unkC; sp28.unk8 = D_800E703C.unk8; sp18.unk0 = D_800E704C.unk0; sp18.unk4 = D_800E704C.unk4; sp18.unkC = D_800E704C.unkC; sp18.unk8 = D_800E704C.unk8; sp8.unk0 = D_800E705C.unk0; sp8.unk4 = D_800E705C.unk4; sp8.unkC = D_800E705C.unkC; sp8.unk8 = D_800E705C.unk8; temp_t9 = gCurrentCourseId; switch (temp_t9) { case 4: temp_t0 = (arg1 * 2) + &D_80165310; temp_v1 = (&D_80164550)[*temp_t0] + (arg0->unk220 * 8); arg2->unk0 = temp_v1->unk0; arg2->unk4 = temp_v1->unk2; arg2->unk8 = temp_v1->unk4; temp_t1 = *temp_t0; temp_v1_2 = (((arg0->unk220 + 5) % ((&D_801645C8)[temp_t1] + 1)) * 8) + (&D_80164550)[temp_t1]; arg3->unk0 = temp_v1_2->unk0; arg3->unk4 = temp_v1_2->unk2; arg3->unk8 = temp_v1_2->unk4; return; case 15: temp_a0 = arg1 * 4; arg2->unk4 = 0.0f; arg2->unk0 = *(&spF8 + temp_a0); arg2->unk8 = *(&spE8 + temp_a0); arg3->unk4 = 0.0f; arg3->unk0 = *(&spD8 + temp_a0); phi_f10 = *(&spC8 + temp_a0); block_8: arg3->unk8 = phi_f10; return; case 16: temp_a0_2 = arg1 * 4; arg2->unk4 = 480.0f; arg2->unk0 = *(&spB8 + temp_a0_2); arg2->unk8 = *(&spA8 + temp_a0_2); arg3->unk4 = 480.0f; arg3->unk0 = *(&sp98 + temp_a0_2); arg3->unk8 = *(&sp88 + temp_a0_2); return; case 17: temp_a0_3 = arg1 * 4; arg2->unk4 = 0.0f; arg2->unk0 = (sp + temp_a0_3)->unk78; arg2->unk8 = (sp + temp_a0_3)->unk68; arg3->unk4 = 0.0f; arg3->unk0 = (sp + temp_a0_3)->unk58; arg3->unk8 = (sp + temp_a0_3)->unk48; return; case 19: temp_a0_4 = arg1 * 4; arg2->unk4 = 200.0f; arg2->unk0 = (sp + temp_a0_4)->unk38; arg2->unk8 = (sp + temp_a0_4)->unk28; arg3->unk4 = 200.0f; arg3->unk0 = (sp + temp_a0_4)->unk18; phi_f10 = (sp + temp_a0_4)->unk8; goto block_8; default: temp_v1_3 = D_80164550 + (arg0->unk220 * 8); arg2->unk0 = temp_v1_3->unk0; arg2->unk4 = temp_v1_3->unk2; arg2->unk8 = temp_v1_3->unk4; temp_v1_4 = (((arg0->unk220 + 5) % (D_801645C8 + 1)) * 8) + D_80164550; arg3->unk0 = temp_v1_4->unk0; arg3->unk4 = temp_v1_4->unk2; phi_f10 = temp_v1_4->unk4; goto block_8; } } #else GLOBAL_ASM("asm/non_matchings/code_8008C1D0/func_80090178.s") #endif void func_80090778(Player* player) { s32 playerIndex = get_player_index_for_player(player); player->unk_078 = 0; player->unk_07C = 0; player->unk_0C0 = 0; player->unk_0CA |= 8; player->unk_0BC &= ~0x10; player->unk_222 = 0; player->unk_08C = 0.0f; func_8008C354(player, playerIndex); func_8008F86C(player, playerIndex); player->unk_DB4 = 0; player->unk_0C2 = 0; player->unk_DBC = 0.0f; if ((player->unk_0BC & 0x40000000) == 0x40000000) { if ((player->unk_0BC & 0x20000) == 0x20000) { player->unk_0BC &= ~0x20000; player->unk_0A8 = 0; player->unk_07C = 0; player->unk_0C0 = 0; player->unk_02E = player->unk_0AE; } func_8008E3C0(player, playerIndex); } player->unk_0BC &= ~0x20; } void func_80090868(Player* player) { s32 playerIndex; player->unk_078 = 0; player->unk_07C = 0; player->unk_0C0 = 0; player->unk_08C = 0.0f; playerIndex = get_player_index_for_player(player); if ((player->unk_0CA & 2) != 2) { player->unk_D98 = 1; player->unk_D9C = 0.0f; player->unk_DA0 = 0.5f; func_8008FF08(player, playerIndex); player->unk_222 = 0; player->unk_0CA |= 2; player->unk_0C8 = 0; if ((player->unk_0DE & 1) == 1) { if ((gCurrentCourseId == COURSE_BOWSER_CASTLE) || (gCurrentCourseId == COURSE_BIG_DONUT)) { player->unk_0CA |= 0x1000; } else { player->unk_0CA |= 0x2000; } if ((gCurrentCourseId == COURSE_SHERBET_LAND) || (gCurrentCourseId == COURSE_SKYSCRAPER) || (gCurrentCourseId == COURSE_RAINBOW_ROAD)) { player->unk_0CA &= ~0x3000; } } } } // Note that D_80004334 is a fake pointer. // Should put this func through mips to C prior to decomp. #ifdef MIPS_TO_C //generated by mips_to_c commit bd0364fa19633bd6201f8007e2d0a7ed87825909 ? move_f32_towards(void *, f32, ?); /* extern */ ? move_s16_towards(void *, ?, ?); /* extern */ ? func_8006B8B4(void *, s8); /* extern */ ? func_8008C354(s8); /* extern */ ? func_8008F104(void *, s8); /* extern */ ? func_8008FB30(void *, s8); /* extern */ ? func_80090178(void *, s8, f32 *, ? *); /* extern */ ? func_8009E020(s8, ?); /* extern */ ? func_8009E088(s8, ?); /* extern */ ? func_800C9018(u8, ?); /* extern */ s32 func_802B5224(f32 *, ? *); /* extern */ f32 sins(s32); /* extern */ f32 coss(s32); /* extern */ extern ? D_80004334; extern void *D_80164550; extern ? D_801652A0; extern ? D_80165330; extern s32 gModeSelection; void func_80090970(void *arg0, s8 arg1, s8 arg2) { f32 sp44; ? sp38; f32 *sp28; f32 *temp_v0_2; f32 temp_f6; s16 temp_v0; s16 temp_v0_6; s16 temp_v1; s16 temp_v1_2; s32 temp_at; s32 temp_v0_5; u16 temp_t7; u16 temp_v0_3; u16 temp_v0_4; void *temp_v0_7; f32 phi_at; arg0->unkC2 = 0xC; arg0->unk78 = 0; arg0->unk7C = 0; arg0->unkC0 = 0; arg0->unk8C = 0.0f; func_8008C354(arg1); temp_t7 = arg0->unk222; switch (temp_t7) { case 0: temp_v1 = arg0->unkCA; if ((temp_v1 & 1) == 1) { temp_v0 = arg0->unkC8; if ((temp_v0 < 0x3C) || ((temp_v1 & 2) != 2)) { arg0->unkC8 = temp_v0 + 1; temp_at = arg0->unkC8 < 0x3C; phi_at = (bitwise f32) temp_at; if (temp_at == 0) { arg0->unkC8 = 0x3C; } } else { temp_v0_2 = (arg1 * 4) + &D_801652A0; sp28 = temp_v0_2; move_f32_towards(arg0 + 0x18, *temp_v0_2 + 100.0f, 0x3C449BA6); move_s16_towards(arg0 + (arg2 * 2) + 0xCC, 0, 0x3E4CCCCD); phi_at = 40.0f; if ((*sp28 + 40.0f) <= arg0->unk18) { arg0->unk222 = 1; arg0->unkC6 = 0xFF; arg0->unkCA = arg0->unkCA | 4; phi_at = 40.0f; } } } else { phi_at = 100.0f; if ((temp_v1 & 2) == 2) { move_f32_towards(arg0 + 0x18, arg0->unk74 + 100.0f, 0x3CCCCCCD); move_s16_towards(arg0 + (arg2 * 2) + 0xCC, 0, 0x3E4CCCCD); phi_at = 40.0f; if ((arg0->unk74 + 40.0f) <= arg0->unk18) { arg0->unk222 = 1; arg0->unkC6 = 0xFF; arg0->unkCA = arg0->unkCA | 4; phi_at = 40.0f; } } } if (&D_80004334 != (arg0->unkBC & &D_80004334)) { // Error: Got lui instruction with macro other than %hi // At instruction: lui $at, %lo(D_80004334) // D_80004334 FAKE POINTER } else { func_8008FB30(arg0, arg1); default: block_49: phi_at = 180.0f; } break; case 1: temp_v0_3 = arg0->unk0; if (((temp_v0_3 & 0x4000) == 0x4000) && ((temp_v0_3 & 0x1000) == 0)) { func_8009E088(arg1, 0xA); } if ((arg0->unkCA & 1) == 1) { move_f32_towards(arg0 + 0x18, *(&D_801652A0 + (arg1 * 4)) + 40.0f, 0x3CA3D70A); arg0->unkC6 = arg0->unkC6 - 8; if (arg0->unkC6 < 9) { arg0->unkC6 = 0; arg0->unk222 = 2; arg0->unkCA = arg0->unkCA & 0xFFFE; } } else { move_f32_towards(arg0 + 0x18, arg0->unk24 + 40.0f, 0x3CA3D70A); arg0->unkC6 = arg0->unkC6 - 8; if (arg0->unkC6 < 9) { arg0->unkC6 = 0; arg0->unk222 = 2; } } arg0->unkCA = arg0->unkCA & 0xDFFF; goto block_49; case 2: func_80090178(arg0, arg1, &sp44, &sp38); arg0->unk2E = -func_802B5224(&sp44, &sp38); arg0->unk14 = sp44; arg0->unk18 = sp48 + 40.0f; arg0->unk222 = 3; arg0->unk1C = sp4C; goto block_49; case 3: *(&D_80165330 + (arg1 * 2)) = 0; temp_v0_4 = arg0->unk0; if (((temp_v0_4 & 0x4000) == 0x4000) && ((temp_v0_4 & 0x1000) == 0)) { func_8009E020(arg1, 0x14); } func_80090178(arg0, arg1, &sp44, &sp38); arg0->unk14 = sp44; arg0->unk18 = sp48 + 40.0f; arg0->unk1C = sp4C; temp_v0_5 = arg1 * 0x1C70; sp28 = temp_v0_5; arg0->unk1C = (coss((temp_v0_5 - arg0->unk2E) & 0xFFFF) * -5.0f) + arg0->unk1C; temp_f6 = sins((temp_v0_5 - arg0->unk2E) & 0xFFFF) * -5.0f; arg0->unkC6 = arg0->unkC6 + 8; arg0->unk14 = temp_f6 + arg0->unk14; if (arg0->unkC6 >= 0xF0) { arg0->unkC6 = 0xFF; arg0->unk222 = 4; arg0->unkCA = arg0->unkCA & 0xFFFB; arg0->unkC8 = 0; } goto block_49; case 4: temp_v0_6 = arg0->unkC8; if ((temp_v0_6 == 0x96) || (temp_v0_6 == 0xC8) || (temp_v0_6 == 0xFA)) { arg0->unk1C = (coss(-arg0->unk2E & 0xFFFF) * -10.0f) + arg0->unk1C; arg0->unk14 = (sins(-arg0->unk2E & 0xFFFF) * -10.0f) + arg0->unk14; } if (arg0->unkC8 == 0xFC) { temp_v0_7 = D_80164550; arg0->unk14 = temp_v0_7->unk0; arg0->unk18 = temp_v0_7->unk2; arg0->unk1C = temp_v0_7->unk4; } move_f32_towards(arg0 + 0x18, (arg0->unk74 + arg0->unk70) - 2.0f, 0x3D23D70A); arg0->unkC8 = arg0->unkC8 + 1; phi_at = (bitwise f32) 8; if ((arg0->unkBC & 8) == 8) { // Error: %hi macro outside of lui // At instruction: andi $t8, $v0, %hi(D_80004334) if (MIPS2C_ERROR()) { // Error: Got lui instruction with macro other than %hi // At instruction: lui $at, %lo(D_80004334) } else { goto block_41; } } else { block_41: arg0->unkCA = arg0->unkCA & 0xEFFF; if (arg0->unkC8 >= 0x5B) { if ((arg0->unk0 & 0x4000) != 0) { func_800C9018(arg1, 0x100FA28); } if (gModeSelection == BATTLE) { func_8006B8B4(arg0, arg1); } arg0->unkCA = arg0->unkCA & 0xFFFD; temp_v1_2 = arg0->unkCA; arg0->unkDE = arg0->unkDE & 0xFFFB; if ((temp_v1_2 & 0x80) != 0x80) { arg0->unkCA = temp_v1_2 & 0xFFF7; if ((arg0->unk214 * 0.9) <= arg0->unk9C) { func_8008F104(arg0, arg1); } } } goto block_49; } break; } arg0->unkDA0 = arg0->unkDA0 + 8.0f; if (phi_at <= arg0->unkDA0) { arg0->unkDA0 = phi_at; } if (arg0->unkD98 == 1) { arg0->unkD9C = arg0->unkD9C + arg0->unkDA0; if (arg0->unkD9C >= 1820.0f) { arg0->unkDA0 = 0.0f; arg0->unkD98 = arg0->unkD98 * -1; } } if (arg0->unkD98 == -1) { arg0->unkD9C = arg0->unkD9C - arg0->unkDA0; if (arg0->unkD9C <= -1820.0f) { arg0->unkDA0 = 0.0f; arg0->unkD98 = arg0->unkD98 * -1; } } } #else GLOBAL_ASM("asm/non_matchings/code_8008C1D0/func_80090970.s") #endif #if NEEDS_RODATA s32 func_800910E4(Player *arg0) { s32 phi_v0; phi_v0 = 0; if ((((((arg0->unk_0CA & 2) == 2) || ((arg0->unk_0CA & 8) == 8)) || ((arg0->unk_000 & 0x40) != 0)) || ((arg0->unk_000 & 0x800) != 0)) || ((arg0->unk_000 & 0x8000) == 0)) { return 1; } switch (arg0->unk_010) { case 12: case 13: case 14: case 15: if ((arg0->unk_0BC & 8) != 0) { return 1; } phi_v0 = 0x5F934EC4; goto func_800910E4_label; case 10: phi_v0 = 0xDF934EC4; case 11: phi_v0 = phi_v0 | 0xDF934EC4; func_800910E4_label: default: if ((arg0->unk_0BC & phi_v0) != 0) { return 1; } return 0; } } #else GLOBAL_ASM("asm/non_matchings/code_8008C1D0/func_800910E4.s") #endif void func_800911B4(Player* player, s8 arg1) { s32 temp_v0; player->unk_0AE = player->unk_02E; player->unk_044 |= 0x1800; player->unk_044 &= ~0x0400; player->unk_044 |= 0x2000; player->kartHopJerk = D_800EF678; player->kartHopAcceleration = 0.0f; player->kartHopVelocity = D_800EF67C; player->unk_0B2 = 2; player->unk_0C0 = 0; player->unk_07C = 0; player->unk_078 = 0; D_8018D920[arg1] = 0; player->unk_258[31].unk_012 = 0; player->unk_258[31].unk_01E = 0; player->unk_258[31].unk_01C = 0; player->unk_258[30].unk_012 = 0; player->unk_258[30].unk_01E = 0; player->unk_258[30].unk_01C = 0; temp_v0 = 2; do { player->unk_258[31 + temp_v0].unk_01C = 0; player->unk_258[31 + temp_v0].unk_01E = 0; player->unk_258[31 + temp_v0].unk_012 = 0; player->unk_258[32 + temp_v0].unk_01C = 0; player->unk_258[32 + temp_v0].unk_01E = 0; player->unk_258[32 + temp_v0].unk_012 = 0; player->unk_258[33 + temp_v0].unk_01C = 0; player->unk_258[33 + temp_v0].unk_01E = 0; player->unk_258[33 + temp_v0].unk_012 = 0; temp_v0 += 4; player->unk_258[26 + temp_v0].unk_01C = 0; player->unk_258[26 + temp_v0].unk_01E = 0; player->unk_258[26 + temp_v0].unk_012 = 0; } while (temp_v0 < 10); } #ifdef MIPS_TO_C //generated by mips_to_c commit bd0364fa19633bd6201f8007e2d0a7ed87825909 extern s8 D_801658BC; extern ? D_8018D920; extern ? gKartGravityTable; static ? D_800E706C; /* unable to generate initializer; const */ void func_80091298(void *arg0, s8 arg1) { ? spC; f32 temp_f0; f32 temp_f2; s16 *temp_a2; s16 temp_t9; s32 temp_t8; s16 phi_v1; spC.unk0 = D_800E706C.unk0; spC.unk4 = D_800E706C.unk4; spC.unk8 = D_800E706C.unk8; arg0->unk44 = arg0->unk44 | 0x2000; if (arg0->unkB2 == 0) { phi_v1 = 0; } else { temp_a2 = (arg1 * 2) + &D_8018D920; arg0->unk2E = arg0->unk2E - 0xE38; temp_t9 = *temp_a2 - 0xE38; temp_t8 = (temp_t9 & 0xFFFF) / 3640; *temp_a2 = temp_t9; phi_v1 = temp_t8; } if (((phi_v1 == 9) && (arg0->unkB2 == 1)) || ((phi_v1 == 0) && (arg0->unkB2 == 2)) || (arg0->unkB2 == 0)) { arg0->unkB2 = arg0->unkB2 - 1; if (arg0->unkB2 <= 0) { arg0->unkB2 = 0; } if (arg0->unkB2 == 0) { temp_f2 = arg0->unk70; temp_f0 = *(&spC + (arg1 * 4)); if ((arg0->unk18 - (temp_f2 + 1.0f)) <= temp_f0) { arg0->unkDCC = 0; arg0->unkA8 = 0; arg0->unk18 = (temp_f0 + temp_f2) + 1.08; arg0->unk7C = 0; arg0->unkC0 = 0; arg0->unk44 = arg0->unk44 & 0xF7FF; arg0->unkDC0 = 3.0f; arg0->unkD4 = 0; arg0->unk100 = *(&gKartGravityTable + (arg0->unk254 * 4)); arg0->unk0 = arg0->unk0 | 0x2000; arg0->unk94 = 0.0f; arg0->unk8C = 0.0f; arg0->unk9C = 0.0f; if (arg1 == 0) { D_801658BC = 1; } } } } } #else GLOBAL_ASM("asm/non_matchings/code_8008C1D0/func_80091298.s") #endif void func_80091440(s8 arg0) { if ((gPlayers[arg0].unk_044 & 0x800) == 0) { gPlayers[arg0].unk_044 |= 0x2400; gPlayers[arg0].unk_000 &= ~0x2000; } } void func_800914A0(void) { D_80152308 = gPlayerOneCopy->unk_006 + 7; if ((s32) D_8015F6F8 < D_80152308) { D_80152308 -= D_8015F6F8; } } #ifdef MIPS_TO_C //generated by mips_to_c commit bd0364fa19633bd6201f8007e2d0a7ed87825909 //This function did not have a glabel in the original assembly, as such it may //be unused/unnamed ? func_800914A0(s16, s32, s16); /* extern */ ? func_802ADDC8(void *, ?, f32, f32, f32); /* extern */ s16 atan2s(f32, f32); /* extern */ f32 sqrtf(f32, f32); /* extern */ extern void *gPlayerOneCopy; extern u16 D_80152308; extern s16 D_8015F6F8; extern u32 D_8015F718; extern ? cameras; extern ? gSegmentTable; static ? D_800E7080; /* unable to generate initializer; const */ static ? D_800E708C; /* unable to generate initializer; const */ void func_800914E0(void) { ? sp64; ? sp58; s32 sp48; f32 sp38; f32 sp34; f32 sp30; f32 temp_f12; f32 temp_f14; f32 temp_f16; f32 temp_f4; f32 temp_f8; s16 temp_a0; s16 temp_a0_2; s16 temp_a3; s16 temp_v0_2; u16 temp_t0; u32 temp_v0; void *temp_v0_3; u16 phi_t0; void **phi_t1; sp64.unk0 = D_800E7080.unk0; sp64.unk4 = D_800E7080.unk4; sp64.unk8 = D_800E7080.unk8; sp58.unk0 = D_800E708C.unk0; sp58.unk4 = D_800E708C.unk4; sp58.unk8 = D_800E708C.unk8; temp_v0 = D_8015F718; temp_a0 = temp_v0 & 0xFFFFFF; sp48 = *(&gSegmentTable + ((temp_v0 >> 0x18) * 4)) + temp_a0 + 0x80000000; temp_t0 = D_80152308; temp_a3 = gPlayerOneCopy->unk6; temp_v0_2 = temp_a3 - temp_t0; cameras.unk18 = 0.0f; cameras.unk20 = 0.0f; cameras.unk1C = 1.0f; phi_t0 = temp_t0; phi_t1 = &gPlayerOneCopy; if (temp_v0_2 == 7) { func_800914A0(temp_a0, 7, temp_a3); phi_t0 = D_80152308; goto block_5; } if (temp_v0_2 < 0xE) { temp_a0_2 = temp_v0_2 + D_8015F6F8; if (temp_a0_2 == 7) { func_800914A0(temp_a0_2, 7, temp_a3); phi_t0 = D_80152308; block_5: phi_t1 = &gPlayerOneCopy; } } temp_v0_3 = (phi_t0 * 8) + sp48; temp_f8 = temp_v0_3->unk0 + 0xA; cameras.unk0 = temp_f8; temp_f16 = temp_v0_3->unk2 + 7; *(&cameras + 4) = temp_f16; temp_f4 = temp_v0_3->unk4 - 0x14; *(&cameras + 8) = temp_f4; *(&cameras + 0xC) = (*phi_t1)->unk14; *(&cameras + 0x10) = (*phi_t1)->unk18; *(&cameras + 0x14) = (*phi_t1)->unk1C; func_802ADDC8(&cameras + 0x54, 0x41A00000, temp_f8, temp_f16, temp_f4); temp_f12 = *(&cameras + 0xC) - cameras.unk0; sp38 = temp_f12; temp_f14 = *(&cameras + 0x14) - *(&cameras + 8); sp34 = *(&cameras + 0x10) - *(&cameras + 4); sp30 = temp_f14; *(&cameras + 0x26) = atan2s(temp_f12, temp_f14); *(&cameras + 0x24) = atan2s(sqrtf((sp38 * sp38) + (temp_f14 * temp_f14), temp_f14), sp34); *(&cameras + 0x28) = 0; } #else GLOBAL_ASM("asm/non_matchings/code_8008C1D0/func_800914E0.s") #endif