summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorU-User-PC\User <golemgalvanize@github.com>2017-09-23 20:23:55 -0400
committerU-User-PC\User <golemgalvanize@github.com>2017-09-23 20:23:55 -0400
commit40eb03542bf2eec8944249474b880854691da6ac (patch)
treea78c74040697dd958305619b0b79e4dd0a1c1891
parent3d16b884b93323d2329bd9d805e3ac958311ef0a (diff)
decompiled up to sub_81C1040
-rwxr-xr-xasm/pokemon_summary_screen.s650
-rwxr-xr-xsrc/pokemon_summary_screen.c432
2 files changed, 288 insertions, 794 deletions
diff --git a/asm/pokemon_summary_screen.s b/asm/pokemon_summary_screen.s
index e337c8b27..862fb3d5b 100755
--- a/asm/pokemon_summary_screen.s
+++ b/asm/pokemon_summary_screen.s
@@ -5,656 +5,6 @@
.text
- thumb_func_start sub_81C0A8C
-sub_81C0A8C: @ 81C0A8C
- push {r4-r7,lr}
- mov r7, r10
- mov r6, r9
- mov r5, r8
- push {r5-r7}
- sub sp, 0xC
- lsls r0, 24
- lsrs r6, r0, 24
- str r6, [sp]
- lsls r1, 24
- lsrs r3, r1, 24
- str r3, [sp, 0x4]
- ldr r0, =gUnknown_0203CF1C
- mov r8, r0
- ldr r2, [r0]
- adds r1, r2, 0
- adds r1, 0x70
- lsls r0, r6, 2
- adds r0, r6
- lsls r7, r0, 3
- ldr r0, =gTasks + 0x8
- mov r9, r0
- adds r0, r7, r0
- str r0, [sp, 0x8]
- ldrb r1, [r1, 0x4]
- mov r10, r1
- cmp r1, 0
- bne _081C0B6E
- lsls r0, r3, 24
- asrs r5, r0, 24
- movs r0, 0x1
- negs r0, r0
- cmp r5, r0
- bne _081C0AE0
- ldr r1, =0x000040c0
- adds r0, r2, r1
- ldr r3, =0x000040c1
- adds r1, r2, r3
- ldrb r0, [r0]
- ldrb r1, [r1]
- cmp r0, r1
- beq _081C0B6E
-_081C0AE0:
- cmp r5, 0x1
- bne _081C0AF4
- ldr r1, =0x000040c0
- adds r0, r2, r1
- ldr r3, =0x000040c2
- adds r1, r2, r3
- ldrb r0, [r0]
- ldrb r1, [r1]
- cmp r0, r1
- beq _081C0B6E
-_081C0AF4:
- movs r0, 0x5
- bl PlaySE
- mov r1, r8
- ldr r0, [r1]
- ldr r4, =0x000040c0
- adds r0, r4
- ldrb r0, [r0]
- bl sub_81C2C38
- mov r2, r8
- ldr r1, [r2]
- adds r1, r4
- ldrb r0, [r1]
- ldr r3, [sp, 0x4]
- adds r0, r3
- strb r0, [r1]
- mov r1, r10
- ldr r0, [sp, 0x8]
- strh r1, [r0]
- cmp r5, 0x1
- bne _081C0B4C
- ldr r1, =sub_81C0B8C
- mov r0, r9
- subs r0, 0x8
- adds r0, r7, r0
- ldr r2, [r0]
- adds r0, r6, 0
- bl SetTaskFuncWithFollowupFunc
- b _081C0B5C
- .pool
-_081C0B4C:
- ldr r1, =sub_81C0CC4
- mov r0, r9
- subs r0, 0x8
- adds r0, r7, r0
- ldr r2, [r0]
- ldr r0, [sp]
- bl SetTaskFuncWithFollowupFunc
-_081C0B5C:
- ldr r0, =gUnknown_0203CF1C
- ldr r0, [r0]
- ldr r2, =0x000040c0
- adds r0, r2
- ldrb r0, [r0]
- bl sub_81C2DE4
- bl sub_81C424C
-_081C0B6E:
- add sp, 0xC
- pop {r3-r5}
- mov r8, r3
- mov r9, r4
- mov r10, r5
- pop {r4-r7}
- pop {r0}
- bx r0
- .pool
- thumb_func_end sub_81C0A8C
-
- thumb_func_start sub_81C0B8C
-sub_81C0B8C: @ 81C0B8C
- push {r4,r5,lr}
- lsls r0, 24
- lsrs r5, r0, 24
- lsls r0, r5, 2
- adds r0, r5
- lsls r0, 3
- ldr r1, =gTasks + 0x8
- adds r4, r0, r1
- movs r1, 0
- ldrsh r0, [r4, r1]
- cmp r0, 0
- bne _081C0C2A
- ldr r0, =gUnknown_0203CF1C
- ldr r0, [r0]
- ldr r3, =0x000040c9
- adds r0, r3
- ldrb r0, [r0]
- cmp r0, 0
- bne _081C0BE0
- movs r0, 0x1
- strh r0, [r4, 0x2]
- movs r0, 0x1
- movs r1, 0x7
- movs r2, 0x1
- bl SetBgAttribute
- movs r0, 0x2
- movs r1, 0x7
- movs r2, 0x2
- bl SetBgAttribute
- movs r0, 0x1
- bl schedule_bg_copy_tilemap_to_vram
- b _081C0BFE
- .pool
-_081C0BE0:
- movs r0, 0x2
- strh r0, [r4, 0x2]
- movs r0, 0x2
- movs r1, 0x7
- movs r2, 0x1
- bl SetBgAttribute
- movs r0, 0x1
- movs r1, 0x7
- movs r2, 0x2
- bl SetBgAttribute
- movs r0, 0x2
- bl schedule_bg_copy_tilemap_to_vram
-_081C0BFE:
- ldrb r0, [r4, 0x2]
- movs r1, 0
- movs r2, 0
- bl ChangeBgX
- ldrb r0, [r4, 0x2]
- ldr r1, =gUnknown_0203CF1C
- ldr r1, [r1]
- ldr r3, =0x000040c0
- adds r2, r1, r3
- ldrb r2, [r2]
- lsls r2, 12
- adds r2, 0xBC
- adds r1, r2
- bl SetBgTilemapBuffer
- movs r0, 0x1
- bl ShowBg
- movs r0, 0x2
- bl ShowBg
-_081C0C2A:
- ldrb r0, [r4, 0x2]
- movs r1, 0x80
- lsls r1, 6
- movs r2, 0x1
- bl ChangeBgX
- ldrh r0, [r4]
- adds r0, 0x20
- strh r0, [r4]
- lsls r0, 16
- asrs r0, 16
- cmp r0, 0xFF
- ble _081C0C52
- ldr r0, =gTasks
- lsls r1, r5, 2
- adds r1, r5
- lsls r1, 3
- adds r1, r0
- ldr r0, =sub_81C0C68
- str r0, [r1]
-_081C0C52:
- pop {r4,r5}
- pop {r0}
- bx r0
- .pool
- thumb_func_end sub_81C0B8C
-
- thumb_func_start sub_81C0C68
-sub_81C0C68: @ 81C0C68
- push {r4,r5,lr}
- adds r4, r0, 0
- lsls r4, 24
- lsrs r4, 24
- lsls r2, r4, 2
- adds r2, r4
- lsls r2, 3
- ldr r0, =gTasks + 0x8
- adds r2, r0
- ldr r5, =gUnknown_0203CF1C
- ldr r3, [r5]
- ldr r0, =0x000040c9
- adds r3, r0
- ldrb r0, [r3]
- movs r1, 0x1
- eors r0, r1
- movs r1, 0
- strb r0, [r3]
- strh r1, [r2, 0x2]
- strh r1, [r2]
- bl sub_81C1BA0
- ldr r0, [r5]
- ldr r1, =0x000040c0
- adds r0, r1
- ldrb r0, [r0]
- bl sub_81C2AFC
- bl sub_81C4280
- bl sub_81C0E24
- adds r0, r4, 0
- bl SwitchTaskToFollowupFunc
- pop {r4,r5}
- pop {r0}
- bx r0
- .pool
- thumb_func_end sub_81C0C68
-
- thumb_func_start sub_81C0CC4
-sub_81C0CC4: @ 81C0CC4
- push {r4,r5,lr}
- lsls r0, 24
- lsrs r5, r0, 24
- lsls r0, r5, 2
- adds r0, r5
- lsls r0, 3
- ldr r1, =gTasks + 0x8
- adds r4, r0, r1
- movs r1, 0
- ldrsh r0, [r4, r1]
- cmp r0, 0
- bne _081C0D0C
- ldr r0, =gUnknown_0203CF1C
- ldr r0, [r0]
- ldr r1, =0x000040c9
- adds r0, r1
- ldrb r0, [r0]
- cmp r0, 0
- bne _081C0CFC
- movs r0, 0x2
- b _081C0CFE
- .pool
-_081C0CFC:
- movs r0, 0x1
-_081C0CFE:
- strh r0, [r4, 0x2]
- ldrb r0, [r4, 0x2]
- movs r1, 0x80
- lsls r1, 9
- movs r2, 0
- bl ChangeBgX
-_081C0D0C:
- ldrb r0, [r4, 0x2]
- movs r1, 0x80
- lsls r1, 6
- movs r2, 0x2
- bl ChangeBgX
- ldrh r0, [r4]
- adds r0, 0x20
- strh r0, [r4]
- lsls r0, 16
- asrs r0, 16
- cmp r0, 0xFF
- ble _081C0D34
- ldr r0, =gTasks
- lsls r1, r5, 2
- adds r1, r5
- lsls r1, 3
- adds r1, r0
- ldr r0, =sub_81C0D44
- str r0, [r1]
-_081C0D34:
- pop {r4,r5}
- pop {r0}
- bx r0
- .pool
- thumb_func_end sub_81C0CC4
-
- thumb_func_start sub_81C0D44
-sub_81C0D44: @ 81C0D44
- push {r4-r7,lr}
- lsls r0, 24
- lsrs r5, r0, 24
- lsls r0, r5, 2
- adds r0, r5
- lsls r0, 3
- ldr r1, =gTasks + 0x8
- adds r4, r0, r1
- ldr r0, =gUnknown_0203CF1C
- ldr r0, [r0]
- ldr r1, =0x000040c9
- adds r0, r1
- ldrb r0, [r0]
- cmp r0, 0
- bne _081C0D8C
- movs r0, 0x1
- movs r1, 0x7
- movs r2, 0x1
- bl SetBgAttribute
- movs r0, 0x2
- movs r1, 0x7
- movs r2, 0x2
- bl SetBgAttribute
- movs r0, 0x2
- bl schedule_bg_copy_tilemap_to_vram
- b _081C0DA6
- .pool
-_081C0D8C:
- movs r0, 0x2
- movs r1, 0x7
- movs r2, 0x1
- bl SetBgAttribute
- movs r0, 0x1
- movs r1, 0x7
- movs r2, 0x2
- bl SetBgAttribute
- movs r0, 0x1
- bl schedule_bg_copy_tilemap_to_vram
-_081C0DA6:
- ldr r6, =gUnknown_0203CF1C
- ldr r2, [r6]
- ldr r7, =0x000040c0
- adds r1, r2, r7
- ldrb r0, [r1]
- cmp r0, 0x1
- bls _081C0DD0
- ldrb r0, [r4, 0x2]
- ldrb r1, [r1]
- lsls r1, 12
- ldr r3, =0xfffff0bc
- adds r1, r3
- adds r1, r2, r1
- bl SetBgTilemapBuffer
- ldrb r0, [r4, 0x2]
- movs r1, 0x80
- lsls r1, 9
- movs r2, 0
- bl ChangeBgX
-_081C0DD0:
- movs r0, 0x1
- bl ShowBg
- movs r0, 0x2
- bl ShowBg
- ldr r2, [r6]
- ldr r0, =0x000040c9
- adds r2, r0
- ldrb r0, [r2]
- movs r1, 0x1
- eors r0, r1
- movs r1, 0
- strb r0, [r2]
- strh r1, [r4, 0x2]
- strh r1, [r4]
- bl sub_81C1BA0
- ldr r0, [r6]
- adds r0, r7
- ldrb r0, [r0]
- bl sub_81C2AFC
- bl sub_81C4280
- bl sub_81C0E24
- adds r0, r5, 0
- bl SwitchTaskToFollowupFunc
- pop {r4-r7}
- pop {r0}
- bx r0
- .pool
- thumb_func_end sub_81C0D44
-
- thumb_func_start sub_81C0E24
-sub_81C0E24: @ 81C0E24
- push {lr}
- ldr r0, =gUnknown_0203CF1C
- ldr r1, [r0]
- ldr r2, =0x000040c0
- adds r0, r1, r2
- ldrb r0, [r0]
- cmp r0, 0x1
- bne _081C0E3C
- adds r0, r1, 0
- adds r0, 0xC
- bl sub_81C22CC
-_081C0E3C:
- pop {r0}
- bx r0
- .pool
- thumb_func_end sub_81C0E24
-
- thumb_func_start sub_81C0E48
-sub_81C0E48: @ 81C0E48
- push {r4-r7,lr}
- mov r7, r8
- push {r7}
- lsls r0, 24
- lsrs r7, r0, 24
- ldr r5, =gUnknown_0203CF1C
- ldr r0, [r5]
- ldr r2, =0x000040c6
- adds r0, r2
- movs r1, 0
- strb r1, [r0]
- ldr r1, [r5]
- adds r2, r1, r2
- ldrb r0, [r2]
- lsls r0, 1
- adds r1, 0x84
- adds r1, r0
- ldrh r6, [r1]
- mov r8, r6
- movs r0, 0x13
- bl ClearWindowTilemap
- ldr r2, =gSprites
- ldr r0, [r5]
- ldr r1, =0x000040d5
- adds r0, r1
- ldrb r1, [r0]
- lsls r0, r1, 4
- adds r0, r1
- lsls r0, 2
- adds r0, r2
- adds r0, 0x3E
- ldrb r0, [r0]
- lsls r0, 29
- cmp r0, 0
- blt _081C0E96
- movs r0, 0xD
- bl ClearWindowTilemap
-_081C0E96:
- movs r4, 0x3
- negs r4, r4
- movs r0, 0x9
- adds r1, r4, 0
- bl sub_81C1DA4
- movs r0, 0x9
- adds r1, r4, 0
- adds r2, r6, 0
- bl sub_81C1EFC
- ldr r0, [r5]
- ldr r1, =0x000040c8
- adds r0, r1
- ldrb r0, [r0]
- cmp r0, 0
- bne _081C0EC4
- movs r0, 0x5
- bl ClearWindowTilemap
- movs r0, 0x6
- bl PutWindowTilemap
-_081C0EC4:
- ldr r0, [r5]
- ldr r1, =0x000020bc
- adds r0, r1
- movs r1, 0x3
- movs r2, 0
- bl sub_81C2194
- ldr r0, [r5]
- ldr r1, =0x000030bc
- adds r0, r1
- movs r1, 0x1
- movs r2, 0
- bl sub_81C2194
- mov r0, r8
- bl sub_81C3E9C
- bl sub_81C3F44
- bl sub_81C44F0
- movs r0, 0
- bl schedule_bg_copy_tilemap_to_vram
- movs r0, 0x1
- bl schedule_bg_copy_tilemap_to_vram
- movs r0, 0x2
- bl schedule_bg_copy_tilemap_to_vram
- movs r0, 0x8
- bl sub_81C4AF8
- ldr r1, =gTasks
- lsls r0, r7, 2
- adds r0, r7
- lsls r0, 3
- adds r0, r1
- ldr r1, =sub_81C0F44
- str r1, [r0]
- pop {r3}
- mov r8, r3
- pop {r4-r7}
- pop {r0}
- bx r0
- .pool
- thumb_func_end sub_81C0E48
-
- thumb_func_start sub_81C0F44
-sub_81C0F44: @ 81C0F44
- push {r4-r6,lr}
- lsls r0, 24
- lsrs r5, r0, 24
- adds r6, r5, 0
- lsls r0, r5, 2
- adds r0, r5
- lsls r0, 3
- ldr r1, =gTasks + 0x8
- adds r4, r0, r1
- bl sub_81221EC
- lsls r0, 24
- lsrs r0, 24
- cmp r0, 0x1
- beq _081C103A
- ldr r0, =gMain
- ldrh r1, [r0, 0x2E]
- movs r0, 0x40
- ands r0, r1
- cmp r0, 0
- beq _081C0F98
- movs r0, 0x4
- strh r0, [r4]
- movs r1, 0x1
- negs r1, r1
- ldr r0, =gUnknown_0203CF1C
- ldr r2, [r0]
- ldr r0, =0x000040c6
- adds r2, r0
- adds r0, r4, 0
- bl sub_81C1070
- b _081C103A
- .pool
-_081C0F98:
- movs r0, 0x80
- ands r0, r1
- cmp r0, 0
- beq _081C0FC0
- movs r0, 0x4
- strh r0, [r4]
- ldr r0, =gUnknown_0203CF1C
- ldr r2, [r0]
- ldr r0, =0x000040c6
- adds r2, r0
- adds r0, r4, 0
- movs r1, 0x1
- bl sub_81C1070
- b _081C103A
- .pool
-_081C0FC0:
- movs r0, 0x1
- ands r0, r1
- cmp r0, 0
- beq _081C1026
- ldr r0, =gUnknown_0203CF1C
- ldr r1, [r0]
- ldr r2, =0x000040c8
- adds r0, r1, r2
- ldrb r0, [r0]
- cmp r0, 0x1
- beq _081C0FE8
- subs r2, 0x4
- adds r0, r1, r2
- ldr r0, [r0]
- ldr r1, =0x00ffffff
- ands r0, r1
- movs r1, 0x80
- lsls r1, 11
- cmp r0, r1
- bne _081C1004
-_081C0FE8:
- movs r0, 0x5
- bl PlaySE
- adds r0, r5, 0
- bl sub_81C11F4
- b _081C103A
- .pool
-_081C1004:
- bl sub_81C1040
- lsls r0, 24
- lsrs r0, 24
- cmp r0, 0x1
- bne _081C101E
- movs r0, 0x5
- bl PlaySE
- adds r0, r5, 0
- bl sub_81C129C
- b _081C103A
-_081C101E:
- movs r0, 0x20
- bl PlaySE
- b _081C103A
-_081C1026:
- movs r0, 0x2
- ands r0, r1
- cmp r0, 0
- beq _081C103A
- movs r0, 0x5
- bl PlaySE
- adds r0, r6, 0
- bl sub_81C11F4
-_081C103A:
- pop {r4-r6}
- pop {r0}
- bx r0
- thumb_func_end sub_81C0F44
-
- thumb_func_start sub_81C1040
-sub_81C1040: @ 81C1040
- push {lr}
- movs r1, 0x1
- ldr r0, =gUnknown_0203CF1C
- ldr r0, [r0]
- adds r2, r0, 0
- adds r2, 0x84
-_081C104C:
- lsls r0, r1, 1
- adds r0, r2, r0
- ldrh r0, [r0]
- cmp r0, 0
- beq _081C1060
- movs r0, 0x1
- b _081C106C
- .pool
-_081C1060:
- adds r0, r1, 0x1
- lsls r0, 24
- lsrs r1, r0, 24
- cmp r1, 0x3
- bls _081C104C
- movs r0, 0
-_081C106C:
- pop {r1}
- bx r1
- thumb_func_end sub_81C1040
-
thumb_func_start sub_81C1070
sub_81C1070: @ 81C1070
push {r4-r7,lr}
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