diff options
Diffstat (limited to 'src/pokemon')
-rw-r--r-- | src/pokemon/mail.c | 614 | ||||
-rw-r--r-- | src/pokemon/pokedex.c | 4 | ||||
-rw-r--r-- | src/pokemon/pokemon_1.c | 47 | ||||
-rw-r--r-- | src/pokemon/pokemon_menu.c | 25 | ||||
-rw-r--r-- | src/pokemon/pokemon_storage_system.c | 178 | ||||
-rw-r--r-- | src/pokemon/pokemon_storage_system_2.c | 995 | ||||
-rw-r--r-- | src/pokemon/pokemon_storage_system_4.c | 5 | ||||
-rw-r--r-- | src/pokemon/pokemon_summary_screen.c | 556 |
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, ¤tHP); } +#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, ¤tHP); +} +#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; |