summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorPikalaxALT <PikalaxALT@users.noreply.github.com>2019-08-05 15:21:20 -0400
committerGitHub <noreply@github.com>2019-08-05 15:21:20 -0400
commit195137b001d7e985d18c40b26f160de08dccb5fa (patch)
treef5b69847b5e6484f7006034de94ebad377dcbb70 /src
parent9beeba842453c836d18ecce4b6760bf03bfdb513 (diff)
parent5d071233547324b4b1c3cac0d069e98968455db3 (diff)
Merge pull request #768 from PikalaxALT/pokenav_unk_8
Finish pokenav_unk_8
Diffstat (limited to 'src')
-rw-r--r--src/pokenav.c6
-rw-r--r--src/pokenav_match_call_ui.c10
-rwxr-xr-xsrc/pokenav_unk_3.c71
-rwxr-xr-xsrc/pokenav_unk_4.c4
-rwxr-xr-xsrc/pokenav_unk_5.c2
-rw-r--r--src/pokenav_unk_8.c645
6 files changed, 629 insertions, 109 deletions
diff --git a/src/pokenav.c b/src/pokenav.c
index b4b185c84..afa110e4b 100644
--- a/src/pokenav.c
+++ b/src/pokenav.c
@@ -31,7 +31,7 @@ struct UnknownPokenavCallbackStruct
bool32 (*unk0)(void);
u32 (*unk4)(void);
bool32 (*unk8)(void);
- void (*unkC)(int);
+ void (*unkC)(s32);
u32 (*unk10)(void);
void (*unk14)(void);
void (*unk18)(void);
@@ -62,14 +62,14 @@ extern bool32 sub_81CF368(void);
extern u32 sub_81CF9BC(void);
extern u32 sub_81CFA34(void);
extern bool32 sub_81CFDD0(void);
-extern void sub_81CFE40(int);
+extern void sub_81CFE40(s32);
extern u32 sub_81CFE70(void);
extern void sub_81CFA48(void);
extern void sub_81CFE98(void);
extern u32 sub_81D0450(void);
extern u32 sub_81D04A0(void);
extern bool32 sub_81D0978(void);
-extern void sub_81D09B0(int);
+extern void sub_81D09B0(s32);
extern u32 sub_81D09E0(void);
extern void sub_81D04B8(void);
extern void sub_81D09F4(void);
diff --git a/src/pokenav_match_call_ui.c b/src/pokenav_match_call_ui.c
index 5204f0ed7..275a4063e 100644
--- a/src/pokenav_match_call_ui.c
+++ b/src/pokenav_match_call_ui.c
@@ -31,7 +31,7 @@ struct MatchCallWindowState {
u16 visibleEntries;
u16 unkA;
u32 unkC;
- u32 unk10;
+ void * unk10;
};
struct PokenavSub17Substruct
@@ -40,13 +40,13 @@ struct PokenavSub17Substruct
u32 unk10;
u32 unk14;
u32 unk18;
- u32 unk1C;
+ void * unk1C;
s32 unk20;
s32 unk24;
u32 unk28;
s32 unk2C;
u32 unk30;
- void (*unk34)(u32, u8*);
+ void (*unk34)(struct PokenavMonList *, u8*);
void (*unk38)(u16, u32, u32);
struct Sprite *rightArrow;
struct Sprite *upArrow;
@@ -82,7 +82,7 @@ void sub_81C8D4C(struct MatchCallWindowState *a0, struct PokenavSub17Substruct *
void sub_81C8CB4(struct MatchCallWindowState *a0, struct PokenavSub17Substruct *a1);
void sub_81C8B70(struct UnknownSubSubStruct_0203CF40 *a0, s32 a1, s32 a2);
void sub_81C8568(s32 a0, struct PokenavSub17Substruct *a1);
-void sub_81C83AC(u32 a0, u32 a1, u32 a2, u32 a3, u32 a4, struct PokenavSub17Substruct *a5);
+void sub_81C83AC(void * a0, u32 a1, u32 a2, u32 a3, u32 a4, struct PokenavSub17Substruct *a5);
void sub_81C837C(struct MatchCallWindowState *a0, struct PokenavSub17Substruct *a1);
void sub_81C835C(struct UnknownSubSubStruct_0203CF40 *a0);
u32 LoopedTask_sub_81C8254(s32 state);
@@ -194,7 +194,7 @@ void sub_81C837C(struct MatchCallWindowState *a0, struct PokenavSub17Substruct *
sub_81C83AC(a0->unk10, a0->windowTopIndex, arg2, a0->unkC, 0, a1);
}
-void sub_81C83AC(u32 a0, u32 a1, u32 a2, u32 a3, u32 a4, struct PokenavSub17Substruct *a5)
+void sub_81C83AC(void * a0, u32 a1, u32 a2, u32 a3, u32 a4, struct PokenavSub17Substruct *a5)
{
if (a2 == 0)
return;
diff --git a/src/pokenav_unk_3.c b/src/pokenav_unk_3.c
index 9b62bea78..e44a6563a 100755
--- a/src/pokenav_unk_3.c
+++ b/src/pokenav_unk_3.c
@@ -26,7 +26,7 @@ struct Pokenav3Struct
u32 unk10;
u32 unk14;
u32 (*callback)(struct Pokenav3Struct*);
- struct Pokenav3Struct_Unk1C unk1C[99];
+ struct PokenavMonList unk1C[99];
};
static u32 sub_81CAB44(struct Pokenav3Struct *);
@@ -84,7 +84,7 @@ static u32 sub_81CAB44(struct Pokenav3Struct *state)
state->callback = sub_81CAC04;
state->unk0 = 0;
selectedMatchCall = GetSelectedMatchCall();
- if (!state->unk1C[selectedMatchCall].unk0 || sub_81D17E8(state->unk1C[selectedMatchCall].unk2))
+ if (!state->unk1C[selectedMatchCall].boxId || sub_81D17E8(state->unk1C[selectedMatchCall].unk6))
{
state->unk4 = gUnknown_0862250A;
state->unk2 = 2;
@@ -206,9 +206,9 @@ static u32 sub_81CAD20(s32 taskState)
{
if (MatchCallFlagGetByIndex(j))
{
- state->unk1C[state->unkA].unk2 = j;
- state->unk1C[state->unkA].unk0 = 1;
- state->unk1C[state->unkA].unk1 = MatchCallMapSecGetByIndex(j);
+ state->unk1C[state->unkA].unk6 = j;
+ state->unk1C[state->unkA].boxId = 1;
+ state->unk1C[state->unkA].monId = MatchCallMapSecGetByIndex(j);
state->unkA++;
}
@@ -226,9 +226,9 @@ static u32 sub_81CAD20(s32 taskState)
{
if (!sub_81D1BF8(state->unk8) && sub_81CAE08(state->unk8))
{
- state->unk1C[state->unkA].unk2 = state->unk8;
- state->unk1C[state->unkA].unk0 = 0;
- state->unk1C[state->unkA].unk1 = sub_81CB0C8(j);
+ state->unk1C[state->unkA].unk6 = state->unk8;
+ state->unk1C[state->unkA].boxId = 0;
+ state->unk1C[state->unkA].monId = sub_81CB0C8(j);
state->unkA++;
}
@@ -284,10 +284,10 @@ int unref_sub_81CAE6C(int arg0)
if (arg0 >= state->unkA)
return REMATCH_TABLE_ENTRIES;
- return state->unk1C[arg0].unk2;
+ return state->unk1C[arg0].unk6;
}
-struct Pokenav3Struct_Unk1C *sub_81CAE94(void)
+struct PokenavMonList *sub_81CAE94(void)
{
struct Pokenav3Struct *state = GetSubstructPtr(5);
return state->unk1C;
@@ -296,16 +296,16 @@ struct Pokenav3Struct_Unk1C *sub_81CAE94(void)
u16 sub_81CAEA4(int index)
{
struct Pokenav3Struct *state = GetSubstructPtr(5);
- return state->unk1C[index].unk1;
+ return state->unk1C[index].monId;
}
bool32 sub_81CAEBC(int index)
{
struct Pokenav3Struct *state = GetSubstructPtr(5);
- if (!state->unk1C[index].unk0)
- index = state->unk1C[index].unk2;
+ if (!state->unk1C[index].boxId)
+ index = state->unk1C[index].unk6;
else
- index = MatchCall_GetRematchTableIdx(state->unk1C[index].unk2);
+ index = MatchCall_GetRematchTableIdx(state->unk1C[index].unk6);
if (index == REMATCH_TABLE_ENTRIES)
return FALSE;
@@ -317,13 +317,13 @@ int sub_81CAF04(int index)
{
int var0;
struct Pokenav3Struct *state = GetSubstructPtr(5);
- if (!state->unk1C[index].unk0)
+ if (!state->unk1C[index].boxId)
{
- index = GetTrainerIdxByRematchIdx(state->unk1C[index].unk2);
+ index = GetTrainerIdxByRematchIdx(state->unk1C[index].unk6);
return gTrainers[index].trainerPic;
}
- var0 = state->unk1C[index].unk2;
+ var0 = state->unk1C[index].unk6;
index = MatchCall_GetRematchTableIdx(var0);
if (index != REMATCH_TABLE_ENTRIES)
{
@@ -342,10 +342,10 @@ const u8 *sub_81CAF78(int index, u8 *arg1)
if (!Overworld_MapTypeAllowsTeleportAndFly(gMapHeader.mapType))
return gText_CallCantBeMadeHere;
- if (!state->unk1C[index].unk0)
- *arg1 = SelectMatchCallMessage(GetTrainerIdxByRematchIdx(state->unk1C[index].unk2), gStringVar4);
+ if (!state->unk1C[index].boxId)
+ *arg1 = SelectMatchCallMessage(GetTrainerIdxByRematchIdx(state->unk1C[index].unk6), gStringVar4);
else
- MatchCall_GetMessage(state->unk1C[index].unk2, gStringVar4);
+ MatchCall_GetMessage(state->unk1C[index].unk6, gStringVar4);
return gStringVar4;
}
@@ -354,15 +354,15 @@ const u8 *sub_81CAFD8(int index, int textType)
{
int var0;
struct Pokenav3Struct *state = GetSubstructPtr(5);
- if (state->unk1C[index].unk0)
+ if (state->unk1C[index].boxId)
{
- var0 = MatchCall_GetRematchTableIdx(state->unk1C[index].unk2);
+ var0 = MatchCall_GetRematchTableIdx(state->unk1C[index].unk6);
if (var0 == REMATCH_TABLE_ENTRIES)
- return sub_81D1B40(state->unk1C[index].unk2, textType);
+ return sub_81D1B40(state->unk1C[index].unk6, textType);
}
else
{
- var0 = state->unk1C[index].unk2;
+ var0 = state->unk1C[index].unk6;
}
return gMatchCallMessages[var0][textType];
@@ -383,14 +383,13 @@ u16 sub_81CB02C(int arg0)
return state->unk4[arg0];
}
-void sub_81CB050(u32 arg0, u8 *str)
+void sub_81CB050(struct PokenavMonList * arg0, u8 *str)
{
- struct Pokenav3Struct_Unk1C *var0 = (struct Pokenav3Struct_Unk1C *)arg0;
const u8 *trainerName;
const u8 *className;
- if (!var0->unk0)
+ if (!arg0->boxId)
{
- int index = GetTrainerIdxByRematchIdx(var0->unk2);
+ int index = GetTrainerIdxByRematchIdx(arg0->unk6);
const struct Trainer *trainer = &gTrainers[index];
int class = trainer->trainerClass;
className = gTrainerClassNames[class];
@@ -398,7 +397,7 @@ void sub_81CB050(u32 arg0, u8 *str)
}
else
{
- sub_81D1A78(var0->unk2, &className, &trainerName);
+ sub_81D1A78(arg0->unk6, &className, &trainerName);
}
if (className && trainerName)
@@ -425,9 +424,9 @@ int sub_81CB0E4(int index)
int count = 1;
while (++index < state->unkA)
{
- if (!state->unk1C[index].unk0)
+ if (!state->unk1C[index].boxId)
return count;
- if (sub_81D17E8(state->unk1C[index].unk2))
+ if (sub_81D17E8(state->unk1C[index].unk6))
return count;
count++;
@@ -442,9 +441,9 @@ int sub_81CB128(int index)
int count = -1;
while (--index >= 0)
{
- if (!state->unk1C[index].unk0)
+ if (!state->unk1C[index].boxId)
return count;
- if (sub_81D17E8(state->unk1C[index].unk2))
+ if (sub_81D17E8(state->unk1C[index].unk6))
return count;
count--;
@@ -480,17 +479,17 @@ static bool32 sub_81CB1D0(void)
{
struct Pokenav3Struct *state = GetSubstructPtr(5);
int index = GetSelectedMatchCall();
- if (!state->unk1C[index].unk0)
+ if (!state->unk1C[index].boxId)
{
if (sub_81CAEA4(index) == gMapHeader.regionMapSectionId)
{
- if (!gSaveBlock1Ptr->trainerRematches[state->unk1C[index].unk2])
+ if (!gSaveBlock1Ptr->trainerRematches[state->unk1C[index].unk6])
return TRUE;
}
}
else
{
- if (state->unk1C[index].unk2 == 11)
+ if (state->unk1C[index].unk6 == 11)
{
if (sub_81CAEA4(index) == gMapHeader.regionMapSectionId
&& FlagGet(FLAG_BADGE05_GET) == TRUE)
diff --git a/src/pokenav_unk_4.c b/src/pokenav_unk_4.c
index 93dab4491..0f05c6f5d 100755
--- a/src/pokenav_unk_4.c
+++ b/src/pokenav_unk_4.c
@@ -290,7 +290,7 @@ bool32 sub_81CB260(void)
return TRUE;
}
-void sub_81CB29C(int index)
+void sub_81CB29C(s32 index)
{
struct Pokenav4Struct *state = GetSubstructPtr(6);
state->unk4 = CreateLoopedTask(gUnknown_08622798[index], 1);
@@ -870,7 +870,7 @@ u32 sub_81CBB74(s32 taskState)
static void sub_81CBBB8(void)
{
struct MatchCallListTemplate template;
- template.unk0 = (u32)sub_81CAE94();
+ template.unk0 = sub_81CAE94();
template.unk4 = sub_81CAE38();
template.unk8 = 4;
template.unk6 = 0;
diff --git a/src/pokenav_unk_5.c b/src/pokenav_unk_5.c
index ccab58078..c4e4f38ce 100755
--- a/src/pokenav_unk_5.c
+++ b/src/pokenav_unk_5.c
@@ -248,7 +248,7 @@ bool32 sub_81CC5F4(void)
return TRUE;
}
-void sub_81CC62C(int index)
+void sub_81CC62C(s32 index)
{
struct Pokenav5Struct_2 *state = GetSubstructPtr(4);
state->unk4 = CreateLoopedTask(gUnknown_086230E4[index], 1);
diff --git a/src/pokenav_unk_8.c b/src/pokenav_unk_8.c
index bcafc14d0..a758c59f5 100644
--- a/src/pokenav_unk_8.c
+++ b/src/pokenav_unk_8.c
@@ -1,22 +1,63 @@
#include "global.h"
#include "pokenav.h"
#include "bg.h"
+#include "menu.h"
#include "window.h"
+#include "sound.h"
+#include "dynamic_placeholder_text_util.h"
+#include "strings.h"
+#include "string_util.h"
+#include "international_string_util.h"
+#include "constants/songs.h"
-u32 sub_81CF134(void);
-u32 sub_81CF1C4(void);
-u32 sub_81CF1D8(void);
-u32 sub_81CF278(void);
-u32 sub_81CF578(s32);
-u32 sub_81CF5F0(s32);
-u32 sub_81CF668(s32);
-u32 sub_81CF6E0(s32);
-u32 sub_81CF758(s32);
-u32 sub_81CF798(s32);
+struct PokenavSub7
+{
+ u32 (*unk0)(struct PokenavSub7 *);
+ u32 loopedTaskId;
+ u8 fill1[4];
+ s32 unkC;
+ s32 unk10;
+ u32 unk14;
+ u32 unk18;
+ u32 unk1C;
+ struct PokenavSub18 *unkPtr;
+};
-const u32 gUnknown_086233A0[] = {0x16, 0x17, 0x18, 0x21, 0x2F};
+struct PokenavSub8
+{
+ bool32 (*callback)(void);
+ u32 ltid;
+ u16 winid;
+ bool32 unkC;
+ u16 buff[0x400];
+}; // size: 0x810
-u32 (*const gUnknown_086233B4[])(void) =
+static u32 sub_81CF010(struct PokenavSub7 *structPtr);
+static u32 sub_81CF030(struct PokenavSub7 *structPtr);
+static u32 sub_81CF0B8(struct PokenavSub7 *structPtr);
+static u32 sub_81CF0B0(struct PokenavSub7 *structPtr);
+static u32 sub_81CF11C(s32 state);
+static u32 sub_81CF134(s32 state);
+static u32 sub_81CF1C4(s32 state);
+static u32 sub_81CF1D8(s32 state);
+static u32 sub_81CF278(s32 state);
+static u32 sub_81CF578(s32 state);
+static u32 sub_81CF5F0(s32 state);
+static u32 sub_81CF668(s32 state);
+static u32 sub_81CF6E0(s32 state);
+static u32 sub_81CF758(s32 state);
+static u32 sub_81CF798(s32 state);
+static void sub_81CF2C4(struct PokenavSub7 *structPtr, struct PokenavMonList *item);
+static bool32 sub_81CF3E4(void);
+static u32 sub_81CF418(s32 state);
+static void sub_81CF7C8(struct PokenavSub8 *);
+static void sub_81CF7F4(struct PokenavSub8 *);
+static void sub_81CF88C(void);
+static void sub_81CF8E4(struct PokenavMonList *, u8 *);
+
+static const u32 gUnknown_086233A0[] = {0x16, 0x17, 0x18, 0x21, 0x2F};
+
+static const LoopedTask gUnknown_086233B4[] =
{
sub_81CF134,
sub_81CF1C4,
@@ -24,34 +65,33 @@ u32 (*const gUnknown_086233B4[])(void) =
sub_81CF278
};
-const u16 gUnknown_086233C4[] = INCBIN_U16("graphics/pokenav/condition_search2.gbapal");
-const u32 gUnknown_086233E4[] = INCBIN_U32("graphics/pokenav/condition_search2.4bpp.lz");
-const u32 gUnknown_086234AC[] = INCBIN_U32("graphics/pokenav/condition_search2.bin.lz");
-const u16 gUnknown_08623570[] = INCBIN_U16("graphics/pokenav/8623570.gbapal");
+static const u16 gUnknown_086233C4[] = INCBIN_U16("graphics/pokenav/condition_search2.gbapal");
+static const u32 gUnknown_086233E4[] = INCBIN_U32("graphics/pokenav/condition_search2.4bpp.lz");
+static const u32 gUnknown_086234AC[] = INCBIN_U32("graphics/pokenav/condition_search2.bin.lz");
+static const u16 gUnknown_08623570[] = INCBIN_U16("graphics/pokenav/8623570.gbapal");
-const struct BgTemplate gUnknown_08623590 =
+static const struct BgTemplate gUnknown_08623590[] =
{
- .bg = 1,
- .charBaseIndex = 1,
- .mapBaseIndex = 0x06,
- .screenSize = 0,
- .paletteMode = 0,
- .priority = 2,
- .baseTile = 0
-};
-
-const struct BgTemplate gUnknown_08623594 =
-{
- .bg = 2,
- .charBaseIndex = 2,
- .mapBaseIndex = 0x07,
- .screenSize = 0,
- .paletteMode = 0,
- .priority = 3,
- .baseTile = 0
+ {
+ .bg = 1,
+ .charBaseIndex = 1,
+ .mapBaseIndex = 0x06,
+ .screenSize = 0,
+ .paletteMode = 0,
+ .priority = 2,
+ .baseTile = 0
+ }, {
+ .bg = 2,
+ .charBaseIndex = 2,
+ .mapBaseIndex = 0x07,
+ .screenSize = 0,
+ .paletteMode = 0,
+ .priority = 3,
+ .baseTile = 0
+ }
};
-const LoopedTask gUnknown_08623598[] =
+static const LoopedTask gUnknown_08623598[] =
{
NULL,
sub_81CF578,
@@ -62,7 +102,7 @@ const LoopedTask gUnknown_08623598[] =
sub_81CF798
};
-const struct WindowTemplate gUnknown_086235B4 =
+static const struct WindowTemplate gUnknown_086235B4 =
{
.bg = 1,
.tilemapLeft = 1,
@@ -73,26 +113,9 @@ const struct WindowTemplate gUnknown_086235B4 =
.baseBlock = 20
};
-const u8 gUnknown_086235BC[] = _("{COLOR_HIGHLIGHT_SHADOW}{LIGHT_RED}{WHITE}{GREEN}♂{COLOR_HIGHLIGHT_SHADOW}{DARK_GREY}{WHITE}{LIGHT_GREY}");
-const u8 gUnknown_086235C8[] = _("{COLOR_HIGHLIGHT_SHADOW}{LIGHT_GREEN}{WHITE}{BLUE}♀{COLOR_HIGHLIGHT_SHADOW}{DARK_GREY}{WHITE}{LIGHT_GREY}");
-const u8 gUnknown_086235D4[] = _("{UNK_SPACER}");
-
-struct PokenavSub7
-{
- u32 (*unk0)(struct PokenavSub7 *);
- u32 loopedTaskId;
- u8 fill1[12];
- u32 unk14;
- u32 unk18;
- u32 unk1C;
- struct PokenavSub18 *unkPtr;
-};
-
-u32 sub_81CF010(struct PokenavSub7 *structPtr);
-u32 sub_81CF030(struct PokenavSub7 *structPtr);
-u32 sub_81CF0B8(struct PokenavSub7 *structPtr);
-u32 sub_81CF0B0(struct PokenavSub7 *structPtr);
-u32 sub_81CF11C(s32 state);
+static const u8 gUnknown_086235BC[] = _("{COLOR_HIGHLIGHT_SHADOW}{LIGHT_RED}{WHITE}{GREEN}♂{COLOR_HIGHLIGHT_SHADOW}{DARK_GREY}{WHITE}{LIGHT_GREY}");
+static const u8 gUnknown_086235C8[] = _("{COLOR_HIGHLIGHT_SHADOW}{LIGHT_GREEN}{WHITE}{BLUE}♀{COLOR_HIGHLIGHT_SHADOW}{DARK_GREY}{WHITE}{LIGHT_GREY}");
+static const u8 gUnknown_086235D4[] = _("{UNK_SPACER}");
bool32 sub_81CEF3C(void)
{
@@ -138,14 +161,14 @@ void sub_81CEFF0(void)
FreePokenavSubstruct(7);
}
-bool32 sub_81CF010(struct PokenavSub7 *structPtr)
+static bool32 sub_81CF010(struct PokenavSub7 *structPtr)
{
if (!IsLoopedTaskActive(structPtr->loopedTaskId))
structPtr->unk0 = sub_81CF030;
return FALSE;
}
-u32 sub_81CF030(struct PokenavSub7 *structPtr)
+static u32 sub_81CF030(struct PokenavSub7 *structPtr)
{
if (gMain.newAndRepeatedKeys & DPAD_UP)
return 1;
@@ -172,18 +195,516 @@ u32 sub_81CF030(struct PokenavSub7 *structPtr)
return 0;
}
-u32 sub_81CF0B0(struct PokenavSub7 *structPtr)
+static u32 sub_81CF0B0(struct PokenavSub7 *structPtr)
{
return 0x186A3;
}
-u32 sub_81CF0B8(struct PokenavSub7 *structPtr)
+static u32 sub_81CF0B8(struct PokenavSub7 *structPtr)
{
return 0x186A9;
}
-u32 sub_81CF0C0(void)
+static u32 sub_81CF0C0(void)
{
struct PokenavSub7 *structPtr = GetSubstructPtr(7);
return structPtr->unk18;
}
+
+static struct PokenavMonList * sub_81CF0D0(void)
+{
+ struct PokenavSub7 * ptr = GetSubstructPtr(7);
+ return ptr->unkPtr->unk4;
+}
+
+static u16 sub_81CF0E0(void)
+{
+ struct PokenavSub7 * ptr = GetSubstructPtr(7);
+ return ptr->unkPtr->unk0;
+}
+
+static s32 sub_81CF0F0(void)
+{
+ struct PokenavSub7 * ptr = GetSubstructPtr(7);
+ s32 i = GetSelectedMatchCall();
+ return ptr->unkPtr->unk4[i].unk6;
+}
+
+static u16 sub_81CF10C(void)
+{
+ struct PokenavSub7 * ptr = GetSubstructPtr(7);
+ return ptr->unkPtr->unk2;
+}
+
+static u32 sub_81CF11C(s32 state)
+{
+ return gUnknown_086233B4[state](state);
+}
+
+static u32 sub_81CF134(s32 state)
+{
+ s32 i;
+ struct PokenavMonList item;
+ struct PokenavSub7 * ptr = GetSubstructPtr(7);
+
+ ptr->unkPtr->unk0 = 0;
+ ptr->unkPtr->unk2 = 0;
+ item.boxId = 14;
+ for (i = 0; i < PARTY_SIZE; i++)
+ {
+ struct Pokemon * pokemon = &gPlayerParty[i];
+ if (!GetMonData(pokemon, MON_DATA_SANITY_HAS_SPECIES))
+ return LT_INC_AND_CONTINUE;
+ if (!GetMonData(pokemon, MON_DATA_SANITY_IS_EGG))
+ {
+ item.monId = i;
+ item.unk6 = GetMonData(pokemon, ptr->unk14);
+ sub_81CF2C4(ptr, &item);
+ }
+ }
+
+ return LT_INC_AND_CONTINUE;
+}
+
+static u32 sub_81CF1C4(s32 state)
+{
+ struct PokenavSub7 * ptr = GetSubstructPtr(7);
+ ptr->unk10 = 0;
+ ptr->unkC = 0;
+ return LT_INC_AND_CONTINUE;
+}
+
+static u32 sub_81CF1D8(s32 state)
+{
+ struct PokenavSub7 * ptr = GetSubstructPtr(7);
+ s32 boxId = ptr->unkC;
+ s32 monId = ptr->unk10;
+ s32 boxCount = 0;
+ struct PokenavMonList item;
+
+ while (boxId < TOTAL_BOXES_COUNT)
+ {
+ while (monId < IN_BOX_COUNT)
+ {
+ if (CheckBoxMonSanityAt(boxId, monId))
+ {
+ item.boxId = boxId;
+ item.monId = monId;
+ item.unk6 = GetBoxMonDataAt(boxId, monId, ptr->unk14);
+ sub_81CF2C4(ptr, &item);
+ }
+ boxCount++;
+ monId++;
+ if (boxCount > 14)
+ {
+ ptr->unkC = boxId;
+ ptr->unk10 = monId;
+ return LT_CONTINUE;
+ }
+ }
+ monId = 0;
+ boxId++;
+ }
+
+ return LT_INC_AND_CONTINUE;
+}
+
+static u32 sub_81CF278(s32 state)
+{
+ struct PokenavSub7 * ptr = GetSubstructPtr(7);
+ s32 r6 = ptr->unkPtr->unk0;
+ s32 r4 = ptr->unkPtr->unk4[0].unk6;
+ s32 i;
+ ptr->unkPtr->unk4[0].unk6 = 1;
+ for (i = 1; i < r6; i++)
+ {
+ if (ptr->unkPtr->unk4[i].unk6 == r4)
+ {
+ ptr->unkPtr->unk4[i].unk6 = ptr->unkPtr->unk4[i - 1].unk6;
+ }
+ else
+ {
+ r4 = ptr->unkPtr->unk4[i].unk6;
+ ptr->unkPtr->unk4[i].unk6 = i + 1;
+ }
+ }
+ ptr->unk18 = 1;
+ return LT_FINISH;
+}
+
+static void sub_81CF2C4(struct PokenavSub7 *structPtr, struct PokenavMonList *item)
+{
+ u32 left = 0;
+ u32 right = structPtr->unkPtr->unk0;
+ u32 insertionIdx = left + (right - left) / 2;
+
+ while (right != insertionIdx)
+ {
+ if (item->unk6 > structPtr->unkPtr->unk4[insertionIdx].unk6)
+ right = insertionIdx;
+ else
+ left = insertionIdx + 1;
+ insertionIdx = left + (right - left) / 2;
+ }
+ for (right = structPtr->unkPtr->unk0; right > insertionIdx; right--)
+ structPtr->unkPtr->unk4[right] = structPtr->unkPtr->unk4[right - 1];
+ structPtr->unkPtr->unk4[insertionIdx] = *item;
+ structPtr->unkPtr->unk0++;
+}
+
+bool32 sub_81CF330(void)
+{
+ struct PokenavSub8 * unk = AllocSubstruct(8, sizeof(struct PokenavSub8));
+ if (unk == NULL)
+ return FALSE;
+ unk->ltid = CreateLoopedTask(sub_81CF418, 1);
+ unk->callback = sub_81CF3E4;
+ unk->unkC = FALSE;
+ return TRUE;
+}
+
+bool32 sub_81CF368(void)
+{
+ struct PokenavSub8 * unk = AllocSubstruct(8, sizeof(struct PokenavSub8));
+ if (unk == NULL)
+ return FALSE;
+ unk->ltid = CreateLoopedTask(sub_81CF418, 1);
+ unk->callback = sub_81CF3E4;
+ unk->unkC = TRUE;
+ return TRUE;
+}
+
+void sub_81CF3A0(s32 idx)
+{
+ struct PokenavSub8 * unk = GetSubstructPtr(8);
+ unk->ltid = CreateLoopedTask(gUnknown_08623598[idx], 1);
+ unk->callback = sub_81CF3E4;
+}
+
+bool32 sub_81CF3D0(void)
+{
+ struct PokenavSub8 * unk = GetSubstructPtr(8);
+ return unk->callback();
+}
+
+static bool32 sub_81CF3E4(void)
+{
+ struct PokenavSub8 * unk = GetSubstructPtr(8);
+ return IsLoopedTaskActive(unk->ltid);
+}
+
+void sub_81CF3F8(void)
+{
+ struct PokenavSub8 * unk = GetSubstructPtr(8);
+ sub_81C8234();
+ RemoveWindow(unk->winid);
+ FreePokenavSubstruct(8);
+}
+
+static u32 sub_81CF418(s32 state)
+{
+ struct PokenavSub8 * unk = GetSubstructPtr(8);
+ switch (state)
+ {
+ case 0:
+ InitBgTemplates(gUnknown_08623590, NELEMS(gUnknown_08623590));
+ decompress_and_copy_tile_data_to_vram(1, gUnknown_086233E4, 0, 0, 0);
+ SetBgTilemapBuffer(1, unk->buff);
+ CopyToBgTilemapBuffer(1, gUnknown_086234AC, 0, 0);
+ CopyBgTilemapBufferToVram(1);
+ CopyPaletteIntoBufferUnfaded(gUnknown_086233C4, 0x10, 0x20);
+ CopyBgTilemapBufferToVram(1);
+ return LT_INC_AND_PAUSE;
+ case 1:
+ if (free_temp_tile_data_buffers_if_possible())
+ return LT_PAUSE;
+ if (!sub_81CF0C0())
+ return LT_PAUSE;
+ return LT_INC_AND_PAUSE;
+ case 2:
+ if (free_temp_tile_data_buffers_if_possible())
+ return LT_PAUSE;
+ CopyPaletteIntoBufferUnfaded(gUnknown_08623570, 0x20, 0x20);
+ sub_81CF88C();
+ return LT_INC_AND_PAUSE;
+ case 3:
+ if (sub_81C8224())
+ return LT_PAUSE;
+ sub_81CF7C8(unk);
+ sub_81C7BA4(3);
+ return LT_INC_AND_PAUSE;
+ case 4:
+ if (free_temp_tile_data_buffers_if_possible())
+ return LT_PAUSE;
+ ChangeBgX(1, 0, 0);
+ ChangeBgY(1, 0, 0);
+ ShowBg(1);
+ ShowBg(2);
+ HideBg(3);
+ if (!unk->unkC)
+ {
+ u8 r4 = sub_81C76AC() + 8;
+ LoadLeftHeaderGfxForIndex(r4);
+ sub_81C7FA0(r4, 1, 0);
+ sub_81C7FA0(1, 1, 0);
+ }
+ sub_81C7AC0(1);
+ return LT_INC_AND_PAUSE;
+ case 5:
+ if (IsPaletteFadeActive())
+ return LT_PAUSE;
+ if (sub_81C8010())
+ return LT_PAUSE;
+ break;
+ }
+ return LT_FINISH;
+}
+
+static u32 sub_81CF578(s32 state)
+{
+ struct PokenavSub8 * unk = GetSubstructPtr(8);
+ switch (state)
+ {
+ case 0:
+ switch (MatchCall_MoveCursorUp())
+ {
+ case 0:
+ return LT_FINISH;
+ case 1:
+ PlaySE(SE_SELECT);
+ return LT_SET_STATE(2);
+ case 2:
+ PlaySE(SE_SELECT);
+ break;
+ }
+ return LT_INC_AND_PAUSE;
+ case 1:
+ if (sub_81C8630())
+ return LT_PAUSE;
+ // fallthrough
+ case 2:
+ sub_81CF7F4(unk);
+ return LT_INC_AND_PAUSE;
+ case 3:
+ if (IsDma3ManagerBusyWithBgCopy())
+ return LT_PAUSE;
+ break;
+ }
+ return LT_FINISH;
+}
+
+static u32 sub_81CF5F0(s32 state)
+{
+ struct PokenavSub8 * unk = GetSubstructPtr(8);
+ switch (state)
+ {
+ case 0:
+ switch (MatchCall_MoveCursorDown())
+ {
+ case 0:
+ return LT_FINISH;
+ case 1:
+ PlaySE(SE_SELECT);
+ return LT_SET_STATE(2);
+ case 2:
+ PlaySE(SE_SELECT);
+ break;
+ }
+ return LT_INC_AND_PAUSE;
+ case 1:
+ if (sub_81C8630())
+ return LT_PAUSE;
+ // fallthrough
+ case 2:
+ sub_81CF7F4(unk);
+ return LT_INC_AND_PAUSE;
+ case 3:
+ if (IsDma3ManagerBusyWithBgCopy())
+ return LT_PAUSE;
+ break;
+ }
+ return LT_FINISH;
+}
+
+static u32 sub_81CF668(s32 state)
+{
+ struct PokenavSub8 * unk = GetSubstructPtr(8);
+ switch (state)
+ {
+ case 0:
+ switch (MatchCall_PageUp())
+ {
+ case 0:
+ return LT_FINISH;
+ case 1:
+ PlaySE(SE_SELECT);
+ return LT_SET_STATE(2);
+ case 2:
+ PlaySE(SE_SELECT);
+ break;
+ }
+ return LT_INC_AND_PAUSE;
+ case 1:
+ if (sub_81C8630())
+ return LT_PAUSE;
+ // fallthrough
+ case 2:
+ sub_81CF7F4(unk);
+ return LT_INC_AND_PAUSE;
+ case 3:
+ if (IsDma3ManagerBusyWithBgCopy())
+ return LT_PAUSE;
+ break;
+ }
+ return LT_FINISH;
+}
+
+static u32 sub_81CF6E0(s32 state)
+{
+ struct PokenavSub8 * unk = GetSubstructPtr(8);
+ switch (state)
+ {
+ case 0:
+ switch (MatchCall_PageDown())
+ {
+ case 0:
+ return LT_FINISH;
+ case 1:
+ PlaySE(SE_SELECT);
+ return LT_SET_STATE(2);
+ case 2:
+ PlaySE(SE_SELECT);
+ break;
+ }
+ return LT_INC_AND_PAUSE;
+ case 1:
+ if (sub_81C8630())
+ return LT_PAUSE;
+ // fallthrough
+ case 2:
+ sub_81CF7F4(unk);
+ return LT_INC_AND_PAUSE;
+ case 3:
+ if (IsDma3ManagerBusyWithBgCopy())
+ return LT_PAUSE;
+ break;
+ }
+ return LT_FINISH;
+}
+
+static u32 sub_81CF758(s32 state)
+{
+ switch (state)
+ {
+ case 0:
+ PlaySE(SE_SELECT);
+ sub_81C7AC0(0);
+ sub_81C78A0();
+ return LT_INC_AND_PAUSE;
+ case 1:
+ if (IsPaletteFadeActive())
+ return LT_PAUSE;
+ if (MainMenuLoopedTaskIsBusy())
+ return LT_PAUSE;
+ sub_81C7FDC();
+ break;
+ }
+ return LT_FINISH;
+}
+
+static u32 sub_81CF798(s32 state)
+{
+ switch (state)
+ {
+ case 0:
+ PlaySE(SE_SELECT);
+ sub_81C7AC0(0);
+ return LT_INC_AND_PAUSE;
+ case 1:
+ if (IsPaletteFadeActive())
+ return LT_PAUSE;
+ break;
+ }
+ return LT_FINISH;
+}
+
+static void sub_81CF7C8(struct PokenavSub8 * ptr)
+{
+ ptr->winid = AddWindow(&gUnknown_086235B4);
+ PutWindowTilemap(ptr->winid);
+ CopyWindowToVram(ptr->winid, 1);
+ sub_81CF7F4(ptr);
+}
+
+static void sub_81CF7F4(struct PokenavSub8 * ptr)
+{
+ s32 r7 = sub_81CF0F0();
+ DynamicPlaceholderTextUtil_Reset();
+ DynamicPlaceholderTextUtil_SetPlaceholderPtr(0, gStringVar1);
+ *gStringVar1 = EOS;
+ DynamicPlaceholderTextUtil_ExpandPlaceholders(gStringVar2, gText_NumberF700);
+ AddTextPrinterParameterized(ptr->winid, 1, gStringVar2, 4, 1, 0xFF, NULL);
+ ConvertIntToDecimalStringN(gStringVar1, r7, STR_CONV_MODE_RIGHT_ALIGN, 3);
+ AddTextPrinterParameterized(ptr->winid, 1, gStringVar1, 34, 1, 0xFF, NULL);
+ CopyWindowToVram(ptr->winid, 2);
+}
+
+static void sub_81CF88C(void)
+{
+ struct MatchCallListTemplate template;
+ template.unk0 = sub_81CF0D0();
+ template.unk4 = sub_81CF0E0();
+ template.unk8 = 4;
+ template.unk6 = sub_81CF10C();
+ template.unk9 = 13;
+ template.unkA = 17;
+ template.unkB = 1;
+ template.unkC = 8;
+ template.unkD = 2;
+ template.unkE = 1;
+ template.unk10 = sub_81CF8E4;
+ template.unk14 = NULL;
+ sub_81C81D4(&gUnknown_08623590[1], &template, 0);
+}
+
+static void sub_81CF8E4(struct PokenavMonList * item, u8 * dest)
+{
+ u8 gender;
+ u8 level;
+ u8 * s;
+ const u8 * genderStr;
+ if (item->boxId == 14)
+ {
+ struct Pokemon * mon = &gPlayerParty[item->monId];
+ gender = GetMonGender(mon);
+ level = GetLevelFromMonExp(mon);
+ GetMonData(mon, MON_DATA_NICKNAME, gStringVar3);
+ }
+ else
+ {
+ struct BoxPokemon * mon = GetBoxedMonPtr(item->boxId, item->monId);
+ gender = GetBoxMonGender(mon);
+ level = GetLevelFromBoxMonExp(mon);
+ GetBoxMonData(mon, MON_DATA_NICKNAME, gStringVar3);
+ }
+ StringGetEnd10(gStringVar3);
+ dest = sub_81DB494(dest, 1, gStringVar3, 60);
+ switch (gender)
+ {
+ default:
+ genderStr = gUnknown_086235D4;
+ break;
+ case MON_MALE:
+ genderStr = gUnknown_086235BC;
+ break;
+ case MON_FEMALE:
+ genderStr = gUnknown_086235C8;
+ break;
+ }
+ s = StringCopy(gStringVar1, genderStr);
+ *s++ = CHAR_SLASH;
+ *s++ = CHAR_SPECIAL_F9;
+ *s++ = 5; // LV
+ ConvertIntToDecimalStringN(s, level, STR_CONV_MODE_LEFT_ALIGN, 3);
+ sub_81DB494(dest, 1, gStringVar1, 40);
+}