summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/battle_pyramid.c248
-rw-r--r--src/data/text/nature_names.h54
-rw-r--r--src/pokemon_summary_screen.c2332
-rw-r--r--src/unk_pokedex_area_screen_helper.c75
4 files changed, 1680 insertions, 1029 deletions
diff --git a/src/battle_pyramid.c b/src/battle_pyramid.c
new file mode 100644
index 000000000..f9cc48a9a
--- /dev/null
+++ b/src/battle_pyramid.c
@@ -0,0 +1,248 @@
+#include "global.h"
+#include "main.h"
+#include "battle_controllers.h"
+#include "bg.h"
+#include "field_effect.h"
+#include "field_weather.h"
+#include "gpu_regs.h"
+#include "malloc.h"
+#include "menu.h"
+#include "menu_helpers.h"
+#include "overworld.h"
+#include "palette.h"
+#include "party_menu.h"
+#include "scanline_effect.h"
+#include "script.h"
+#include "task.h"
+#include "constants/rgb.h"
+
+EWRAM_DATA struct
+{
+ u32 unk0;
+ u8 filler4[0x804 - 0x4];
+ u8 unk804[11];
+ u8 unk80F[5];
+ u8 unk814;
+ u8 filler815;
+ s8 unk816;
+ u8 filler817[0x984 - 0x817];
+ u16 unk984;
+ u8 filler986[0x98C - 0x986];
+} *gUnknown_0203CF2C = NULL;
+EWRAM_DATA struct
+{
+ void (*callback)(void);
+ u8 unk4;
+ u16 unk6;
+ u16 unk8;
+} gUnknown_0203CF30 = {0};
+
+extern const struct BgTemplate gUnknown_0861F2B4[3];
+
+void sub_81C4F98(u8 a0, void (*callback)(void));
+void sub_81C4F44(u8 taskId);
+void sub_81C504C(void);
+bool8 sub_81C5078(void);
+void sub_81C51DC(void);
+bool8 sub_81C5238(void);
+void sub_81C5314(void);
+void sub_81C5674(void);
+void sub_81C56F8(void);
+void sub_81C5924(void);
+void sub_81C59BC(void);
+void sub_81C5A20(void);
+void sub_81C6BD8(void);
+void sub_81C6EF4(void);
+void sub_81C700C(void);
+
+void sub_81C4EEC(void)
+{
+ gUnknown_0203CF30.unk6 = 0;
+ gUnknown_0203CF30.unk8 = 0;
+}
+
+void sub_81C4EFC(void)
+{
+ sub_81C4F98(0, CB2_ReturnToFieldWithOpenMenu);
+}
+
+void sub_81C4F10(void)
+{
+ sub_81C4F98(1, SetCB2ToReshowScreenAfterMenu2);
+}
+
+void sub_81C4F24(void)
+{
+ ScriptContext2_Enable();
+ FadeScreen(1, 0);
+ CreateTask(sub_81C4F44, 10);
+}
+
+void sub_81C4F44(u8 taskId)
+{
+ if (!gPaletteFade.active)
+ {
+ overworld_free_bg_tilemaps();
+ gFieldCallback2 = hm_add_c3_without_phase_2;
+ sub_81C4F98(3, CB2_ReturnToField);
+ DestroyTask(taskId);
+ }
+}
+
+void sub_81C4F84(void)
+{
+ sub_81C4F98(4, gUnknown_0203CF30.callback);
+}
+
+void sub_81C4F98(u8 a0, void (*callback)(void))
+{
+ gUnknown_0203CF2C = AllocZeroed(sizeof(*gUnknown_0203CF2C));
+
+ if (a0 != 4)
+ {
+ gUnknown_0203CF30.unk4 = a0;
+ }
+
+ if (callback != NULL)
+ {
+ gUnknown_0203CF30.callback = callback;
+ }
+
+ gUnknown_0203CF2C->unk0 = 0;
+ gUnknown_0203CF2C->unk814 = -1;
+ gUnknown_0203CF2C->unk816 = -1;
+
+ memset(gUnknown_0203CF2C->unk804, 0xFF, sizeof(gUnknown_0203CF2C->unk804));
+ memset(gUnknown_0203CF2C->unk80F, 0xFF, sizeof(gUnknown_0203CF2C->unk80F));
+
+ SetMainCallback2(sub_81C504C);
+}
+
+void sub_81C501C(void)
+{
+ RunTasks();
+ AnimateSprites();
+ BuildOamBuffer();
+ do_scheduled_bg_tilemap_copies_to_vram();
+ UpdatePaletteFade();
+}
+
+void sub_81C5038(void)
+{
+ LoadOam();
+ ProcessSpriteCopyRequests();
+ TransferPlttBuffer();
+}
+
+void sub_81C504C(void)
+{
+ while (sub_81221EC() != TRUE && sub_81C5078() != TRUE && sub_81221AC() != TRUE);
+}
+
+bool8 sub_81C5078(void)
+{
+ switch (gMain.state)
+ {
+ case 0:
+ SetVBlankHBlankCallbacksToNull();
+ clear_scheduled_bg_copies_to_vram();
+ gMain.state++;
+ break;
+ case 1:
+ ScanlineEffect_Stop();
+ gMain.state++;
+ break;
+ case 2:
+ FreeAllSpritePalettes();
+ gMain.state++;
+ break;
+ case 3:
+ ResetPaletteFade();
+ gPaletteFade.bufferTransferDisabled = TRUE;
+ gMain.state++;
+ break;
+ case 4:
+ ResetSpriteData();
+ gMain.state++;
+ break;
+ case 5:
+ if (!sub_81221AC())
+ {
+ ResetTasks();
+ }
+ gMain.state++;
+ break;
+ case 6:
+ sub_81C51DC();
+ gUnknown_0203CF2C->unk984 = 0;
+ gMain.state++;
+ break;
+ case 7:
+ if (sub_81C5238())
+ {
+ gMain.state++;
+ }
+ break;
+ case 8:
+ sub_81C6BD8();
+ gMain.state++;
+ break;
+ case 9:
+ sub_81C5924();
+ sub_81C59BC();
+ sub_81C5A20();
+ gMain.state++;
+ break;
+ case 10:
+ sub_81C5314();
+ gMain.state++;
+ break;
+ case 11:
+ sub_81C56F8();
+ gMain.state++;
+ break;
+ case 12:
+ sub_81C6EF4();
+ gMain.state++;
+ break;
+ case 13:
+ sub_81C5674();
+ gMain.state++;
+ break;
+ case 14:
+ sub_81C700C();
+ gMain.state++;
+ break;
+ case 15:
+ BlendPalettes(0xFFFFFFFF, 0x10, 0);
+ gMain.state++;
+ break;
+ case 16:
+ BeginNormalPaletteFade(0xFFFFFFFF, 0, 0x10, 0, RGB_BLACK);
+ gPaletteFade.bufferTransferDisabled = FALSE;
+ gMain.state++;
+ break;
+ default:
+ SetVBlankCallback(sub_81C5038);
+ SetMainCallback2(sub_81C501C);
+ return TRUE;
+ }
+ return FALSE;
+}
+
+void sub_81C51DC(void)
+{
+ ResetVramOamAndBgCntRegs();
+ ResetBgsAndClearDma3BusyFlags(0);
+ InitBgsFromTemplates(0, gUnknown_0861F2B4, ARRAY_COUNT(gUnknown_0861F2B4));
+ SetBgTilemapBuffer(2, gUnknown_0203CF2C->filler4);
+ ResetAllBgsCoordinates();
+ schedule_bg_copy_tilemap_to_vram(2);
+ SetGpuReg(REG_OFFSET_DISPCNT, DISPCNT_MODE_0 |
+ DISPCNT_OBJ_1D_MAP |
+ DISPCNT_OBJ_ON);
+ ShowBg(0);
+ ShowBg(1);
+ ShowBg(2);
+ SetGpuReg(REG_OFFSET_BLDCNT, 0);
+}
diff --git a/src/data/text/nature_names.h b/src/data/text/nature_names.h
new file mode 100644
index 000000000..d0d217d9b
--- /dev/null
+++ b/src/data/text/nature_names.h
@@ -0,0 +1,54 @@
+static const u8 sHardyNatureName[] = _("HARDY");
+static const u8 sLonelyNatureName[] = _("LONELY");
+static const u8 sBraveNatureName[] = _("BRAVE");
+static const u8 sAdamantNatureName[] = _("ADAMANT");
+static const u8 sNaughtyNatureName[] = _("NAUGHTY");
+static const u8 sBoldNatureName[] = _("BOLD");
+static const u8 sDocileNatureName[] = _("DOCILE");
+static const u8 sRelaxedNatureName[] = _("RELAXED");
+static const u8 sImpishNatureName[] = _("IMPISH");
+static const u8 sLaxNatureName[] = _("LAX");
+static const u8 sTimidNatureName[] = _("TIMID");
+static const u8 sHastyNatureName[] = _("HASTY");
+static const u8 sSeriousNatureName[] = _("SERIOUS");
+static const u8 sJollyNatureName[] = _("JOLLY");
+static const u8 sNaiveNatureName[] = _("NAIVE");
+static const u8 sModestNatureName[] = _("MODEST");
+static const u8 sMildNatureName[] = _("MILD");
+static const u8 sQuietNatureName[] = _("QUIET");
+static const u8 sBashfulNatureName[] = _("BASHFUL");
+static const u8 sRashNatureName[] = _("RASH");
+static const u8 sCalmNatureName[] = _("CALM");
+static const u8 sGentleNatureName[] = _("GENTLE");
+static const u8 sSassyNatureName[] = _("SASSY");
+static const u8 sCarefulNatureName[] = _("CAREFUL");
+static const u8 sQuirkyNatureName[] = _("QUIRKY");
+
+const u8 *const gNatureNamePointers[] =
+{
+ [NATURE_HARDY] = sHardyNatureName,
+ [NATURE_LONELY] = sLonelyNatureName,
+ [NATURE_BRAVE] = sBraveNatureName,
+ [NATURE_ADAMANT] = sAdamantNatureName,
+ [NATURE_NAUGHTY] = sNaughtyNatureName,
+ [NATURE_BOLD] = sBoldNatureName,
+ [NATURE_DOCILE] = sDocileNatureName,
+ [NATURE_RELAXED] = sRelaxedNatureName,
+ [NATURE_IMPISH] = sImpishNatureName,
+ [NATURE_LAX] = sLaxNatureName,
+ [NATURE_TIMID] = sTimidNatureName,
+ [NATURE_HASTY] = sHastyNatureName,
+ [NATURE_SERIOUS] = sSeriousNatureName,
+ [NATURE_JOLLY] = sJollyNatureName,
+ [NATURE_NAIVE] = sNaiveNatureName,
+ [NATURE_MODEST] = sModestNatureName,
+ [NATURE_MILD] = sMildNatureName,
+ [NATURE_QUIET] = sQuietNatureName,
+ [NATURE_BASHFUL] = sBashfulNatureName,
+ [NATURE_RASH] = sRashNatureName,
+ [NATURE_CALM] = sCalmNatureName,
+ [NATURE_GENTLE] = sGentleNatureName,
+ [NATURE_SASSY] = sSassyNatureName,
+ [NATURE_CAREFUL] = sCarefulNatureName,
+ [NATURE_QUIRKY] = sQuirkyNatureName,
+};
diff --git a/src/pokemon_summary_screen.c b/src/pokemon_summary_screen.c
index 7e20a2a92..b5117d45d 100644
--- a/src/pokemon_summary_screen.c
+++ b/src/pokemon_summary_screen.c
@@ -1,364 +1,731 @@
#include "global.h"
+#include "main.h"
#include "battle.h"
+#include "battle_anim.h"
+#include "battle_frontier_2.h"
+#include "battle_message.h"
+#include "battle_tent.h"
#include "bg.h"
+#include "contest.h"
+#include "contest_effect.h"
+#include "data2.h"
+#include "daycare.h"
#include "decompress.h"
+#include "dynamic_placeholder_text_util.h"
+#include "event_data.h"
+#include "gpu_regs.h"
+#include "graphics.h"
+#include "international_string_util.h"
#include "item.h"
-#include "constants/items.h"
#include "link.h"
#include "m4a.h"
-#include "main.h"
#include "malloc.h"
-#include "constants/moves.h"
+#include "menu.h"
+#include "menu_helpers.h"
+#include "mon_markings.h"
+#include "party_menu.h"
#include "palette.h"
+#include "pokeball.h"
#include "pokemon.h"
-#include "constants/songs.h"
+#include "pokemon_storage_system.h"
+#include "region_map.h"
+#include "scanline_effect.h"
#include "sound.h"
-#include "constants/species.h"
#include "sprite.h"
-#include "dynamic_placeholder_text_util.h"
#include "string_util.h"
+#include "strings.h"
#include "task.h"
#include "text.h"
+#include "tv.h"
#include "window.h"
-#include "event_data.h"
-#include "gpu_regs.h"
-#include "menu.h"
-#include "international_string_util.h"
-#include "scanline_effect.h"
-#include "menu_helpers.h"
-#include "daycare.h"
-#include "data2.h"
-#include "contest.h"
-#include "contest_effect.h"
+#include "constants/items.h"
+#include "constants/moves.h"
+#include "constants/songs.h"
+#include "constants/species.h"
-extern struct UnkSummaryStruct* gUnknown_0203CF1C;
-extern struct BgTemplate gUnknown_0861CBB4;
-extern u8 gUnknown_0203CF20;
-extern struct MusicPlayerInfo gMPlayInfo_BGM;
-extern s8 gUnknown_0861CC1C[];
-extern u8 gUnknown_0203CF21;
-extern struct UnkStruct_61CC04 gUnknown_0861CC04;
-extern struct UnkStruct_61CC04 gUnknown_0861CC10;
-extern struct UnkStruct_61CC04 gUnknown_0861CBEC;
-extern struct UnkStruct_61CC04 gUnknown_0861CBF8;
-extern u16 gSummaryScreenWindow_Tilemap[];
-extern struct ContestEffect gContestEffects[];
-extern struct WindowTemplate gUnknown_0861CC24;
-extern u8 gUnknown_0861CD2C[][3];
-extern const u8 gSpeciesNames[][POKEMON_NAME_LENGTH + 1];
-extern u8 gText_MaleSymbol[];
-extern u8 gText_FemaleSymbol[];
-extern u8 gUnknown_0861CDD3[];
-extern void (*const gUnknown_0861CE54[])();
-extern void (*const gUnknown_0861CE64[])(u8 taskId);
-extern struct WindowTemplate gUnknown_0861CCCC;
-extern u8 gUnknown_0861CE74[];
-extern u8 gUnknown_0861CE7B[];
-extern struct WindowTemplate gUnknown_0861CCEC;
-extern struct WindowTemplate gUnknown_0861CD14;
-extern const u8 *const gContestEffectDescriptionPointers[];
+static EWRAM_DATA struct UnkSummaryStruct
+{
+ /*0x00*/ union
+ {
+ struct Pokemon *mons;
+ struct BoxPokemon *boxMons;
+ } monList;
+ /*0x04*/ void (*callback)(void);
+ /*0x08*/ struct Sprite *markingsSpriteId;
+ /*0x0C*/ struct Pokemon currentMon;
+ /*0x70*/ struct PokeSummary
+ {
+ u16 species; // 0x0
+ u16 species2; // 0x2
+ u8 isEgg; // 0x4
+ u8 level; // 0x5
+ u8 ribbons; // 0x6
+ u8 unk7; // 0x7
+ u8 altAbility; // 0x8
+ u8 metLocation; // 0x9
+ u8 metLevel; // 0xA
+ u8 metGame; // 0xB
+ u32 pid; // 0xC
+ u32 exp; // 0x10
+ u16 moves[4]; // 0x14
+ u8 pp[4]; // 0x1C
+ u16 currentHP; // 0x20
+ u16 maxHP; // 0x22
+ u16 atk; // 0x24
+ u16 def; // 0x26
+ u16 spatk; // 0x28
+ u16 spdef; // 0x2A
+ u16 speed; // 0x2C
+ u16 item; // 0x2E
+ u16 friendship; // 0x30
+ u8 OTGender; // 0x32
+ u8 nature; // 0x33
+ u8 ppBonuses; // 0x34
+ u8 sanity; // 0x35
+ u8 OTName[8]; // 0x36
+ u8 unk3E[9]; // 0x3E
+ u32 OTID; // 0x48
+ } summary;
+ u16 bgTilemapBuffer1[0x800];
+ u16 bgTilemapBuffer2[0x800];
+ u16 bgTilemapBuffer3[0x800];
+ u16 bgTilemapBuffer4[0x800];
+ u8 mode;
+ bool8 isBoxMon;
+ u8 curMonIndex;
+ u8 maxMonIndex;
+ u8 unk40C0;
+ u8 unk40C1;
+ u8 unk40C2;
+ bool8 unk40C3;
+ u16 newMove;
+ u8 firstMoveIndex;
+ u8 secondMoveIndex;
+ bool8 unk40C8;
+ u8 unk40C9;
+ u8 filler40CA;
+ u8 windowIds[8];
+ u8 spriteIds[28];
+ bool8 unk40EF;
+ s16 unk40F0;
+ u8 unk_filler4[6];
+} *gUnknown_0203CF1C = NULL;
+EWRAM_DATA u8 gUnknown_0203CF20 = 0;
+static EWRAM_DATA u8 gUnknown_0203CF21 = 0;
+static EWRAM_DATA u8 gFiller_0203CF22[2] = {0};
+static EWRAM_DATA u8 sUnusedTaskId = 0;
+static EWRAM_DATA u8 gFiller_0203CF25[3] = {0};
-void sub_81C488C(u8 a);
-extern u8 sub_81221EC();
-extern u8 sub_81221AC();
-extern u8 gUnknown_08D9862C;
-extern u8 gUnknown_08D98CC8;
-extern u8 gUnknown_08D987FC;
-extern u8 gUnknown_08D9898C;
-extern u8 gUnknown_08D98B28;
-extern u8 gUnknown_08D9853C;
-extern u8 gUnknown_08D85620;
-extern struct CompressedSpriteSheet gUnknown_0861CFBC;
-extern struct CompressedSpriteSheet gUnknown_0861D074;
-extern struct CompressedSpriteSheet gUnknown_0861D0F8;
-extern struct CompressedSpritePalette gUnknown_0861D100;
-extern struct CompressedSpritePalette gUnknown_0861D07C;
-extern u8 gMoveTypes_Pal;
-extern u8 gUnknown_08D97D0C;
-extern void sub_81C1E20(u8 taskId);
-extern u8 *GetMonNickname(struct Pokemon *mon, u8 *dest);
-extern u16 SpeciesToPokedexNum(u16 species);
-extern u8 gText_UnkCtrlF908Clear01[];
-extern u8 gText_LevelSymbol[];
-extern u8 gText_PkmnInfo[];
-extern u8 gText_PkmnSkills[];
-extern u8 gText_BattleMoves[];
-extern u8 gText_ContestMoves[];
-extern u8 gText_HMMovesCantBeForgotten2[];
-extern u8 gText_Cancel2[];
-extern u8 gText_Info[];
-extern u8 gText_Switch[];
-extern u8 gText_RentalPkmn[];
-extern u8 gText_TypeSlash[];
-extern u8 gText_HP4[];
-extern u8 gText_Attack3[];
-extern u8 gText_Defense3[];
-extern u8 gText_SpAtk4[];
-extern u8 gText_SpDef4[];
-extern u8 gText_Speed2[];
-extern u8 gText_ExpPoints[];
-extern u8 gText_NextLv[];
-extern u8 gText_Status[];
-extern u8 gText_Power[];
-extern u8 gText_Accuracy2[];
-extern u8 gText_Appeal[];
-extern u8 gText_Jam[];
-extern u8 gText_OTSlash[];
-extern u8 gText_UnkCtrlF907F908[];
-extern u8 gText_XNature[];
-extern u8 gText_XNatureHatchedAtYZ[];
-extern u8 gText_XNatureHatchedSomewhereAt[];
-extern u8 gText_XNatureMetAtYZ[];
-extern u8 gText_XNatureMetSomewhereAt[];
-extern u8 gText_XNatureFatefulEncounter[];
-extern u8 gText_XNatureProbablyMetAt[];
-extern u8 gText_XNatureObtainedInTrade[];
-extern u8 *gNatureNamePointers[];
-extern u8 gText_EmptyString5[];
-extern u32 gBattleTypeFlags;
-extern u8 gText_FiveMarks[];
-extern u8 gText_EggWillTakeALongTime[];
-extern u8 gText_EggAboutToHatch[];
-extern u8 gText_EggWillHatchSoon[];
-extern u8 gText_EggWillTakeSomeTime[];
-extern u8 gText_PeculiarEggNicePlace[];
-extern u8 gText_PeculiarEggTrade[];
-extern u8 gText_EggFromTraveler[];
-extern u8 gText_EggFromHotSprings[];
-extern u8 gText_OddEggFoundByCouple[];
-extern u8 gText_None[];
-extern u8 gText_RibbonsVar1[];
-extern u8 gUnknown_0861CE82[];
-extern u8 gUnknown_0861CE8E[];
-extern u8 gText_OneDash[];
-extern u8 gText_TwoDashes[];
-extern u8 gText_ThreeDashes[];
-extern u8 gText_Cancel[];
-extern u8 gUnknown_0861CE97[];
-extern const struct SpriteTemplate gUnknown_0861CFC4;
-
-extern void sub_8199C30(u8 a, u8 b, u8 c, u8 d, u8 e, u8 f);
-extern bool8 sub_81A6BF4();
-extern bool8 sub_81B9E94();
-extern void DynamicPlaceholderTextUtil_Reset();
-extern void sub_8124610(u8 *a, u8 b);
-extern int GetPlayerIDAsU32();
-extern u8 GetCurrentPpToMaxPpState(u8 a, u8 b);
+extern const struct CompressedSpriteSheet gMonFrontPicTable[];
+
+struct UnkStruct_61CC04
+{
+ const u16 *ptr;
+ u16 field_4;
+ u8 field_6;
+ u8 field_7;
+ u8 field_8;
+ u8 field_9;
+};
+// forward declarations
+bool8 sub_81B1250(void);
+bool8 sub_81BFB10(void);
void sub_81BFAE4(void);
-void sub_81BFE24();
-u8 sub_81BFEB0();
-void sub_81C2554();
-void sub_81C1BA0();
+void sub_81BFE24(void);
+u8 sub_81BFEB0(void);
void sub_81C0098(struct Pokemon* a);
bool8 sub_81C00F0(struct Pokemon* a);
-void sub_81C25E8();
-void sub_81C286C();
-void sub_81C2D9C(u8 a);
-void sub_81C0348();
-void sub_81C2AFC(u8 a);
-void sub_81C4190();
-void sub_81C42C8();
-u8 sub_81C45F4(void* a, u16* b);
-void sub_81C4984();
-void sub_81C4A08();
-void sub_81C4A88();
-void sub_81C4280();
-void sub_81C43A0();
-void sub_81C4484();
-void sub_81C4420();
-void sub_81C0510(u8 taskId);
-void sub_81C171C(u8 taskId);
-void ResetAllBgsCoordinates();
-u8 sub_81B205C(struct Pokemon* a);
-void sub_81C1DA4(u16 a, s16 b);
-void sub_81C1EFC(u16 a, s16 b, u16 c);
-void sub_81C240C(u16 a);
-void sub_81C2194(u16 *a, u16 b, u8 c);
-void sub_81C2074(u16 a, s16 b);
-void sub_81C2524();
-void sub_81C2228(struct Pokemon* mon);
+void sub_81C0348(void);
void sub_81C0484(u8 taskId);
-void sub_81C4898();
-void sub_806F47C(u8 a);
-u8 GetLRKeysState();
+void sub_81C0510(u8 taskId);
void sub_81C0604(u8 taskId, s8 a);
-void sub_81C0A8C(u8 taskId, s8 a);
-void sub_81C48F0();
-void sub_81C0E48(u8 taskId);
void sub_81C0704(u8 taskId);
-s8 sub_81C09B4(s8 a);
s8 sub_81C08F8(s8 a);
-void sub_81C4204(u8 a, u8 b);
-void sub_81C20F0(u8 taskId);
+s8 sub_81C09B4(s8 a);
bool8 sub_81C0A50(struct Pokemon* mon);
-void sub_81C49E0();
-void sub_81C0E24();
-void sub_81C2C38(u8 a);
+void sub_81C0A8C(u8 taskId, s8 a);
void sub_81C0B8C(u8 taskId);
-void sub_81C0CC4(u8 taskId);
-void sub_81C2DE4(u8 a);
-void sub_81C424C();
void sub_81C0C68(u8 taskId);
+void sub_81C0CC4(u8 taskId);
void sub_81C0D44(u8 taskId);
-void sub_81C22CC(struct Pokemon* mon);
+void sub_81C0E24(void);
+void sub_81C0E48(u8 taskId);
void sub_81C0F44(u8 taskId);
-void sub_81C3E9C(u16 a);
-void sub_81C3F44();
-void sub_81C44F0();
-void sub_81C4AF8(u8 a);
+bool8 sub_81C1040(void);
void sub_81C1070(s16* a, s8 b, u8* c);
void sub_81C11F4(u8 a);
void sub_81C129C(u8 a);
-bool8 sub_81C1040();
-void sub_81C4064();
-void sub_81C4C60(u8 a);
void sub_81C12E4(u8 taskId);
-void sub_81C4C84(u8 a);
void sub_81C13B0(u8 a, u8 b);
void sub_81C14BC(struct Pokemon *mon, u8 a, u8 b);
void sub_81C15EC(struct BoxPokemon *mon, u8 a, u8 b);
-void sub_81C40A0(u8 a, u8 b);
-void sub_81C4568(u8 a, u8 b);
+void sub_81C171C(u8 taskId);
void sub_81C174C(u8 taskId);
-bool8 sub_81C18A8();
+bool8 sub_81C18A8(void);
void sub_81C18F4(u8 a);
-u8 sub_81B6D14(u16 a);
void sub_81C1940(u8 taskId);
-void sub_81C4154();
+void sub_81C1BA0(void);
+void sub_81C1DA4(u16 a, s16 b);
+void sub_81C1E20(u8 taskId);
+void sub_81C1EFC(u16 a, s16 b, u16 c);
void sub_81C1F80(u8 taskId);
-void sub_81C2628();
-void sub_81C2794();
+void sub_81C2074(u16 a, s16 b);
+void sub_81C20F0(u8 taskId);
+void sub_81C2194(u16 *a, u16 b, u8 c);
+void sub_81C2228(struct Pokemon* mon);
+void sub_81C22CC(struct Pokemon* mon);
+void sub_81C240C(u16 a);
+void sub_81C2524(void);
+void sub_81C2554(void);
+void sub_81C25E8(void);
+void sub_81C2628(void);
+void sub_81C2794(void);
void sub_81C27DC(struct Pokemon *mon, u16 a);
+void sub_81C286C(void);
+void sub_81C2AFC(u8 a);
+void sub_81C2C38(u8 a);
void sub_81C2D68(u8 a);
-void sub_81C335C();
-void sub_81C33CC();
-void sub_81C3428();
-void sub_81C349C();
-void sub_81C2EC4();
-void sub_81C2F5C();
-void sub_81C2FD8();
-void sub_81C302C();
-void sub_81C307C();
-void sub_81C3194();
-void sub_81C31C0();
-bool8 sub_81C3304();
+void sub_81C2D9C(u8 a);
+void sub_81C2DE4(u8 a);
+void sub_81C2E00(void);
+void sub_81C2E40(u8 taskId);
+void sub_81C2EC4(void);
+void sub_81C2F5C(void);
+void sub_81C2FD8(void);
+void sub_81C302C(void);
+void sub_81C307C(void);
+void sub_81C3194(void);
+void sub_81C31C0(void);
void sub_81C31F0(u8 *a);
-u8 sub_81C3220();
-bool8 sub_81C32BC();
-void sub_81C35E4();
-void sub_81C3690();
-void sub_81C3710();
-void sub_81C37D8();
-void sub_81C3808();
-void sub_81C3890();
-void sub_81C38C0();
+u8 sub_81C3220(void);
+bool8 sub_81C32BC(void);
+bool8 sub_81C3304(void);
+void sub_81C335C(void);
+void sub_81C33CC(void);
+void sub_81C3428(void);
+void sub_81C349C(void);
+void sub_81C3554(u8 taskId);
+void sub_81C35E4(void);
+void sub_81C3530(void);
+void sub_81C3690(void);
+void sub_81C3710(void);
+void sub_81C37D8(void);
+void sub_81C3808(void);
+void sub_81C3890(void);
+void sub_81C38C0(void);
+void sub_81C3984(void);
+void sub_81C39F0(u8 taskId);
void sub_81C3B08(u8 a);
+void sub_81C3D08(void);
+void sub_81C3D54(u8 taskId);
void sub_81C3E2C(u8 a);
-void sub_81C4D18();
-
-void SetBgAttribute(u8 bg, u8 attributeId, u8 value);
-
-bool8 sub_81BFB10();
-u8 sub_81B1250();
-
-union UnkUnion
-{
- struct Pokemon mon[6];
- struct BoxPokemon boxMon[6];
-};
-
-
-u8 sub_80D214C(union UnkUnion* a, u8 b, u8 c, u8 d);
-
-struct PokeSummary
-{
- u16 species; // 0x0
- u16 species2; // 0x2
- u8 isEgg; // 0x4
- u8 level; // 0x5
- u8 ribbons; // 0x6
- u8 unk7; // 0x7
- u8 altAbility; // 0x8
- u8 metLocation; // 0x9
- u8 metLevel; // 0xA
- u8 metGame; // 0xB
- u32 pid; // 0xC
- u32 exp; // 0x10
- u16 moves[4]; // 0x14
- u8 pp[4]; // 0x1C
- u16 currentHP; // 0x20
- u16 maxHP; // 0x22
- u16 atk; // 0x24
- u16 def; // 0x26
- u16 spatk; // 0x28
- u16 spdef; // 0x2A
- u16 speed; // 0x2C
- u16 item; // 0x2E
- u16 friendship; // 0x30
- u8 OTGender; // 0x32
- u8 nature; // 0x33
- u8 ppBonuses; // 0x34
- u8 sanity; // 0x35
- u8 OTName[8]; // 0x36
- u8 unk3E[9]; // 0x3E
- u32 OTID; // 0x48
-};
-
-struct UnkSummaryStruct
-{
- /*0x00*/ union UnkUnion *unk0;
- /*0x04*/ void *unk4;
- /*0x08*/ void *unk8;
- /*0x0C*/ struct Pokemon currentMon;
- /*0x70*/ struct PokeSummary summary;
- u16 unkTilemap0[0x400];
- u16 unkTilemap0_1[0x400];
- u16 unkTilemap1[0x400];
- u16 unkTilemap1_1[0x400];
- u16 unkTilemap2[0x400];
- u16 unkTilemap2_1[0x400];
- u16 unkTilemap3[0x400];
- u16 unkTilemap3_1[0x400];
- u8 unk40BC;
- u8 unk40BD;
- u8 unk40BE;
- u8 unk40BF;
- u8 unk40C0;
- u8 unk40C1;
- u8 unk40C2;
- u8 unk40C3;
- u16 unk40C4;
- u8 unk40C6;
- u8 unk40C7;
- u8 unk40C8;
- u8 unk40C9;
- u8 unk40CA;
- u8 unk40CB[8];
- u8 unk40D3[0x1C];
- u8 unk40EF;
- s16 unk40F0;
- u8 unk_filler4[6];
-};
+void sub_81C3E9C(u16 a);
+void sub_81C3F44(void);
+void sub_81C4064(void);
+void sub_81C40A0(u8 a, u8 b);
+void sub_81C4154(void);
+void sub_81C4190(void);
+void sub_81C4204(u8 a, u8 b);
+void sub_81C424C(void);
+void sub_81C4280(void);
+void sub_81C42C8(void);
+void sub_81C43A0(void);
+void sub_81C4420(void);
+void sub_81C4484(void);
+void sub_81C44F0(void);
+void sub_81C4568(u8 a, u8 b);
+u8 sub_81C45F4(struct Pokemon *a, s16 *b);
+u8 sub_81C47B4(struct Pokemon *unused);
+void sub_81C4844(struct Sprite *);
+void sub_81C488C(u8 a);
+void sub_81C4898(void);
+void sub_81C48F0(void);
+void sub_81C4984(struct Pokemon *mon);
+void sub_81C49E0(struct Pokemon *mon);
+void sub_81C4A08(struct Pokemon *mon);
+void sub_81C4A88(void);
+void sub_81C4AF8(u8 a);
+void sub_81C4BE4(struct Sprite *sprite);
+void sub_81C4C60(u8 a);
+void sub_81C4C84(u8 a);
+void sub_81C4D18(u8 a);
// const rom data
#include "data/text/move_descriptions.h"
+#include "data/text/nature_names.h"
+
+static const struct BgTemplate gUnknown_0861CBB4[] =
+{
+ {
+ .bg = 0,
+ .charBaseIndex = 0,
+ .mapBaseIndex = 31,
+ .screenSize = 0,
+ .paletteMode = 0,
+ .priority = 0,
+ .baseTile = 0,
+ },
+ {
+ .bg = 1,
+ .charBaseIndex = 2,
+ .mapBaseIndex = 27,
+ .screenSize = 1,
+ .paletteMode = 0,
+ .priority = 1,
+ .baseTile = 0,
+ },
+ {
+ .bg = 2,
+ .charBaseIndex = 2,
+ .mapBaseIndex = 25,
+ .screenSize = 1,
+ .paletteMode = 0,
+ .priority = 2,
+ .baseTile = 0,
+ },
+ {
+ .bg = 3,
+ .charBaseIndex = 2,
+ .mapBaseIndex = 29,
+ .screenSize = 1,
+ .paletteMode = 0,
+ .priority = 3,
+ .baseTile = 0,
+ },
+};
+
+static const u16 gUnknown_0861CBC4[] = INCBIN_U16("graphics/interface/unk_tilemap2.bin");
+static const struct UnkStruct_61CC04 gUnknown_0861CBEC =
+{
+ gUnknown_0861CBC4, 1, 10, 2, 0, 18
+};
+static const struct UnkStruct_61CC04 gUnknown_0861CBF8 =
+{
+ gUnknown_0861CBC4, 1, 10, 2, 0, 50
+};
+static const struct UnkStruct_61CC04 gUnknown_0861CC04 =
+{
+ gSummaryScreenPowAcc_Tilemap, 0, 10, 7, 0, 45
+};
+static const struct UnkStruct_61CC04 gUnknown_0861CC10 =
+{
+ gUnknown_08DC3C34, 0, 10, 7, 0, 45
+};
+static const s8 gUnknown_0861CC1C[] = {0, 2, 3, 1, 4, 5};
+static const struct WindowTemplate gUnknown_0861CC24[] =
+{
+ { 0x00, 0x00, 0x00, 0x0b, 0x02, 0x06, 0x0001 },
+ { 0x00, 0x00, 0x00, 0x0b, 0x02, 0x06, 0x0017 },
+ { 0x00, 0x00, 0x00, 0x0b, 0x02, 0x06, 0x002d },
+ { 0x00, 0x00, 0x00, 0x0b, 0x02, 0x06, 0x0043 },
+ { 0x00, 0x16, 0x00, 0x08, 0x02, 0x07, 0x0059 },
+ { 0x00, 0x16, 0x00, 0x08, 0x02, 0x07, 0x0069 },
+ { 0x00, 0x16, 0x00, 0x08, 0x02, 0x07, 0x0079 },
+ { 0x00, 0x0b, 0x04, 0x00, 0x02, 0x06, 0x0089 },
+ { 0x00, 0x0b, 0x04, 0x12, 0x02, 0x06, 0x0089 },
+ { 0x00, 0x0b, 0x06, 0x12, 0x02, 0x06, 0x00ad },
+ { 0x00, 0x0a, 0x07, 0x06, 0x06, 0x06, 0x00d1 },
+ { 0x00, 0x16, 0x07, 0x05, 0x06, 0x06, 0x00f5 },
+ { 0x00, 0x0a, 0x0e, 0x0b, 0x04, 0x06, 0x0113 },
+ { 0x00, 0x00, 0x12, 0x06, 0x02, 0x06, 0x013f },
+ { 0x00, 0x01, 0x0f, 0x09, 0x04, 0x06, 0x014b },
+ { 0x00, 0x01, 0x0f, 0x05, 0x04, 0x06, 0x016f },
+ { 0x00, 0x16, 0x04, 0x00, 0x02, 0x06, 0x0183 },
+ { 0x00, 0x01, 0x02, 0x04, 0x02, 0x07, 0x0183 },
+ { 0x00, 0x01, 0x0c, 0x09, 0x02, 0x06, 0x018b },
+ { 0x00, 0x01, 0x0e, 0x09, 0x04, 0x06, 0x019d },
+ DUMMY_WIN_TEMPLATE
+};
+static const struct WindowTemplate gUnknown_0861CCCC[] =
+{
+ { 0x00, 0x0b, 0x04, 0x0b, 0x02, 0x06, 0x01c1 },
+ { 0x00, 0x16, 0x04, 0x07, 0x02, 0x06, 0x01d7 },
+ { 0x00, 0x0b, 0x09, 0x12, 0x04, 0x06, 0x01e5 },
+ { 0x00, 0x0b, 0x0e, 0x12, 0x06, 0x06, 0x022d },
+};
+static const struct WindowTemplate gUnknown_0861CCEC[] =
+{
+ { 0x00, 0x0a, 0x04, 0x0a, 0x02, 0x06, 0x01c1 },
+ { 0x00, 0x14, 0x04, 0x0a, 0x02, 0x06, 0x01d5 },
+ { 0x00, 0x10, 0x07, 0x06, 0x06, 0x06, 0x01e9 },
+ { 0x00, 0x1b, 0x07, 0x03, 0x06, 0x06, 0x020d },
+ { 0x00, 0x18, 0x0e, 0x06, 0x04, 0x06, 0x021f },
+};
+static const struct WindowTemplate gUnknown_0861CD14[] =
+{
+ { 0x00, 0x0f, 0x04, 0x09, 0x0a, 0x06, 0x01c1 },
+ { 0x00, 0x18, 0x04, 0x06, 0x0a, 0x08, 0x021b },
+ { 0x00, 0x0a, 0x0f, 0x14, 0x04, 0x06, 0x0257 },
+};
+static const u8 sTextColors_861CD2C[][3] =
+{
+ {0, 1, 2},
+ {0, 3, 4},
+ {0, 5, 6},
+ {0, 7, 8},
+ {0, 9, 10},
+ {0, 11, 12},
+ {0, 13, 14},
+ {0, 7, 8},
+ {13, 15, 14},
+ {0, 1, 2},
+ {0, 3, 4},
+ {0, 5, 6},
+ {0, 7, 8}
+};
+static const u8 gUnknown_0861CD53[] = INCBIN_U8("graphics/interface/summary_a_button.4bpp");
+static const u8 gUnknown_0861CDD3[] = INCBIN_U8("graphics/interface/summary_b_button.4bpp");
+static void (*const gUnknown_0861CE54[])(void) =
+{
+ sub_81C2E00,
+ sub_81C3530,
+ sub_81C3984,
+ sub_81C3D08
+};
+static void (*const gUnknown_0861CE64[])(u8 taskId) =
+{
+ sub_81C2E40,
+ sub_81C3554,
+ sub_81C39F0,
+ sub_81C3D54
+};
+static const u8 gUnknown_0861CE74[] = _("{COLOR LIGHT_RED}{SHADOW GREEN}");
+static const u8 gUnknown_0861CE7B[] = _("{COLOR WHITE}{SHADOW DARK_GREY}");
+static const u8 gUnknown_0861CE82[] = _("{SPECIAL_F7 0x00}/{SPECIAL_F7 0x01}\n{SPECIAL_F7 0x02}\n{SPECIAL_F7 0x03}");
+static const u8 gUnknown_0861CE8E[] = _("{SPECIAL_F7 0x00}\n{SPECIAL_F7 0x01}\n{SPECIAL_F7 0x02}");
+static const u8 gUnknown_0861CE97[] = _("{PP}{SPECIAL_F7 0x00}/{SPECIAL_F7 0x01}");
+static const struct OamData gOamData_861CEA0 =
+{
+ .y = 0,
+ .affineMode = 0,
+ .objMode = 0,
+ .mosaic = 0,
+ .bpp = 0,
+ .shape = 1,
+ .x = 0,
+ .matrixNum = 0,
+ .size = 2,
+ .tileNum = 0,
+ .priority = 1,
+ .paletteNum = 0,
+ .affineParam = 0,
+};
+static const union AnimCmd gSpriteAnim_861CEA8[] = {
+ ANIMCMD_FRAME(0, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861CEB0[] = {
+ ANIMCMD_FRAME(8, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861CEB8[] = {
+ ANIMCMD_FRAME(16, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861CEC0[] = {
+ ANIMCMD_FRAME(24, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861CEC8[] = {
+ ANIMCMD_FRAME(32, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861CED0[] = {
+ ANIMCMD_FRAME(40, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861CED8[] = {
+ ANIMCMD_FRAME(48, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861CEE0[] = {
+ ANIMCMD_FRAME(56, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861CEE8[] = {
+ ANIMCMD_FRAME(64, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861CEF0[] = {
+ ANIMCMD_FRAME(72, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861CEF8[] = {
+ ANIMCMD_FRAME(80, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861CF00[] = {
+ ANIMCMD_FRAME(88, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861CF08[] = {
+ ANIMCMD_FRAME(96, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861CF10[] = {
+ ANIMCMD_FRAME(104, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861CF18[] = {
+ ANIMCMD_FRAME(112, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861CF20[] = {
+ ANIMCMD_FRAME(120, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861CF28[] = {
+ ANIMCMD_FRAME(128, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861CF30[] = {
+ ANIMCMD_FRAME(136, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861CF38[] = {
+ ANIMCMD_FRAME(144, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861CF40[] = {
+ ANIMCMD_FRAME(152, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861CF48[] = {
+ ANIMCMD_FRAME(160, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861CF50[] = {
+ ANIMCMD_FRAME(168, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861CF58[] = {
+ ANIMCMD_FRAME(176, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd *const gSpriteAnimTable_861CF60[] = {
+ gSpriteAnim_861CEA8,
+ gSpriteAnim_861CEB0,
+ gSpriteAnim_861CEB8,
+ gSpriteAnim_861CEC0,
+ gSpriteAnim_861CEC8,
+ gSpriteAnim_861CED0,
+ gSpriteAnim_861CED8,
+ gSpriteAnim_861CEE0,
+ gSpriteAnim_861CEE8,
+ gSpriteAnim_861CEF0,
+ gSpriteAnim_861CEF8,
+ gSpriteAnim_861CF00,
+ gSpriteAnim_861CF08,
+ gSpriteAnim_861CF10,
+ gSpriteAnim_861CF18,
+ gSpriteAnim_861CF20,
+ gSpriteAnim_861CF28,
+ gSpriteAnim_861CF30,
+ gSpriteAnim_861CF38,
+ gSpriteAnim_861CF40,
+ gSpriteAnim_861CF48,
+ gSpriteAnim_861CF50,
+ gSpriteAnim_861CF58,
+};
+static const struct CompressedSpriteSheet gUnknown_0861CFBC =
+{
+ .data = gMoveTypes_Gfx,
+ .size = 0x1700,
+ .tag = 30002
+};
+static const struct SpriteTemplate gUnknown_0861CFC4 =
+{
+ .tileTag = 30002,
+ .paletteTag = 30002,
+ .oam = &gOamData_861CEA0,
+ .anims = gSpriteAnimTable_861CF60,
+ .images = NULL,
+ .affineAnims = gDummySpriteAffineAnimTable,
+ .callback = SpriteCallbackDummy
+};
+static const u8 gUnknown_0861CFDC[] = {13, 13, 14, 14, 13, 13, 15, 14, 13, 15, 13, 14, 15, 13, 14, 14, 15, 13, 13, 14, 14, 15, 13};
+static const struct OamData gOamData_861CFF4 =
+{
+ .y = 0,
+ .affineMode = 0,
+ .objMode = 0,
+ .mosaic = 0,
+ .bpp = 0,
+ .shape = 0,
+ .x = 0,
+ .matrixNum = 0,
+ .size = 1,
+ .tileNum = 0,
+ .priority = 1,
+ .paletteNum = 0,
+ .affineParam = 0,
+};
+static const union AnimCmd gSpriteAnim_861CFFC[] = {
+ ANIMCMD_FRAME(0, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861D004[] = {
+ ANIMCMD_FRAME(4, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861D00C[] = {
+ ANIMCMD_FRAME(8, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861D014[] = {
+ ANIMCMD_FRAME(12, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861D01C[] = {
+ ANIMCMD_FRAME(16, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861D024[] = {
+ ANIMCMD_FRAME(16, 0, TRUE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861D02C[] = {
+ ANIMCMD_FRAME(20, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861D034[] = {
+ ANIMCMD_FRAME(24, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861D03C[] = {
+ ANIMCMD_FRAME(24, 0, TRUE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861D044[] = {
+ ANIMCMD_FRAME(28, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd *const gSpriteAnimTable_861D04C[] = {
+ gSpriteAnim_861CFFC,
+ gSpriteAnim_861D004,
+ gSpriteAnim_861D00C,
+ gSpriteAnim_861D014,
+ gSpriteAnim_861D01C,
+ gSpriteAnim_861D024,
+ gSpriteAnim_861D02C,
+ gSpriteAnim_861D034,
+ gSpriteAnim_861D03C,
+ gSpriteAnim_861D044,
+};
+static const struct CompressedSpriteSheet gUnknown_0861D074 =
+{
+ .data = gUnknown_08D97BEC,
+ .size = 0x400,
+ .tag = 30000
+};
+static const struct CompressedSpritePalette gUnknown_0861D07C =
+{
+ .data = gUnknown_08D97CF4,
+ .tag = 30000
+};
+static const struct SpriteTemplate gUnknown_0861D084 =
+{
+ .tileTag = 30000,
+ .paletteTag = 30000,
+ .oam = &gOamData_861CFF4,
+ .anims = gSpriteAnimTable_861D04C,
+ .images = NULL,
+ .affineAnims = gDummySpriteAffineAnimTable,
+ .callback = SpriteCallbackDummy
+};
+ const struct OamData gOamData_861D09C =
+{
+ .y = 0,
+ .affineMode = 0,
+ .objMode = 0,
+ .mosaic = 0,
+ .bpp = 0,
+ .shape = 1,
+ .x = 0,
+ .matrixNum = 0,
+ .size = 1,
+ .tileNum = 0,
+ .priority = 3,
+ .paletteNum = 0,
+ .affineParam = 0,
+};
+static const union AnimCmd gSpriteAnim_861D0A4[] = {
+ ANIMCMD_FRAME(0, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861D0AC[] = {
+ ANIMCMD_FRAME(4, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861D0B4[] = {
+ ANIMCMD_FRAME(8, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861D0BC[] = {
+ ANIMCMD_FRAME(12, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861D0C4[] = {
+ ANIMCMD_FRAME(16, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861D0CC[] = {
+ ANIMCMD_FRAME(20, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+static const union AnimCmd gSpriteAnim_861D0D4[] = {
+ ANIMCMD_FRAME(24, 0, FALSE, FALSE),
+ ANIMCMD_END
+};
+ const union AnimCmd *const gSpriteAnimTable_861D0DC[] = {
+ gSpriteAnim_861D0A4,
+ gSpriteAnim_861D0AC,
+ gSpriteAnim_861D0B4,
+ gSpriteAnim_861D0BC,
+ gSpriteAnim_861D0C4,
+ gSpriteAnim_861D0CC,
+ gSpriteAnim_861D0D4,
+};
+static const struct CompressedSpriteSheet gUnknown_0861D0F8 =
+{
+ .data = gStatusGfx_Icons,
+ .size = 0x380,
+ .tag = 30001
+};
+static const struct CompressedSpritePalette gUnknown_0861D100 =
+{
+ .data = gStatusPal_Icons,
+ .tag = 30001
+};
+static const struct SpriteTemplate gUnknown_0861D108 =
+{
+ .tileTag = 30001,
+ .paletteTag = 30001,
+ .oam = &gOamData_861D09C,
+ .anims = gSpriteAnimTable_861D0DC,
+ .images = NULL,
+ .affineAnims = gDummySpriteAffineAnimTable,
+ .callback = SpriteCallbackDummy
+};
+static const u16 gUnknown_0861D120[] = INCBIN_U16("graphics/interface/summary_markings.gbapal");
// code
-void sub_81BF8EC(u8 a, void *b, u8 c, u8 d, void *e)
-{
- u8 byte;
- gUnknown_0203CF1C = AllocZeroed(sizeof(struct UnkSummaryStruct));
- gUnknown_0203CF1C->unk40BC = a;
- gUnknown_0203CF1C->unk0 = b;
- gUnknown_0203CF1C->unk40BE = c;
- gUnknown_0203CF1C->unk40BF = d;
- gUnknown_0203CF1C->unk4 = e;
- if (a == 2)
- gUnknown_0203CF1C->unk40BD = 1;
+void sub_81BF8EC(u8 mode, void *mons, u8 monIndex, u8 maxMonIndex, void (*callback)(void))
+{
+ gUnknown_0203CF1C = AllocZeroed(sizeof(*gUnknown_0203CF1C));
+ gUnknown_0203CF1C->mode = mode;
+ gUnknown_0203CF1C->monList.mons = mons;
+ gUnknown_0203CF1C->curMonIndex = monIndex;
+ gUnknown_0203CF1C->maxMonIndex = maxMonIndex;
+ gUnknown_0203CF1C->callback = callback;
+
+ if (mode == 2)
+ gUnknown_0203CF1C->isBoxMon = TRUE;
else
- gUnknown_0203CF1C->unk40BD = 0;
- switch (a)
+ gUnknown_0203CF1C->isBoxMon = FALSE;
+
+ switch (mode)
{
case 0:
case 2:
@@ -368,32 +735,34 @@ void sub_81BF8EC(u8 a, void *b, u8 c, u8 d, void *e)
case 1:
gUnknown_0203CF1C->unk40C1 = 0;
gUnknown_0203CF1C->unk40C2 = 3;
- gUnknown_0203CF1C->unk40C8 = 1;
+ gUnknown_0203CF1C->unk40C8 = TRUE;
break;
case 3:
gUnknown_0203CF1C->unk40C1 = 2;
gUnknown_0203CF1C->unk40C2 = 3;
- gUnknown_0203CF1C->unk40C3 = 1;
+ gUnknown_0203CF1C->unk40C3 = TRUE;
break;
}
- byte = gUnknown_0203CF1C->unk40C1;
- gUnknown_0203CF1C->unk40C0 = byte;
- sub_81C488C(0xFF);
+
+ gUnknown_0203CF1C->unk40C0 = gUnknown_0203CF1C->unk40C1;
+ sub_81C488C(-1);
+
if (gMonSpritesGfxPtr == 0)
sub_806F2AC(0, 0);
+
SetMainCallback2(sub_81BFAE4);
}
-void ShowSelectMovePokemonSummaryScreen(void *a, u8 b, u8 c, void *d, u16 e)
+void ShowSelectMovePokemonSummaryScreen(struct Pokemon *mons, u8 monIndex, u8 maxMonIndex, void (*callback)(void), u16 newMove)
{
- sub_81BF8EC(3, a, b, c, d);
- gUnknown_0203CF1C->unk40C4 = e;
+ sub_81BF8EC(3, mons, monIndex, maxMonIndex, callback);
+ gUnknown_0203CF1C->newMove = newMove;
}
-void sub_81BFA80(u8 a, void *b, u8 c, u8 d, void *e)
+void sub_81BFA80(u8 a, struct BoxPokemon *mons, u8 monIndex, u8 maxMonIndex, void (*callback)(void))
{
- sub_81BF8EC(a, b, c, d, e);
- gUnknown_0203CF1C->unk40EF = 1;
+ sub_81BF8EC(a, mons, monIndex, maxMonIndex, callback);
+ gUnknown_0203CF1C->unk40EF = TRUE;
}
void sub_81BFAB4(void)
@@ -412,13 +781,9 @@ void sub_81BFAD0(void)
TransferPlttBuffer();
}
-void sub_81BFAE4()
+void sub_81BFAE4(void)
{
- while (1)
- {
- if (sub_81221EC() == 1 || sub_81BFB10() == TRUE || sub_81221AC() == 1)
- break;
- }
+ while (sub_81221EC() != TRUE && sub_81BFB10() != TRUE && sub_81221AC() != TRUE);
}
bool8 sub_81BFB10(void)
@@ -454,7 +819,7 @@ bool8 sub_81BFB10(void)
gMain.state++;
break;
case 6:
- if (sub_81BFEB0() != 0)
+ if (sub_81BFEB0() != FALSE)
gMain.state++;
break;
case 7:
@@ -501,8 +866,8 @@ bool8 sub_81BFB10(void)
gMain.state++;
break;
case 17:
- gUnknown_0203CF1C->unk40D3[0] = sub_81C45F4(&gUnknown_0203CF1C->currentMon, &gUnknown_0203CF1C->unk40F0);
- if (gUnknown_0203CF1C->unk40D3[0] != 0xFF)
+ gUnknown_0203CF1C->spriteIds[0] = sub_81C45F4(&gUnknown_0203CF1C->currentMon, &gUnknown_0203CF1C->unk40F0);
+ if (gUnknown_0203CF1C->spriteIds[0] != 0xFF)
{
gUnknown_0203CF1C->unk40F0 = 0;
gMain.state++;
@@ -525,7 +890,7 @@ bool8 sub_81BFB10(void)
gMain.state++;
break;
case 22:
- if (gUnknown_0203CF1C->unk40BC != 3)
+ if (gUnknown_0203CF1C->mode != 3)
CreateTask(sub_81C0510, 0);
else
CreateTask(sub_81C171C, 0);
@@ -548,13 +913,13 @@ bool8 sub_81BFB10(void)
return FALSE;
}
-void sub_81BFE24()
+void sub_81BFE24(void)
{
ResetBgsAndClearDma3BusyFlags(0);
- InitBgsFromTemplates(0, &gUnknown_0861CBB4, 4);
- SetBgTilemapBuffer(1, &gUnknown_0203CF1C->unkTilemap2);
- SetBgTilemapBuffer(2, &gUnknown_0203CF1C->unkTilemap1);
- SetBgTilemapBuffer(3, &gUnknown_0203CF1C->unkTilemap0);
+ InitBgsFromTemplates(0, gUnknown_0861CBB4, ARRAY_COUNT(gUnknown_0861CBB4));
+ SetBgTilemapBuffer(1, &gUnknown_0203CF1C->bgTilemapBuffer3);
+ SetBgTilemapBuffer(2, &gUnknown_0203CF1C->bgTilemapBuffer2);
+ SetBgTilemapBuffer(3, &gUnknown_0203CF1C->bgTilemapBuffer1);
ResetAllBgsCoordinates();
schedule_bg_copy_tilemap_to_vram(1);
schedule_bg_copy_tilemap_to_vram(2);
@@ -567,7 +932,7 @@ void sub_81BFE24()
ShowBg(3);
}
-u8 sub_81BFEB0()
+bool8 sub_81BFEB0(void)
{
switch (gUnknown_0203CF1C->unk40F0)
{
@@ -579,24 +944,24 @@ u8 sub_81BFEB0()
case 1:
if (free_temp_tile_data_buffers_if_possible() != 1)
{
- LZDecompressWram(&gUnknown_08D9862C, gUnknown_0203CF1C->unkTilemap0);
+ LZDecompressWram(&gUnknown_08D9862C, &gUnknown_0203CF1C->bgTilemapBuffer1[0]);
gUnknown_0203CF1C->unk40F0++;
}
break;
case 2:
- LZDecompressWram(&gUnknown_08D98CC8, gUnknown_0203CF1C->unkTilemap0_1);
+ LZDecompressWram(&gUnknown_08D98CC8, &gUnknown_0203CF1C->bgTilemapBuffer1[0x400]);
gUnknown_0203CF1C->unk40F0++;
break;
case 3:
- LZDecompressWram(&gUnknown_08D987FC, gUnknown_0203CF1C->unkTilemap1_1);
+ LZDecompressWram(&gUnknown_08D987FC, &gUnknown_0203CF1C->bgTilemapBuffer2[0x400]);
gUnknown_0203CF1C->unk40F0++;
break;
case 4:
- LZDecompressWram(&gUnknown_08D9898C, gUnknown_0203CF1C->unkTilemap2_1);
+ LZDecompressWram(&gUnknown_08D9898C, &gUnknown_0203CF1C->bgTilemapBuffer3[0x400]);
gUnknown_0203CF1C->unk40F0++;
break;
case 5:
- LZDecompressWram(&gUnknown_08D98B28, gUnknown_0203CF1C->unkTilemap3_1);
+ LZDecompressWram(&gUnknown_08D98B28, &gUnknown_0203CF1C->bgTilemapBuffer4[0x400]);
gUnknown_0203CF1C->unk40F0++;
break;
case 6:
@@ -627,22 +992,22 @@ u8 sub_81BFEB0()
case 12:
LoadCompressedPalette(&gMoveTypes_Pal, 0x1D0, 0x60);
gUnknown_0203CF1C->unk40F0 = 0;
- return 1;
+ return TRUE;
}
- return 0;
+ return FALSE;
}
void sub_81C0098(struct Pokemon *mon)
{
- if (gUnknown_0203CF1C->unk40BD == 0)
+ if (!gUnknown_0203CF1C->isBoxMon)
{
- struct Pokemon *partyMon = gUnknown_0203CF1C->unk0->mon;
- *mon = partyMon[gUnknown_0203CF1C->unk40BE];
+ struct Pokemon *partyMon = gUnknown_0203CF1C->monList.mons;
+ *mon = partyMon[gUnknown_0203CF1C->curMonIndex];
}
else
{
- struct BoxPokemon *boxMon = gUnknown_0203CF1C->unk0->boxMon;
- BoxMonToMon(&boxMon[gUnknown_0203CF1C->unk40BE], mon);
+ struct BoxPokemon *boxMon = gUnknown_0203CF1C->monList.boxMons;
+ BoxMonToMon(&boxMon[gUnknown_0203CF1C->curMonIndex], mon);
}
}
@@ -675,7 +1040,7 @@ bool8 sub_81C00F0(struct Pokemon *a)
sum->ppBonuses = GetMonData(a, MON_DATA_PP_BONUSES);
break;
case 2:
- if ((struct Pokemon*)gUnknown_0203CF1C->unk0 == gPlayerParty || gUnknown_0203CF1C->unk40BC == 2 || gUnknown_0203CF1C->unk40EF == 1)
+ if (gUnknown_0203CF1C->monList.mons == gPlayerParty || gUnknown_0203CF1C->mode == 2 || gUnknown_0203CF1C->unk40EF == TRUE)
{
sum->nature = GetNature(a);
sum->currentHP = GetMonData(a, MON_DATA_HP);
@@ -726,14 +1091,14 @@ void sub_81C0348(void)
}
else
{
- sub_81C240C(gUnknown_0203CF1C->summary.moves[gUnknown_0203CF1C->unk40C6]);
- sub_81C2194(&gUnknown_0203CF1C->unkTilemap2[0], 3, 0);
- sub_81C2194(&gUnknown_0203CF1C->unkTilemap3[0], 1, 0);
- SetBgTilemapBuffer(1, &gUnknown_0203CF1C->unkTilemap3);
- SetBgTilemapBuffer(2, &gUnknown_0203CF1C->unkTilemap2);
+ sub_81C240C(gUnknown_0203CF1C->summary.moves[gUnknown_0203CF1C->firstMoveIndex]);
+ sub_81C2194(&gUnknown_0203CF1C->bgTilemapBuffer3[0], 3, 0);
+ sub_81C2194(&gUnknown_0203CF1C->bgTilemapBuffer4[0], 1, 0);
+ SetBgTilemapBuffer(1, &gUnknown_0203CF1C->bgTilemapBuffer4);
+ SetBgTilemapBuffer(2, &gUnknown_0203CF1C->bgTilemapBuffer3);
ChangeBgX(2, 0x10000, 1);
- ClearWindowTilemap(0x13);
- ClearWindowTilemap(0xD);
+ ClearWindowTilemap(19);
+ ClearWindowTilemap(13);
}
if (gUnknown_0203CF1C->summary.unk7 == 0)
{
@@ -742,13 +1107,13 @@ void sub_81C0348(void)
else
{
if (gUnknown_0203CF1C->unk40C0 != 2 && gUnknown_0203CF1C->unk40C0 != 3)
- PutWindowTilemap(0xD);
+ PutWindowTilemap(13);
}
sub_81C2524();
sub_81C2228(&gUnknown_0203CF1C->currentMon);
}
-void sub_81C0434()
+void sub_81C0434(void)
{
FreeAllWindowBuffers();
Free(gUnknown_0203CF1C);
@@ -764,8 +1129,8 @@ void sub_81C0484(u8 taskId)
{
if (sub_81221EC() != 1 && !gPaletteFade.active)
{
- SetMainCallback2(gUnknown_0203CF1C->unk4);
- gUnknown_0203CF20 = gUnknown_0203CF1C->unk40BE;
+ SetMainCallback2(gUnknown_0203CF1C->callback);
+ gUnknown_0203CF20 = gUnknown_0203CF1C->curMonIndex;
sub_81C4898();
ResetSpriteData();
FreeAllSpritePalettes();
@@ -828,9 +1193,9 @@ void sub_81C0604(u8 taskId, s8 a)
{
s8 r4_2;
- if (gUnknown_0203CF1C->unk40C3 == 0)
+ if (!gUnknown_0203CF1C->unk40C3)
{
- if (gUnknown_0203CF1C->unk40BD == 1)
+ if (gUnknown_0203CF1C->isBoxMon == TRUE)
{
if (gUnknown_0203CF1C->unk40C0 != 0)
{
@@ -846,7 +1211,7 @@ void sub_81C0604(u8 taskId, s8 a)
else
a = 3;
}
- r4_2 = sub_80D214C(gUnknown_0203CF1C->unk0, gUnknown_0203CF1C->unk40BE, gUnknown_0203CF1C->unk40BF, a);
+ r4_2 = sub_80D214C(gUnknown_0203CF1C->monList.boxMons, gUnknown_0203CF1C->curMonIndex, gUnknown_0203CF1C->maxMonIndex, a);
}
else if (sub_81B1250() == 1)
{
@@ -867,7 +1232,7 @@ void sub_81C0604(u8 taskId, s8 a)
schedule_bg_copy_tilemap_to_vram(0);
sub_81C2074(0, 2);
}
- gUnknown_0203CF1C->unk40BE = r4_2;
+ gUnknown_0203CF1C->curMonIndex = r4_2;
gTasks[taskId].data[0] = 0;
gTasks[taskId].func = sub_81C0704;
}
@@ -885,10 +1250,10 @@ void sub_81C0704(u8 taskId)
break;
case 1:
sub_81C4898();
- DestroySpriteAndFreeResources(&gSprites[gUnknown_0203CF1C->unk40D3[0]]);
+ DestroySpriteAndFreeResources(&gSprites[gUnknown_0203CF1C->spriteIds[0]]);
break;
case 2:
- DestroySpriteAndFreeResources(&gSprites[gUnknown_0203CF1C->unk40D3[1]]);
+ DestroySpriteAndFreeResources(&gSprites[gUnknown_0203CF1C->spriteIds[1]]);
break;
case 3:
sub_81C0098(&gUnknown_0203CF1C->currentMon);
@@ -911,10 +1276,10 @@ void sub_81C0704(u8 taskId)
data[1] = 0;
break;
case 8:
- gUnknown_0203CF1C->unk40D3[0] = sub_81C45F4(&gUnknown_0203CF1C->currentMon, &data[1]);
- if (gUnknown_0203CF1C->unk40D3[0] == 0xFF)
+ gUnknown_0203CF1C->spriteIds[0] = sub_81C45F4(&gUnknown_0203CF1C->currentMon, &data[1]);
+ if (gUnknown_0203CF1C->spriteIds[0] == 0xFF)
return;
- gSprites[gUnknown_0203CF1C->unk40D3[0]].data[2] = 1;
+ gSprites[gUnknown_0203CF1C->spriteIds[0]].data[2] = 1;
sub_81C0E24();
data[1] = 0;
break;
@@ -929,7 +1294,7 @@ void sub_81C0704(u8 taskId)
sub_81C2524();
break;
case 12:
- gSprites[gUnknown_0203CF1C->unk40D3[0]].data[2] = 0;
+ gSprites[gUnknown_0203CF1C->spriteIds[0]].data[2] = 0;
break;
default:
if (sub_81221EC() == 0 && FuncIsActiveTask(sub_81C20F0) == 0)
@@ -944,24 +1309,24 @@ void sub_81C0704(u8 taskId)
s8 sub_81C08F8(s8 a)
{
- struct Pokemon *mon = gUnknown_0203CF1C->unk0->mon;
+ struct Pokemon *mon = gUnknown_0203CF1C->monList.mons;
if (gUnknown_0203CF1C->unk40C0 == 0)
{
- if (a == -1 && gUnknown_0203CF1C->unk40BE == 0)
+ if (a == -1 && gUnknown_0203CF1C->curMonIndex == 0)
return -1;
- if (a == 1 && gUnknown_0203CF1C->unk40BE >= gUnknown_0203CF1C->unk40BF)
+ if (a == 1 && gUnknown_0203CF1C->curMonIndex >= gUnknown_0203CF1C->maxMonIndex)
return -1;
- return gUnknown_0203CF1C->unk40BE + a;
+ return gUnknown_0203CF1C->curMonIndex + a;
}
else
{
- s8 index = gUnknown_0203CF1C->unk40BE;
+ s8 index = gUnknown_0203CF1C->curMonIndex;
do
{
index += a;
- if (index < 0 || index > gUnknown_0203CF1C->unk40BF)
+ if (index < 0 || index > gUnknown_0203CF1C->maxMonIndex)
return -1;
} while (GetMonData(&mon[index], MON_DATA_IS_EGG) != 0);
return index;
@@ -970,23 +1335,23 @@ s8 sub_81C08F8(s8 a)
s8 sub_81C09B4(s8 a)
{
- struct Pokemon *mon = gUnknown_0203CF1C->unk0->mon;
+ struct Pokemon *mon = gUnknown_0203CF1C->monList.mons;
s8 r5 = 0;
u8 i;
for (i = 0; i < 6; i++)
{
- if (gUnknown_0861CC1C[i] == gUnknown_0203CF1C->unk40BE)
+ if (gUnknown_0861CC1C[i] == gUnknown_0203CF1C->curMonIndex)
{
r5 = i;
break;
}
}
- while (1)
+ while (TRUE)
{
int b;
- s8* c = &gUnknown_0861CC1C[0];
+ const s8* c = gUnknown_0861CC1C;
r5 += a;
if (r5 < 0 || r5 >= 6)
@@ -1001,7 +1366,7 @@ bool8 sub_81C0A50(struct Pokemon* mon)
{
if (GetMonData(mon, MON_DATA_SPECIES) == 0)
return FALSE;
- else if (gUnknown_0203CF1C->unk40BE != 0 || GetMonData(mon, MON_DATA_IS_EGG) == 0)
+ else if (gUnknown_0203CF1C->curMonIndex != 0 || GetMonData(mon, MON_DATA_IS_EGG) == 0)
return TRUE;
else
return FALSE;
@@ -1014,10 +1379,11 @@ void sub_81C0A8C(u8 taskId, s8 b)
if (summary->isEgg)
return;
- if (b == -1 && gUnknown_0203CF1C->unk40C0 == gUnknown_0203CF1C->unk40C1)
+ else if (b == -1 && gUnknown_0203CF1C->unk40C0 == gUnknown_0203CF1C->unk40C1)
return;
- if (b == 1 && gUnknown_0203CF1C->unk40C0 == gUnknown_0203CF1C->unk40C2)
+ else if (b == 1 && gUnknown_0203CF1C->unk40C0 == gUnknown_0203CF1C->unk40C2)
return;
+
PlaySE(SE_SELECT);
sub_81C2C38(gUnknown_0203CF1C->unk40C0);
gUnknown_0203CF1C->unk40C0 += b;
@@ -1122,7 +1488,7 @@ void sub_81C0D44(u8 taskId)
SwitchTaskToFollowupFunc(taskId);
}
-void sub_81C0E24()
+void sub_81C0E24(void)
{
if (gUnknown_0203CF1C->unk40C0 == 1)
sub_81C22CC(&gUnknown_0203CF1C->currentMon);
@@ -1131,20 +1497,20 @@ void sub_81C0E24()
void sub_81C0E48(u8 taskId)
{
u16 move;
- gUnknown_0203CF1C->unk40C6 = 0;
- move = gUnknown_0203CF1C->summary.moves[gUnknown_0203CF1C->unk40C6];
+ gUnknown_0203CF1C->firstMoveIndex = 0;
+ move = gUnknown_0203CF1C->summary.moves[gUnknown_0203CF1C->firstMoveIndex];
ClearWindowTilemap(0x13);
- if (gSprites[gUnknown_0203CF1C->unk40D3[2]].invisible == 0)
+ if (gSprites[gUnknown_0203CF1C->spriteIds[2]].invisible == 0)
ClearWindowTilemap(0xD);
sub_81C1DA4(9, -3);
sub_81C1EFC(9, -3, move);
- if (gUnknown_0203CF1C->unk40C8 == 0)
+ if (!gUnknown_0203CF1C->unk40C8)
{
ClearWindowTilemap(5);
PutWindowTilemap(6);
}
- sub_81C2194(&gUnknown_0203CF1C->unkTilemap2[0], 3, 0);
- sub_81C2194(&gUnknown_0203CF1C->unkTilemap3[0], 1, 0);
+ sub_81C2194(&gUnknown_0203CF1C->bgTilemapBuffer3[0], 3, 0);
+ sub_81C2194(&gUnknown_0203CF1C->bgTilemapBuffer4[0], 1, 0);
sub_81C3E9C(move);
sub_81C3F44();
sub_81C44F0();
@@ -1165,17 +1531,17 @@ void sub_81C0F44(u8 taskId)
if (gMain.newKeys & DPAD_UP)
{
data[0] = 4;
- sub_81C1070(data, -1, &gUnknown_0203CF1C->unk40C6);
+ sub_81C1070(data, -1, &gUnknown_0203CF1C->firstMoveIndex);
}
else if (gMain.newKeys & DPAD_DOWN)
{
data[0] = 4;
- sub_81C1070(data, 1, &gUnknown_0203CF1C->unk40C6);
+ sub_81C1070(data, 1, &gUnknown_0203CF1C->firstMoveIndex);
}
else if (gMain.newKeys & A_BUTTON)
{
- if (gUnknown_0203CF1C->unk40C8 == 1
- || (gUnknown_0203CF1C->unk40C4 == 0 && gUnknown_0203CF1C->unk40C6 == 4))
+ if (gUnknown_0203CF1C->unk40C8 == TRUE
+ || (gUnknown_0203CF1C->newMove == MOVE_NONE && gUnknown_0203CF1C->firstMoveIndex == MAX_MON_MOVES))
{
PlaySE(SE_SELECT);
sub_81C11F4(taskId);
@@ -1226,7 +1592,7 @@ void sub_81C1070(s16 *a, s8 b, u8 *c)
moveIndex = a[0];
if (moveIndex == 4)
{
- move = gUnknown_0203CF1C->unk40C4;
+ move = gUnknown_0203CF1C->newMove;
break;
}
move = gUnknown_0203CF1C->summary.moves[moveIndex];
@@ -1237,16 +1603,16 @@ void sub_81C1070(s16 *a, s8 b, u8 *c)
schedule_bg_copy_tilemap_to_vram(1);
schedule_bg_copy_tilemap_to_vram(2);
sub_81C3E9C(move);
- if ((*c == 4 && gUnknown_0203CF1C->unk40C4 == 0) || a[1] == 1)
+ if ((*c == 4 && gUnknown_0203CF1C->newMove == MOVE_NONE) || a[1] == 1)
{
ClearWindowTilemap(19);
- if (!gSprites[gUnknown_0203CF1C->unk40D3[2]].invisible)
+ if (!gSprites[gUnknown_0203CF1C->spriteIds[2]].invisible)
ClearWindowTilemap(13);
schedule_bg_copy_tilemap_to_vram(0);
sub_81C1DA4(9, -3);
sub_81C1EFC(9, -3, move);
}
- if (*c != 4 && moveIndex == 4 && gUnknown_0203CF1C->unk40C4 == 0)
+ if (*c != 4 && moveIndex == 4 && gUnknown_0203CF1C->newMove == MOVE_NONE)
{
ClearWindowTilemap(14);
ClearWindowTilemap(15);
@@ -1255,7 +1621,7 @@ void sub_81C1070(s16 *a, s8 b, u8 *c)
sub_81C1EFC(0, 3, 0);
}
*c = moveIndex;
- if (c == &gUnknown_0203CF1C->unk40C6)
+ if (c == &gUnknown_0203CF1C->firstMoveIndex)
sub_81C4D18(8);
else
sub_81C4D18(18);
@@ -1267,10 +1633,10 @@ void sub_81C11F4(u8 taskId)
ClearWindowTilemap(6);
PutWindowTilemap(5);
sub_81C3E9C(0);
- sub_81C2194(&gUnknown_0203CF1C->unkTilemap2[0], 3, 1);
- sub_81C2194(&gUnknown_0203CF1C->unkTilemap3[0], 1, 1);
+ sub_81C2194(&gUnknown_0203CF1C->bgTilemapBuffer3[0], 3, 1);
+ sub_81C2194(&gUnknown_0203CF1C->bgTilemapBuffer4[0], 1, 1);
sub_81C4064();
- if (gUnknown_0203CF1C->unk40C6 != 4)
+ if (gUnknown_0203CF1C->firstMoveIndex != MAX_MON_MOVES)
{
ClearWindowTilemap(14);
ClearWindowTilemap(15);
@@ -1285,7 +1651,7 @@ void sub_81C11F4(u8 taskId)
void sub_81C129C(u8 taskId)
{
- gUnknown_0203CF1C->unk40C7 = gUnknown_0203CF1C->unk40C6;
+ gUnknown_0203CF1C->secondMoveIndex = gUnknown_0203CF1C->firstMoveIndex;
sub_81C4C84(1);
sub_81C4AF8(18);
gTasks[taskId].func = sub_81C12E4;
@@ -1300,16 +1666,16 @@ void sub_81C12E4(u8 taskId)
if (gMain.newKeys & DPAD_UP)
{
data[0] = 3;
- sub_81C1070(&data[0], -1, &gUnknown_0203CF1C->unk40C7);
+ sub_81C1070(&data[0], -1, &gUnknown_0203CF1C->secondMoveIndex);
}
else if (gMain.newKeys & DPAD_DOWN)
{
data[0] = 3;
- sub_81C1070(&data[0], 1, &gUnknown_0203CF1C->unk40C7);
+ sub_81C1070(&data[0], 1, &gUnknown_0203CF1C->secondMoveIndex);
}
else if (gMain.newKeys & A_BUTTON)
{
- if (gUnknown_0203CF1C->unk40C6 == gUnknown_0203CF1C->unk40C7)
+ if (gUnknown_0203CF1C->firstMoveIndex == gUnknown_0203CF1C->secondMoveIndex)
{
sub_81C13B0(taskId, 0);
}
@@ -1329,22 +1695,22 @@ void sub_81C13B0(u8 taskId, u8 b)
sub_81C4C60(18);
if (b == 1)
{
- if (gUnknown_0203CF1C->unk40BD == 0)
+ if (!gUnknown_0203CF1C->isBoxMon)
{
- struct Pokemon *why = gUnknown_0203CF1C->unk0->mon;
- sub_81C14BC(&why[gUnknown_0203CF1C->unk40BE], gUnknown_0203CF1C->unk40C6, gUnknown_0203CF1C->unk40C7);
+ struct Pokemon *why = gUnknown_0203CF1C->monList.mons;
+ sub_81C14BC(&why[gUnknown_0203CF1C->curMonIndex], gUnknown_0203CF1C->firstMoveIndex, gUnknown_0203CF1C->secondMoveIndex);
}
else
{
- struct BoxPokemon *why = gUnknown_0203CF1C->unk0->boxMon;
- sub_81C15EC(&why[gUnknown_0203CF1C->unk40BE], gUnknown_0203CF1C->unk40C6, gUnknown_0203CF1C->unk40C7);
+ struct BoxPokemon *why = gUnknown_0203CF1C->monList.boxMons;
+ sub_81C15EC(&why[gUnknown_0203CF1C->curMonIndex], gUnknown_0203CF1C->firstMoveIndex, gUnknown_0203CF1C->secondMoveIndex);
}
sub_81C0098(&gUnknown_0203CF1C->currentMon);
- sub_81C40A0(gUnknown_0203CF1C->unk40C6, gUnknown_0203CF1C->unk40C7);
- sub_81C4568(gUnknown_0203CF1C->unk40C6, gUnknown_0203CF1C->unk40C7);
- gUnknown_0203CF1C->unk40C6 = gUnknown_0203CF1C->unk40C7;
+ sub_81C40A0(gUnknown_0203CF1C->firstMoveIndex, gUnknown_0203CF1C->secondMoveIndex);
+ sub_81C4568(gUnknown_0203CF1C->firstMoveIndex, gUnknown_0203CF1C->secondMoveIndex);
+ gUnknown_0203CF1C->firstMoveIndex = gUnknown_0203CF1C->secondMoveIndex;
}
- move = gUnknown_0203CF1C->summary.moves[gUnknown_0203CF1C->unk40C6];
+ move = gUnknown_0203CF1C->summary.moves[gUnknown_0203CF1C->firstMoveIndex];
sub_81C3E9C(move);
sub_81C240C(move);
schedule_bg_copy_tilemap_to_vram(1);
@@ -1793,12 +2159,12 @@ void sub_81C174C(u8 taskId)
if (gMain.newKeys & DPAD_UP)
{
data[0] = 4;
- sub_81C1070(data, -1, &gUnknown_0203CF1C->unk40C6);
+ sub_81C1070(data, -1, &gUnknown_0203CF1C->firstMoveIndex);
}
else if (gMain.newKeys & DPAD_DOWN)
{
data[0] = 4;
- sub_81C1070(data, 1, &gUnknown_0203CF1C->unk40C6);
+ sub_81C1070(data, 1, &gUnknown_0203CF1C->firstMoveIndex);
}
else if (gMain.newKeys & DPAD_LEFT || GetLRKeysState() == 1)
{
@@ -1814,7 +2180,7 @@ void sub_81C174C(u8 taskId)
{
sub_81C48F0();
PlaySE(SE_SELECT);
- gUnknown_0203CF21 = gUnknown_0203CF1C->unk40C6;
+ gUnknown_0203CF21 = gUnknown_0203CF1C->firstMoveIndex;
gSpecialVar_0x8005 = gUnknown_0203CF21;
sub_81C044C(taskId);
}
@@ -1837,9 +2203,9 @@ void sub_81C174C(u8 taskId)
}
}
-bool8 sub_81C18A8()
+bool8 sub_81C18A8(void)
{
- if (gUnknown_0203CF1C->unk40C6 == 4 || gUnknown_0203CF1C->unk40C4 == 0 || sub_81B6D14(gUnknown_0203CF1C->summary.moves[gUnknown_0203CF1C->unk40C6]) != 1)
+ if (gUnknown_0203CF1C->firstMoveIndex == MAX_MON_MOVES || gUnknown_0203CF1C->newMove == MOVE_NONE || sub_81B6D14(gUnknown_0203CF1C->summary.moves[gUnknown_0203CF1C->firstMoveIndex]) != 1)
return TRUE;
else
return FALSE;
@@ -1866,7 +2232,7 @@ void sub_81C1940(u8 taskId)
{
data[1] = 1;
data[0] = 4;
- sub_81C1070(&data[0], -1, &gUnknown_0203CF1C->unk40C6);
+ sub_81C1070(&data[0], -1, &gUnknown_0203CF1C->firstMoveIndex);
data[1] = 0;
gTasks[taskId].func = sub_81C174C;
}
@@ -1874,7 +2240,7 @@ void sub_81C1940(u8 taskId)
{
data[1] = 1;
data[0] = 4;
- sub_81C1070(&data[0], 1, &gUnknown_0203CF1C->unk40C6);
+ sub_81C1070(&data[0], 1, &gUnknown_0203CF1C->firstMoveIndex);
data[1] = 0;
gTasks[taskId].func = sub_81C174C;
}
@@ -1882,11 +2248,10 @@ void sub_81C1940(u8 taskId)
{
if (gUnknown_0203CF1C->unk40C0 != 2)
{
-
ClearWindowTilemap(19);
- if (!gSprites[gUnknown_0203CF1C->unk40D3[2]].invisible)
+ if (!gSprites[gUnknown_0203CF1C->spriteIds[2]].invisible)
ClearWindowTilemap(13);
- move = gUnknown_0203CF1C->summary.moves[gUnknown_0203CF1C->unk40C6];
+ move = gUnknown_0203CF1C->summary.moves[gUnknown_0203CF1C->firstMoveIndex];
gTasks[taskId].func = sub_81C174C;
sub_81C0A8C(taskId, -1);
sub_81C1DA4(9, -2);
@@ -1898,9 +2263,9 @@ void sub_81C1940(u8 taskId)
if (gUnknown_0203CF1C->unk40C0 != 3)
{
ClearWindowTilemap(19);
- if (!gSprites[gUnknown_0203CF1C->unk40D3[2]].invisible)
+ if (!gSprites[gUnknown_0203CF1C->spriteIds[2]].invisible)
ClearWindowTilemap(13);
- move = gUnknown_0203CF1C->summary.moves[gUnknown_0203CF1C->unk40C6];
+ move = gUnknown_0203CF1C->summary.moves[gUnknown_0203CF1C->firstMoveIndex];
gTasks[taskId].func = sub_81C174C;
sub_81C0A8C(taskId, 1);
sub_81C1DA4(9, -2);
@@ -1910,9 +2275,9 @@ void sub_81C1940(u8 taskId)
else if (gMain.newKeys & (A_BUTTON | B_BUTTON))
{
ClearWindowTilemap(19);
- if (!gSprites[gUnknown_0203CF1C->unk40D3[2]].invisible)
+ if (!gSprites[gUnknown_0203CF1C->spriteIds[2]].invisible)
ClearWindowTilemap(13);
- move = gUnknown_0203CF1C->summary.moves[gUnknown_0203CF1C->unk40C6];
+ move = gUnknown_0203CF1C->summary.moves[gUnknown_0203CF1C->firstMoveIndex];
sub_81C3E9C(move);
schedule_bg_copy_tilemap_to_vram(0);
sub_81C1DA4(9, -3);
@@ -1922,12 +2287,12 @@ void sub_81C1940(u8 taskId)
}
}
-u8 sub_81C1B94()
+u8 sub_81C1B94(void)
{
return gUnknown_0203CF21;
}
-void sub_81C1BA0()
+void sub_81C1BA0(void)
{
u16 *alloced = Alloc(32);
u8 i;
@@ -1992,173 +2357,34 @@ void sub_81C1BA0()
Free(alloced);
}
-struct UnkStruct_61CC04
+void sub_81C1CB0(const struct UnkStruct_61CC04 *unkStruct, u16 *dest, u8 c, bool8 d)
{
- u8 *ptr;
- u8 field_4;
- u8 field_5;
- u8 field_6;
- u8 field_7;
- u8 field_8;
- u8 field_9;
-};
-
-#ifdef NONMATCHING
-void sub_81C1CB0(struct UnkStruct_61CC04 *a, u16 *b, u8 c, u8 d)
-{
- u8 *alloced = Alloc(a->field_6 * (a->field_7 << 1));
- CpuFill16(a->field_4, alloced, a->field_7*a->field_6);
- if (a->field_6 != c)
+ u16 i;
+ u16 *alloced = Alloc(unkStruct->field_6 * 2 * unkStruct->field_7);
+ CpuFill16(unkStruct->field_4, alloced, unkStruct->field_6 * 2 * unkStruct->field_7);
+ if (unkStruct->field_6 != c)
{
if (!d)
{
- for (d;d < a->field_7; d++)
+ for (i = 0; i < unkStruct->field_7; i++)
{
- CpuCopy16(&a->ptr + ((c + a->field_6*d)), alloced + ((a->field_6*d) << 1), (a->field_6 - c) * 2);
+ CpuCopy16(&unkStruct->ptr[c + unkStruct->field_6 * i], &alloced[unkStruct->field_6 * i], (unkStruct->field_6 - c) * 2);
}
}
else
{
- for (d = 0;d < a->field_7; d++)
+ for (i = 0; i < unkStruct->field_7; i++)
{
- CpuCopy16(&a->ptr + (a->field_6*d), alloced + ((c + a->field_6*d) << 1), (a->field_6 - c) * 2);
+ CpuCopy16(&unkStruct->ptr[unkStruct->field_6 * i], &alloced[c + unkStruct->field_6 * i], (unkStruct->field_6 - c) * 2);
}
}
}
- d = 0;
- while (d < a->field_7)
+ for (i = 0; i < unkStruct->field_7; i++)
{
- CpuCopy16(alloced + ((a->field_6*d) << 1), b + ((((a->field_9 + d) << 5) + a->field_8) << 1), a->field_6 * 2);
- d++;
+ CpuCopy16(&alloced[unkStruct->field_6 * i], &dest[(unkStruct->field_9 + i) * 32 + unkStruct->field_8], unkStruct->field_6 * 2);
}
Free(alloced);
}
-#else
-NAKED
-void sub_81C1CB0(struct UnkStruct_61CC04 *a, u16 *b, u8 c, u8 d)
-{
- asm(".syntax unified\n\
- push {r4-r7,lr}\n\
- mov r7, r8\n\
- push {r7}\n\
- sub sp, 0x4\n\
- adds r4, r0, 0\n\
- mov r8, r1\n\
- lsls r2, 24\n\
- lsrs r6, r2, 24\n\
- lsls r3, 24\n\
- lsrs r5, r3, 24\n\
- ldrb r1, [r4, 0x6]\n\
- ldrb r0, [r4, 0x7]\n\
- lsls r0, 1\n\
- muls r0, r1\n\
- bl Alloc\n\
- adds r7, r0, 0\n\
- mov r1, sp\n\
- ldrh r0, [r4, 0x4]\n\
- strh r0, [r1]\n\
- ldrb r1, [r4, 0x7]\n\
- ldrb r0, [r4, 0x6]\n\
- adds r2, r1, 0\n\
- muls r2, r0\n\
- movs r0, 0x80\n\
- lsls r0, 17\n\
- orrs r2, r0\n\
- mov r0, sp\n\
- adds r1, r7, 0\n\
- bl CpuSet\n\
- ldrb r0, [r4, 0x6]\n\
- cmp r0, r6\n\
- beq _081C1D60\n\
- cmp r5, 0\n\
- bne _081C1D30\n\
- movs r5, 0\n\
- ldrb r0, [r4, 0x7]\n\
- cmp r5, r0\n\
- bcs _081C1D60\n\
-_081C1D00:\n\
- ldrb r2, [r4, 0x6]\n\
- adds r1, r2, 0\n\
- muls r1, r5\n\
- adds r3, r6, r1\n\
- lsls r3, 1\n\
- ldr r0, [r4]\n\
- adds r0, r3\n\
- lsls r1, 1\n\
- adds r1, r7, r1\n\
- subs r2, r6\n\
- ldr r3, =0x001fffff\n\
- ands r2, r3\n\
- bl CpuSet\n\
- adds r0, r5, 0x1\n\
- lsls r0, 16\n\
- lsrs r5, r0, 16\n\
- ldrb r3, [r4, 0x7]\n\
- cmp r5, r3\n\
- bcc _081C1D00\n\
- b _081C1D60\n\
- .pool\n\
-_081C1D30:\n\
- movs r5, 0\n\
- ldrb r0, [r4, 0x7]\n\
- cmp r5, r0\n\
- bcs _081C1D60\n\
-_081C1D38:\n\
- ldrb r2, [r4, 0x6]\n\
- adds r1, r2, 0\n\
- muls r1, r5\n\
- lsls r3, r1, 1\n\
- ldr r0, [r4]\n\
- adds r0, r3\n\
- adds r1, r6, r1\n\
- lsls r1, 1\n\
- adds r1, r7, r1\n\
- subs r2, r6\n\
- ldr r3, =0x001fffff\n\
- ands r2, r3\n\
- bl CpuSet\n\
- adds r0, r5, 0x1\n\
- lsls r0, 16\n\
- lsrs r5, r0, 16\n\
- ldrb r3, [r4, 0x7]\n\
- cmp r5, r3\n\
- bcc _081C1D38\n\
-_081C1D60:\n\
- movs r5, 0\n\
- b _081C1D8A\n\
- .pool\n\
-_081C1D68:\n\
- ldrb r2, [r4, 0x6]\n\
- adds r0, r2, 0\n\
- muls r0, r5\n\
- lsls r0, 1\n\
- adds r0, r7, r0\n\
- ldrb r1, [r4, 0x9]\n\
- adds r1, r5\n\
- lsls r1, 5\n\
- ldrb r3, [r4, 0x8]\n\
- adds r1, r3\n\
- lsls r1, 1\n\
- add r1, r8\n\
- bl CpuSet\n\
- adds r0, r5, 0x1\n\
- lsls r0, 16\n\
- lsrs r5, r0, 16\n\
-_081C1D8A:\n\
- ldrb r0, [r4, 0x7]\n\
- cmp r5, r0\n\
- bcc _081C1D68\n\
- adds r0, r7, 0\n\
- bl Free\n\
- add sp, 0x4\n\
- pop {r3}\n\
- mov r8, r3\n\
- pop {r4-r7}\n\
- pop {r0}\n\
- bx r0\n\
- .syntax divided\n");
-}
-#endif
void sub_81C1DA4(u16 a, s16 b)
{
@@ -2166,7 +2392,7 @@ void sub_81C1DA4(u16 a, s16 b)
b = gUnknown_0861CC04.field_6;
if (b == 0 || b == gUnknown_0861CC04.field_6)
{
- sub_81C1CB0(&gUnknown_0861CC04, &gUnknown_0203CF1C->unkTilemap2[0], b, 1);
+ sub_81C1CB0(&gUnknown_0861CC04, &gUnknown_0203CF1C->bgTilemapBuffer3[0], b, 1);
}
else
{
@@ -2192,18 +2418,17 @@ void sub_81C1E20(u8 taskId)
{
data[1] = gUnknown_0861CC04.field_6;
}
- sub_81C1CB0(&gUnknown_0861CC04, &gUnknown_0203CF1C->unkTilemap2[0], data[1], 1);
+ sub_81C1CB0(&gUnknown_0861CC04, &gUnknown_0203CF1C->bgTilemapBuffer3[0], data[1], 1);
if (data[1] <= 0 || data[1] >= gUnknown_0861CC04.field_6)
{
if (data[0] < 0)
{
if (gUnknown_0203CF1C->unk40C0 == 2)
PutWindowTilemap(14);
-
}
else
{
- if (!gSprites[gUnknown_0203CF1C->unk40D3[2]].invisible)
+ if (!gSprites[gUnknown_0203CF1C->spriteIds[2]].invisible)
PutWindowTilemap(13);
PutWindowTilemap(19);
}
@@ -2219,7 +2444,7 @@ void sub_81C1EFC(u16 a, s16 b, u16 move)
if (b > gUnknown_0861CC10.field_6)
b = gUnknown_0861CC10.field_6;
if (b == 0 || b == gUnknown_0861CC10.field_6)
- sub_81C1CB0(&gUnknown_0861CC10, &gUnknown_0203CF1C->unkTilemap3[0], b, 1);
+ sub_81C1CB0(&gUnknown_0861CC10, &gUnknown_0203CF1C->bgTilemapBuffer4[0], b, 1);
else
{
u8 taskId = FindTaskIdByFunc(sub_81C1F80);
@@ -2243,7 +2468,7 @@ void sub_81C1F80(u8 taskId)
{
data[1] = gUnknown_0861CC10.field_6;
}
- sub_81C1CB0(&gUnknown_0861CC10, &gUnknown_0203CF1C->unkTilemap3[0], data[1], 1);
+ sub_81C1CB0(&gUnknown_0861CC10, &gUnknown_0203CF1C->bgTilemapBuffer4[0], data[1], 1);
if (data[1] <= 0 || data[1] >= gUnknown_0861CC10.field_6)
{
if (data[0] < 0)
@@ -2254,7 +2479,7 @@ void sub_81C1F80(u8 taskId)
}
else
{
- if (!gSprites[gUnknown_0203CF1C->unk40D3[2]].invisible)
+ if (!gSprites[gUnknown_0203CF1C->spriteIds[2]].invisible)
{
PutWindowTilemap(13);
}
@@ -2273,8 +2498,8 @@ void sub_81C2074(u16 a, s16 b)
b = gUnknown_0861CBEC.field_6;
if (b == 0 || b == gUnknown_0861CBEC.field_6)
{
- sub_81C1CB0(&gUnknown_0861CBEC, &gUnknown_0203CF1C->unkTilemap0[0], b, 0);
- sub_81C1CB0(&gUnknown_0861CBF8, &gUnknown_0203CF1C->unkTilemap0[0], b, 0);
+ sub_81C1CB0(&gUnknown_0861CBEC, &gUnknown_0203CF1C->bgTilemapBuffer1[0], b, 0);
+ sub_81C1CB0(&gUnknown_0861CBF8, &gUnknown_0203CF1C->bgTilemapBuffer1[0], b, 0);
}
else
{
@@ -2292,8 +2517,8 @@ void sub_81C20F0(u8 taskId)
data[1] = 0;
else if (data[1] > gUnknown_0861CBEC.field_6)
data[1] = gUnknown_0861CBEC.field_6;
- sub_81C1CB0(&gUnknown_0861CBEC, &gUnknown_0203CF1C->unkTilemap0[0], data[1], 0);
- sub_81C1CB0(&gUnknown_0861CBF8, &gUnknown_0203CF1C->unkTilemap0[0], data[1], 0);
+ sub_81C1CB0(&gUnknown_0861CBEC, &gUnknown_0203CF1C->bgTilemapBuffer1[0], data[1], 0);
+ sub_81C1CB0(&gUnknown_0861CBF8, &gUnknown_0203CF1C->bgTilemapBuffer1[0], data[1], 0);
schedule_bg_copy_tilemap_to_vram(3);
if (data[1] <= 0 || data[1] >= gUnknown_0861CBEC.field_6)
{
@@ -2307,126 +2532,44 @@ void sub_81C20F0(u8 taskId)
}
}
-// somebody send help this is a complete fucking mess
-#ifdef NONMATCHING
-void sub_81C2194(u16 *a, u16 b, u8 c)
+void sub_81C2194(u16 *output, u16 palette, bool8 c)
{
u16 i;
- int var;
- b *= 0x1000;
+ u32 var;
+ palette <<= 12;
var = 0x56A;
if (c == 0)
{
for (i = 0; i < 20; i++)
{
- a[(i + var) << 1] = gSummaryScreenWindow_Tilemap[i] + b;
- a[((i + var) << 1) + 0x40] = gSummaryScreenWindow_Tilemap[i] + b;
- a[((i + var) << 1) + 0x80] = gSummaryScreenWindow_Tilemap[i + 20] + b;
+ output[var + i] = gSummaryScreenWindow_Tilemap[i] + palette;
+ output[var + i + 0x20] = gSummaryScreenWindow_Tilemap[i] + palette;
+ output[var + i + 0x40] = gSummaryScreenWindow_Tilemap[i + 20] + palette;
}
}
else
{
for (i = 0; i < 20; i++)
{
- a[(i + var)] = gSummaryScreenWindow_Tilemap[i + 20] + b;
- a[((i + var)) + 0x40] = gSummaryScreenWindow_Tilemap[i + 40] + b;
- a[((i + var)) + 0x80] = gSummaryScreenWindow_Tilemap[i + 40] + b;
+ output[var + i] = gSummaryScreenWindow_Tilemap[i + 20] + palette;
+ output[var + i + 0x20] = gSummaryScreenWindow_Tilemap[i + 40] + palette;
+ output[var + i + 0x40] = gSummaryScreenWindow_Tilemap[i + 40] + palette;
}
}
}
-#else
-NAKED
-void sub_81C2194(u16 *a, u16 b, u8 c)
-{
- asm(".syntax unified\n\
- push {r4-r7,lr}\n\
- adds r6, r0, 0\n\
- lsls r2, 24\n\
- lsls r1, 28\n\
- lsrs r4, r1, 16\n\
- ldr r7, =0x0000056a\n\
- cmp r2, 0\n\
- bne _081C21E4\n\
- movs r3, 0\n\
- ldr r5, =gSummaryScreenWindow_Tilemap\n\
-_081C21A8:\n\
- adds r2, r7, r3\n\
- lsls r2, 1\n\
- adds r2, r6\n\
- lsls r0, r3, 1\n\
- adds r0, r5\n\
- ldrh r1, [r0]\n\
- adds r1, r4, r1\n\
- strh r1, [r2]\n\
- adds r0, r2, 0\n\
- adds r0, 0x40\n\
- strh r1, [r0]\n\
- adds r2, 0x80\n\
- adds r0, r3, 0\n\
- adds r0, 0x14\n\
- lsls r0, 1\n\
- adds r0, r5\n\
- ldrh r0, [r0]\n\
- adds r0, r4, r0\n\
- strh r0, [r2]\n\
- adds r0, r3, 0x1\n\
- lsls r0, 16\n\
- lsrs r3, r0, 16\n\
- cmp r3, 0x13\n\
- bls _081C21A8\n\
- b _081C221C\n\
- .pool\n\
-_081C21E4:\n\
- movs r3, 0\n\
- ldr r5, =gSummaryScreenWindow_Tilemap\n\
-_081C21E8:\n\
- adds r1, r7, r3\n\
- lsls r1, 1\n\
- adds r1, r6\n\
- adds r0, r3, 0\n\
- adds r0, 0x14\n\
- lsls r0, 1\n\
- adds r0, r5\n\
- ldrh r0, [r0]\n\
- adds r0, r4, r0\n\
- strh r0, [r1]\n\
- adds r2, r1, 0\n\
- adds r2, 0x40\n\
- adds r0, r3, 0\n\
- adds r0, 0x28\n\
- lsls r0, 1\n\
- adds r0, r5\n\
- ldrh r0, [r0]\n\
- adds r0, r4, r0\n\
- strh r0, [r2]\n\
- adds r1, 0x80\n\
- strh r0, [r1]\n\
- adds r0, r3, 0x1\n\
- lsls r0, 16\n\
- lsrs r3, r0, 16\n\
- cmp r3, 0x13\n\
- bls _081C21E8\n\
-_081C221C:\n\
- pop {r4-r7}\n\
- pop {r0}\n\
- bx r0\n\
- .pool\n\
- .syntax divided\n");
-}
-#endif
void sub_81C2228(struct Pokemon *mon)
{
if (!CheckPartyPokerus(mon, 0) && CheckPartyHasHadPokerus(mon, 0))
{
- gUnknown_0203CF1C->unkTilemap0[0x223] = 0x2C;
- gUnknown_0203CF1C->unkTilemap0_1[0x223] = 0x2C;
+ gUnknown_0203CF1C->bgTilemapBuffer1[0x223] = 0x2C;
+ gUnknown_0203CF1C->bgTilemapBuffer1[0x623] = 0x2C;
}
else
{
- gUnknown_0203CF1C->unkTilemap0[0x223] = 0x81A;
- gUnknown_0203CF1C->unkTilemap0_1[0x223] = 0x81A;
+ gUnknown_0203CF1C->bgTilemapBuffer1[0x223] = 0x81A;
+ gUnknown_0203CF1C->bgTilemapBuffer1[0x623] = 0x81A;
}
schedule_bg_copy_tilemap_to_vram(3);
}
@@ -2461,7 +2604,7 @@ void sub_81C22CC(struct Pokemon *unused)
r6r7 = 0;
}
- r9 = &gUnknown_0203CF1C->unkTilemap1_1[0x255];
+ r9 = &gUnknown_0203CF1C->bgTilemapBuffer2[0x655];
for (i = 0; i < 8; i++)
{
if (r6r7 > 7)
@@ -2473,7 +2616,7 @@ void sub_81C22CC(struct Pokemon *unused)
r6r7 = 0;
}
- if (GetBgTilemapBuffer(1) == gUnknown_0203CF1C->unkTilemap1)
+ if (GetBgTilemapBuffer(1) == gUnknown_0203CF1C->bgTilemapBuffer2)
schedule_bg_copy_tilemap_to_vram(1);
else
schedule_bg_copy_tilemap_to_vram(2);
@@ -2481,7 +2624,7 @@ void sub_81C22CC(struct Pokemon *unused)
void sub_81C240C(u16 move)
{
- u16* r5 = &gUnknown_0203CF1C->unkTilemap3_1[0];
+ u16* r5 = &gUnknown_0203CF1C->bgTilemapBuffer4[0x400];
u8 i;
u8 r4;
if (move != MOVE_NONE)
@@ -2513,7 +2656,7 @@ void sub_81C240C(u16 move)
}
}
-void sub_81C2524()
+void sub_81C2524(void)
{
if (gUnknown_0203CF1C->summary.isEgg != 0)
ChangeBgX(3, 0x10000, 0);
@@ -2521,23 +2664,23 @@ void sub_81C2524()
ChangeBgX(3, 0, 0);
}
-void sub_81C2554()
+void sub_81C2554(void)
{
u8 i;
- InitWindows(&gUnknown_0861CC24);
+ InitWindows(gUnknown_0861CC24);
DeactivateAllTextPrinters();
for (i = 0; i < 20; i++)
FillWindowPixelBuffer(i, 0);
for (i = 0; i < 8; i++)
- gUnknown_0203CF1C->unk40CB[i] |= 0xFF;
+ gUnknown_0203CF1C->windowIds[i] |= 0xFF;
}
void sub_81C25A4(u8 a, const u8 *b, u8 c, u8 d, u8 e, u8 f)
{
- AddTextPrinterParameterized2(a, 1, c, d, 0, e, gUnknown_0861CD2C[f], 0, b);
+ AddTextPrinterParameterized2(a, 1, c, d, 0, e, sTextColors_861CD2C[f], 0, b);
}
-void sub_81C25E8()
+void sub_81C25E8(void)
{
FillWindowPixelBuffer(17, 0);
FillWindowPixelBuffer(18, 0);
@@ -2549,7 +2692,7 @@ void sub_81C25E8()
schedule_bg_copy_tilemap_to_vram(0);
}
-void sub_81C2628()
+void sub_81C2628(void)
{
u8 strArray[16];
struct Pokemon *mon = &gUnknown_0203CF1C->currentMon;
@@ -2594,7 +2737,7 @@ void sub_81C2628()
PutWindowTilemap(19);
}
-void sub_81C2794()
+void sub_81C2794(void)
{
GetMonNickname(&gUnknown_0203CF1C->currentMon, gStringVar1);
sub_81C25A4(18, gStringVar1, 0, 1, 0, 1);
@@ -2625,7 +2768,7 @@ void sub_81C2838(u8 a, bool8 b, u32 c)
BlitBitmapToWindow(a, (b) ? &gUnknown_0861CDD3[0] : &gUnknown_0861CDD3[0] - 0x80, c, 0, 16, 16);
}
-void sub_81C286C()
+void sub_81C286C(void)
{
int r4;
int r2;
@@ -2705,9 +2848,9 @@ void sub_81C2AFC(u8 a)
break;
case 2:
PutWindowTilemap(2);
- if (gUnknown_0203CF1C->unk40BC == 3)
+ if (gUnknown_0203CF1C->mode == 3)
{
- if(!(gUnknown_0203CF1C->unk40C4 == 0 && gUnknown_0203CF1C->unk40C6 == 4))
+ if(!(gUnknown_0203CF1C->newMove == MOVE_NONE && gUnknown_0203CF1C->firstMoveIndex == MAX_MON_MOVES))
PutWindowTilemap(14);
}
else
@@ -2715,9 +2858,9 @@ void sub_81C2AFC(u8 a)
break;
case 3:
PutWindowTilemap(3);
- if (gUnknown_0203CF1C->unk40BC == 3)
+ if (gUnknown_0203CF1C->mode == 3)
{
- if(!(gUnknown_0203CF1C->unk40C4 == 0 && gUnknown_0203CF1C->unk40C6 == 4))
+ if(!(gUnknown_0203CF1C->newMove == MOVE_NONE && gUnknown_0203CF1C->firstMoveIndex == MAX_MON_MOVES))
PutWindowTilemap(15);
}
else
@@ -2726,7 +2869,7 @@ void sub_81C2AFC(u8 a)
}
for (i = 0; i < 8; i++)
{
- PutWindowTilemap(gUnknown_0203CF1C->unk40CB[i]);
+ PutWindowTilemap(gUnknown_0203CF1C->windowIds[i]);
}
schedule_bg_copy_tilemap_to_vram(0);
}
@@ -2748,18 +2891,18 @@ void sub_81C2C38(u8 a)
ClearWindowTilemap(12);
break;
case 2:
- if (gUnknown_0203CF1C->unk40BC == 3)
+ if (gUnknown_0203CF1C->mode == 3)
{
- if(!(gUnknown_0203CF1C->unk40C4 == 0 && gUnknown_0203CF1C->unk40C6 == 4))
+ if(!(gUnknown_0203CF1C->newMove == MOVE_NONE && gUnknown_0203CF1C->firstMoveIndex == MAX_MON_MOVES))
ClearWindowTilemap(14);
}
else
ClearWindowTilemap(5);
break;
case 3:
- if (gUnknown_0203CF1C->unk40BC == 3)
+ if (gUnknown_0203CF1C->mode == 3)
{
- if(!(gUnknown_0203CF1C->unk40C4 == 0 && gUnknown_0203CF1C->unk40C6 == 4))
+ if(!(gUnknown_0203CF1C->newMove == MOVE_NONE && gUnknown_0203CF1C->firstMoveIndex == MAX_MON_MOVES))
ClearWindowTilemap(15);
}
else
@@ -2771,9 +2914,9 @@ void sub_81C2C38(u8 a)
schedule_bg_copy_tilemap_to_vram(0);
}
-u8 sub_81C2D2C(struct WindowTemplate *template, u8 a)
+u8 sub_81C2D2C(const struct WindowTemplate *template, u8 a)
{
- u8 *windowIdPtr = &(gUnknown_0203CF1C->unk40CB[a]);
+ u8 *windowIdPtr = &(gUnknown_0203CF1C->windowIds[a]);
if (*windowIdPtr == 0xFF)
{
*windowIdPtr = AddWindow(&template[a]);
@@ -2784,7 +2927,7 @@ u8 sub_81C2D2C(struct WindowTemplate *template, u8 a)
void sub_81C2D68(u8 a)
{
- u8 *windowIdPtr = &(gUnknown_0203CF1C->unk40CB[a]);
+ u8 *windowIdPtr = &(gUnknown_0203CF1C->windowIds[a]);
if (*windowIdPtr != 0xFF)
{
ClearWindowTilemap(*windowIdPtr);
@@ -2798,8 +2941,8 @@ void sub_81C2D9C(u8 a)
u16 i;
for (i = 0; i < 8; i++)
{
- if (gUnknown_0203CF1C->unk40CB[i] != 0xFF)
- FillWindowPixelBuffer(gUnknown_0203CF1C->unk40CB[i], 0);
+ if (gUnknown_0203CF1C->windowIds[i] != 0xFF)
+ FillWindowPixelBuffer(gUnknown_0203CF1C->windowIds[i], 0);
}
gUnknown_0861CE54[a]();
}
@@ -2809,7 +2952,7 @@ void sub_81C2DE4(u8 a)
CreateTask(gUnknown_0861CE64[a], 16);
}
-void sub_81C2E00()
+void sub_81C2E00(void)
{
if (gUnknown_0203CF1C->summary.isEgg)
{
@@ -2860,13 +3003,13 @@ void sub_81C2E40(u8 taskId)
data[0]++;
}
-void sub_81C2EC4()
+void sub_81C2EC4(void)
{
u8 r5;
int r2;
if (sub_81A6BF4() != 1 && sub_81B9E94() != 1)
{
- r5 = sub_81C2D2C(&gUnknown_0861CCCC, 0);
+ r5 = sub_81C2D2C(gUnknown_0861CCCC, 0);
sub_81C25A4(r5, gText_OTSlash, 0, 1, 0, 1);
r2 = GetStringWidth(1, gText_OTSlash, 0);
if (gUnknown_0203CF1C->summary.OTGender == 0)
@@ -2876,33 +3019,33 @@ void sub_81C2EC4()
}
}
-void sub_81C2F5C()
+void sub_81C2F5C(void)
{
int r4;
if (sub_81A6BF4() != TRUE && sub_81B9E94() != TRUE)
{
ConvertIntToDecimalStringN(StringCopy(gStringVar1, gText_UnkCtrlF907F908), (u16)gUnknown_0203CF1C->summary.OTID, 2, 5);
r4 = GetStringRightAlignXOffset(1, gStringVar1, 0x38);
- sub_81C25A4(sub_81C2D2C(&gUnknown_0861CCCC, 1), gStringVar1, r4, 1, 0, 1);
+ sub_81C25A4(sub_81C2D2C(gUnknown_0861CCCC, 1), gStringVar1, r4, 1, 0, 1);
}
}
-void sub_81C2FD8()
+void sub_81C2FD8(void)
{
u8 ability = GetAbilityBySpecies(gUnknown_0203CF1C->summary.species, gUnknown_0203CF1C->summary.altAbility);
- sub_81C25A4(sub_81C2D2C(&gUnknown_0861CCCC, 2), gAbilityNames[ability], 0, 1, 0, 1);
+ sub_81C25A4(sub_81C2D2C(gUnknown_0861CCCC, 2), gAbilityNames[ability], 0, 1, 0, 1);
}
-void sub_81C302C()
+void sub_81C302C(void)
{
u8 ability = GetAbilityBySpecies(gUnknown_0203CF1C->summary.species, gUnknown_0203CF1C->summary.altAbility);
- sub_81C25A4(sub_81C2D2C(&gUnknown_0861CCCC, 2), gAbilityDescriptionPointers[ability], 0, 17, 0, 0);
+ sub_81C25A4(sub_81C2D2C(gUnknown_0861CCCC, 2), gAbilityDescriptionPointers[ability], 0, 17, 0, 0);
}
-void sub_81C307C()
+void sub_81C307C(void)
{
struct PokeSummary *sum = &gUnknown_0203CF1C->summary;
- u8 *text;
+ const u8 *text;
DynamicPlaceholderTextUtil_Reset();
DynamicPlaceholderTextUtil_SetPlaceholderPtr(0, gUnknown_0861CE74);
DynamicPlaceholderTextUtil_SetPlaceholderPtr(1, gUnknown_0861CE7B);
@@ -2938,12 +3081,12 @@ void sub_81C307C()
}
}
-void sub_81C3194()
+void sub_81C3194(void)
{
- sub_81C25A4(sub_81C2D2C(&gUnknown_0861CCCC, 3), gStringVar4, 0, 1, 0, 0);
+ sub_81C25A4(sub_81C2D2C(gUnknown_0861CCCC, 3), gStringVar4, 0, 1, 0, 0);
}
-void sub_81C31C0()
+void sub_81C31C0(void)
{
struct UnkSummaryStruct *sumStruct = gUnknown_0203CF1C;
DynamicPlaceholderTextUtil_SetPlaceholderPtr(2, gNatureNamePointers[sumStruct->summary.nature]);
@@ -2959,14 +3102,15 @@ void sub_81C31F0(u8 *a)
DynamicPlaceholderTextUtil_SetPlaceholderPtr(3, a);
}
-u8 sub_81C3220()
+u8 sub_81C3220(void)
{
struct PokeSummary *sum = &gUnknown_0203CF1C->summary;
u32 r4;
u8 r5;
- if (gUnknown_0203CF1C->unk0 == (union UnkUnion *)&gEnemyParty)
+
+ if (gUnknown_0203CF1C->monList.mons == gEnemyParty)
{
- u8 multiID = GetMultiplayerId()^1;
+ u8 multiID = GetMultiplayerId() ^ 1;
r4 = (u16)gLinkPlayers[multiID].trainerId;
r5 = gLinkPlayers[multiID].gender;
StringCopy(gStringVar1, gLinkPlayers[multiID].name);
@@ -2984,7 +3128,7 @@ u8 sub_81C3220()
return 1;
}
-bool8 sub_81C32BC()
+bool8 sub_81C32BC(void)
{
struct PokeSummary *sum = &gUnknown_0203CF1C->summary;
u8 r0 = sum->metGame - 1;
@@ -2993,7 +3137,7 @@ bool8 sub_81C32BC()
return FALSE;
}
-bool8 sub_81C32E0()
+bool8 sub_81C32E0(void)
{
struct PokeSummary *sum = &gUnknown_0203CF1C->summary;
u8 r0 = sum->metGame - 1;
@@ -3002,91 +3146,36 @@ bool8 sub_81C32E0()
return FALSE;
}
-bool8 sub_81C3304()
+bool8 sub_81C3304(void)
{
if ((gBattleTypeFlags & BATTLE_TYPE_INGAME_PARTNER) && gMain.inBattle)
{
- if (gUnknown_0203CF1C->unk40BE == 1 || gUnknown_0203CF1C->unk40BE == 4 || gUnknown_0203CF1C->unk40BE == 5)
+ if (gUnknown_0203CF1C->curMonIndex == 1 || gUnknown_0203CF1C->curMonIndex == 4 || gUnknown_0203CF1C->curMonIndex == 5)
return TRUE;
}
return FALSE;
}
-#ifdef NONMATCHING
-void sub_81C335C()
+void sub_81C335C(void)
{
- u8 r4 = sub_81C2D2C(&gUnknown_0861CCCC, 0);
- u32 r5 = GetStringWidth(1, gText_OTSlash, 0);
- sub_81C25A4(r4, gText_OTSlash, 0, 1, 0, 1);
- sub_81C25A4(r4, gText_FiveMarks, r5, 1, 0, 1);
+ u32 windowId = sub_81C2D2C(gUnknown_0861CCCC, 0);
+ u32 width = GetStringWidth(1, gText_OTSlash, 0);
+ sub_81C25A4(windowId, gText_OTSlash, 0, 1, 0, 1);
+ sub_81C25A4(windowId, gText_FiveMarks, width, 1, 0, 1);
}
-#else
-NAKED
-void sub_81C335C()
-{
- asm(".syntax unified\n\
- push {r4-r6,lr}\n\
- mov r6, r9\n\
- mov r5, r8\n\
- push {r5,r6}\n\
- sub sp, 0x8\n\
- ldr r0, =gUnknown_0861CCCC\n\
- movs r1, 0\n\
- bl sub_81C2D2C\n\
- adds r4, r0, 0\n\
- lsls r4, 24\n\
- lsrs r4, 24\n\
- ldr r0, =gText_OTSlash\n\
- mov r8, r0\n\
- movs r0, 0x1\n\
- mov r1, r8\n\
- movs r2, 0\n\
- bl GetStringWidth\n\
- adds r5, r0, 0\n\
- movs r0, 0\n\
- mov r9, r0\n\
- str r0, [sp]\n\
- movs r6, 0x1\n\
- str r6, [sp, 0x4]\n\
- adds r0, r4, 0\n\
- mov r1, r8\n\
- movs r2, 0\n\
- movs r3, 0x1\n\
- bl sub_81C25A4\n\
- ldr r1, =gText_FiveMarks\n\
- lsls r5, 24\n\
- lsrs r5, 24\n\
- mov r0, r9\n\
- str r0, [sp]\n\
- str r6, [sp, 0x4]\n\
- adds r0, r4, 0\n\
- adds r2, r5, 0\n\
- movs r3, 0x1\n\
- bl sub_81C25A4\n\
- add sp, 0x8\n\
- pop {r3,r4}\n\
- mov r8, r3\n\
- mov r9, r4\n\
- pop {r4-r6}\n\
- pop {r0}\n\
- bx r0\n\
- .pool\n\
- .syntax divided\n");
-}
-#endif
-void sub_81C33CC()
+void sub_81C33CC(void)
{
int r4;
StringCopy(gStringVar1, gText_UnkCtrlF907F908);
StringAppend(gStringVar1, gText_FiveMarks);
r4 = GetStringRightAlignXOffset(1, gStringVar1, 0x38);
- sub_81C25A4(sub_81C2D2C(&gUnknown_0861CCCC, 1), gStringVar1, r4, 1, 0, 1);
+ sub_81C25A4(sub_81C2D2C(gUnknown_0861CCCC, 1), gStringVar1, r4, 1, 0, 1);
}
-void sub_81C3428()
+void sub_81C3428(void)
{
- u8 *text;
+ const u8 *text;
struct PokeSummary *sum = &gUnknown_0203CF1C->summary;
if (gUnknown_0203CF1C->summary.sanity == 1)
text = gText_EggWillTakeALongTime;
@@ -3098,12 +3187,12 @@ void sub_81C3428()
text = gText_EggWillTakeSomeTime;
else
text = gText_EggWillTakeALongTime;
- sub_81C25A4(sub_81C2D2C(&gUnknown_0861CCCC, 2), text, 0, 1, 0, 0);
+ sub_81C25A4(sub_81C2D2C(gUnknown_0861CCCC, 2), text, 0, 1, 0, 0);
}
-void sub_81C349C()
+void sub_81C349C(void)
{
- u8 *text;
+ const u8 *text;
struct PokeSummary *sum = &gUnknown_0203CF1C->summary;
if (gUnknown_0203CF1C->summary.sanity != 1)
{
@@ -3118,10 +3207,10 @@ void sub_81C349C()
}
else
text = gText_OddEggFoundByCouple;
- sub_81C25A4(sub_81C2D2C(&gUnknown_0861CCCC, 3), text, 0, 1, 0, 0);
+ sub_81C25A4(sub_81C2D2C(gUnknown_0861CCCC, 3), text, 0, 1, 0, 0);
}
-void sub_81C3530()
+void sub_81C3530(void)
{
sub_81C35E4();
sub_81C3690();
@@ -3166,11 +3255,11 @@ void sub_81C3554(u8 taskId)
data[0]++;
}
-void sub_81C35E4()
+void sub_81C35E4(void)
{
const u8 *text;
int offset;
- if (gUnknown_0203CF1C->summary.item == ITEM_ENIGMA_BERRY && sub_81B1250() == 1 && (gUnknown_0203CF1C->unk40BE == 1 || gUnknown_0203CF1C->unk40BE == 4 || gUnknown_0203CF1C->unk40BE == 5))
+ if (gUnknown_0203CF1C->summary.item == ITEM_ENIGMA_BERRY && sub_81B1250() == 1 && (gUnknown_0203CF1C->curMonIndex == 1 || gUnknown_0203CF1C->curMonIndex == 4 || gUnknown_0203CF1C->curMonIndex == 5))
{
text = ItemId_GetName(ITEM_ENIGMA_BERRY);
}
@@ -3182,12 +3271,12 @@ void sub_81C35E4()
text = gStringVar1;
}
offset = GetStringCenterAlignXOffset(1, text, 0x48) + 6;
- sub_81C25A4(sub_81C2D2C(&gUnknown_0861CCEC, 0), text, offset, 1, 0, 0);
+ sub_81C25A4(sub_81C2D2C(gUnknown_0861CCEC, 0), text, offset, 1, 0, 0);
}
-void sub_81C3690()
+void sub_81C3690(void)
{
- u8 *text;
+ const u8 *text;
int offset;
if (gUnknown_0203CF1C->summary.ribbons == 0)
text = gText_None;
@@ -3198,10 +3287,10 @@ void sub_81C3690()
text = gStringVar4;
}
offset = GetStringCenterAlignXOffset(1, text, 0x46) + 6;
- sub_81C25A4(sub_81C2D2C(&gUnknown_0861CCEC, 1), text, offset, 1, 0, 0);
+ sub_81C25A4(sub_81C2D2C(gUnknown_0861CCEC, 1), text, offset, 1, 0, 0);
}
-void sub_81C3710()
+void sub_81C3710(void)
{
u8 *alloced1 = Alloc(8);
u8 *alloced2 = Alloc(8);
@@ -3223,12 +3312,12 @@ void sub_81C3710()
Free(alloced4);
}
-void sub_81C37D8()
+void sub_81C37D8(void)
{
- sub_81C25A4(sub_81C2D2C(&gUnknown_0861CCEC, 2), gStringVar4, 4, 1, 0, 0);
+ sub_81C25A4(sub_81C2D2C(gUnknown_0861CCEC, 2), gStringVar4, 4, 1, 0, 0);
}
-void sub_81C3808()
+void sub_81C3808(void)
{
ConvertIntToDecimalStringN(gStringVar1, gUnknown_0203CF1C->summary.spatk, 1, 3);
ConvertIntToDecimalStringN(gStringVar2, gUnknown_0203CF1C->summary.spdef, 1, 3);
@@ -3240,15 +3329,15 @@ void sub_81C3808()
DynamicPlaceholderTextUtil_ExpandPlaceholders(gStringVar4, gUnknown_0861CE8E);
}
-void sub_81C3890()
+void sub_81C3890(void)
{
- sub_81C25A4(sub_81C2D2C(&gUnknown_0861CCEC, 3), gStringVar4, 2, 1, 0, 0);
+ sub_81C25A4(sub_81C2D2C(gUnknown_0861CCEC, 3), gStringVar4, 2, 1, 0, 0);
}
-void sub_81C38C0()
+void sub_81C38C0(void)
{
struct PokeSummary *sum = &gUnknown_0203CF1C->summary;
- u8 r6 = sub_81C2D2C(&gUnknown_0861CCEC, 4);
+ u8 r6 = sub_81C2D2C(gUnknown_0861CCEC, 4);
int offset;
u32 expToNextLevel;
ConvertIntToDecimalStringN(gStringVar1, sum->exp, 1, 7);
@@ -3263,22 +3352,22 @@ void sub_81C38C0()
sub_81C25A4(r6, gStringVar1, offset, 17, 0, 0);
}
-void sub_81C3984()
+void sub_81C3984(void)
{
sub_81C3B08(0);
sub_81C3B08(1);
sub_81C3B08(2);
sub_81C3B08(3);
- if (gUnknown_0203CF1C->unk40BC == 3)
+ if (gUnknown_0203CF1C->mode == 3)
{
sub_81C3F44();
- if (gUnknown_0203CF1C->unk40C6 == 4)
+ if (gUnknown_0203CF1C->firstMoveIndex == MAX_MON_MOVES)
{
- if (gUnknown_0203CF1C->unk40C4 != 0)
- sub_81C3E9C(gUnknown_0203CF1C->unk40C4);
+ if (gUnknown_0203CF1C->newMove != MOVE_NONE)
+ sub_81C3E9C(gUnknown_0203CF1C->newMove);
}
else
- sub_81C3E9C(gUnknown_0203CF1C->summary.moves[gUnknown_0203CF1C->unk40C6]);
+ sub_81C3E9C(gUnknown_0203CF1C->summary.moves[gUnknown_0203CF1C->firstMoveIndex]);
}
}
@@ -3302,22 +3391,22 @@ void sub_81C39F0(u8 taskId)
sub_81C3B08(3);
break;
case 4:
- if (gUnknown_0203CF1C->unk40BC == 3)
+ if (gUnknown_0203CF1C->mode == 3)
sub_81C3F44();
break;
case 5:
- if (gUnknown_0203CF1C->unk40BC == 3)
+ if (gUnknown_0203CF1C->mode == 3)
{
- if (gUnknown_0203CF1C->unk40C6 == 4)
- data[1] = gUnknown_0203CF1C->unk40C4;
+ if (gUnknown_0203CF1C->firstMoveIndex == MAX_MON_MOVES)
+ data[1] = gUnknown_0203CF1C->newMove;
else
- data[1] = gUnknown_0203CF1C->summary.moves[gUnknown_0203CF1C->unk40C6];
+ data[1] = gUnknown_0203CF1C->summary.moves[gUnknown_0203CF1C->firstMoveIndex];
}
break;
case 6:
- if (gUnknown_0203CF1C->unk40BC == 3)
+ if (gUnknown_0203CF1C->mode == 3)
{
- if (!(gUnknown_0203CF1C->unk40C4 == 0 && gUnknown_0203CF1C->unk40C6 == 4))
+ if (!(gUnknown_0203CF1C->newMove == MOVE_NONE && gUnknown_0203CF1C->firstMoveIndex == MAX_MON_MOVES))
sub_81C3E9C(data[1]);
}
break;
@@ -3328,193 +3417,44 @@ void sub_81C39F0(u8 taskId)
data[0]++;
}
-#ifdef NONMATCHING
void sub_81C3B08(u8 a)
{
- struct UnkSummaryStruct *r10 = gUnknown_0203CF1C;
- u8 r8 = sub_81C2D2C(&gUnknown_0861CD14, 0);
- u8 sp = sub_81C2D2C(&gUnknown_0861CD14, 1);
- u8 r6;
- u8 r5;
- u8 *text;
- int offset;
- u16 move;
- if (r10->summary.moves[a] != 0)
+ u8 pp;
+ u32 ppState;
+ const u8 *text;
+ u32 offset;
+ struct UnkSummaryStruct *summaryStruct = gUnknown_0203CF1C;
+ u8 r8 = sub_81C2D2C(gUnknown_0861CD14, 0);
+ u8 sp = sub_81C2D2C(gUnknown_0861CD14, 1);
+ u16 move = summaryStruct->summary.moves[a];
+
+ if (move != 0)
{
- move = r10->summary.moves[a];
- r6 = CalculatePPWithBonus(move, r10->summary.ppBonuses, a);
- sub_81C25A4(r8, gMoveNames[move], 0, (a<<4) + 1, 0, 1);
- ConvertIntToDecimalStringN(gStringVar1, r10->summary.pp[a], 1, 2);
- ConvertIntToDecimalStringN(gStringVar2, r6, 1, 2);
+ pp = CalculatePPWithBonus(move, summaryStruct->summary.ppBonuses, a);
+ sub_81C25A4(r8, gMoveNames[move], 0, a * 16 + 1, 0, 1);
+ ConvertIntToDecimalStringN(gStringVar1, summaryStruct->summary.pp[a], 1, 2);
+ ConvertIntToDecimalStringN(gStringVar2, pp, 1, 2);
DynamicPlaceholderTextUtil_Reset();
DynamicPlaceholderTextUtil_SetPlaceholderPtr(0, gStringVar1);
DynamicPlaceholderTextUtil_SetPlaceholderPtr(1, gStringVar2);
DynamicPlaceholderTextUtil_ExpandPlaceholders(gStringVar4, gUnknown_0861CE97);
text = gStringVar4;
- r5 = GetCurrentPpToMaxPpState(r10->summary.pp[a], r6) + 9;
+ ppState = GetCurrentPpToMaxPpState(summaryStruct->summary.pp[a], pp) + 9;
offset = GetStringRightAlignXOffset(1, text, 0x2C);
}
else
{
- sub_81C25A4(r8, gText_OneDash, 0, (a<<4) + 1, 0, 1);
+ sub_81C25A4(r8, gText_OneDash, 0, a * 16 + 1, 0, 1);
text = gText_TwoDashes;
- r5 = 12;
+ ppState = 12;
offset = GetStringCenterAlignXOffset(1, text, 0x2C);
}
- sub_81C25A4(sp, text, offset, (a<<4), 0, r5);
-}
-#else
-NAKED
-void sub_81C3B08(u8 a)
-{
- asm(".syntax unified\n\
- push {r4-r7,lr}\n\
- mov r7, r10\n\
- mov r6, r9\n\
- mov r5, r8\n\
- push {r5-r7}\n\
- sub sp, 0xC\n\
- lsls r0, 24\n\
- lsrs r7, r0, 24\n\
- ldr r0, =gUnknown_0203CF1C\n\
- ldr r0, [r0]\n\
- mov r10, r0\n\
- ldr r4, =gUnknown_0861CD14\n\
- adds r0, r4, 0\n\
- movs r1, 0\n\
- bl sub_81C2D2C\n\
- lsls r0, 24\n\
- lsrs r0, 24\n\
- mov r8, r0\n\
- adds r0, r4, 0\n\
- movs r1, 0x1\n\
- bl sub_81C2D2C\n\
- lsls r0, 24\n\
- lsrs r0, 24\n\
- str r0, [sp, 0x8]\n\
- lsls r1, r7, 1\n\
- mov r0, r10\n\
- adds r0, 0x84\n\
- adds r0, r1\n\
- ldrh r5, [r0]\n\
- cmp r5, 0\n\
- beq _081C3C00\n\
- mov r0, r10\n\
- adds r0, 0xA4\n\
- ldrb r1, [r0]\n\
- adds r0, r5, 0\n\
- adds r2, r7, 0\n\
- bl CalculatePPWithBonus\n\
- adds r6, r0, 0\n\
- lsls r6, 24\n\
- lsrs r6, 24\n\
- movs r0, 0xD\n\
- adds r1, r5, 0\n\
- muls r1, r0\n\
- ldr r0, =gMoveNames\n\
- adds r1, r0\n\
- lsls r0, r7, 4\n\
- mov r9, r0\n\
- mov r3, r9\n\
- adds r3, 0x1\n\
- lsls r3, 24\n\
- lsrs r3, 24\n\
- movs r0, 0\n\
- str r0, [sp]\n\
- movs r0, 0x1\n\
- str r0, [sp, 0x4]\n\
- mov r0, r8\n\
- movs r2, 0\n\
- bl sub_81C25A4\n\
- ldr r0, =gStringVar1\n\
- mov r8, r0\n\
- mov r5, r10\n\
- adds r5, 0x8C\n\
- adds r5, r7\n\
- ldrb r1, [r5]\n\
- movs r2, 0x1\n\
- movs r3, 0x2\n\
- bl ConvertIntToDecimalStringN\n\
- ldr r4, =gStringVar2\n\
- adds r0, r4, 0\n\
- adds r1, r6, 0\n\
- movs r2, 0x1\n\
- movs r3, 0x2\n\
- bl ConvertIntToDecimalStringN\n\
- bl DynamicPlaceholderTextUtil_Reset\n\
- movs r0, 0\n\
- mov r1, r8\n\
- bl DynamicPlaceholderTextUtil_SetPlaceholderPtr\n\
- movs r0, 0x1\n\
- adds r1, r4, 0\n\
- bl DynamicPlaceholderTextUtil_SetPlaceholderPtr\n\
- ldr r4, =gStringVar4\n\
- ldr r1, =gUnknown_0861CE97\n\
- adds r0, r4, 0\n\
- bl DynamicPlaceholderTextUtil_ExpandPlaceholders\n\
- adds r7, r4, 0\n\
- ldrb r0, [r5]\n\
- adds r1, r6, 0\n\
- bl GetCurrentPpToMaxPpState\n\
- lsls r0, 24\n\
- lsrs r0, 24\n\
- adds r5, r0, 0\n\
- adds r5, 0x9\n\
- movs r0, 0x1\n\
- adds r1, r7, 0\n\
- movs r2, 0x2C\n\
- bl GetStringRightAlignXOffset\n\
- mov r4, r9\n\
- b _081C3C26\n\
- .pool\n\
-_081C3C00:\n\
- ldr r1, =gText_OneDash\n\
- lsls r4, r7, 4\n\
- adds r3, r4, 0x1\n\
- lsls r3, 24\n\
- lsrs r3, 24\n\
- str r5, [sp]\n\
- movs r0, 0x1\n\
- str r0, [sp, 0x4]\n\
- mov r0, r8\n\
- movs r2, 0\n\
- bl sub_81C25A4\n\
- ldr r7, =gText_TwoDashes\n\
- movs r5, 0xC\n\
- movs r0, 0x1\n\
- adds r1, r7, 0\n\
- movs r2, 0x2C\n\
- bl GetStringCenterAlignXOffset\n\
-_081C3C26:\n\
- lsls r2, r0, 24\n\
- lsrs r2, 24\n\
- adds r3, r4, 0x1\n\
- lsls r3, 24\n\
- lsrs r3, 24\n\
- movs r0, 0\n\
- str r0, [sp]\n\
- lsls r0, r5, 24\n\
- lsrs r0, 24\n\
- str r0, [sp, 0x4]\n\
- ldr r0, [sp, 0x8]\n\
- adds r1, r7, 0\n\
- bl sub_81C25A4\n\
- add sp, 0xC\n\
- pop {r3-r5}\n\
- mov r8, r3\n\
- mov r9, r4\n\
- mov r10, r5\n\
- pop {r4-r7}\n\
- pop {r0}\n\
- bx r0\n\
- .pool\n\
- .syntax divided\n");
+ sub_81C25A4(sp, text, offset, a * 16 + 1, 0, ppState);
}
-#endif
void sub_81C3C5C(u16 move)
{
- u8 *text;
+ const u8 *text;
if (move != 0)
{
FillWindowPixelRect(14, 0, 0x35, 0, 0x13, 0x20);
@@ -3537,16 +3477,16 @@ void sub_81C3C5C(u16 move)
}
}
-void sub_81C3D08()
+void sub_81C3D08(void)
{
sub_81C3B08(0);
sub_81C3B08(1);
sub_81C3B08(2);
sub_81C3B08(3);
- if (gUnknown_0203CF1C->unk40BC == 3)
+ if (gUnknown_0203CF1C->mode == 3)
{
sub_81C3F44();
- sub_81C3E2C(gUnknown_0203CF1C->unk40C6);
+ sub_81C3E2C(gUnknown_0203CF1C->firstMoveIndex);
}
}
@@ -3570,14 +3510,14 @@ void sub_81C3D54(u8 taskId)
sub_81C3B08(3);
break;
case 4:
- if (gUnknown_0203CF1C->unk40BC == 3)
+ if (gUnknown_0203CF1C->mode == 3)
sub_81C3F44();
break;
case 5:
- if (gUnknown_0203CF1C->unk40BC == 3)
+ if (gUnknown_0203CF1C->mode == 3)
{
- if (!(gUnknown_0203CF1C->unk40C4 == 0 && gUnknown_0203CF1C->unk40C6 == 4))
- sub_81C3E2C(gUnknown_0203CF1C->unk40C6);
+ if (!(gUnknown_0203CF1C->newMove == MOVE_NONE && gUnknown_0203CF1C->firstMoveIndex == MAX_MON_MOVES))
+ sub_81C3E2C(gUnknown_0203CF1C->firstMoveIndex);
}
break;
case 6:
@@ -3592,20 +3532,20 @@ void sub_81C3E2C(u8 moveSlot)
u16 move;
if (moveSlot == 4)
- move = gUnknown_0203CF1C->unk40C4;
+ move = gUnknown_0203CF1C->newMove;
else
move = gUnknown_0203CF1C->summary.moves[moveSlot];
if (move != MOVE_NONE)
{
- u8 windowId = sub_81C2D2C(&gUnknown_0861CD14, 2);
+ u8 windowId = sub_81C2D2C(gUnknown_0861CD14, 2);
sub_81C25A4(windowId, gContestEffectDescriptionPointers[gContestMoves[move].effect], 6, 1, 0, 0);
}
}
void sub_81C3E9C(u16 move)
{
- u8 windowId = sub_81C2D2C(&gUnknown_0861CD14, 2);
+ u8 windowId = sub_81C2D2C(gUnknown_0861CD14, 2);
FillWindowPixelBuffer(windowId, 0);
if (move != MOVE_NONE)
{
@@ -3630,15 +3570,15 @@ void sub_81C3E9C(u16 move)
void sub_81C3F44(void)
{
- u8 windowId1 = sub_81C2D2C(&gUnknown_0861CD14, 0);
- u8 windowId2 = sub_81C2D2C(&gUnknown_0861CD14, 1);
- if (gUnknown_0203CF1C->unk40C4 == MOVE_NONE)
+ u8 windowId1 = sub_81C2D2C(gUnknown_0861CD14, 0);
+ u8 windowId2 = sub_81C2D2C(gUnknown_0861CD14, 1);
+ if (gUnknown_0203CF1C->newMove == MOVE_NONE)
{
sub_81C25A4(windowId1, gText_Cancel, 0, 0x41, 0, 1);
}
else
{
- u16 move = gUnknown_0203CF1C->unk40C4;
+ u16 move = gUnknown_0203CF1C->newMove;
if (gUnknown_0203CF1C->unk40C0 == 2)
sub_81C25A4(windowId1, gMoveNames[move], 0, 0x41, 0, 6);
else
@@ -3655,15 +3595,15 @@ void sub_81C3F44(void)
void sub_81C4064(void)
{
- u8 windowId = sub_81C2D2C(&gUnknown_0861CD14, 0);
+ u8 windowId = sub_81C2D2C(gUnknown_0861CD14, 0);
FillWindowPixelRect(windowId, 0, 0, 0x42, 0x48, 0x10);
CopyWindowToVram(windowId, 2);
}
void sub_81C40A0(u8 a, u8 b)
{
- u8 windowId1 = sub_81C2D2C(&gUnknown_0861CD14, 0);
- u8 windowId2 = sub_81C2D2C(&gUnknown_0861CD14, 1);
+ u8 windowId1 = sub_81C2D2C(gUnknown_0861CD14, 0);
+ u8 windowId2 = sub_81C2D2C(gUnknown_0861CD14, 1);
FillWindowPixelRect(windowId1, 0, 0, a * 16, 0x48, 0x10);
FillWindowPixelRect(windowId1, 0, 0, b * 16, 0x48, 0x10);
@@ -3677,7 +3617,7 @@ void sub_81C40A0(u8 a, u8 b)
void sub_81C4154(void)
{
- u8 windowId = sub_81C2D2C(&gUnknown_0861CD14, 2);
+ u8 windowId = sub_81C2D2C(gUnknown_0861CD14, 2);
FillWindowPixelBuffer(windowId, 0);
sub_81C25A4(windowId, gText_HMMovesCantBeForgotten2, 6, 1, 0, 0);
}
@@ -3687,21 +3627,21 @@ void sub_81C4190(void)
u8 i;
for (i = 0; i < 28; i++)
- gUnknown_0203CF1C->unk40D3[i] |= 0xFF;
+ gUnknown_0203CF1C->spriteIds[i] |= 0xFF;
}
void sub_81C41C0(u8 spriteArrayId)
{
- if (gUnknown_0203CF1C->unk40D3[spriteArrayId] != 0xFF)
+ if (gUnknown_0203CF1C->spriteIds[spriteArrayId] != 0xFF)
{
- DestroySprite(&gSprites[gUnknown_0203CF1C->unk40D3[spriteArrayId]]);
- gUnknown_0203CF1C->unk40D3[spriteArrayId] = 0xFF;
+ DestroySprite(&gSprites[gUnknown_0203CF1C->spriteIds[spriteArrayId]]);
+ gUnknown_0203CF1C->spriteIds[spriteArrayId] = 0xFF;
}
}
void sub_81C4204(u8 spriteArrayId, bool8 invisible)
{
- gSprites[gUnknown_0203CF1C->unk40D3[spriteArrayId]].invisible = invisible;
+ gSprites[gUnknown_0203CF1C->spriteIds[spriteArrayId]].invisible = invisible;
}
void sub_81C424C(void)
@@ -3710,7 +3650,7 @@ void sub_81C424C(void)
for (i = 3; i < 28; i++)
{
- if (gUnknown_0203CF1C->unk40D3[i] != 0xFF)
+ if (gUnknown_0203CF1C->spriteIds[i] != 0xFF)
sub_81C4204(i, TRUE);
}
}
@@ -3739,18 +3679,16 @@ void sub_81C42C8(void)
for (i = 3; i < 8; i++)
{
- if (gUnknown_0203CF1C->unk40D3[i] == 0xFF)
- gUnknown_0203CF1C->unk40D3[i] = CreateSprite(&gUnknown_0861CFC4, 0, 0, 2);
+ if (gUnknown_0203CF1C->spriteIds[i] == 0xFF)
+ gUnknown_0203CF1C->spriteIds[i] = CreateSprite(&gUnknown_0861CFC4, 0, 0, 2);
sub_81C4204(i, TRUE);
}
}
-extern const u8 gUnknown_0861CFDC[];
-
void sub_81C4318(u8 typeId, u8 x, u8 y, u8 spriteArrayId)
{
- struct Sprite *sprite = &gSprites[gUnknown_0203CF1C->unk40D3[spriteArrayId]];
+ struct Sprite *sprite = &gSprites[gUnknown_0203CF1C->spriteIds[spriteArrayId]];
StartSpriteAnim(sprite, typeId);
sprite->oam.paletteNum = gUnknown_0861CFDC[typeId];
sprite->pos1.x = x + 16;
@@ -3809,15 +3747,351 @@ void sub_81C4484(void)
void sub_81C44F0(void)
{
- if (gUnknown_0203CF1C->unk40C4 == MOVE_NONE)
+ if (gUnknown_0203CF1C->newMove == MOVE_NONE)
{
sub_81C4204(7, TRUE);
}
else
{
if (gUnknown_0203CF1C->unk40C0 == 2)
- sub_81C4318(gBattleMoves[gUnknown_0203CF1C->unk40C4].type, 0x55, 0x60, 7);
+ sub_81C4318(gBattleMoves[gUnknown_0203CF1C->newMove].type, 0x55, 0x60, 7);
+ else
+ sub_81C4318(NUMBER_OF_MON_TYPES + gContestMoves[gUnknown_0203CF1C->newMove].contestCategory, 0x55, 0x60, 7);
+ }
+}
+
+void sub_81C4568(u8 a0, u8 a1)
+{
+ struct Sprite *sprite1 = &gSprites[gUnknown_0203CF1C->spriteIds[a0 + 3]];
+ struct Sprite *sprite2 = &gSprites[gUnknown_0203CF1C->spriteIds[a1 + 3]];
+
+ u8 temp = sprite1->animNum;
+ sprite1->animNum = sprite2->animNum;
+ sprite2->animNum = temp;
+
+ temp = sprite1->oam.paletteNum;
+ sprite1->oam.paletteNum = sprite2->oam.paletteNum;
+ sprite2->oam.paletteNum = temp;
+
+ sprite1->animBeginning = TRUE;
+ sprite1->animEnded = FALSE;
+ sprite2->animBeginning = TRUE;
+ sprite2->animEnded = FALSE;
+}
+
+u8 sub_81C45F4(struct Pokemon *mon, s16 *a1)
+{
+ const struct CompressedSpritePalette *pal;
+ struct PokeSummary *summary = &gUnknown_0203CF1C->summary;
+
+ switch (*a1)
+ {
+ default:
+ return sub_81C47B4(mon);
+ case 0:
+ if (gMain.inBattle)
+ {
+ if (sub_80688F8(3, gUnknown_0203CF1C->curMonIndex))
+ {
+ HandleLoadSpecialPokePic_DontHandleDeoxys(&gMonFrontPicTable[summary->species2], gMonSpritesGfxPtr->sprites[1], summary->species2, summary->pid);
+ }
+ else
+ {
+ HandleLoadSpecialPokePic_2(&gMonFrontPicTable[summary->species2], gMonSpritesGfxPtr->sprites[1], summary->species2, summary->pid);
+ }
+ }
+ else
+ {
+ if (gMonSpritesGfxPtr != NULL)
+ {
+ if (gUnknown_0203CF1C->monList.mons == gPlayerParty || gUnknown_0203CF1C->mode == 2 || gUnknown_0203CF1C->unk40EF == TRUE)
+ {
+ HandleLoadSpecialPokePic_2(&gMonFrontPicTable[summary->species2], gMonSpritesGfxPtr->sprites[1], summary->species2, summary->pid);
+ }
+ else
+ {
+ HandleLoadSpecialPokePic_DontHandleDeoxys(&gMonFrontPicTable[summary->species2], gMonSpritesGfxPtr->sprites[1], summary->species2, summary->pid);
+ }
+ }
+ else
+ {
+ if (gUnknown_0203CF1C->monList.mons == gPlayerParty || gUnknown_0203CF1C->mode == 2 || gUnknown_0203CF1C->unk40EF == TRUE)
+ {
+ HandleLoadSpecialPokePic_2(&gMonFrontPicTable[summary->species2], sub_806F4F8(0, 1), summary->species2, summary->pid);
+ }
+ else
+ {
+ HandleLoadSpecialPokePic_DontHandleDeoxys(&gMonFrontPicTable[summary->species2], sub_806F4F8(0, 1), summary->species2, summary->pid);
+ }
+ }
+ }
+ (*a1)++;
+ return -1;
+ case 1:
+ pal = GetMonSpritePalStructFromOtIdPersonality(summary->species2, summary->OTID, summary->pid);
+ LoadCompressedObjectPalette(pal);
+ SetMultiuseSpriteTemplateToPokemon(pal->tag, 1);
+ (*a1)++;
+ return -1;
+ }
+}
+
+void sub_81C4778(void)
+{
+ struct PokeSummary *summary = &gUnknown_0203CF1C->summary;
+ if (!summary->isEgg)
+ {
+ if (ShouldPlayNormalMonCry(&gUnknown_0203CF1C->currentMon) == TRUE)
+ {
+ PlayCry3(summary->species2, 0, 0);
+ }
+ else
+ {
+ PlayCry3(summary->species2, 0, 11);
+ }
+ }
+}
+
+u8 sub_81C47B4(struct Pokemon *unused)
+{
+ struct PokeSummary *summary = &gUnknown_0203CF1C->summary;
+ u8 spriteId = CreateSprite(&gMultiuseSpriteTemplate, 40, 64, 5);
+ struct Sprite *sprite = &gSprites[spriteId];
+
+ FreeSpriteOamMatrix(sprite);
+
+ sprite->data[0] = summary->species2;
+ sprite->data[2] = 0;
+ gSprites[spriteId].callback = sub_81C4844;
+ sprite->oam.priority = 0;
+
+ if (!IsMonSpriteNotFlipped(summary->species2))
+ {
+ sprite->hFlip = TRUE;
+ }
+ else
+ {
+ sprite->hFlip = FALSE;
+ }
+
+ return spriteId;
+}
+
+void sub_81C4844(struct Sprite *sprite)
+{
+ struct PokeSummary *summary = &gUnknown_0203CF1C->summary;
+
+ if (!gPaletteFade.active && sprite->data[2] != 1)
+ {
+ sprite->data[1] = IsMonSpriteNotFlipped(sprite->data[0]);
+ sub_81C4778();
+ PokemonSummaryDoMonAnimation(sprite, sprite->data[0], summary->isEgg);
+ }
+}
+
+void sub_81C488C(u8 a0)
+{
+ sUnusedTaskId = a0;
+}
+
+void sub_81C4898(void)
+{
+ if (sUnusedTaskId != 0xFF)
+ {
+ DestroyTask(sUnusedTaskId);
+ sUnusedTaskId = 0xFF;
+ }
+}
+
+bool32 sub_81C48B4(void)
+{
+ if (gSprites[gUnknown_0203CF1C->spriteIds[0]].callback == SpriteCallbackDummy)
+ {
+ return FALSE;
+ }
+ else
+ {
+ return TRUE;
+ }
+}
+
+void sub_81C48F0(void)
+{
+ u16 i;
+ u16 paletteIndex;
+
+ gSprites[gUnknown_0203CF1C->spriteIds[0]].animPaused = TRUE;
+ gSprites[gUnknown_0203CF1C->spriteIds[0]].callback = SpriteCallbackDummy;
+ sub_806EE98();
+
+ paletteIndex = (gSprites[gUnknown_0203CF1C->spriteIds[0]].oam.paletteNum * 16) | 0x100;
+
+ for (i = 0; i < 16; i++)
+ {
+ gPlttBufferUnfaded[(u16)(i + paletteIndex)] = gPlttBufferFaded[(u16)(i + paletteIndex)];
+ }
+}
+
+void sub_81C4984(struct Pokemon *mon)
+{
+ struct Sprite *sprite = sub_811FF94(30003, 30003, gUnknown_0861D120);
+
+ gUnknown_0203CF1C->markingsSpriteId = sprite;
+
+ if (sprite != NULL)
+ {
+ StartSpriteAnim(sprite, GetMonData(mon, MON_DATA_MARKINGS));
+ gUnknown_0203CF1C->markingsSpriteId->pos1.x = 60;
+ gUnknown_0203CF1C->markingsSpriteId->pos1.y = 26;
+ gUnknown_0203CF1C->markingsSpriteId->oam.priority = 1;
+ }
+}
+
+void sub_81C49E0(struct Pokemon *mon)
+{
+ DestroySprite(gUnknown_0203CF1C->markingsSpriteId);
+ FreeSpriteTilesByTag(30003);
+ sub_81C4984(mon);
+}
+
+void sub_81C4A08(struct Pokemon *mon)
+{
+ u8 ball = ItemIdToBallId(GetMonData(mon, MON_DATA_POKEBALL));
+
+ LoadBallGfx(ball);
+ gUnknown_0203CF1C->spriteIds[1] = CreateSprite(&gBallSpriteTemplates[ball], 16, 136, 0);
+ gSprites[gUnknown_0203CF1C->spriteIds[1]].callback = SpriteCallbackDummy;
+ gSprites[gUnknown_0203CF1C->spriteIds[1]].oam.priority = 3;
+}
+
+void sub_81C4A88(void)
+{
+ u8 *spriteId = &gUnknown_0203CF1C->spriteIds[2];
+ u8 anim;
+
+ if (*spriteId == 0xFF)
+ {
+ *spriteId = CreateSprite(&gUnknown_0861D108, 64, 152, 0);
+ }
+
+ anim = sub_81B205C(&gUnknown_0203CF1C->currentMon);
+
+ if (anim != 0)
+ {
+ StartSpriteAnim(&gSprites[*spriteId], anim - 1);
+ sub_81C4204(2, FALSE);
+ }
+ else
+ {
+ sub_81C4204(2, TRUE);
+ }
+}
+
+void sub_81C4AF8(u8 a0)
+{
+ u8 i;
+ u8 *spriteIds = &gUnknown_0203CF1C->spriteIds[a0];
+
+ if (gUnknown_0203CF1C->unk40C0 > 1)
+ {
+ u8 subsprite = 0;
+ if (a0 == 8)
+ {
+ subsprite = 1;
+ }
+
+ for (i = 0; i < 10; i++)
+ {
+ spriteIds[i] = CreateSprite(&gUnknown_0861D084, i * 16 + 89, 40, subsprite);
+ if (i == 0)
+ {
+ StartSpriteAnim(&gSprites[spriteIds[0]], 4);
+ }
+ else if (i == 9)
+ {
+ StartSpriteAnim(&gSprites[spriteIds[9]], 5);
+ }
+ else
+ {
+ StartSpriteAnim(&gSprites[spriteIds[i]], 6);
+ }
+ gSprites[spriteIds[i]].callback = sub_81C4BE4;
+ gSprites[spriteIds[i]].data[0] = a0;
+ gSprites[spriteIds[i]].data[1] = 0;
+ }
+ }
+}
+
+void sub_81C4BE4(struct Sprite *sprite)
+{
+ if (sprite->animNum > 3 && sprite->animNum < 7)
+ {
+ sprite->data[1] = (sprite->data[1] + 1) & 0x1F;
+ if (sprite->data[1] > 24)
+ {
+ sprite->invisible = TRUE;
+ }
else
- sub_81C4318(NUMBER_OF_MON_TYPES + gContestMoves[gUnknown_0203CF1C->unk40C4].contestCategory, 0x55, 0x60, 7);
+ {
+ sprite->invisible = FALSE;
+ }
+ }
+ else
+ {
+ sprite->data[1] = 0;
+ sprite->invisible = FALSE;
+ }
+
+ if (sprite->data[0] == 8)
+ {
+ sprite->pos2.y = gUnknown_0203CF1C->firstMoveIndex * 16;
+ }
+ else
+ {
+ sprite->pos2.y = gUnknown_0203CF1C->secondMoveIndex * 16;
+ }
+}
+
+void sub_81C4C60(u8 a0)
+{
+ u8 i;
+ for (i = 0; i < 10; i++)
+ {
+ sub_81C41C0(a0 + i);
+ }
+}
+
+void sub_81C4C84(u8 a0)
+{
+ u8 i;
+ u8 *spriteIds = &gUnknown_0203CF1C->spriteIds[8];
+ a0 *= 3;
+
+ for (i = 0; i < 10; i++)
+ {
+ if (i == 0)
+ {
+ StartSpriteAnim(&gSprites[spriteIds[0]], a0 + 4);
+ }
+ else if (i == 9)
+ {
+ StartSpriteAnim(&gSprites[spriteIds[9]], a0 + 5);
+ }
+ else
+ {
+ StartSpriteAnim(&gSprites[spriteIds[i]], a0 + 6);
+ }
+ }
+}
+
+void sub_81C4D18(u8 a0)
+{
+ u8 i;
+ u8 *spriteIds = &gUnknown_0203CF1C->spriteIds[a0];
+
+ for (i = 0; i < 10; i++)
+ {
+ gSprites[spriteIds[i]].data[1] = 0;
+ gSprites[spriteIds[i]].invisible = FALSE;
}
}
diff --git a/src/unk_pokedex_area_screen_helper.c b/src/unk_pokedex_area_screen_helper.c
new file mode 100644
index 000000000..3bed79a65
--- /dev/null
+++ b/src/unk_pokedex_area_screen_helper.c
@@ -0,0 +1,75 @@
+#include "global.h"
+#include "main.h"
+#include "menu.h"
+#include "bg.h"
+#include "malloc.h"
+#include "palette.h"
+
+EWRAM_DATA u8 *gUnknown_0203CF28 = NULL;
+
+static const u16 gUnknown_0861D140[] = INCBIN_U16("graphics/interface/region_map.gbapal");
+extern const u8 gUnknown_0861D1A0[];
+extern const u8 gUnknown_0861DEF4[];
+extern const u8 gUnknown_0861E208[];
+extern const u8 gUnknown_0861EF64[];
+
+struct UnkStruct_1C4D70
+{
+ u32 bg:2;
+ u32 unk2:8;
+ u32 unk10:2;
+ u32 unk12:20;
+};
+
+void sub_81C4D70(struct UnkStruct_1C4D70 *template)
+{
+ u8 unk;
+ gUnknown_0203CF28 = Alloc(4);
+ unk = template->unk10;
+
+ if (unk == 0)
+ {
+ SetBgAttribute(template->bg, BG_CTRL_ATTR_WRAPAROUND, 0);
+ decompress_and_copy_tile_data_to_vram(template->bg, gUnknown_0861D1A0, 0, template->unk2, unk);
+ sub_8199D3C(decompress_and_copy_tile_data_to_vram(template->bg, gUnknown_0861DEF4, 0, 0, 1), template->unk2, 32, 32, unk);
+ }
+ else
+ {
+ SetBgAttribute(template->bg, BG_CTRL_ATTR_WRAPAROUND, 2);
+ SetBgAttribute(template->bg, 9, 1);
+ decompress_and_copy_tile_data_to_vram(template->bg, gUnknown_0861E208, 0, template->unk2, 0);
+ sub_8199D3C(decompress_and_copy_tile_data_to_vram(template->bg, gUnknown_0861EF64, 0, 0, 1), template->unk2, 64, 64, 1);
+ }
+
+ ChangeBgX(template->bg, 0, 0);
+ ChangeBgY(template->bg, 0, 0);
+ SetBgAttribute(template->bg, BG_CTRL_ATTR_SCREENSIZE, 1);
+ CpuCopy32(gUnknown_0861D140, &gPlttBufferUnfaded[0x70], 0x60);
+ *gUnknown_0203CF28 = template->bg;
+}
+
+bool32 sub_81C4E90(void)
+{
+ if (!free_temp_tile_data_buffers_if_possible())
+ {
+ ShowBg(*gUnknown_0203CF28);
+ return FALSE;
+ }
+ else
+ {
+ return TRUE;
+ }
+}
+
+void sub_81C4EB4(void)
+{
+ if (gUnknown_0203CF28 != NULL)
+ {
+ FREE_AND_SET_NULL(gUnknown_0203CF28);
+ }
+}
+
+void sub_81C4ED0(u32 a0)
+{
+ ChangeBgY(*gUnknown_0203CF28, a0 * 0x100, 0);
+}