diff options
author | U-User-PC\User <golemgalvanize@github.com> | 2017-09-23 20:23:55 -0400 |
---|---|---|
committer | U-User-PC\User <golemgalvanize@github.com> | 2017-09-23 20:23:55 -0400 |
commit | 40eb03542bf2eec8944249474b880854691da6ac (patch) | |
tree | a78c74040697dd958305619b0b79e4dd0a1c1891 /src | |
parent | 3d16b884b93323d2329bd9d805e3ac958311ef0a (diff) |
decompiled up to sub_81C1040
Diffstat (limited to 'src')
-rwxr-xr-x | src/pokemon_summary_screen.c | 432 |
1 files changed, 288 insertions, 144 deletions
diff --git a/src/pokemon_summary_screen.c b/src/pokemon_summary_screen.c index d555b8834..9c4647cf0 100755 --- a/src/pokemon_summary_screen.c +++ b/src/pokemon_summary_screen.c @@ -78,8 +78,8 @@ void sub_81C0510(u8 taskId); void sub_81C171C(u8 taskId); void sub_8121E10(); u8 sub_81B205C(struct Pokemon* a); -void sub_81C1DA4(u8 a, u8 b); -void sub_81C1EFC(u8 a, u8 b, u8 c); +void sub_81C1DA4(u8 a, s16 b); +void sub_81C1EFC(u8 a, s16 b, u16 c); void sub_81C240C(u16 a); void sub_81C2194(void* a, u8 b, u8 c); void sub_81C2074(u16 a, s16 b); @@ -101,6 +101,26 @@ void sub_81C20F0(u8 taskId); u8 sub_81C0A50(struct Pokemon* mon); void sub_81C49E0(); void sub_81C0E24(); +void sub_81C2C38(); +void sub_81C0B8C(u8 taskId); +void sub_81C0CC4(u8 taskId); +void sub_81C2DE4(u8 a); +void sub_81C424C(); +void sub_81C0C68(u8 taskId); +void sub_81C0D44(u8 taskId); +void sub_81C22CC(struct Pokemon* mon); +void sub_81C0F44(u8 taskId); +void sub_81C3E9C(u16 a); +void sub_81C3F44(); +void sub_81C44F0(); +void sub_81C4AF8(u8 a); +void sub_81C1070(s16* a, s8 b, u8* c); +void sub_81C11F4(u8 a); +void sub_81C129C(u8 a); +u8 sub_81C1040(); + + +void SetBgAttribute(u8 bg, u8 attributeId, u8 value); u8 sub_81BFB10(); u8 sub_81B1250(); @@ -110,6 +130,8 @@ union unkUnion{ struct BoxPokemon boxMons[6]; }; + + u8 sub_80D214C(union unkUnion* a, u8 b, u8 c, u8 d); struct pokeSummary{ @@ -167,14 +189,23 @@ struct unkSummaryStruct{ u8 unk40C1; u8 unk40C2; u8 unk40C3; - u16 unk40C4; - u8 unk40C6; - u8 unk_filler3; + union +{ + struct + { + u16 unk40C4; + u8 unk40C6; + u8 unkfiller3; + } fooFiller; + u32 loadThis; +} unionThing; u8 unk40C8; - u8 unk_filler2[0xA]; + u8 unk40C9; + u8 unk_filler2[0x9]; u8 unk40D3; u8 unk40D4; - u8 unk_filler5[0x1A]; + u8 unk40D5; + u8 unk_filler5[0x19]; u8 unk40EF; s16 unk40F0; u8 unk_filler4[6]; @@ -222,7 +253,7 @@ void sub_81BF8EC(u8 a, void* b, u8 c, u8 d, void* e) void sub_81BFA38(void* a, u8 b, u8 c, void* d, u16 e) { sub_81BF8EC(3, a, b, c, d); - gUnknown_0203CF1C->unk40C4 = e; + gUnknown_0203CF1C->unionThing.fooFiller.unk40C4 = e; } void sub_81BFA80(u8 a, void* b, u8 c, u8 d, void* e) @@ -563,7 +594,7 @@ void sub_81C0348() } else { - sub_81C240C(gUnknown_0203CF1C->summary.moves[gUnknown_0203CF1C->unk40C6]); + sub_81C240C(gUnknown_0203CF1C->summary.moves[gUnknown_0203CF1C->unionThing.fooFiller.unk40C6]); sub_81C2194(&gUnknown_0203CF1C->unkTilemap2, 3, 0); sub_81C2194(&gUnknown_0203CF1C->unkTilemap3, 1, 0); SetBgTilemapBuffer(1, &gUnknown_0203CF1C->unkTilemap3); @@ -772,164 +803,58 @@ void sub_81C0704(u8 taskId) data[0]++; } -#ifdef NONMATCHING s8 sub_81C08F8(s8 a) { - union unkUnion* r7 = gUnknown_0203CF1C->unk0; + struct Pokemon *mons = gUnknown_0203CF1C->unk0->mons; + if (gUnknown_0203CF1C->unk40C0 == 0) { - if (a != -1 || gUnknown_0203CF1C->unk40BE != 0) - { - if (a != 1 || gUnknown_0203CF1C->unk40BE < gUnknown_0203CF1C->unk40BF) - { - return gUnknown_0203CF1C->unk40BE + a; - } - } - return -1; + if (a == -1 && gUnknown_0203CF1C->unk40BE == 0) + return -1; + if (a == 1 && gUnknown_0203CF1C->unk40BE >= gUnknown_0203CF1C->unk40BF) + return -1; + return gUnknown_0203CF1C->unk40BE + a; } else { - s8 r5r4 = gUnknown_0203CF1C->unk40BE; - while(1) + s8 index = gUnknown_0203CF1C->unk40BE; + + do { - r5r4 += a; - if (r5r4 < 0 || r5r4 > gUnknown_0203CF1C->unk40BF) + index += a; + if (index < 0 || index > gUnknown_0203CF1C->unk40BF) return -1; - else if (GetMonData(&r7->mons[r5r4], MON_DATA_IS_EGG) == 0) - return r5r4; - } + } while (GetMonData(&mons[index], MON_DATA_IS_EGG) != 0); + return index; } } -#else -__attribute__((naked)) -s8 sub_81C08F8(s8 a) -{ - asm(".syntax unified\n\ - push {r4-r7,lr}\n\ - lsls r0, 24\n\ - lsrs r4, r0, 24\n\ - ldr r1, =gUnknown_0203CF1C\n\ - ldr r2, [r1]\n\ - ldr r7, [r2]\n\ - ldr r3, =0x000040c0\n\ - adds r0, r2, r3\n\ - ldrb r0, [r0]\n\ - adds r5, r1, 0\n\ - cmp r0, 0\n\ - bne _081C0960\n\ - lsls r0, r4, 24\n\ - asrs r3, r0, 24\n\ - movs r1, 0x1\n\ - negs r1, r1\n\ - adds r6, r0, 0\n\ - cmp r3, r1\n\ - bne _081C0928\n\ - ldr r1, =0x000040be\n\ - adds r0, r2, r1\n\ - ldrb r0, [r0]\n\ - cmp r0, 0\n\ - beq _081C0988\n\ -_081C0928:\n\ - asrs r0, r6, 24\n\ - cmp r0, 0x1\n\ - bne _081C0940\n\ - ldr r0, [r5]\n\ - ldr r2, =0x000040be\n\ - adds r1, r0, r2\n\ - ldr r3, =0x000040bf\n\ - adds r0, r3\n\ - ldrb r1, [r1]\n\ - ldrb r0, [r0]\n\ - cmp r1, r0\n\ - bcs _081C0988\n\ -_081C0940:\n\ - ldr r0, [r5]\n\ - ldr r1, =0x000040be\n\ - adds r0, r1\n\ - ldrb r0, [r0]\n\ - adds r0, r4\n\ - lsls r0, 24\n\ - asrs r0, 24\n\ - b _081C09AE\n\ - .pool\n\ -_081C0960:\n\ - ldr r3, =0x000040be\n\ - adds r0, r2, r3\n\ - ldrb r5, [r0]\n\ - lsls r6, r4, 24\n\ -_081C0968:\n\ - lsls r0, r5, 24\n\ - asrs r0, 24\n\ - asrs r1, r6, 24\n\ - adds r0, r1\n\ - lsls r0, 24\n\ - lsrs r5, r0, 24\n\ - asrs r4, r0, 24\n\ - cmp r4, 0\n\ - blt _081C0988\n\ - ldr r0, =gUnknown_0203CF1C\n\ - ldr r0, [r0]\n\ - ldr r1, =0x000040bf\n\ - adds r0, r1\n\ - ldrb r0, [r0]\n\ - cmp r4, r0\n\ - ble _081C099C\n\ -_081C0988:\n\ - movs r0, 0x1\n\ - negs r0, r0\n\ - b _081C09AE\n\ - .pool\n\ -_081C099C:\n\ - movs r0, 0x64\n\ - muls r0, r4\n\ - adds r0, r7, r0\n\ - movs r1, 0x2D\n\ - bl GetMonData\n\ - cmp r0, 0\n\ - bne _081C0968\n\ - adds r0, r4, 0\n\ -_081C09AE:\n\ - pop {r4-r7}\n\ - pop {r1}\n\ - bx r1\n\ - .syntax divided\n"); -} -#endif s8 sub_81C09B4(s8 a) { - union unkUnion* r8 = gUnknown_0203CF1C->unk0; + struct Pokemon *mons = gUnknown_0203CF1C->unk0->mons; s8 r5 = 0; - u8 i = 0; - if (gUnknown_0861CC1C[0] != gUnknown_0203CF1C->unk40BE) + u8 i; + + for (i = 0; i < 6; i++) { - while(1) + if (gUnknown_0861CC1C[i] == gUnknown_0203CF1C->unk40BE) { - i += 1; - if (i > 5) - break; - if (gUnknown_0861CC1C[i] == gUnknown_0203CF1C->unk40BE) - { - r5 = i; - break; - } + r5 = i; + break; } } - while(1) + + while (1) { int b; s8* c = &gUnknown_0861CC1C[0]; + r5 += a; - if ((u8)(r5) > 5) - { + if (r5 < 0 || r5 >= 6) return -1; - } - else - { - b = c[r5]; - if (sub_81C0A50(&r8->mons[c[r5]]) == 1) - return b; - } + b = c[r5]; + if (sub_81C0A50(&mons[b]) == 1) + return b; } } @@ -943,4 +868,223 @@ u8 sub_81C0A50(struct Pokemon* mon) return 1; else return 0; -}
\ No newline at end of file +} + +void sub_81C0A8C(u8 taskId, s8 b) +{ + struct pokeSummary *summary = &gUnknown_0203CF1C->summary; + s16 *data = gTasks[taskId].data; + + if (summary->isEgg) + return; + if (b == -1 && gUnknown_0203CF1C->unk40C0 == gUnknown_0203CF1C->unk40C1) + return; + if (b == 1 && gUnknown_0203CF1C->unk40C0 == gUnknown_0203CF1C->unk40C2) + return; + PlaySE(SE_SELECT); + sub_81C2C38(gUnknown_0203CF1C->unk40C0); + gUnknown_0203CF1C->unk40C0 += b; + data[0] = 0; + if (b == 1) + SetTaskFuncWithFollowupFunc(taskId, sub_81C0B8C, gTasks[taskId].func); + else + SetTaskFuncWithFollowupFunc(taskId, sub_81C0CC4, gTasks[taskId].func); + sub_81C2DE4(gUnknown_0203CF1C->unk40C0); + sub_81C424C(); +} + +void sub_81C0B8C(u8 taskId) +{ + s16 *data = gTasks[taskId].data; + if (data[0] == 0) + { + if (gUnknown_0203CF1C->unk40C9 == 0) + { + data[1] = 1; + SetBgAttribute(1, 7, 1); + SetBgAttribute(2, 7, 2); + schedule_bg_copy_tilemap_to_vram(1); + } + else + { + data[1] = 2; + SetBgAttribute(2, 7, 1); + SetBgAttribute(1, 7, 2); + schedule_bg_copy_tilemap_to_vram(2); + } + ChangeBgX(data[1], 0, 0); + SetBgTilemapBuffer(data[1], (u8*)gUnknown_0203CF1C + ((gUnknown_0203CF1C->unk40C0 << 12) + 0xBC)); + ShowBg(1); + ShowBg(2); + } + ChangeBgX(data[1], 0x2000, 1); + data[0] += 32; + if (data[0] > 0xFF) + { + gTasks[taskId].func = sub_81C0C68; + } +} + +void sub_81C0C68(u8 taskId) +{ + s16 *data = gTasks[taskId].data; + gUnknown_0203CF1C->unk40C9 ^= 1; + data[1] = 0; + data[0] = 0; + sub_81C1BA0(); + sub_81C2AFC(gUnknown_0203CF1C->unk40C0); + sub_81C4280(); + sub_81C0E24(); + SwitchTaskToFollowupFunc(taskId); +} + +void sub_81C0CC4(u8 taskId) +{ + s16 *data = gTasks[taskId].data; + if (data[0] == 0) + { + if (gUnknown_0203CF1C->unk40C9 == 0) + data[1] = 2; + else + data[1] = 1; + ChangeBgX(data[1], 0x10000, 0); + } + ChangeBgX(data[1], 0x2000, 2); + data[0] += 32; + if (data[0] > 0xFF) + gTasks[taskId].func = sub_81C0D44; +} + +void sub_81C0D44(u8 taskId) +{ + s16 *data = gTasks[taskId].data; + if (gUnknown_0203CF1C->unk40C9 == 0) + { + SetBgAttribute(1, 7, 1); + SetBgAttribute(2, 7, 2); + schedule_bg_copy_tilemap_to_vram(2); + } + else + { + SetBgAttribute(2, 7, 1); + SetBgAttribute(1, 7, 2); + schedule_bg_copy_tilemap_to_vram(1); + } + if (gUnknown_0203CF1C->unk40C0 > 1) + { + SetBgTilemapBuffer(data[1], (u8*)gUnknown_0203CF1C + ((gUnknown_0203CF1C->unk40C0 << 12) + 0xFFFFF0BC)); + ChangeBgX(data[1], 0x10000, 0); + } + ShowBg(1); + ShowBg(2); + gUnknown_0203CF1C->unk40C9 ^= 1; + data[1] = 0; + data[0] = 0; + sub_81C1BA0(); + sub_81C2AFC(gUnknown_0203CF1C->unk40C0); + sub_81C4280(); + sub_81C0E24(); + SwitchTaskToFollowupFunc(taskId); +} + +void sub_81C0E24() +{ + if (gUnknown_0203CF1C->unk40C0 == 1) + sub_81C22CC(&gUnknown_0203CF1C->currentPoke); +} + +void sub_81C0E48(u8 taskId) +{ + u16 move; + gUnknown_0203CF1C->unionThing.fooFiller.unk40C6 = 0; + move = gUnknown_0203CF1C->summary.moves[gUnknown_0203CF1C->unionThing.fooFiller.unk40C6]; + ClearWindowTilemap(0x13); + if (gSprites[gUnknown_0203CF1C->unk40D5].invisible == 0) + ClearWindowTilemap(0xD); + sub_81C1DA4(9, -3); + sub_81C1EFC(9, -3, move); + if (gUnknown_0203CF1C->unk40C8 == 0) + { + ClearWindowTilemap(5); + PutWindowTilemap(6); + } + sub_81C2194(&gUnknown_0203CF1C->unkTilemap2, 3, 0); + sub_81C2194(&gUnknown_0203CF1C->unkTilemap3, 1, 0); + sub_81C3E9C(move); + sub_81C3F44(); + sub_81C44F0(); + schedule_bg_copy_tilemap_to_vram(0); + schedule_bg_copy_tilemap_to_vram(1); + schedule_bg_copy_tilemap_to_vram(2); + sub_81C4AF8(8); + gTasks[taskId].func = sub_81C0F44; +} + +void sub_81C0F44(u8 taskId) +{ + u8 id = taskId; + s16 *data = gTasks[taskId].data; + if (sub_81221EC() != 1) + { + if (gMain.newKeys & DPAD_UP) + { + data[0] = 4; + sub_81C1070(data, -1, &gUnknown_0203CF1C->unionThing.fooFiller.unk40C6); + } + else if (gMain.newKeys & DPAD_DOWN) + { + data[0] = 4; + sub_81C1070(data, 1, &gUnknown_0203CF1C->unionThing.fooFiller.unk40C6); + } + else if (gMain.newKeys & A_BUTTON) + { + if (gUnknown_0203CF1C->unk40C8 == 1 || ((int)(gUnknown_0203CF1C->unionThing.loadThis & 0xFFFFFF) == 0x40000)) + { + PlaySE(SE_SELECT); + sub_81C11F4(taskId); + } + else if (sub_81C1040() == 1) + { + PlaySE(SE_SELECT); + sub_81C129C(taskId); + } + else + PlaySE(0x20); + } + else if (gMain.newKeys & B_BUTTON) + { + PlaySE(SE_SELECT); + sub_81C11F4(id); + } + } +} + +u8 sub_81C1040() +{ + u8 i; + for (i = 1; i <= 3; i++) + { + if (gUnknown_0203CF1C->summary.moves[i] != 0) + return 1; + } + return 0; +} + +/* void sub_81C1070(s16* a, s8 b, u8* c) +{ + s8 i; + s8 d = c*; + PlaySE(SE_SELECT); + i = 0; + while (i <= 3) + { + d += b + if (d > a[0]) + d = 0; + else if (d < 0) + d = data[0]; + if (d == 4) + break; + + } +} */
\ No newline at end of file |