summaryrefslogtreecommitdiff
path: root/src/pokemon
diff options
context:
space:
mode:
Diffstat (limited to 'src/pokemon')
-rw-r--r--src/pokemon/mail.c614
-rw-r--r--src/pokemon/pokedex.c4
-rw-r--r--src/pokemon/pokemon_1.c47
-rw-r--r--src/pokemon/pokemon_menu.c25
-rw-r--r--src/pokemon/pokemon_storage_system.c178
-rw-r--r--src/pokemon/pokemon_storage_system_2.c995
-rw-r--r--src/pokemon/pokemon_storage_system_4.c5
-rw-r--r--src/pokemon/pokemon_summary_screen.c556
8 files changed, 2377 insertions, 47 deletions
diff --git a/src/pokemon/mail.c b/src/pokemon/mail.c
index 921a3ad93..4497c98fb 100644
--- a/src/pokemon/mail.c
+++ b/src/pokemon/mail.c
@@ -1,7 +1,10 @@
#include "global.h"
#include "mail.h"
+#include "data2.h"
#include "easy_chat.h"
#include "constants/items.h"
+#include "constants/species.h"
+#include "field_fadetransition.h"
#include "graphics.h"
#include "mail_data.h"
#include "menu.h"
@@ -10,6 +13,7 @@
#include "palette.h"
#include "pokemon_icon.h"
#include "overworld.h"
+#include "script.h"
#include "sprite.h"
#include "string_util.h"
#include "strings2.h"
@@ -18,6 +22,8 @@
#include "scanline_effect.h"
#include "ewram.h"
+extern u8 (*gMenuCallback)(void);
+
struct UnkMailStruct
{
u8 unk_0_0:2;
@@ -234,6 +240,56 @@ const struct MailLayout gUnknown_083E57A4[] =
{5, 15, 15, 4, 3, Unknown_3E5790},
};
+#if DEBUG
+
+const u8 Str_8411540[] = _("レイアウトを にほんごで ひょうじ?"); // Display using Japanese layout?
+const u8 Str_8411553[] = _("にほんご "); // Japanese
+const u8 Str_8411559[] = _("かいがい "); // Overseas
+
+const u8 *const _8411560[] =
+{
+ Str_8411553,
+ Str_8411559,
+};
+
+const u8 Str_8411568[] = _("イメージ タイプを えらんでね"); // Choose an image type
+const u8 Str_8411578[] = _("{STR_VAR_1}");
+const u8 Str_841157B[] = _("オレンジ "); // Orange
+const u8 Str_8411581[] = _("ハーバー "); // Harbor
+const u8 Str_8411587[] = _("キラキラ "); // Glitter
+const u8 Str_841158D[] = _("メカニカル"); // Mech
+const u8 Str_8411593[] = _("ウッディー"); // Wood
+const u8 Str_8411599[] = _("クロス  "); // Wave
+const u8 Str_841159F[] = _("トレジャー"); // Bead
+const u8 Str_84115A5[] = _("シャドウ "); // Shadow
+const u8 Str_84115AB[] = _("トロピカル"); // Tropic
+const u8 Str_84115B1[] = _("ドリーム "); // Dream
+const u8 Str_84115B7[] = _("ミラクル "); // Fab
+const u8 Str_84115BD[] = _("レトロ  "); // Retro
+
+const u8 *const _84115C4[] =
+{
+ Str_841157B,
+ Str_8411581,
+ Str_8411587,
+ Str_841158D,
+ Str_8411593,
+ Str_8411599,
+ Str_841159F,
+ Str_84115A5,
+ Str_84115AB,
+ Str_84115B1,
+ Str_84115B7,
+ Str_84115BD,
+};
+
+const u8 Str_84115F4[] = _("メールをみる"); // View Mail
+const u8 Str_84115FB[] = _("メールとうろく"); // Register Mail
+const u8 Str_8411603[] = _("もたせる"); // Give to Pokémon
+const u8 Str_8411608[] = _("メールをけす"); // Delete Mail
+
+#endif
+
// XXX: what is this?
static u8 *const sSharedMemPtr = gSharedMem;
@@ -247,26 +303,44 @@ static void sub_80F8F58(void);
static void sub_80F8F78(void);
static void sub_80F8FB4(void);
+extern u16 gSpecialVar_0x8004;
+extern u16 gSpecialVar_0x8005;
+extern u16 gSpecialVar_0x8006;
+
+#if DEBUG
+static u8 gUnknown_Debug_0300079C;
+#endif
+
void HandleReadMail(struct MailStruct *arg0, MainCallback arg1, bool8 arg2)
{
- u16 mailDesign;
u16 buffer[2];
+ u16 species;
- ewram0_4.varFF = GAME_LANGUAGE;
- ewram0_4.var100 = 1;
- ewram0_4.var104 = (MainCallback)EasyChat_GetWordText;
- ewram0_4.var108 = (MainCallback)ConvertEasyChatWordsToString;
-
- mailDesign = arg0->itemId - ITEM_ORANGE_MAIL;
-
- if (mailDesign <= 11)
+#if DEBUG
+ if (gUnknown_Debug_0300079C != 0)
{
- ewram0_4.varFA = arg0->itemId - ITEM_ORANGE_MAIL;
+ ewram0_4.varFF = GAME_LANGUAGE;
+ ewram0_4.var100 = gSpecialVar_0x8004;
+ ewram0_4.var104 = (MainCallback)EasyChat_GetWordText;
+ ewram0_4.var108 = (MainCallback)ConvertEasyChatWordsToString;
+ ewram0_4.varFA = gSpecialVar_0x8006;
}
else
+#endif
{
- ewram0_4.varFA = 0;
- arg2 = FALSE;
+ ewram0_4.varFF = GAME_LANGUAGE;
+ ewram0_4.var100 = 1;
+ ewram0_4.var104 = (MainCallback)EasyChat_GetWordText;
+ ewram0_4.var108 = (MainCallback)ConvertEasyChatWordsToString;
+ if (IS_ITEM_MAIL(arg0->itemId))
+ {
+ ewram0_4.varFA = arg0->itemId - 0x79;
+ }
+ else
+ {
+ ewram0_4.varFA = 0;
+ arg2 = FALSE;
+ }
}
switch (ewram0_4.var100)
@@ -275,24 +349,22 @@ void HandleReadMail(struct MailStruct *arg0, MainCallback arg1, bool8 arg2)
default:
ewram0_4.var10C = &gUnknown_083E5730[ewram0_4.varFA];
break;
-
case 1:
ewram0_4.var10C = &gUnknown_083E57A4[ewram0_4.varFA];
break;
}
- if (((MailSpeciesToSpecies(arg0->species, buffer) << 16) + 0xFFFF0000) <= (410 << 16))
+ species = MailSpeciesToSpecies(arg0->species, buffer);
+ if (species >= 1 && species <= 411)
{
switch (ewram0_4.varFA)
{
case 6:
ewram0_4.varFB = 1;
break;
-
case 9:
ewram0_4.varFB = 2;
break;
-
default:
ewram0_4.varFB = 0;
break;
@@ -303,7 +375,6 @@ void HandleReadMail(struct MailStruct *arg0, MainCallback arg1, bool8 arg2)
ewram0_4.varFB = 0;
}
-
ewram0_4.varF4 = arg0;
ewram0_4.varEC = arg1;
ewram0_4.varF8 = arg2;
@@ -575,25 +646,514 @@ static void sub_80F8F78(void)
static void sub_80F8FB4(void)
{
- u16 local1;
+ if (!UpdatePaletteFade())
+ {
+ SetMainCallback2(ewram0_4.varEC);
+ switch (ewram0_4.varFB)
+ {
+ case 2:
+ case 1:
+ sub_809D608(sub_809D4A8(ewram0_4.varF4->species));
+ sub_809D510(&gSprites[ewram0_4.varFC]);
+ break;
+ }
+#if !DEBUG
+ memset(&ewram0_4, 0, 0x110);
+#endif
+ ResetPaletteFade();
+ }
+}
+
+#if DEBUG
- if (UpdatePaletteFade())
+void debug_sub_810CA7C(u8);
+void debug_sub_810CE1C(u8);
+void debug_sub_810D388(void);
+void debug_sub_810D340(void);
+
+void debug_sub_810C910(u8 taskId)
+{
+ if (!gPaletteFade.active)
{
+ gUnknown_Debug_0300079C = 1;
+ Menu_EraseScreen();
+ DestroyTask(taskId);
+ if (gSaveBlock1.mail[gSpecialVar_0x8005].itemId == 0)
+ HandleReadMail(&gSaveBlock1.mail[gSpecialVar_0x8005], debug_sub_810D388, 0);
+ else
+ HandleReadMail(&gSaveBlock1.mail[gSpecialVar_0x8005], debug_sub_810D388, 1);
+ }
+}
+
+void debug_sub_810C990(u8 taskId)
+{
+ if (gMain.newKeys & (DPAD_LEFT | DPAD_DOWN))
+ {
+ gSpecialVar_0x8006 = (gSpecialVar_0x8006 + 11) % 12;
+ Menu_DrawStdWindowFrame(1, 1, 10, 4);
+ Menu_PrintText(_84115C4[gSpecialVar_0x8006], 2, 2);
+ }
+ else if (gMain.newKeys & (DPAD_UP | DPAD_RIGHT))
+ {
+ gSpecialVar_0x8006 = (gSpecialVar_0x8006 + 1) % 12;
+ Menu_DrawStdWindowFrame(1, 1, 10, 4);
+ Menu_PrintText(_84115C4[gSpecialVar_0x8006], 2, 2);
+ }
+ else if (gMain.newKeys & A_BUTTON)
+ {
+ BeginNormalPaletteFade(0xFFFFFFFF, 0, 0, 16, 0);
+ gTasks[taskId].func = debug_sub_810C910;
+ }
+ else if (gMain.newKeys & B_BUTTON)
+ {
+ Menu_DisplayDialogueFrame();
+ Menu_PrintText(Str_8411540, 4, 15);
+ Menu_PrintText(_8411560[gSpecialVar_0x8004], 2, 2);
+ gTasks[taskId].func = debug_sub_810CA7C;
+ }
+}
+
+void debug_sub_810CA7C(u8 taskId)
+{
+ if (gMain.newKeys & 0xF0)
+ {
+ gSpecialVar_0x8004 ^= 1;
+ Menu_PrintText(_8411560[gSpecialVar_0x8004], 2, 2);
+ }
+ else if (gMain.newKeys & A_BUTTON)
+ {
+ if (gMain.watchedKeysPressed)
+ {
+ gMain.watchedKeysPressed = FALSE;
+ Menu_DisplayDialogueFrame();
+ Menu_PrintText(Str_8411540, 4, 15);
+ Menu_DrawStdWindowFrame(1, 1, 10, 4);
+ Menu_PrintText(_8411560[gSpecialVar_0x8004], 2, 2);
+ }
+ else
+ {
+ Menu_DisplayDialogueFrame();
+ Menu_PrintText(Str_8411568, 4, 15);
+ Menu_DrawStdWindowFrame(1, 1, 10, 4);
+ Menu_PrintText(_84115C4[gSpecialVar_0x8006], 2, 2);
+ gTasks[taskId].func = debug_sub_810C990;
+ }
+ }
+}
+
+void debug_sub_810CB50(u8 taskId)
+{
+ u8 sp0[] = _("{STR_VAR_1} {STR_VAR_2}");
+ u8 sp8[] = _("メール{STR_VAR_1} {STR_VAR_2}");
+ bool8 r2 = FALSE;
+
+ if (gMain.newKeys & A_BUTTON)
+ {
+ ConvertIntToDecimalStringN(gStringVar1, gSpecialVar_0x8005, 2, 1);
+ StringCopy(gStringVar2, gSpeciesNames[gTasks[taskId].data[0]]);
+ gSaveBlock1.mail[gSpecialVar_0x8005].species = gTasks[taskId].data[0];
+ StringExpandPlaceholders(gStringVar4, sp8);
+ Menu_DisplayDialogueFrame();
+ Menu_PrintText(gStringVar4, 4, 15);
+ DestroyTask(taskId);
+ CreateTask(debug_sub_810CE1C, 0);
+ debug_sub_810D340();
return;
}
+ else if (gMain.newKeys & B_BUTTON)
+ {
+ DestroyTask(taskId);
+ Menu_EraseScreen();
+ CreateTask(debug_sub_810CE1C, 0);
+ debug_sub_810D340();
+ return;
+ }
+ else if (gMain.newKeys & (DPAD_LEFT | DPAD_DOWN))
+ {
+ gTasks[taskId].data[0] = (gTasks[taskId].data[0] + 0x19B) % 0x19C;
+ r2 = TRUE;
+ }
+ else if (gMain.newKeys & (DPAD_UP | DPAD_RIGHT))
+ {
+ gTasks[taskId].data[0] = (gTasks[taskId].data[0] + 1) % 0x19C;
+ r2 = TRUE;
+ }
+
+ if (r2)
+ {
+ ConvertIntToDecimalStringN(gStringVar1, gTasks[taskId].data[0], 2, 3);
+ StringCopy(gStringVar2, gSpeciesNames[gTasks[taskId].data[0]]);
+ StringExpandPlaceholders(gStringVar4, sp0);
+ Menu_DrawStdWindowFrame(0, 0, 12, 3);
+ Menu_PrintText(gStringVar4, 1, 1);
+ }
+}
+
+void debug_sub_810CCEC(u8 taskId)
+{
+ u8 string1[] = _("メール{STR_VAR_1}を だれに もたせる?");
+ u8 string2[] = _("000 {STR_VAR_1}");
+
+ ConvertIntToDecimalStringN(gStringVar1, gSpecialVar_0x8005, 1, 1);
+ StringExpandPlaceholders(gStringVar4, string1);
+ Menu_DisplayDialogueFrame();
+ Menu_PrintText(gStringVar4, 4, 15);
+
+ StringCopy(gStringVar1, gSpeciesNames[0]);
+ StringExpandPlaceholders(gStringVar4, string2);
+ Menu_DrawStdWindowFrame(0, 0, 12, 3);
+ Menu_PrintText(string2, 1, 1); // This probably should have been gStringVar4
+
+ gTasks[taskId].func = debug_sub_810CB50;
+}
+
+u8 debug_sub_810CD9C(void)
+{
+ CloseMenu();
+ ScriptContext1_Stop();
+ ScriptContext2_Enable();
+ gUnknown_Debug_0300079C = 0;
+ gSpecialVar_0x8004 = gSpecialVar_0x8005 = gSpecialVar_0x8006 = 0;
+ SetMainCallback2(debug_sub_810D388);
+ return 1;
+}
+
+void debug_sub_810CDE0(void)
+{
+ UpdatePaletteFade();
+ RunTasks();
+}
+
+void debug_sub_810CDF0(void)
+{
+ gMain.watchedKeysPressed = 0;
+ gMain.watchedKeysMask = 0;
+ gFieldCallback = mapldr_default;
+ SetMainCallback2(c2_exit_to_overworld_2_switch);
+}
+
+void debug_sub_810CE1C(u8 taskId)
+{
+ if (gMenuCallback() == TRUE)
+ {
+ CloseMenu();
+ DestroyTask(taskId);
+ }
+}
+
+u8 debug_sub_810CE48(void)
+{
+ s8 input = Menu_ProcessInput();
- SetMainCallback2(ewram0_4.varEC);
- switch (ewram0_4.varFB)
+ switch (input)
{
+ case -1:
+ Menu_EraseScreen();
+ debug_sub_810D340();
+ return 0;
+ case -2:
+ return 0;
+ default:
+ gSpecialVar_0x8005 = input;
+ gSpecialVar_0x8006 %= 12;
+ CreateTask(debug_sub_810CA7C, 0);
+ gMain.watchedKeysPressed = TRUE; // huh?
+ gMain.watchedKeysMask = 0;
+ return 1;
+ }
+}
+
+u8 debug_sub_810CEA4(void)
+{
+ if (!gPaletteFade.active)
+ {
+ gSpecialVar_0x8004 = 4;
+ sub_80E60D8();
+ return 1;
+ }
+ return 0;
+}
+
+u8 debug_sub_810CED0(void)
+{
+ u8 text[] = _("せいきの データが とうろくずみ です\n"
+ "しんき とうろく できません");
+ s8 input = Menu_ProcessInput();
+
+ switch (input)
+ {
+ case -1:
+ Menu_EraseScreen();
+ break;
+ case -2:
+ return 0;
+ default:
+ gSpecialVar_0x8005 = input;
+ if (IS_ITEM_MAIL(gSaveBlock1.mail[input].itemId))
+ {
+ Menu_EraseScreen();
+ Menu_DisplayDialogueFrame();
+ Menu_PrintText(text, 4, 15);
+ }
+ else
+ {
+ gSaveBlock1.mail[gSpecialVar_0x8005].itemId = 0xFFFF;
+ StringCopy(gSaveBlock1.mail[gSpecialVar_0x8005].playerName, gSaveBlock2.playerName);
+ *(u32 *)gSaveBlock1.mail[gSpecialVar_0x8005].trainerId = *(u32 *)gSaveBlock2.playerTrainerId;
+ gMenuCallback = debug_sub_810CEA4;
+ return 0;
+ }
+ break;
+ }
+ debug_sub_810D340();
+ return 0;
+}
+
+u8 debug_sub_810CFA4(void)
+{
+ u8 text[] = _("せいきに とうろくされたメールデータは\n"
+ "へんこう できません");
+ s8 input = Menu_ProcessInput();
+
+ switch (input)
+ {
+ case -1:
+ Menu_EraseScreen();
+ debug_sub_810D340();
+ return 0;
+ case -2:
+ return 0;
+ default:
+ gSpecialVar_0x8005 = input;
+ if (IS_ITEM_MAIL(gSaveBlock1.mail[input].itemId))
+ {
+ Menu_EraseScreen();
+ Menu_DisplayDialogueFrame();
+ Menu_PrintText(text, 4, 15);
+ debug_sub_810D340();
+ return 0;
+ }
+ else
+ {
+ CreateTask(debug_sub_810CCEC, 0);
+ return 1;
+ }
+ }
+}
+
+u8 debug_sub_810D030(void)
+{
+ const u8 text1[] = _("メール{STR_VAR_1} とうろく かいじょ");
+ const u8 text2[] = _("デバッグメニューから とうろくした\n"
+ "メール いがいは けせません");
+ s8 input = Menu_ProcessInput();
+
+ switch (input)
+ {
+ case -1:
+ Menu_EraseScreen();
+ debug_sub_810D340();
+ return 0;
+ case -2:
+ return 0;
+ default:
+ gSpecialVar_0x8005 = input;
+ if (gSaveBlock1.mail[gSpecialVar_0x8005].itemId != 0xFFFF
+ && gSaveBlock1.mail[gSpecialVar_0x8005].itemId != 0)
+ {
+ Menu_EraseScreen();
+ Menu_DisplayDialogueFrame();
+ Menu_PrintText(text2, 4, 15);
+ debug_sub_810D340();
+ return 0;
+ }
+ else
+ {
+ s8 i;
+
+ gSaveBlock1.mail[gSpecialVar_0x8005].itemId = 0;
+ gSaveBlock1.mail[gSpecialVar_0x8005].species = 0;
+ gSaveBlock1.mail[gSpecialVar_0x8005].playerName[0] = EOS;
+ *(u32 *)gSaveBlock1.mail[gSpecialVar_0x8005].trainerId = 0;
+ for (i = 0; i < 9; i++)
+ gSaveBlock1.mail[gSpecialVar_0x8005].words[i] = 0xFFFF;
+ ConvertIntToDecimalStringN(gStringVar1, gSpecialVar_0x8005, 1, 1);
+ StringExpandPlaceholders(gStringVar4, text1);
+ Menu_EraseScreen();
+ Menu_DisplayDialogueFrame();
+ Menu_PrintText(gStringVar4, 4, 15);
+ debug_sub_810D340();
+ return 0;
+ }
+ }
+}
+
+void debug_sub_810D174(u8 a)
+{
+ u8 string[] = _("メール{STR_VAR_1} {STR_VAR_2} {STR_VAR_3}");
+ u8 buffer[9][20];
+ struct MenuAction menuActions[9];
+ u8 i;
+
+ for (i = 0; i < 9; i++)
+ {
+ ConvertIntToDecimalStringN(gStringVar1, i, 1, 1);
+ if (gSaveBlock1.mail[i].itemId == 0xFFFF)
+ {
+ ConvertIntToDecimalStringN(gStringVar2, 1, 1, 1);
+ }
+ else if (IS_ITEM_MAIL(gSaveBlock1.mail[i].itemId))
+ {
+ ConvertIntToDecimalStringN(gStringVar2, 2, 1, 1);
+ }
+ else
+ {
+ ConvertIntToDecimalStringN(gStringVar2, 0, 1, 1);
+ gSaveBlock1.mail[i].itemId = 0;
+ }
+ StringCopy(gStringVar3, gSpeciesNames[gSaveBlock1.mail[i].species]);
+ StringExpandPlaceholders(buffer[i], string);
+ menuActions[i].text = buffer[i];
+ menuActions[i].func = NULL;
+ }
+ Menu_DrawStdWindowFrame(0, 0, 16, 19);
+ Menu_PrintItems(2, 1, 9, menuActions);
+ InitMenu(0, 1, 1, 9, 0, 15);
+ switch (a)
+ {
+ case 0:
+ gMenuCallback = debug_sub_810CE48;
+ break;
+ case 1:
+ gMenuCallback = debug_sub_810CED0;
+ break;
case 2:
+ gMenuCallback = debug_sub_810CFA4;
+ break;
+ case 3:
+ gMenuCallback = debug_sub_810D030;
+ break;
+ }
+}
+
+u8 debug_sub_810D2F4(void)
+{
+ s8 input = Menu_ProcessInput();
+
+ switch (input)
+ {
+ case -1:
+ SetMainCallback2(debug_sub_810CDF0);
+ return 1;
+ case -2:
+ return 0;
+ }
+
+ switch (input)
+ {
+ case 0:
+ debug_sub_810D174(input);
+ return 0;
case 1:
- local1 = sub_809D4A8(ewram0_4.varF4->species);
- sub_809D608(local1);
+ debug_sub_810D174(input);
+ return 0;
+ case 2:
+ debug_sub_810D174(input);
+ return 0;
+ case 3:
+ debug_sub_810D174(input);
+ return 0;
+ }
- sub_809D510(&gSprites[ewram0_4.varFC]);
+ return 1;
+}
+
+const struct MenuAction _84116BC[] =
+{
+ {Str_84115F4, NULL},
+ {Str_84115FB, NULL},
+ {Str_8411603, NULL},
+ {Str_8411608, NULL},
+};
+
+void debug_sub_810D340(void)
+{
+ Menu_DrawStdWindowFrame(0, 0, 9, 9);
+ Menu_PrintItems(2, 1, 4, _84116BC);
+ InitMenu(0, 1, 1, 4, 0, 8);
+ gMenuCallback = debug_sub_810D2F4;
+}
+
+void debug_sub_810D388(void)
+{
+ switch (gMain.state)
+ {
+ case 0:
+ if (gUnknown_Debug_0300079C != 0)
+ {
+ gMain.state = 2;
+ gUnknown_Debug_0300079C = 0;
+ return;
+ }
+ else
+ {
+ ScanlineEffect_Stop();
+ ResetPaletteFade();
+ SetVBlankCallback(sub_80F8F18);
+ BeginNormalPaletteFade(0xFFFFFFFF, 0, 0, 16, 0);
+ }
+ break;
+ case 1:
+ if (UpdatePaletteFade())
+ return;
+ break;
+ case 2:
+ SetVBlankCallback(NULL);
+ REG_BG0HOFS = 0;
+ REG_BG0VOFS = 0;
+ REG_BG1HOFS = 0;
+ REG_BG1VOFS = 0;
+ REG_BG2VOFS = 0;
+ REG_BG2HOFS = 0;
+ REG_BG3HOFS = 0;
+ REG_BG3VOFS = 0;
break;
+ case 3:
+ ResetSpriteData();
+ ResetTasks();
+ FreeAllSpritePalettes();
+ break;
+ case 4:
+ Text_LoadWindowTemplate(&gWindowTemplate_81E6CE4);
+ InitMenuWindow(&gWindowTemplate_81E6CE4);
+ Menu_EraseScreen();
+ break;
+ case 5:
+ LoadPalette(gMailGraphicsTable[0].palette, 0, 32);
+ LZ77UnCompVram(gMailGraphicsTable[0].tiles, (void *)VRAM);
+ DmaFill16(3, 1, (void *)(VRAM + 0x4000), 0x500);
+ break;
+ case 6:
+ REG_BG0CNT = 0x9F08;
+ REG_BG1CNT = 0x0801;
+ REG_BLDCNT = 0;
+ REG_DISPCNT = 0x0340;
+ debug_sub_810D340();
+ BeginNormalPaletteFade(0xFFFFFFFF, 0, 16, 0, 0);
+ SetVBlankCallback(sub_80F8F18);
+ break;
+ case 7:
+ if (!UpdatePaletteFade())
+ return;
+ break;
+ case 8:
+ CreateTask(debug_sub_810CE1C, 0);
+ SetMainCallback2(debug_sub_810CDE0);
+ break;
+ default:
+ return;
}
-
- memset(&ewram0_4, 0, 0x110);
- ResetPaletteFade();
+ gMain.state++;
}
+
+#endif
diff --git a/src/pokemon/pokedex.c b/src/pokemon/pokedex.c
index cbd816206..090873f9d 100644
--- a/src/pokemon/pokedex.c
+++ b/src/pokemon/pokedex.c
@@ -1273,7 +1273,7 @@ static u8 sub_8091260(u16 num, u8, u8, u8);
static void sub_8091304(const u8 *name, u8, u8);
static void sub_8091458(u16 height, u8 i, u8 i1);
static void sub_8091564(u16 weight, u8 i, u8 i1);
-static void sub_8091738(u16, u16, u16);
+void sub_8091738(u16, u16, u16);
static void sub_80917CC(u16 i, u16 i1);
static u16 sub_8091818(u8, u16, u16, u16);
u16 sub_80918EC(u16 a, s16 b, s16 c, u16 d);
@@ -4449,7 +4449,7 @@ static void sub_8091564(u16 arg0, u8 left, u8 top)
}
#endif
-static void sub_8091738(u16 num, u16 b, u16 c)
+void sub_8091738(u16 num, u16 b, u16 c)
{
u8 arr[0x80];
u16 i;
diff --git a/src/pokemon/pokemon_1.c b/src/pokemon/pokemon_1.c
index 06a088046..80d245b52 100644
--- a/src/pokemon/pokemon_1.c
+++ b/src/pokemon/pokemon_1.c
@@ -524,6 +524,53 @@ void CalculateMonStats(struct Pokemon *mon)
SetMonData(mon, MON_DATA_HP, &currentHP);
}
+#if DEBUG
+void debug_sub_803F55C(struct Pokemon *mon)
+{
+ s32 currentHP = GetMonData(mon, MON_DATA_HP, NULL);
+ s32 hpIV = GetMonData(mon, MON_DATA_HP_IV, NULL);
+ s32 hpEV = GetMonData(mon, MON_DATA_HP_EV, NULL);
+ s32 attackIV = GetMonData(mon, MON_DATA_ATK_IV, NULL);
+ s32 attackEV = GetMonData(mon, MON_DATA_ATK_EV, NULL);
+ s32 defenseIV = GetMonData(mon, MON_DATA_DEF_IV, NULL);
+ s32 defenseEV = GetMonData(mon, MON_DATA_DEF_EV, NULL);
+ s32 speedIV = GetMonData(mon, MON_DATA_SPEED_IV, NULL);
+ s32 speedEV = GetMonData(mon, MON_DATA_SPEED_EV, NULL);
+ s32 spAttackIV = GetMonData(mon, MON_DATA_SPATK_IV, NULL);
+ s32 spAttackEV = GetMonData(mon, MON_DATA_SPATK_EV, NULL);
+ s32 spDefenseIV = GetMonData(mon, MON_DATA_SPDEF_IV, NULL);
+ s32 spDefenseEV = GetMonData(mon, MON_DATA_SPDEF_EV, NULL);
+ u16 species = GetMonData(mon, MON_DATA_SPECIES, NULL);
+ s32 level = GetLevelFromMonExp(mon);
+ s32 newMaxHP;
+
+ SetMonData(mon, MON_DATA_LEVEL, &level);
+
+ if (species == SPECIES_SHEDINJA)
+ {
+ newMaxHP = 1;
+ }
+ else
+ {
+ s32 n = 2 * gBaseStats[species].baseHP + hpIV;
+ newMaxHP = (((n + hpEV / 4) * level) / 100) + level + 10;
+ }
+
+ SetMonData(mon, MON_DATA_MAX_HP, &newMaxHP);
+
+ CALC_STAT(baseAttack, attackIV, attackEV, 1, MON_DATA_ATK)
+ CALC_STAT(baseDefense, defenseIV, defenseEV, 2, MON_DATA_DEF)
+ CALC_STAT(baseSpeed, speedIV, speedEV, 3, MON_DATA_SPEED)
+ CALC_STAT(baseSpAttack, spAttackIV, spAttackEV, 4, MON_DATA_SPATK)
+ CALC_STAT(baseSpDefense, spDefenseIV, spDefenseEV, 5, MON_DATA_SPDEF)
+
+ if (newMaxHP < currentHP)
+ currentHP = newMaxHP;
+
+ SetMonData(mon, MON_DATA_HP, &currentHP);
+}
+#endif
+
void ExpandBoxMon(const struct BoxPokemon *src, struct Pokemon *dest)
{
u32 value = 0;
diff --git a/src/pokemon/pokemon_menu.c b/src/pokemon/pokemon_menu.c
index c0cae9353..532340ce4 100644
--- a/src/pokemon/pokemon_menu.c
+++ b/src/pokemon/pokemon_menu.c
@@ -31,6 +31,7 @@
#include "item_menu.h"
#include "player_pc.h"
#include "ewram.h"
+#include "script.h"
/*
Pokemon menu:
@@ -45,6 +46,7 @@ struct PokeMenuFieldMoveFunc
u8 field_1;
};
+extern u8 gUnknown_020297ED;
extern u8 gUnknown_020384F0;
extern u8 gUnknown_0202E8F4;
extern u8 gUnknown_0202E8F5;
@@ -900,9 +902,10 @@ static void sub_808AE08(void)
static bool8 SetUpFieldMove_Waterfall(void)
{
s16 x, y;
+
GetXYCoordsOneStepInFrontOfPlayer(&x, &y);
if (MetatileBehavior_IsWaterfall(MapGridGetMetatileBehaviorAt(x, y)) == TRUE
- && IsPlayerSurfingNorth() == TRUE)
+ && IsPlayerSurfingNorth() == TRUE)
{
gFieldCallback = FieldCallback_Teleport;
gUnknown_03005CE4 = sub_808AE08;
@@ -912,6 +915,20 @@ static bool8 SetUpFieldMove_Waterfall(void)
return FALSE;
}
+#if DEBUG
+void debug_sub_80986AC(void)
+{
+ s16 x, y;
+
+ GetXYCoordsOneStepInFrontOfPlayer(&x, &y);
+ if (MetatileBehavior_IsWaterfall(MapGridGetMetatileBehaviorAt(x, y)) == TRUE
+ && IsPlayerSurfingNorth() == TRUE)
+ sub_808AE08();
+ else
+ ScriptContext2_Disable();
+}
+#endif
+
static void sub_808AE8C(void)
{
u8 i;
@@ -921,7 +938,11 @@ static void sub_808AE8C(void)
if (GetMonData(&gPlayerParty[i], MON_DATA_SPECIES))
{
sub_806D668(i);
- if (GetMonData(&gPlayerParty[i], MON_DATA_IS_EGG) || !CanMonLearnTMHM(&gPlayerParty[i], arg))
+ if (
+#if DEBUG
+ gUnknown_020297ED == 0 &&
+#endif
+ (GetMonData(&gPlayerParty[i], MON_DATA_IS_EGG) || !CanMonLearnTMHM(&gPlayerParty[i], arg)))
sub_806BC3C(i, 0x9A);
else if (pokemon_has_move(&gPlayerParty[i], ItemIdToBattleMoveId(gSpecialVar_ItemId)))
sub_806BC3C(i, 0xA8);
diff --git a/src/pokemon/pokemon_storage_system.c b/src/pokemon/pokemon_storage_system.c
index 24c45247e..1ea8bc205 100644
--- a/src/pokemon/pokemon_storage_system.c
+++ b/src/pokemon/pokemon_storage_system.c
@@ -35,6 +35,10 @@ const struct PSS_MenuStringPtrs gUnknown_083B600C[] = {
{PCText_SeeYa, PCText_ReturnToPrevMenu}
};
+#if DEBUG
+const u16 gUnknown_Debug_083E05F0[2] = {0};
+#endif
+
const union AnimCmd gSpriteAnim_83B602C[] = {
ANIMCMD_FRAME( 0, 5),
ANIMCMD_END
@@ -400,6 +404,180 @@ void ResetPokemonStorageSystem(void)
}
}
+#if DEBUG
+__attribute__((naked))
+void debug_sub_80A3904(void)
+{
+ asm("\
+ push {r4, r5, r6, r7, lr}\n\
+ mov r7, sl\n\
+ mov r6, r9\n\
+ mov r5, r8\n\
+ push {r5, r6, r7}\n\
+ add sp, sp, #0xffffffe4\n\
+ mov r0, #0x0\n\
+ mov r8, r0\n\
+ mov r7, r8\n\
+ mov r1, #0x14\n\
+ str r1, [sp, #0x18]\n\
+ mov r2, #0xff\n\
+ mov r9, r2\n\
+._162:\n\
+ mov r5, #0x0\n\
+ cmp r7, #0\n\
+ beq ._160 @cond_branch\n\
+ mov r0, #0xe\n\
+ mov r8, r0\n\
+ b ._158\n\
+._160:\n\
+ bl Random\n\
+ lsl r0, r0, #0x10\n\
+ lsr r0, r0, #0x10\n\
+ str r0, [sp, #0x14]\n\
+ mov r2, r8\n\
+ lsl r1, r2, #0x2\n\
+ add r1, r1, r8\n\
+ lsl r3, r1, #0x4\n\
+ sub r3, r3, r1\n\
+ lsl r3, r3, #0x5\n\
+ lsl r1, r5, #0x2\n\
+ add r1, r1, r5\n\
+ lsl r1, r1, #0x4\n\
+ ldr r2, ._163 @ gPokemonStorage\n\
+ add r1, r1, r2\n\
+ add r6, r3, r1\n\
+ ldr r2, ._163 + 4 @ gUnknown_Debug_083E05F0\n\
+ lsl r1, r7, #0x1\n\
+ add r1, r1, r2\n\
+ ldrh r4, [r1]\n\
+ add r5, r5, #0x1\n\
+ lsl r2, r5, #0x18\n\
+ lsr r2, r2, #0x18\n\
+ mov r1, #0x0\n\
+ str r1, [sp]\n\
+ str r1, [sp, #0x4]\n\
+ mov r1, #0x1\n\
+ mov sl, r1\n\
+ str r1, [sp, #0x8]\n\
+ str r0, [sp, #0xc]\n\
+ add r0, r6, #0\n\
+ add r1, r4, #0\n\
+ mov r3, #0x20\n\
+ bl CreateBoxMon\n\
+ cmp r4, #0\n\
+ beq ._157 @cond_branch\n\
+ cmp r4, #0xac\n\
+ bne ._156 @cond_branch\n\
+ add r0, sp, #0x10\n\
+ mov r2, sl\n\
+ strb r2, [r0]\n\
+ add r0, r6, #0\n\
+ mov r1, #0x2d\n\
+ add r2, sp, #0x10\n\
+ bl SetBoxMonData\n\
+._156:\n\
+ bl Random\n\
+ mov r1, r9\n\
+ and r1, r1, r0\n\
+ str r1, [sp, #0x14]\n\
+ add r4, sp, #0x14\n\
+ add r0, r6, #0\n\
+ mov r1, #0x16\n\
+ add r2, r4, #0\n\
+ bl SetBoxMonData\n\
+ bl Random\n\
+ mov r1, r9\n\
+ and r1, r1, r0\n\
+ str r1, [sp, #0x14]\n\
+ add r0, r6, #0\n\
+ mov r1, #0x17\n\
+ add r2, r4, #0\n\
+ bl SetBoxMonData\n\
+ bl Random\n\
+ mov r1, r9\n\
+ and r1, r1, r0\n\
+ str r1, [sp, #0x14]\n\
+ add r0, r6, #0\n\
+ mov r1, #0x18\n\
+ add r2, r4, #0\n\
+ bl SetBoxMonData\n\
+ bl Random\n\
+ mov r1, r9\n\
+ and r1, r1, r0\n\
+ str r1, [sp, #0x14]\n\
+ add r0, r6, #0\n\
+ mov r1, #0x21\n\
+ add r2, r4, #0\n\
+ bl SetBoxMonData\n\
+ bl Random\n\
+ mov r1, r9\n\
+ and r1, r1, r0\n\
+ str r1, [sp, #0x14]\n\
+ add r0, r6, #0\n\
+ mov r1, #0x2f\n\
+ add r2, r4, #0\n\
+ bl SetBoxMonData\n\
+ bl Random\n\
+ mov r1, r9\n\
+ and r1, r1, r0\n\
+ str r1, [sp, #0x14]\n\
+ add r0, r6, #0\n\
+ mov r1, #0x30\n\
+ add r2, r4, #0\n\
+ bl SetBoxMonData\n\
+ ldr r0, [sp, #0x18]\n\
+ cmp r0, #0\n\
+ beq ._157 @cond_branch\n\
+ sub r0, r0, #0x1\n\
+ lsl r0, r0, #0x10\n\
+ lsr r0, r0, #0x10\n\
+ str r0, [sp, #0x18]\n\
+ mov r1, sl\n\
+ str r1, [sp, #0x14]\n\
+ add r0, r6, #0\n\
+ mov r1, #0x32\n\
+ add r2, r4, #0\n\
+ bl SetBoxMonData\n\
+._157:\n\
+ add r0, r7, #1\n\
+ lsl r0, r0, #0x10\n\
+ lsr r7, r0, #0x10\n\
+ lsl r0, r5, #0x10\n\
+ lsr r5, r0, #0x10\n\
+ cmp r5, #0x1d\n\
+ bhi ._158 @cond_branch\n\
+ cmp r7, #0\n\
+ bne ._159 @cond_branch\n\
+ b ._160\n\
+._159:\n\
+ mov r2, #0xe\n\
+ mov r8, r2\n\
+._158:\n\
+ mov r0, r8\n\
+ add r0, r0, #0x1\n\
+ lsl r0, r0, #0x10\n\
+ lsr r0, r0, #0x10\n\
+ mov r8, r0\n\
+ cmp r0, #0xd\n\
+ bhi ._161 @cond_branch\n\
+ b ._162\n\
+._161:\n\
+ add sp, sp, #0x1c\n\
+ pop {r3, r4, r5}\n\
+ mov r8, r3\n\
+ mov r9, r4\n\
+ mov sl, r5\n\
+ pop {r4, r5, r6, r7}\n\
+ pop {r0}\n\
+ bx r0\n\
+._164:\n\
+ .align 2, 0\n\
+._163:\n\
+ .word gPokemonStorage+0x4\n\
+ .word gUnknown_Debug_083E05F0");
+}
+#endif
+
void sub_8096264(struct UnkPSSStruct_2002370 *a0, u16 tileTag, u16 palTag, u8 a3)
{
struct SpritePalette palette = {
diff --git a/src/pokemon/pokemon_storage_system_2.c b/src/pokemon/pokemon_storage_system_2.c
index 512bde5db..2f12b6bfa 100644
--- a/src/pokemon/pokemon_storage_system_2.c
+++ b/src/pokemon/pokemon_storage_system_2.c
@@ -192,6 +192,144 @@ void sub_8096874(void)
REG_DISPCNT = DISPCNT_OBJ_1D_MAP | DISPCNT_BG_ALL_ON | DISPCNT_OBJ_ON;
}
+#if DEBUG
+__attribute__((naked))
+void sub_8096884(void)
+{
+ asm("\
+ push {r4, lr}\n\
+ ldr r0, ._223 @ gMain\n\
+ ldr r1, ._223 + 4 @ 0x43c\n\
+ add r0, r0, r1\n\
+ ldrb r0, [r0]\n\
+ cmp r0, #0x9\n\
+ bls ._221 @cond_branch\n\
+ b ._222\n\
+._221:\n\
+ lsl r0, r0, #0x2\n\
+ ldr r1, ._223 + 8 @ \n\
+ add r0, r0, r1\n\
+ ldr r0, [r0]\n\
+ mov pc, r0\n\
+._224:\n\
+ .align 2, 0\n\
+._223:\n\
+ .word gMain\n\
+ .word 0x43c\n\
+ .word ._225\n\
+._225:\n\
+ .word ._226\n\
+ .word ._227\n\
+ .word ._228\n\
+ .word ._229\n\
+ .word ._230\n\
+ .word ._231\n\
+ .word ._232\n\
+ .word ._233\n\
+ .word ._234\n\
+ .word ._235\n\
+._226:\n\
+ mov r0, #0x0\n\
+ bl SetVBlankCallback\n\
+ mov r0, #0x80\n\
+ lsl r0, r0, #0x13\n\
+ mov r4, #0x0\n\
+ strh r4, [r0]\n\
+ bl sub_8096804\n\
+ ldr r0, ._237 @ unk_2038790\n\
+ strb r4, [r0]\n\
+ b ._250\n\
+._238:\n\
+ .align 2, 0\n\
+._237:\n\
+ .word unk_2038790\n\
+._227:\n\
+ ldr r0, ._240 @ gWindowTemplate_81E6D00\n\
+ bl Text_LoadWindowTemplate\n\
+ b ._250\n\
+._241:\n\
+ .align 2, 0\n\
+._240:\n\
+ .word gWindowTemplate_81E6D00\n\
+._228:\n\
+ ldr r0, ._243 @ gWindowTemplate_81E6D00\n\
+ bl InitMenuWindow\n\
+ bl Menu_EraseScreen\n\
+ b ._250\n\
+._244:\n\
+ .align 2, 0\n\
+._243:\n\
+ .word gWindowTemplate_81E6D00\n\
+._229:\n\
+ bl sub_80967DC\n\
+ bl sub_8096848\n\
+ b ._250\n\
+._230:\n\
+ bl ResetPSSMonIconSprites\n\
+ bl sub_809AA24\n\
+ b ._250\n\
+._231:\n\
+ bl sub_8097DE0\n\
+ b ._250\n\
+._232:\n\
+ bl sub_8097E70\n\
+ b ._250\n\
+._233:\n\
+ bl sub_8098400\n\
+ b ._250\n\
+._234:\n\
+ ldr r0, ._251 @ gPokemonStorage\n\
+ ldrb r0, [r0]\n\
+ bl sub_8099BF8\n\
+ ldr r2, ._251 + 4 @ 0x2000000\n\
+ ldr r1, ._251 + 8 @ 0x12bc\n\
+ add r0, r2, r1\n\
+ mov r1, #0xa\n\
+ strh r1, [r0]\n\
+ ldr r1, ._251 + 12 @ 0x12be\n\
+ add r2, r2, r1\n\
+ ldr r1, ._251 + 16 @ 0xdacb\n\
+ strh r1, [r2]\n\
+ bl sub_80F727C\n\
+ bl sub_80F7404\n\
+ b ._250\n\
+._252:\n\
+ .align 2, 0\n\
+._251:\n\
+ .word gPokemonStorage\n\
+ .word 0x2000000\n\
+ .word 0x12bc\n\
+ .word 0x12be\n\
+ .word 0xdacb\n\
+._235:\n\
+ bl sub_8096874\n\
+ ldr r0, ._253 @ sub_8096BF0\n\
+ bl SetPSSCallback\n\
+ ldr r0, ._253 + 4 @ sub_8096B38\n\
+ bl SetMainCallback2\n\
+ ldr r0, ._253 + 8 @ sub_8096AFC\n\
+ bl SetVBlankCallback\n\
+._250:\n\
+ ldr r1, ._253 + 12 @ gMain\n\
+ ldr r0, ._253 + 16 @ 0x43c\n\
+ add r1, r1, r0\n\
+ ldrb r0, [r1]\n\
+ add r0, r0, #0x1\n\
+ strb r0, [r1]\n\
+._222:\n\
+ pop {r4}\n\
+ pop {r0}\n\
+ bx r0\n\
+._254:\n\
+ .align 2, 0\n\
+._253:\n\
+ .word sub_8096BF0+1\n\
+ .word sub_8096B38+1\n\
+ .word sub_8096AFC+1\n\
+ .word gMain\n\
+ .word 0x43c");
+}
+#else
void sub_8096884(void)
{
switch (gMain.state)
@@ -250,6 +388,7 @@ void sub_8096884(void)
break;
}
}
+#endif
void sub_80969A0(void)
{
@@ -318,6 +457,117 @@ void sub_80969A0(void)
}
}
+#if DEBUG
+__attribute__((naked))
+void debug_sub_80A4300()
+{
+ asm("\
+ push {lr}\n\
+ ldr r1, ._296 @ gUnknown_0203847D\n\
+ mov r0, #0x0\n\
+ strb r0, [r1]\n\
+ ldr r1, ._296 + 4 @ 0x2000000\n\
+ mov r0, #0x0\n\
+ strb r0, [r1, #0x5]\n\
+ bl sub_8096884\n\
+ ldr r0, ._296 + 8 @ gMain\n\
+ ldr r1, [r0, #0x4]\n\
+ ldr r0, ._296 + 12 @ sub_8096B38\n\
+ cmp r1, r0\n\
+ bne ._295 @cond_branch\n\
+ ldr r1, ._296 + 16 @ unk_2038790\n\
+ mov r0, #0x1\n\
+ strb r0, [r1]\n\
+._295:\n\
+ pop {r0}\n\
+ bx r0\n\
+._297:\n\
+ .align 2, 0\n\
+._296:\n\
+ .word gUnknown_0203847D\n\
+ .word 0x2000000\n\
+ .word gMain\n\
+ .word sub_8096B38+1\n\
+ .word unk_2038790");
+}
+
+__attribute__((naked))
+void debug_sub_80A433C()
+{
+ asm("\
+ push {lr}\n\
+ ldr r2, ._298 @ unk_2038794\n\
+ str r1, [r2]\n\
+ ldr r1, ._298 + 4 @ unk_2038798\n\
+ str r0, [r1]\n\
+ ldr r0, ._298 + 8 @ debug_sub_80A4300\n\
+ bl SetMainCallback2\n\
+ pop {r0}\n\
+ bx r0\n\
+._299:\n\
+ .align 2, 0\n\
+._298:\n\
+ .word unk_2038794\n\
+ .word unk_2038798\n\
+ .word debug_sub_80A4300+1");
+}
+
+__attribute__((naked))
+void debug_sub_80A435C()
+{
+ asm("\
+ push {r4, r5, lr}\n\
+ add sp, sp, #0xfffffffc\n\
+ ldr r5, ._303 @ 0x2000000\n\
+ ldrb r4, [r5, #0x4]\n\
+ cmp r4, #0\n\
+ beq ._300 @cond_branch\n\
+ cmp r4, #0x1\n\
+ beq ._301 @cond_branch\n\
+ b ._308\n\
+._304:\n\
+ .align 2, 0\n\
+._303:\n\
+ .word 0x2000000\n\
+._300:\n\
+ ldr r0, ._306 @ unk_2038798\n\
+ ldr r0, [r0]\n\
+ bl unref_sub_809CB94\n\
+ mov r0, #0x1\n\
+ neg r0, r0\n\
+ str r4, [sp]\n\
+ mov r1, #0x0\n\
+ mov r2, #0x0\n\
+ mov r3, #0x10\n\
+ bl BeginNormalPaletteFade\n\
+ ldrb r0, [r5, #0x4]\n\
+ add r0, r0, #0x1\n\
+ strb r0, [r5, #0x4]\n\
+ b ._308\n\
+._307:\n\
+ .align 2, 0\n\
+._306:\n\
+ .word unk_2038798\n\
+._301:\n\
+ bl UpdatePaletteFade\n\
+ lsl r0, r0, #0x18\n\
+ cmp r0, #0\n\
+ bne ._308 @cond_branch\n\
+ ldr r0, ._309 @ unk_2038794\n\
+ ldr r0, [r0]\n\
+ bl _call_via_r0\n\
+._308:\n\
+ add sp, sp, #0x4\n\
+ pop {r4, r5}\n\
+ pop {r0}\n\
+ bx r0\n\
+._310:\n\
+ .align 2, 0\n\
+._309:\n\
+ .word unk_2038794");
+}
+#endif
+
void sub_8096AFC(void)
{
REG_BG2HOFS = gPokemonStorageSystemPtr->unk_08b4;
@@ -388,6 +638,438 @@ void sub_8096C68(void)
SetPSSCallback(sub_8096C84);
}
+#if DEBUG
+__attribute__((naked))
+void sub_8096C84(void)
+{
+ asm("\
+ push {r4, lr}\n\
+ ldr r0, ._347 @ 0x2000000\n\
+ ldrb r0, [r0, #0x4]\n\
+ cmp r0, #0x6\n\
+ bls ._345 @cond_branch\n\
+ b ._466\n\
+._345:\n\
+ lsl r0, r0, #0x2\n\
+ ldr r1, ._347 + 4 @ \n\
+ add r0, r0, r1\n\
+ ldr r0, [r0]\n\
+ mov pc, r0\n\
+._348:\n\
+ .align 2, 0\n\
+._347:\n\
+ .word 0x2000000\n\
+ .word ._349\n\
+._349:\n\
+ .word ._350\n\
+ .word ._351\n\
+ .word ._352\n\
+ .word ._353\n\
+ .word ._354\n\
+ .word ._355\n\
+ .word ._356\n\
+._350:\n\
+ bl sub_809CA40\n\
+ lsl r0, r0, #0x18\n\
+ lsr r0, r0, #0x18\n\
+ sub r0, r0, #0x1\n\
+ cmp r0, #0xf\n\
+ bls ._357 @cond_branch\n\
+ b ._466\n\
+._357:\n\
+ lsl r0, r0, #0x2\n\
+ ldr r1, ._360 @ \n\
+ add r0, r0, r1\n\
+ ldr r0, [r0]\n\
+ mov pc, r0\n\
+._361:\n\
+ .align 2, 0\n\
+._360:\n\
+ .word ._359\n\
+._359:\n\
+ .word ._362\n\
+ .word ._466\n\
+ .word ._466\n\
+ .word ._365\n\
+ .word ._366\n\
+ .word ._367\n\
+ .word ._368\n\
+ .word ._369\n\
+ .word ._370\n\
+ .word ._371\n\
+ .word ._372\n\
+ .word ._373\n\
+ .word ._374\n\
+ .word ._375\n\
+ .word ._376\n\
+ .word ._377\n\
+._362:\n\
+ mov r0, #0x5\n\
+ bl PlaySE\n\
+ ldr r1, ._379 @ 0x2000000\n\
+ mov r0, #0x1\n\
+ strb r0, [r1, #0x4]\n\
+ b ._466\n\
+._380:\n\
+ .align 2, 0\n\
+._379:\n\
+ .word 0x2000000\n\
+._366:\n\
+ ldr r4, ._383 @ 0x2000000\n\
+ ldrb r0, [r4, #0x5]\n\
+ cmp r0, #0x2\n\
+ beq ._381 @cond_branch\n\
+ mov r0, #0x10\n\
+ bl PrintStorageActionText\n\
+ mov r0, #0x3\n\
+ strb r0, [r4, #0x4]\n\
+ b ._466\n\
+._384:\n\
+ .align 2, 0\n\
+._383:\n\
+ .word 0x2000000\n\
+._381:\n\
+ bl sub_809B0D4\n\
+ ldr r0, ._386 @ sub_8096FC8\n\
+ bl SetPSSCallback\n\
+ b ._466\n\
+._387:\n\
+ .align 2, 0\n\
+._386:\n\
+ .word sub_8096FC8+1\n\
+._367:\n\
+ ldr r4, ._394 @ 0x2000000\n\
+ ldrb r0, [r4, #0x5]\n\
+ cmp r0, #0x2\n\
+ beq ._388 @cond_branch\n\
+ b ._466\n\
+._388:\n\
+ bl sub_809BF20\n\
+ lsl r0, r0, #0x18\n\
+ cmp r0, #0\n\
+ beq ._391 @cond_branch\n\
+ ldr r1, ._394 + 4 @ 0x11f2\n\
+ add r0, r4, r1\n\
+ ldrh r0, [r0]\n\
+ bl ItemIsMail\n\
+ lsl r0, r0, #0x18\n\
+ cmp r0, #0\n\
+ beq ._391 @cond_branch\n\
+ b ._392\n\
+._391:\n\
+ ldr r0, ._394 + 8 @ sub_8097004\n\
+ bl SetPSSCallback\n\
+ b ._466\n\
+._395:\n\
+ .align 2, 0\n\
+._394:\n\
+ .word 0x2000000\n\
+ .word 0x11f2\n\
+ .word sub_8097004+1\n\
+._365:\n\
+ ldr r0, ._399 @ unk_2038790\n\
+ ldrb r0, [r0]\n\
+ cmp r0, #0\n\
+ beq ._396 @cond_branch\n\
+ b ._466\n\
+._396:\n\
+ ldr r0, ._399 + 4 @ sub_8097BA0\n\
+ bl SetPSSCallback\n\
+ b ._466\n\
+._400:\n\
+ .align 2, 0\n\
+._399:\n\
+ .word unk_2038790\n\
+ .word sub_8097BA0+1\n\
+._377:\n\
+ ldr r0, ._404 @ unk_2038790\n\
+ ldrb r0, [r0]\n\
+ cmp r0, #0\n\
+ beq ._401 @cond_branch\n\
+ b ._466\n\
+._401:\n\
+ ldr r0, ._404 + 4 @ sub_8097CC0\n\
+ bl SetPSSCallback\n\
+ b ._466\n\
+._405:\n\
+ .align 2, 0\n\
+._404:\n\
+ .word unk_2038790\n\
+ .word sub_8097CC0+1\n\
+._368:\n\
+ mov r0, #0x5\n\
+ bl PlaySE\n\
+ ldr r0, ._407 @ sub_809789C\n\
+ bl SetPSSCallback\n\
+ b ._466\n\
+._408:\n\
+ .align 2, 0\n\
+._407:\n\
+ .word sub_809789C+1\n\
+._369:\n\
+ mov r0, #0x5\n\
+ bl PlaySE\n\
+ ldr r0, ._410 @ sub_8097078\n\
+ bl SetPSSCallback\n\
+ b ._466\n\
+._411:\n\
+ .align 2, 0\n\
+._410:\n\
+ .word sub_8097078+1\n\
+._370:\n\
+ mov r0, #0x5\n\
+ bl PlaySE\n\
+ ldr r4, ._414 @ 0x2000000\n\
+ ldr r0, ._414 + 4 @ gPokemonStorage\n\
+ ldrb r0, [r0]\n\
+ add r0, r0, #0x1\n\
+ ldr r2, ._414 + 8 @ 0x8b2\n\
+ add r1, r4, r2\n\
+ strh r0, [r1]\n\
+ cmp r0, #0xd\n\
+ ble ._416 @cond_branch\n\
+ mov r0, #0x0\n\
+ b ._413\n\
+._415:\n\
+ .align 2, 0\n\
+._414:\n\
+ .word 0x2000000\n\
+ .word gPokemonStorage\n\
+ .word 0x8b2\n\
+._371:\n\
+ mov r0, #0x5\n\
+ bl PlaySE\n\
+ ldr r4, ._418 @ 0x2000000\n\
+ ldr r0, ._418 + 4 @ gPokemonStorage\n\
+ ldrb r0, [r0]\n\
+ sub r0, r0, #0x1\n\
+ ldr r2, ._418 + 8 @ 0x8b2\n\
+ add r1, r4, r2\n\
+ strh r0, [r1]\n\
+ cmp r0, #0\n\
+ bge ._416 @cond_branch\n\
+ mov r0, #0xd\n\
+._413:\n\
+ strh r0, [r1]\n\
+._416:\n\
+ ldrb r0, [r1]\n\
+ bl sub_8099C70\n\
+ mov r0, #0x2\n\
+ strb r0, [r4, #0x4]\n\
+ b ._466\n\
+._419:\n\
+ .align 2, 0\n\
+._418:\n\
+ .word 0x2000000\n\
+ .word gPokemonStorage\n\
+ .word 0x8b2\n\
+._372:\n\
+ bl sub_809BE80\n\
+ lsl r0, r0, #0x18\n\
+ cmp r0, #0\n\
+ bne ._428 @cond_branch\n\
+ ldr r4, ._423 @ 0x2000000\n\
+ ldr r1, ._423 + 4 @ 0x11f2\n\
+ add r0, r4, r1\n\
+ ldrh r0, [r0]\n\
+ bl ItemIsMail\n\
+ lsl r0, r0, #0x18\n\
+ cmp r0, #0\n\
+ beq ._421 @cond_branch\n\
+._392:\n\
+ mov r0, #0x5\n\
+ strb r0, [r4, #0x4]\n\
+ b ._466\n\
+._424:\n\
+ .align 2, 0\n\
+._423:\n\
+ .word 0x2000000\n\
+ .word 0x11f2\n\
+._421:\n\
+ mov r0, #0x5\n\
+ bl PlaySE\n\
+ ldr r0, ._426 @ sub_809746C\n\
+ bl SetPSSCallback\n\
+ b ._466\n\
+._427:\n\
+ .align 2, 0\n\
+._426:\n\
+ .word sub_809746C+1\n\
+._374:\n\
+ bl sub_809BE80\n\
+ lsl r0, r0, #0x18\n\
+ cmp r0, #0\n\
+ bne ._428 @cond_branch\n\
+ mov r0, #0x5\n\
+ bl PlaySE\n\
+ ldr r0, ._430 @ sub_80972A8\n\
+ bl SetPSSCallback\n\
+ b ._466\n\
+._431:\n\
+ .align 2, 0\n\
+._430:\n\
+ .word sub_80972A8+1\n\
+._375:\n\
+ bl sub_809BEBC\n\
+ lsl r0, r0, #0x18\n\
+ cmp r0, #0\n\
+ bne ._432 @cond_branch\n\
+._428:\n\
+ ldr r1, ._434 @ 0x2000000\n\
+ mov r0, #0x4\n\
+ strb r0, [r1, #0x4]\n\
+ b ._466\n\
+._435:\n\
+ .align 2, 0\n\
+._434:\n\
+ .word 0x2000000\n\
+._432:\n\
+ mov r0, #0x5\n\
+ bl PlaySE\n\
+ ldr r0, ._437 @ c3_0808DC50\n\
+ bl SetPSSCallback\n\
+ b ._466\n\
+._438:\n\
+ .align 2, 0\n\
+._437:\n\
+ .word c3_0808DC50+1\n\
+._373:\n\
+ mov r0, #0x5\n\
+ bl PlaySE\n\
+ ldr r0, ._440 @ sub_8097390\n\
+ bl SetPSSCallback\n\
+ b ._466\n\
+._441:\n\
+ .align 2, 0\n\
+._440:\n\
+ .word sub_8097390+1\n\
+._376:\n\
+ mov r0, #0x5\n\
+ bl PlaySE\n\
+ ldr r0, ._443 @ sub_80972FC\n\
+ bl SetPSSCallback\n\
+ b ._466\n\
+._444:\n\
+ .align 2, 0\n\
+._443:\n\
+ .word sub_80972FC+1\n\
+._351:\n\
+ bl sub_809AC00\n\
+ lsl r0, r0, #0x18\n\
+ cmp r0, #0\n\
+ bne ._466 @cond_branch\n\
+ bl sub_809BF48\n\
+ lsl r0, r0, #0x18\n\
+ cmp r0, #0\n\
+ beq ._446 @cond_branch\n\
+ bl sub_80986E8\n\
+ b ._447\n\
+._446:\n\
+ bl sub_8098710\n\
+._447:\n\
+ ldr r4, ._450 @ 0x2000000\n\
+ ldr r2, ._450 + 4 @ 0x11f6\n\
+ add r0, r4, r2\n\
+ ldrb r0, [r0]\n\
+ cmp r0, #0\n\
+ beq ._448 @cond_branch\n\
+ bl BoxSetMosaic\n\
+._448:\n\
+ mov r0, #0x0\n\
+ strb r0, [r4, #0x4]\n\
+ b ._466\n\
+._451:\n\
+ .align 2, 0\n\
+._450:\n\
+ .word 0x2000000\n\
+ .word 0x11f6\n\
+._352:\n\
+ bl sub_8099D34\n\
+ lsl r0, r0, #0x18\n\
+ cmp r0, #0\n\
+ bne ._466 @cond_branch\n\
+ ldr r1, ._456 @ gPokemonStorage\n\
+ ldr r0, ._456 + 4 @ 0x2000000\n\
+ ldr r2, ._456 + 8 @ 0x8b2\n\
+ add r0, r0, r2\n\
+ ldrh r0, [r0]\n\
+ strb r0, [r1]\n\
+ ldr r0, ._456 + 12 @ gUnknown_0203847C\n\
+ ldrb r0, [r0]\n\
+ cmp r0, #0\n\
+ bne ._455 @cond_branch\n\
+ bl sub_809BF20\n\
+ lsl r0, r0, #0x18\n\
+ cmp r0, #0\n\
+ bne ._455 @cond_branch\n\
+ bl sub_809B440\n\
+ bl BoxSetMosaic\n\
+ b ._455\n\
+._457:\n\
+ .align 2, 0\n\
+._456:\n\
+ .word gPokemonStorage\n\
+ .word 0x2000000\n\
+ .word 0x8b2\n\
+ .word gUnknown_0203847C\n\
+._353:\n\
+ ldr r0, ._460 @ gMain\n\
+ ldrh r1, [r0, #0x2e]\n\
+ mov r0, #0xf3\n\
+ and r0, r0, r1\n\
+ cmp r0, #0\n\
+ beq ._466 @cond_branch\n\
+ bl sub_8098A5C\n\
+._455:\n\
+ ldr r1, ._460 + 4 @ 0x2000000\n\
+ mov r0, #0x0\n\
+ strb r0, [r1, #0x4]\n\
+ b ._466\n\
+._461:\n\
+ .align 2, 0\n\
+._460:\n\
+ .word gMain\n\
+ .word 0x2000000\n\
+._354:\n\
+ mov r0, #0x20\n\
+ bl PlaySE\n\
+ mov r0, #0xd\n\
+ b ._462\n\
+._355:\n\
+ mov r0, #0x20\n\
+ bl PlaySE\n\
+ mov r0, #0x16\n\
+._462:\n\
+ bl PrintStorageActionText\n\
+ ldr r1, ._464 @ 0x2000000\n\
+ mov r0, #0x6\n\
+ strb r0, [r1, #0x4]\n\
+ b ._466\n\
+._465:\n\
+ .align 2, 0\n\
+._464:\n\
+ .word 0x2000000\n\
+._356:\n\
+ ldr r0, ._467 @ gMain\n\
+ ldrh r1, [r0, #0x2e]\n\
+ mov r0, #0xf3\n\
+ and r0, r0, r1\n\
+ cmp r0, #0\n\
+ beq ._466 @cond_branch\n\
+ bl sub_8098A5C\n\
+ ldr r0, ._467 + 4 @ sub_8096C84\n\
+ bl SetPSSCallback\n\
+._466:\n\
+ pop {r4}\n\
+ pop {r0}\n\
+ bx r0\n\
+._468:\n\
+ .align 2, 0\n\
+._467:\n\
+ .word gMain\n\
+ .word sub_8096C84+1");
+}
+#else
void sub_8096C84(void)
{
switch (gPokemonStorageSystemPtr->unk_0004)
@@ -554,6 +1236,7 @@ void sub_8096C84(void)
break;
}
}
+#endif
void sub_8096FC8(void)
{
@@ -597,6 +1280,317 @@ void sub_8097004(void)
}
}
+#if DEBUG
+__attribute__((naked))
+void sub_8097078(void)
+{
+ asm("\
+ push {r4, lr}\n\
+ ldr r0, ._495 @ 0x2000000\n\
+ ldrb r0, [r0, #0x4]\n\
+ cmp r0, #0x5\n\
+ bls ._493 @cond_branch\n\
+ b ._597\n\
+._493:\n\
+ lsl r0, r0, #0x2\n\
+ ldr r1, ._495 + 4 @ \n\
+ add r0, r0, r1\n\
+ ldr r0, [r0]\n\
+ mov pc, r0\n\
+._496:\n\
+ .align 2, 0\n\
+._495:\n\
+ .word 0x2000000\n\
+ .word ._497\n\
+._497:\n\
+ .word ._498\n\
+ .word ._499\n\
+ .word ._500\n\
+ .word ._501\n\
+ .word ._502\n\
+ .word ._503\n\
+._498:\n\
+ mov r0, #0x4\n\
+ bl PrintStorageActionText\n\
+ bl sub_809CE84\n\
+ ldr r1, ._505 @ 0x2000000\n\
+ mov r0, #0x1\n\
+ strb r0, [r1, #0x4]\n\
+ b ._597\n\
+._506:\n\
+ .align 2, 0\n\
+._505:\n\
+ .word 0x2000000\n\
+._499:\n\
+ bl sub_809CF30\n\
+ add r0, r0, #0x1\n\
+ lsl r0, r0, #0x10\n\
+ asr r0, r0, #0x10\n\
+ cmp r0, #0x21\n\
+ bls ._507 @cond_branch\n\
+ b ._597\n\
+._507:\n\
+ lsl r0, r0, #0x2\n\
+ ldr r1, ._510 @ \n\
+ add r0, r0, r1\n\
+ ldr r0, [r0]\n\
+ mov pc, r0\n\
+._511:\n\
+ .align 2, 0\n\
+._510:\n\
+ .word ._509\n\
+._509:\n\
+ .word ._513\n\
+ .word ._513\n\
+ .word ._514\n\
+ .word ._515\n\
+ .word ._516\n\
+ .word ._517\n\
+ .word ._518\n\
+ .word ._519\n\
+ .word ._520\n\
+ .word ._521\n\
+ .word ._597\n\
+ .word ._597\n\
+ .word ._597\n\
+ .word ._597\n\
+ .word ._597\n\
+ .word ._597\n\
+ .word ._597\n\
+ .word ._597\n\
+ .word ._597\n\
+ .word ._597\n\
+ .word ._597\n\
+ .word ._597\n\
+ .word ._597\n\
+ .word ._597\n\
+ .word ._597\n\
+ .word ._597\n\
+ .word ._597\n\
+ .word ._597\n\
+ .word ._597\n\
+ .word ._597\n\
+ .word ._597\n\
+ .word ._597\n\
+ .word ._597\n\
+ .word ._545\n\
+._513:\n\
+ bl sub_8098A5C\n\
+ ldr r0, ._547 @ sub_8096C84\n\
+ bl SetPSSCallback\n\
+ b ._597\n\
+._548:\n\
+ .align 2, 0\n\
+._547:\n\
+ .word sub_8096C84+1\n\
+._516:\n\
+ bl sub_809BE80\n\
+ lsl r0, r0, #0x18\n\
+ cmp r0, #0\n\
+ bne ._563 @cond_branch\n\
+ mov r0, #0x5\n\
+ bl PlaySE\n\
+ bl sub_8098A5C\n\
+ ldr r0, ._551 @ sub_80972A8\n\
+ bl SetPSSCallback\n\
+ b ._597\n\
+._552:\n\
+ .align 2, 0\n\
+._551:\n\
+ .word sub_80972A8+1\n\
+._518:\n\
+ mov r0, #0x5\n\
+ bl PlaySE\n\
+ bl sub_8098A5C\n\
+ ldr r0, ._554 @ sub_80972FC\n\
+ bl SetPSSCallback\n\
+ b ._597\n\
+._555:\n\
+ .align 2, 0\n\
+._554:\n\
+ .word sub_80972FC+1\n\
+._517:\n\
+ bl sub_809BEBC\n\
+ lsl r0, r0, #0x18\n\
+ cmp r0, #0\n\
+ beq ._563 @cond_branch\n\
+ mov r0, #0x5\n\
+ bl PlaySE\n\
+ bl sub_8098A5C\n\
+ ldr r0, ._558 @ c3_0808DC50\n\
+ bl SetPSSCallback\n\
+ b ._597\n\
+._559:\n\
+ .align 2, 0\n\
+._558:\n\
+ .word c3_0808DC50+1\n\
+._515:\n\
+ mov r0, #0x5\n\
+ bl PlaySE\n\
+ bl sub_8098A5C\n\
+ ldr r0, ._561 @ sub_8097390\n\
+ bl SetPSSCallback\n\
+ b ._597\n\
+._562:\n\
+ .align 2, 0\n\
+._561:\n\
+ .word sub_8097390+1\n\
+._514:\n\
+ bl sub_809BE80\n\
+ lsl r0, r0, #0x18\n\
+ cmp r0, #0\n\
+ bne ._563 @cond_branch\n\
+ ldr r4, ._566 @ 0x2000000\n\
+ ldr r1, ._566 + 4 @ 0x11f2\n\
+ add r0, r4, r1\n\
+ ldrh r0, [r0]\n\
+ bl ItemIsMail\n\
+ lsl r0, r0, #0x18\n\
+ cmp r0, #0\n\
+ bne ._564 @cond_branch\n\
+ mov r0, #0x5\n\
+ bl PlaySE\n\
+ bl sub_8098A5C\n\
+ ldr r0, ._566 + 8 @ sub_809746C\n\
+ bl SetPSSCallback\n\
+ b ._597\n\
+._567:\n\
+ .align 2, 0\n\
+._566:\n\
+ .word 0x2000000\n\
+ .word 0x11f2\n\
+ .word sub_809746C+1\n\
+._520:\n\
+ bl sub_809BE80\n\
+ lsl r0, r0, #0x18\n\
+ cmp r0, #0\n\
+ beq ._568 @cond_branch\n\
+._563:\n\
+ ldr r1, ._570 @ 0x2000000\n\
+ mov r0, #0x2\n\
+ strb r0, [r1, #0x4]\n\
+ b ._597\n\
+._571:\n\
+ .align 2, 0\n\
+._570:\n\
+ .word 0x2000000\n\
+._568:\n\
+ ldr r4, ._574 @ 0x2000000\n\
+ ldr r1, ._574 + 4 @ 0x11f9\n\
+ add r0, r4, r1\n\
+ ldrb r0, [r0]\n\
+ cmp r0, #0\n\
+ beq ._572 @cond_branch\n\
+ mov r0, #0x4\n\
+ strb r0, [r4, #0x4]\n\
+ b ._597\n\
+._575:\n\
+ .align 2, 0\n\
+._574:\n\
+ .word 0x2000000\n\
+ .word 0x11f9\n\
+._572:\n\
+ ldr r1, ._578 @ 0x11f2\n\
+ add r0, r4, r1\n\
+ ldrh r0, [r0]\n\
+ bl ItemIsMail\n\
+ lsl r0, r0, #0x18\n\
+ cmp r0, #0\n\
+ beq ._576 @cond_branch\n\
+._564:\n\
+ mov r0, #0x3\n\
+ strb r0, [r4, #0x4]\n\
+ b ._597\n\
+._579:\n\
+ .align 2, 0\n\
+._578:\n\
+ .word 0x11f2\n\
+._576:\n\
+ mov r0, #0x5\n\
+ bl PlaySE\n\
+ ldr r0, ._581 @ sub_8097594\n\
+ bl SetPSSCallback\n\
+ b ._597\n\
+._582:\n\
+ .align 2, 0\n\
+._581:\n\
+ .word sub_8097594+1\n\
+._519:\n\
+ mov r0, #0x5\n\
+ bl PlaySE\n\
+ ldr r0, ._584 @ sub_8097788\n\
+ bl SetPSSCallback\n\
+ b ._597\n\
+._585:\n\
+ .align 2, 0\n\
+._584:\n\
+ .word sub_8097788+1\n\
+._521:\n\
+ mov r0, #0x5\n\
+ bl PlaySE\n\
+ ldr r0, ._587 @ sub_80977E4\n\
+ bl SetPSSCallback\n\
+ b ._597\n\
+._588:\n\
+ .align 2, 0\n\
+._587:\n\
+ .word sub_80977E4+1\n\
+._545:\n\
+ mov r0, #0x5\n\
+ bl PlaySE\n\
+ bl sub_8098A5C\n\
+ ldr r0, ._590 @ debug_sub_80A435C\n\
+ bl SetPSSCallback\n\
+ b ._597\n\
+._591:\n\
+ .align 2, 0\n\
+._590:\n\
+ .word debug_sub_80A435C+1\n\
+._500:\n\
+ mov r0, #0x20\n\
+ bl PlaySE\n\
+ mov r0, #0xd\n\
+ b ._593\n\
+._502:\n\
+ mov r0, #0x20\n\
+ bl PlaySE\n\
+ mov r0, #0x11\n\
+ b ._593\n\
+._501:\n\
+ mov r0, #0x20\n\
+ bl PlaySE\n\
+ mov r0, #0x16\n\
+._593:\n\
+ bl PrintStorageActionText\n\
+ ldr r1, ._595 @ 0x2000000\n\
+ mov r0, #0x5\n\
+ strb r0, [r1, #0x4]\n\
+ b ._597\n\
+._596:\n\
+ .align 2, 0\n\
+._595:\n\
+ .word 0x2000000\n\
+._503:\n\
+ ldr r0, ._598 @ gMain\n\
+ ldrh r1, [r0, #0x2e]\n\
+ mov r0, #0xf3\n\
+ and r0, r0, r1\n\
+ cmp r0, #0\n\
+ beq ._597 @cond_branch\n\
+ bl sub_8098A5C\n\
+ ldr r0, ._598 + 4 @ sub_8096C84\n\
+ bl SetPSSCallback\n\
+._597:\n\
+ pop {r4}\n\
+ pop {r0}\n\
+ bx r0\n\
+._599:\n\
+ .align 2, 0\n\
+._598:\n\
+ .word gMain\n\
+ .word sub_8096C84+1");
+}
+#else
void sub_8097078(void)
{
switch (gPokemonStorageSystemPtr->unk_0004)
@@ -717,6 +1711,7 @@ void sub_8097078(void)
break;
}
}
+#endif
void sub_80972A8(void)
{
diff --git a/src/pokemon/pokemon_storage_system_4.c b/src/pokemon/pokemon_storage_system_4.c
index 1cc9f7e3b..19fddc0f7 100644
--- a/src/pokemon/pokemon_storage_system_4.c
+++ b/src/pokemon/pokemon_storage_system_4.c
@@ -25,6 +25,11 @@ struct WallpaperTable {
// Static RAM declarations
EWRAM_DATA struct Pokemon gUnknown_02038480 = {};
+#if DEBUG
+EWRAM_DATA u32 unk_2038790 = 0;
+EWRAM_DATA u32 unk_2038794 = 0;
+EWRAM_DATA u32 unk_2038798 = 0;
+#endif
EWRAM_DATA s8 gUnknown_020384E4 = 0;
EWRAM_DATA s8 gUnknown_020384E5 = 0;
EWRAM_DATA bool8 gUnknown_020384E6 = FALSE;
diff --git a/src/pokemon/pokemon_summary_screen.c b/src/pokemon/pokemon_summary_screen.c
index 325a94117..9c621780a 100644
--- a/src/pokemon/pokemon_summary_screen.c
+++ b/src/pokemon/pokemon_summary_screen.c
@@ -41,11 +41,11 @@ static void sub_80A0090(struct Pokemon *);
static void sub_80A015C(struct Pokemon *);
static void sub_809DE44(void);
static void sub_809EB40(u8);
-static void sub_809EBC4(void);
-static void sub_809E044(void);
+/*static*/ void sub_809EBC4(void);
+/*static*/ void sub_809E044(void);
static void sub_80A1D84(struct Pokemon *);
-static void sub_80A18C4(void);
-static bool8 LoadPokemonSummaryScreenGraphics(void);
+/*static*/ void sub_80A18C4(void);
+/*static*/ bool8 LoadPokemonSummaryScreenGraphics(void);
static bool8 MonKnowsMultipleMoves(struct Pokemon *);
static void PrintSummaryWindowHeaderText(void);
static void sub_80A1DCC(struct Pokemon *);
@@ -63,8 +63,8 @@ static void PrintHeldItemName(u16, u8, u8);
static void PrintNumRibbons(struct Pokemon *);
static void DrawExperienceProgressBar(struct Pokemon *, u8, u8);
static void sub_809E13C(u8 taskId);
-static void sub_80A1950(void);
-static void sub_809DE64(void);
+/*static*/ void sub_80A1950(void);
+/*static*/ void sub_809DE64(void);
static void SummaryScreenHandleAButton(u8);
static void SummaryScreenHandleUpDownInput(u8, s8);
static bool8 sub_809F7D0(u8);
@@ -571,7 +571,43 @@ static const u8 sUnknown_083C15BC[] = {
-1, 15, 0, 10,
};
-
+#if DEBUG
+__attribute__((naked))
+void sub_809D844(void)
+{
+ asm("\
+ push {lr}\n\
+ add sp, sp, #0xfffffffc\n\
+ bl RunTasks\n\
+ bl AnimateSprites\n\
+ bl BuildOamBuffer\n\
+ bl UpdatePaletteFade\n\
+ ldr r0, ._2 @ gLinkOpen\n\
+ ldrb r0, [r0]\n\
+ cmp r0, #0x1\n\
+ bne ._1 @cond_branch\n\
+ ldr r0, ._2 + 4 @ gLink\n\
+ ldr r1, ._2 + 8 @ 0xfbd\n\
+ add r0, r0, r1\n\
+ ldrb r0, [r0]\n\
+ mov r1, #0x3\n\
+ str r1, [sp]\n\
+ mov r1, #0x14\n\
+ mov r2, #0x1\n\
+ mov r3, #0x2\n\
+ bl debug_sub_8008264\n\
+._1:\n\
+ add sp, sp, #0x4\n\
+ pop {r0}\n\
+ bx r0\n\
+._3:\n\
+ .align 2, 0\n\
+._2:\n\
+ .word gLinkOpen\n\
+ .word gLink\n\
+ .word 0xfbd");
+}
+#else
void sub_809D844(void)
{
RunTasks();
@@ -579,6 +615,7 @@ void sub_809D844(void)
BuildOamBuffer();
UpdatePaletteFade();
}
+#endif
void sub_809D85C(void)
{
@@ -688,6 +725,491 @@ void sub_809DA1C(void)
}
}
+#if DEBUG
+__attribute__((naked))
+bool8 sub_809DA84(void)
+{
+ asm("\
+ push {r4, r5, r6, r7, lr}\n\
+ add sp, sp, #0xfffffff8\n\
+ ldr r1, ._52 @ gMain\n\
+ ldr r2, ._52 + 4 @ 0x43c\n\
+ add r0, r1, r2\n\
+ ldrb r0, [r0]\n\
+ mov ip, r1\n\
+ cmp r0, #0x16\n\
+ bls ._50 @cond_branch\n\
+ b ._51\n\
+._50:\n\
+ lsl r0, r0, #0x2\n\
+ ldr r1, ._52 + 8 @ \n\
+ add r0, r0, r1\n\
+ ldr r0, [r0]\n\
+ mov pc, r0\n\
+._53:\n\
+ .align 2, 0\n\
+._52:\n\
+ .word gMain\n\
+ .word 0x43c\n\
+ .word ._54\n\
+._54:\n\
+ .word ._55\n\
+ .word ._56\n\
+ .word ._57\n\
+ .word ._58\n\
+ .word ._59\n\
+ .word ._60\n\
+ .word ._61\n\
+ .word ._62\n\
+ .word ._63\n\
+ .word ._64\n\
+ .word ._65\n\
+ .word ._66\n\
+ .word ._67\n\
+ .word ._68\n\
+ .word ._69\n\
+ .word ._70\n\
+ .word ._71\n\
+ .word ._72\n\
+ .word ._73\n\
+ .word ._74\n\
+ .word ._75\n\
+ .word ._76\n\
+ .word ._77\n\
+._55:\n\
+ mov r0, #0x0\n\
+ bl SetVBlankCallback\n\
+ bl ResetSpriteData\n\
+ b ._146\n\
+._56:\n\
+ bl ScanlineEffect_Stop\n\
+ ldr r1, ._80 @ gMain\n\
+ ldr r2, ._80 + 4 @ 0x43c\n\
+ add r1, r1, r2\n\
+ b ._153\n\
+._81:\n\
+ .align 2, 0\n\
+._80:\n\
+ .word gMain\n\
+ .word 0x43c\n\
+._57:\n\
+ bl FreeAllSpritePalettes\n\
+ b ._146\n\
+._58:\n\
+ mov r2, #0xc0\n\
+ lsl r2, r2, #0x13\n\
+ mov r3, #0x80\n\
+ lsl r3, r3, #0x9\n\
+ mov r5, #0x0\n\
+ ldr r1, ._85 @ 0x40000d4\n\
+ mov r4, #0x80\n\
+ lsl r4, r4, #0x5\n\
+ ldr r6, ._85 + 4 @ 0x85000400\n\
+ mov r7, #0x85\n\
+ lsl r7, r7, #0x18\n\
+._83:\n\
+ str r5, [sp, #0x4]\n\
+ add r0, sp, #0x4\n\
+ str r0, [r1]\n\
+ str r2, [r1, #0x4]\n\
+ str r6, [r1, #0x8]\n\
+ ldr r0, [r1, #0x8]\n\
+ add r2, r2, r4\n\
+ sub r3, r3, r4\n\
+ cmp r3, r4\n\
+ bhi ._83 @cond_branch\n\
+ str r5, [sp, #0x4]\n\
+ add r0, sp, #0x4\n\
+ str r0, [r1]\n\
+ str r2, [r1, #0x4]\n\
+ lsr r0, r3, #0x2\n\
+ orr r0, r0, r7\n\
+ str r0, [r1, #0x8]\n\
+ ldr r0, [r1, #0x8]\n\
+ ldr r1, ._85 + 8 @ 0x43c\n\
+ add r1, r1, ip\n\
+ b ._153\n\
+._86:\n\
+ .align 2, 0\n\
+._85:\n\
+ .word 0x40000d4\n\
+ .word 0x85000400\n\
+ .word 0x43c\n\
+._59:\n\
+ bl sub_809DE64\n\
+ ldr r1, ._88 @ gMain\n\
+ ldr r2, ._88 + 4 @ 0x43c\n\
+ add r1, r1, r2\n\
+ b ._153\n\
+._89:\n\
+ .align 2, 0\n\
+._88:\n\
+ .word gMain\n\
+ .word 0x43c\n\
+._60:\n\
+ ldr r0, ._91 @ gWindowTemplate_81E6E6C\n\
+ bl Text_LoadWindowTemplate\n\
+ b ._146\n\
+._92:\n\
+ .align 2, 0\n\
+._91:\n\
+ .word gWindowTemplate_81E6E6C\n\
+._61:\n\
+ ldr r0, ._94 @ gWindowTemplate_81E6E6C\n\
+ bl MultistepInitMenuWindowBegin\n\
+ ldr r1, ._94 + 4 @ gMain\n\
+ ldr r2, ._94 + 8 @ 0x43c\n\
+ add r1, r1, r2\n\
+ b ._153\n\
+._95:\n\
+ .align 2, 0\n\
+._94:\n\
+ .word gWindowTemplate_81E6E6C\n\
+ .word gMain\n\
+ .word 0x43c\n\
+._62:\n\
+ bl MultistepInitMenuWindowContinue\n\
+ cmp r0, #0\n\
+ bne ._96 @cond_branch\n\
+ b ._157\n\
+._96:\n\
+ b ._146\n\
+._63:\n\
+ bl sub_809DA1C\n\
+ ldr r1, ._100 @ gMain\n\
+ ldr r2, ._100 + 4 @ 0x43c\n\
+ add r1, r1, r2\n\
+ b ._153\n\
+._101:\n\
+ .align 2, 0\n\
+._100:\n\
+ .word gMain\n\
+ .word 0x43c\n\
+._64:\n\
+ ldr r1, ._103 @ gSummaryScreenTextTiles\n\
+ ldr r2, ._103 + 4 @ 0x600d000\n\
+ ldr r0, ._103 + 8 @ 0x40000d4\n\
+ str r1, [r0]\n\
+ str r2, [r0, #0x4]\n\
+ ldr r1, ._103 + 12 @ 0x800000a0\n\
+ str r1, [r0, #0x8]\n\
+ ldr r1, [r0, #0x8]\n\
+ ldr r1, ._103 + 16 @ sSummaryScreenButtonTiles\n\
+ ldr r2, ._103 + 20 @ 0x600d140\n\
+ str r1, [r0]\n\
+ str r2, [r0, #0x4]\n\
+ ldr r1, ._103 + 24 @ 0x80000080\n\
+ str r1, [r0, #0x8]\n\
+ ldr r0, [r0, #0x8]\n\
+ ldr r0, ._103 + 28 @ \n\
+ add r0, r0, #0x74\n\
+ mov r1, #0x0\n\
+ strb r1, [r0]\n\
+ ldr r1, ._103 + 32 @ \n\
+ add r1, r1, ip\n\
+ b ._153\n\
+._104:\n\
+ .align 2, 0\n\
+._103:\n\
+ .word gSummaryScreenTextTiles\n\
+ .word 0x600d000\n\
+ .word 0x40000d4\n\
+ .word 0x800000a0\n\
+ .word sSummaryScreenButtonTiles\n\
+ .word 0x600d140\n\
+ .word 0x80000080\n\
+ .word +0x2018000\n\
+ .word 0x43c\n\
+._65:\n\
+ bl LoadPokemonSummaryScreenGraphics\n\
+ lsl r0, r0, #0x18\n\
+ cmp r0, #0\n\
+ bne ._105 @cond_branch\n\
+ b ._157\n\
+._105:\n\
+ ldr r0, ._108 @ \n\
+ add r0, r0, #0x74\n\
+ mov r1, #0x0\n\
+ strb r1, [r0]\n\
+ b ._146\n\
+._109:\n\
+ .align 2, 0\n\
+._108:\n\
+ .word +0x2018000\n\
+._66:\n\
+ bl sub_80A18C4\n\
+ ldr r1, ._111 @ gMain\n\
+ ldr r2, ._111 + 4 @ 0x43c\n\
+ add r1, r1, r2\n\
+ b ._153\n\
+._112:\n\
+ .align 2, 0\n\
+._111:\n\
+ .word gMain\n\
+ .word 0x43c\n\
+._67:\n\
+ ldr r4, ._115 @ \n\
+ add r0, r4, #0\n\
+ bl sub_809F678\n\
+ add r0, r4, #0\n\
+ bl GetMonStatusAndPokerus\n\
+ lsl r0, r0, #0x18\n\
+ cmp r0, #0\n\
+ bne ._113 @cond_branch\n\
+ mov r0, #0x0\n\
+ bl sub_80A12D0\n\
+ b ._114\n\
+._116:\n\
+ .align 2, 0\n\
+._115:\n\
+ .word +0x2018010\n\
+._113:\n\
+ mov r0, #0xa\n\
+ bl sub_80A12D0\n\
+._114:\n\
+ ldr r0, ._118 @ \n\
+ bl DrawPokerusSurvivorDot\n\
+ b ._146\n\
+._119:\n\
+ .align 2, 0\n\
+._118:\n\
+ .word +0x2018010\n\
+._68:\n\
+ bl sub_80A1950\n\
+ ldr r0, ._121 @ \n\
+ bl sub_80A1D84\n\
+ ldr r1, ._121 + 4 @ \n\
+ ldr r2, ._121 + 8 @ \n\
+ add r1, r1, r2\n\
+ b ._153\n\
+._122:\n\
+ .align 2, 0\n\
+._121:\n\
+ .word +0x2018010\n\
+ .word gMain\n\
+ .word 0x43c\n\
+._69:\n\
+ ldr r4, ._124 @ \n\
+ add r0, r4, #0\n\
+ bl sub_80A1DE8\n\
+ add r4, r4, #0x64\n\
+ mov r0, #0x0\n\
+ strb r0, [r4]\n\
+ b ._146\n\
+._125:\n\
+ .align 2, 0\n\
+._124:\n\
+ .word +0x2018010\n\
+._70:\n\
+ ldr r4, ._129 @ \n\
+ add r5, r4, #0\n\
+ add r5, r5, #0x64\n\
+ add r0, r4, #0\n\
+ add r1, r5, #0\n\
+ bl sub_809F6B4\n\
+ sub r4, r4, #0x10\n\
+ strb r0, [r4, #0xc]\n\
+ lsl r0, r0, #0x18\n\
+ lsr r0, r0, #0x18\n\
+ cmp r0, #0xff\n\
+ bne ._126 @cond_branch\n\
+ b ._157\n\
+._126:\n\
+ mov r0, #0x0\n\
+ strb r0, [r5]\n\
+ ldr r1, ._129 + 4 @ \n\
+ ldr r2, ._129 + 8 @ \n\
+ add r1, r1, r2\n\
+ b ._153\n\
+._130:\n\
+ .align 2, 0\n\
+._129:\n\
+ .word +0x2018010\n\
+ .word gMain\n\
+ .word 0x43c\n\
+._71:\n\
+ bl sub_809E044\n\
+ bl DrawSummaryScreenNavigationDots\n\
+ b ._146\n\
+._72:\n\
+ ldr r1, ._134 @ \n\
+ ldrb r0, [r1, #0xb]\n\
+ cmp r0, #0x1\n\
+ bhi ._132 @cond_branch\n\
+ ldr r0, ._134 + 4 @ \n\
+ ldrb r1, [r1, #0xb]\n\
+ lsl r1, r1, #0x2\n\
+ add r1, r1, r0\n\
+ ldr r0, [r1]\n\
+ bl _call_via_r0\n\
+._132:\n\
+ ldr r1, ._134 + 8 @ \n\
+ ldr r2, ._134 + 12 @ \n\
+ add r1, r1, r2\n\
+ b ._153\n\
+._135:\n\
+ .align 2, 0\n\
+._134:\n\
+ .word +0x2018000\n\
+ .word sUnknown_083C1580\n\
+ .word gMain\n\
+ .word 0x43c\n\
+._73:\n\
+ ldr r0, ._137 @ \n\
+ bl sub_809FAC8\n\
+ b ._146\n\
+._138:\n\
+ .align 2, 0\n\
+._137:\n\
+ .word +0x2018010\n\
+._74:\n\
+ ldr r2, ._140 @ sUnknown_083C1598\n\
+ ldr r0, ._140 + 4 @ \n\
+ ldrb r1, [r0, #0xb]\n\
+ lsl r1, r1, #0x2\n\
+ add r1, r1, r2\n\
+ add r0, r0, #0x10\n\
+ ldr r1, [r1]\n\
+ bl _call_via_r1\n\
+ ldr r1, ._140 + 8 @ \n\
+ ldr r2, ._140 + 12 @ \n\
+ add r1, r1, r2\n\
+ b ._153\n\
+._141:\n\
+ .align 2, 0\n\
+._140:\n\
+ .word sUnknown_083C1598\n\
+ .word +0x2018000\n\
+ .word gMain\n\
+ .word 0x43c\n\
+._75:\n\
+ ldr r0, ._144 @ \n\
+ mov r1, #0x2d\n\
+ bl GetMonData\n\
+ add r1, r0, #0\n\
+ cmp r1, #0\n\
+ beq ._142 @cond_branch\n\
+ ldr r1, ._144 + 4 @ \n\
+ mov r2, #0x80\n\
+ lsl r2, r2, #0x1\n\
+ add r0, r2, #0\n\
+ strh r0, [r1]\n\
+ b ._146\n\
+._145:\n\
+ .align 2, 0\n\
+._144:\n\
+ .word +0x2018010\n\
+ .word gBattle_BG3_X\n\
+._142:\n\
+ ldr r0, ._147 @ gBattle_BG3_X\n\
+ strh r1, [r0]\n\
+ b ._146\n\
+._148:\n\
+ .align 2, 0\n\
+._147:\n\
+ .word gBattle_BG3_X\n\
+._76:\n\
+ bl sub_809EBC4\n\
+ ldr r0, ._151 @ \n\
+ add r0, r0, #0x79\n\
+ ldrb r0, [r0]\n\
+ cmp r0, #0\n\
+ beq ._149 @cond_branch\n\
+ mov r0, #0x0\n\
+ mov r1, #0x0\n\
+ bl sub_80A1488\n\
+ mov r0, #0x0\n\
+ mov r1, #0x0\n\
+ bl sub_80A1654\n\
+ b ._150\n\
+._152:\n\
+ .align 2, 0\n\
+._151:\n\
+ .word +0x2018000\n\
+._149:\n\
+ mov r0, #0xa\n\
+ mov r1, #0x0\n\
+ bl sub_80A1488\n\
+ mov r0, #0xa\n\
+ mov r1, #0x0\n\
+ bl sub_80A1654\n\
+._150:\n\
+ bl PrintSummaryWindowHeaderText\n\
+ ldr r1, ._154 @ gMain\n\
+ ldr r2, ._154 + 4 @ 0x43c\n\
+ add r1, r1, r2\n\
+ b ._153\n\
+._155:\n\
+ .align 2, 0\n\
+._154:\n\
+ .word gMain\n\
+ .word 0x43c\n\
+._77:\n\
+ bl sub_8055870\n\
+ cmp r0, #0x1\n\
+ beq ._157 @cond_branch\n\
+._146:\n\
+ ldr r1, ._158 @ gMain\n\
+ ldr r0, ._158 + 4 @ 0x43c\n\
+ add r1, r1, r0\n\
+._153:\n\
+ ldrb r0, [r1]\n\
+ add r0, r0, #0x1\n\
+ strb r0, [r1]\n\
+ b ._157\n\
+._159:\n\
+ .align 2, 0\n\
+._158:\n\
+ .word gMain\n\
+ .word 0x43c\n\
+._51:\n\
+ ldr r0, ._162 @ sub_809D85C\n\
+ bl SetVBlankCallback\n\
+ mov r0, #0x1\n\
+ str r0, [sp]\n\
+ mov r0, #0xff\n\
+ mov r1, #0x0\n\
+ mov r2, #0x10\n\
+ mov r3, #0x0\n\
+ bl BeginHardwarePaletteFade\n\
+ ldr r0, ._162 + 4 @ sub_809D844\n\
+ bl SetMainCallback2\n\
+ ldr r2, ._162 + 8 @ gPaletteFade\n\
+ ldrb r1, [r2, #0x8]\n\
+ mov r0, #0x7f\n\
+ and r0, r0, r1\n\
+ strb r0, [r2, #0x8]\n\
+ ldr r0, ._162 + 12 @ gLinkOpen\n\
+ ldrb r0, [r0]\n\
+ cmp r0, #0x1\n\
+ bne ._160 @cond_branch\n\
+ ldr r0, ._162 + 16 @ 0x600dde0\n\
+ mov r1, #0x80\n\
+ lsl r1, r1, #0x8\n\
+ ldr r2, ._162 + 20 @ 0x600f000\n\
+ mov r3, #0x3\n\
+ bl debug_sub_8008218\n\
+._160:\n\
+ mov r0, #0x1\n\
+ b ._161\n\
+._163:\n\
+ .align 2, 0\n\
+._162:\n\
+ .word sub_809D85C+1\n\
+ .word sub_809D844+1\n\
+ .word gPaletteFade\n\
+ .word gLinkOpen\n\
+ .word 0x600dde0\n\
+ .word 0x600f000\n\
+._157:\n\
+ mov r0, #0x0\n\
+._161:\n\
+ add sp, sp, #0x8\n\
+ pop {r4, r5, r6, r7}\n\
+ pop {r1}\n\
+ bx r1");
+}
+#else
bool8 sub_809DA84(void)
{
switch (gMain.state)
@@ -845,13 +1367,15 @@ bool8 sub_809DA84(void)
return FALSE;
}
+#endif
static void sub_809DE44(void)
{
- while (sub_809DA84() != TRUE && sub_80F9344() != TRUE);
+ while (sub_809DA84() != TRUE && sub_80F9344() != TRUE)
+ ;
}
-static void sub_809DE64(void)
+/*static*/ void sub_809DE64(void)
{
REG_BG0CNT = 0x1E08;
REG_BG1CNT = 0x4801;
@@ -878,7 +1402,7 @@ static void sub_809DE64(void)
REG_DISPCNT = 0x1F40;
}
-static bool8 LoadPokemonSummaryScreenGraphics(void)
+/*static*/ bool8 LoadPokemonSummaryScreenGraphics(void)
{
switch (pssData.loadGfxState)
{
@@ -928,7 +1452,7 @@ static bool8 LoadPokemonSummaryScreenGraphics(void)
return FALSE;
}
-static void sub_809E044(void)
+/*static*/ void sub_809E044(void)
{
LoadPalette(gUnknownPalette_81E6692 + 14, 129, 2);
LoadPalette(gUnknownPalette_81E6692 + 15, 136, 2);
@@ -1507,7 +2031,7 @@ static void sub_809EB40(u8 taskId)
}
}
-static void sub_809EBC4(void)
+/*static*/ void sub_809EBC4(void)
{
if (pssData.page != PSS_PAGE_INFO)
{
@@ -2565,14 +3089,14 @@ static void sub_809FC34(struct Pokemon *mon)
buffer = gStringVar1;
buffer = sub_80A1E58(buffer, 13);
buffer = StringCopy(buffer, gOtherText_OriginalTrainer);
- buffer = StringCopy(buffer, gOtherText_FiveQuestionsAndSlash);
+ buffer = StringCopy(buffer, gOtherText_FiveQuestions);
buffer[0] = EXT_CTRL_CODE_BEGIN;
buffer[1] = 0x13;
buffer[2] = 0x4E;
buffer[3] = EOS;
Menu_PrintText(gStringVar1, 11, 4);
- sub_80A1EF8(gOtherText_FiveQuestionsAndSlash, 13, 193, 32, 1);
+ sub_80A1EF8(gOtherText_FiveQuestions, 13, 193, 32, 1);
sub_80A198C(9, 120, 48, 0);
friendship = GetMonData(mon, MON_DATA_FRIENDSHIP);
@@ -4874,7 +5398,7 @@ static void sub_80A1888(struct Sprite *sprite)
}
}
-static void sub_80A18C4(void)
+/*static*/ void sub_80A18C4(void)
{
u8 i;
@@ -4898,7 +5422,7 @@ static void sub_80A1918(u8 a, u8 invisible)
gSprites[ewram1A000[a]].invisible = invisible;
}
-static void sub_80A1950(void)
+/*static*/ void sub_80A1950(void)
{
u8 i;