summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/bag.c272
-rw-r--r--src/battle_controller_oak_old_man.c4
-rw-r--r--src/battle_controller_player.c2
-rw-r--r--src/battle_controller_pokedude.c11
-rw-r--r--src/battle_main.c6
-rw-r--r--src/battle_message.c4
-rw-r--r--src/berry_pouch.c6
-rw-r--r--src/data.c10
-rw-r--r--src/data/trainer_graphics/back_pic_anims.h8
-rw-r--r--src/data/trainer_graphics/back_pic_tables.h4
-rw-r--r--src/graphics.c0
-rw-r--r--src/item_menu.c2400
-rw-r--r--src/item_menu_icons.c148
-rw-r--r--src/item_pc.c14
-rw-r--r--src/item_use.c34
-rw-r--r--src/menu_helpers.c4
-rw-r--r--src/new_game.c2
-rw-r--r--src/party_menu.c12
-rw-r--r--src/player_pc.c2
-rw-r--r--src/pokemon.c2
-rw-r--r--src/shop.c2
-rw-r--r--src/teachy_tv.c16
-rw-r--r--src/tm_case.c34
23 files changed, 2693 insertions, 304 deletions
diff --git a/src/bag.c b/src/bag.c
index c30bc626d..049aa9f8f 100644
--- a/src/bag.c
+++ b/src/bag.c
@@ -10,17 +10,18 @@
#include "menu.h"
#include "money.h"
#include "bag.h"
+#include "strings.h"
-extern const u8 gText_DepositItem[];
+static const u16 sBagWindowPalF[] = INCBIN_U16("data/bag/bag_window_pal.gbapal");
-const u16 gUnknown_8453098[] = INCBIN_U16("data/bag/bag_window_pal.gbapal");
-const u8 gUnknown_84530B8[][3] = {
+static const u8 sTextColors[][3] = {
{0, 1, 2},
{0, 2, 3},
{0, 3, 2},
{0, 8, 9}
};
-const struct WindowTemplate gUnknown_84530C4[] = {
+
+static const struct WindowTemplate sDefaultBagWindowsStd[] = {
{
.bg = 0,
.tilemapLeft = 0x0b,
@@ -47,7 +48,8 @@ const struct WindowTemplate gUnknown_84530C4[] = {
.baseBlock = 0x01f8
}, DUMMY_WIN_TEMPLATE
};
-const struct WindowTemplate gUnknown_84530E4[] = {
+
+static const struct WindowTemplate sDefaultBagWindowsDeposit[] = {
{
.bg = 0,
.tilemapLeft = 0x0b,
@@ -74,7 +76,8 @@ const struct WindowTemplate gUnknown_84530E4[] = {
.baseBlock = 0x01f8
}, DUMMY_WIN_TEMPLATE
};
-const struct WindowTemplate gUnknown_8453104[] = {
+
+static const struct WindowTemplate sWindowTemplates[] = {
{
.bg = 0,
.tilemapLeft = 24,
@@ -99,122 +102,114 @@ const struct WindowTemplate gUnknown_8453104[] = {
.height = 3,
.paletteNum = 0xC,
.baseBlock = 0x272
- }
-};
-
-const struct WindowTemplate gUnknown_845311C = {
- .bg = 0,
- .tilemapLeft = 23,
- .tilemapTop = 15,
- .width = 6,
- .height = 4,
- .paletteNum = 0xF,
- .baseBlock = 0x28a
-};
-
-const struct WindowTemplate gUnknown_8453124 = {
- .bg = 0,
- .tilemapLeft = 21,
- .tilemapTop = 9,
- .width = 6,
- .height = 4,
- .paletteNum = 0xF,
- .baseBlock = 0x28a
-};
-
-const struct WindowTemplate gUnknown_845312C[] = {
- {
- .bg = 0x00,
- .tilemapLeft = 0x02,
- .tilemapTop = 0x0f,
- .width = 0x1a,
- .height = 0x04,
- .paletteNum = 0x0f,
- .baseBlock = 0x02a2
}, {
- .bg = 0x00,
- .tilemapLeft = 0x06,
- .tilemapTop = 0x0f,
- .width = 0x0e,
- .height = 0x04,
- .paletteNum = 0x0c,
- .baseBlock = 0x02a2
+ .bg = 0,
+ .tilemapLeft = 23,
+ .tilemapTop = 15,
+ .width = 6,
+ .height = 4,
+ .paletteNum = 0xF,
+ .baseBlock = 0x28a
}, {
- .bg = 0x00,
- .tilemapLeft = 0x06,
- .tilemapTop = 0x0f,
- .width = 0x0f,
- .height = 0x04,
- .paletteNum = 0x0c,
- .baseBlock = 0x02da
+ .bg = 0,
+ .tilemapLeft = 21,
+ .tilemapTop = 9,
+ .width = 6,
+ .height = 4,
+ .paletteNum = 0xF,
+ .baseBlock = 0x28a
}, {
- .bg = 0x00,
- .tilemapLeft = 0x06,
- .tilemapTop = 0x0f,
- .width = 0x10,
- .height = 0x04,
- .paletteNum = 0x0c,
- .baseBlock = 0x0316
+ .bg = 0,
+ .tilemapLeft = 2,
+ .tilemapTop = 15,
+ .width = 26,
+ .height = 4,
+ .paletteNum = 0xF,
+ .baseBlock = 0x2a2
}, {
- .bg = 0x00,
- .tilemapLeft = 0x06,
- .tilemapTop = 0x0f,
- .width = 0x17,
- .height = 0x04,
- .paletteNum = 0x0c,
- .baseBlock = 0x0356
+ .bg = 0,
+ .tilemapLeft = 6,
+ .tilemapTop = 15,
+ .width = 14,
+ .height = 4,
+ .paletteNum = 0xC,
+ .baseBlock = 0x2a2
}, {
- .bg = 0x00,
- .tilemapLeft = 0x16,
- .tilemapTop = 0x11,
- .width = 0x07,
- .height = 0x02,
- .paletteNum = 0x0f,
- .baseBlock = 0x020a
+ .bg = 0,
+ .tilemapLeft = 6,
+ .tilemapTop = 15,
+ .width = 15,
+ .height = 4,
+ .paletteNum = 0xC,
+ .baseBlock = 0x2da
}, {
- .bg = 0x00,
- .tilemapLeft = 0x16,
- .tilemapTop = 0x0f,
- .width = 0x07,
- .height = 0x04,
- .paletteNum = 0x0f,
- .baseBlock = 0x020a
+ .bg = 0,
+ .tilemapLeft = 6,
+ .tilemapTop = 15,
+ .width = 16,
+ .height = 4,
+ .paletteNum = 0xC,
+ .baseBlock = 0x316
}, {
- .bg = 0x00,
- .tilemapLeft = 0x16,
- .tilemapTop = 0x0d,
- .width = 0x07,
- .height = 0x06,
- .paletteNum = 0x0f,
- .baseBlock = 0x020a
+ .bg = 0,
+ .tilemapLeft = 6,
+ .tilemapTop = 15,
+ .width = 23,
+ .height = 4,
+ .paletteNum = 0xC,
+ .baseBlock = 0x356
}, {
- .bg = 0x00,
- .tilemapLeft = 0x16,
- .tilemapTop = 0x0b,
- .width = 0x07,
- .height = 0x08,
- .paletteNum = 0x0f,
- .baseBlock = 0x020a
+ .bg = 0,
+ .tilemapLeft = 22,
+ .tilemapTop = 17,
+ .width = 7,
+ .height = 2,
+ .paletteNum = 0xF,
+ .baseBlock = 0x20a
+ }, {
+ .bg = 0,
+ .tilemapLeft = 22,
+ .tilemapTop = 15,
+ .width = 7,
+ .height = 4,
+ .paletteNum = 0xF,
+ .baseBlock = 0x20a
+ }, {
+ .bg = 0,
+ .tilemapLeft = 22,
+ .tilemapTop = 13,
+ .width = 7,
+ .height = 6,
+ .paletteNum = 0xF,
+ .baseBlock = 0x20a
+ }, {
+ .bg = 0,
+ .tilemapLeft = 22,
+ .tilemapTop = 11,
+ .width = 7,
+ .height = 8,
+ .paletteNum = 0xF,
+ .baseBlock = 0x20a
}
};
-const u8 gUnknown_8453174[] = {16, 8, 4};
+static const u8 sUnused_8453174[] = {16, 8, 4};
-EWRAM_DATA u8 gUnknown_203AD34[11] = {};
+static EWRAM_DATA u8 sOpenWindows[11] = {};
-void sub_810B858(void)
+void InitBagWindows(void)
{
u8 i;
- if (gUnknown_203ACFC.location != 3)
- InitWindows(gUnknown_84530C4);
+ if (gBagMenuState.location != 3)
+ InitWindows(sDefaultBagWindowsStd);
else
- InitWindows(gUnknown_84530E4);
+ InitWindows(sDefaultBagWindowsDeposit);
DeactivateAllTextPrinters();
TextWindow_SetUserSelectedFrame(0, 0x64, 0xE0);
TextWindow_LoadResourcesStdFrame0(0, 0x6D, 0xD0);
TextWindow_SetStdFrame0_WithPal(0, 0x81, 0xC0);
- LoadPalette(gUnknown_8453098, 0xF0, 0x20);
+ LoadPalette(sBagWindowPalF, 0xF0, 0x20);
for (i = 0; i < 3; i++)
{
FillWindowPixelBuffer(i, 0x00);
@@ -223,22 +218,22 @@ void sub_810B858(void)
ScheduleBgCopyTilemapToVram(0);
for (i = 0; i < 11; i++)
{
- gUnknown_203AD34[i] = 0xFF;
+ sOpenWindows[i] = 0xFF;
}
}
-void sub_810B8F0(u8 windowId, u8 fontId, const u8 * str, u8 x, u8 y, u8 letterSpacing, u8 lineSpacing, s8 speed, u8 colorIdx)
+void BagPrintTextOnWindow(u8 windowId, u8 fontId, const u8 * str, u8 x, u8 y, u8 letterSpacing, u8 lineSpacing, u8 speed, u8 colorIdx)
{
- AddTextPrinterParameterized4(windowId, fontId, x, y, letterSpacing, lineSpacing, gUnknown_84530B8[colorIdx], speed, str);
+ AddTextPrinterParameterized4(windowId, fontId, x, y, letterSpacing, lineSpacing, sTextColors[colorIdx], speed, str);
}
-void sub_810B958(const u8 * str)
+void BagPrintTextOnWin1CenteredColor0(const u8 * str, u8 unused)
{
u32 x = 0x48 - GetStringWidth(1, str, 0);
- AddTextPrinterParameterized3(2, 1, x / 2, 1, gUnknown_84530B8[0], 0, str);
+ AddTextPrinterParameterized3(2, 1, x / 2, 1, sTextColors[0], 0, str);
}
-void sub_810B994(void)
+void BagDrawDepositItemTextBox(void)
{
u32 x;
DrawStdFrameWithCustomTileAndPalette(2, FALSE, 0x081, 0x0C);
@@ -246,77 +241,76 @@ void sub_810B994(void)
AddTextPrinterParameterized(2, 0, gText_DepositItem, x / 2, 1, 0, NULL);
}
-u8 sub_810B9DC(u8 a0, u8 a1)
+u8 ShowBagWindow(u8 whichWindow, u8 nItems)
{
- if (gUnknown_203AD34[a0] == 0xFF)
+ if (sOpenWindows[whichWindow] == 0xFF)
{
- gUnknown_203AD34[a0] = AddWindow(&gUnknown_8453104[a0 + a1]);
- if (a0 != 6)
+ sOpenWindows[whichWindow] = AddWindow(&sWindowTemplates[whichWindow + nItems]);
+ if (whichWindow != 6)
{
- DrawStdFrameWithCustomTileAndPalette(gUnknown_203AD34[a0], FALSE, 0x064, 0x0E);
+ DrawStdFrameWithCustomTileAndPalette(sOpenWindows[whichWindow], FALSE, 0x064, 0xE);
}
else
{
- DrawStdFrameWithCustomTileAndPalette(gUnknown_203AD34[a0], FALSE, 0x081, 0x0C);
+ DrawStdFrameWithCustomTileAndPalette(sOpenWindows[whichWindow], FALSE, 0x081, 0xC);
}
ScheduleBgCopyTilemapToVram(0);
}
- return gUnknown_203AD34[a0];
+ return sOpenWindows[whichWindow];
}
-void sub_810BA3C(u8 a0)
+void HideBagWindow(u8 whichWindow)
{
- ClearStdWindowAndFrameToTransparent(gUnknown_203AD34[a0], FALSE);
- ClearWindowTilemap(gUnknown_203AD34[a0]);
- RemoveWindow(gUnknown_203AD34[a0]);
+ ClearStdWindowAndFrameToTransparent(sOpenWindows[whichWindow], FALSE);
+ ClearWindowTilemap(sOpenWindows[whichWindow]);
+ RemoveWindow(sOpenWindows[whichWindow]);
ScheduleBgCopyTilemapToVram(0);
- gUnknown_203AD34[a0] = 0xFF;
+ sOpenWindows[whichWindow] = 0xFF;
}
-u8 sub_810BA70(u8 a0)
+u8 OpenBagWindow(u8 whichWindow)
{
- if (gUnknown_203AD34[a0] == 0xFF)
+ if (sOpenWindows[whichWindow] == 0xFF)
{
- gUnknown_203AD34[a0] = AddWindow(&gUnknown_8453104[a0]);
+ sOpenWindows[whichWindow] = AddWindow(&sWindowTemplates[whichWindow]);
}
- return gUnknown_203AD34[a0];
+ return sOpenWindows[whichWindow];
}
-void sub_810BA9C(u8 a0)
+void CloseBagWindow(u8 whichWindow)
{
- if (gUnknown_203AD34[a0] != 0xFF)
+ if (sOpenWindows[whichWindow] != 0xFF)
{
- ClearDialogWindowAndFrameToTransparent(gUnknown_203AD34[a0], FALSE);
- ClearWindowTilemap(gUnknown_203AD34[a0]);
- RemoveWindow(gUnknown_203AD34[a0]);
+ ClearDialogWindowAndFrameToTransparent(sOpenWindows[whichWindow], FALSE);
+ ClearWindowTilemap(sOpenWindows[whichWindow]);
+ RemoveWindow(sOpenWindows[whichWindow]);
PutWindowTilemap(1);
ScheduleBgCopyTilemapToVram(0);
- gUnknown_203AD34[a0] = 0xFF;
-
+ sOpenWindows[whichWindow] = 0xFF;
}
}
-u8 sub_810BAD8(u8 a0)
+u8 GetBagWindow(u8 whichWindow)
{
- return gUnknown_203AD34[a0];
+ return sOpenWindows[whichWindow];
}
-void sub_810BAE8(u8 taskId, const struct YesNoFuncTable * ptrs)
+void BagCreateYesNoMenuBottomRight(u8 taskId, const struct YesNoFuncTable * ptrs)
{
- CreateYesNoMenuWithCallbacks(taskId, &gUnknown_845311C, 2, 0, 2, 0x64, 0x0E, ptrs);
+ CreateYesNoMenuWithCallbacks(taskId, &sWindowTemplates[3], 2, 0, 2, 0x064, 0x0E, ptrs);
}
-void sub_810BB14(u8 taskId, const struct YesNoFuncTable * ptrs)
+void BagCreateYesNoMenuTopRight(u8 taskId, const struct YesNoFuncTable * ptrs)
{
- CreateYesNoMenuWithCallbacks(taskId, &gUnknown_8453124, 2, 0, 2, 0x064, 0x0E, ptrs);
+ CreateYesNoMenuWithCallbacks(taskId, &sWindowTemplates[4], 2, 0, 2, 0x064, 0x0E, ptrs);
}
-void sub_810BB40(void)
+void BagPrintMoneyAmount(void)
{
- PrintMoneyAmountInMoneyBoxWithBorder(sub_810B9DC(2, 0), 0x081, 0x0C, GetMoney(&gSaveBlock1Ptr->money));
+ PrintMoneyAmountInMoneyBoxWithBorder(ShowBagWindow(2, 0), 0x081, 0x0C, GetMoney(&gSaveBlock1Ptr->money));
}
-void sub_810BB74(u8 windowId)
+void BagDrawTextBoxOnWindow(u8 windowId)
{
DrawTextBorderOuter(windowId, 0x064, 0x0E);
}
diff --git a/src/battle_controller_oak_old_man.c b/src/battle_controller_oak_old_man.c
index 6ae50d058..0807018a2 100644
--- a/src/battle_controller_oak_old_man.c
+++ b/src/battle_controller_oak_old_man.c
@@ -379,9 +379,9 @@ static void OpenBagAndChooseItem(void)
nullsub_44();
FreeAllWindowBuffers();
if (gBattleTypeFlags & BATTLE_TYPE_FIRST_BATTLE)
- sub_8107ECC();
+ CB2_BagMenuFromBattle();
else
- sub_810AF74();
+ InitOldManBag();
}
}
diff --git a/src/battle_controller_player.c b/src/battle_controller_player.c
index 7f1f738a3..cb9e04a50 100644
--- a/src/battle_controller_player.c
+++ b/src/battle_controller_player.c
@@ -1330,7 +1330,7 @@ static void OpenBagAndChooseItem(void)
gBattlerControllerFuncs[gActiveBattler] = CompleteWhenChoseItem;
nullsub_44();
FreeAllWindowBuffers();
- sub_8107ECC();
+ CB2_BagMenuFromBattle();
}
}
diff --git a/src/battle_controller_pokedude.c b/src/battle_controller_pokedude.c
index 86da27ee3..d8ebe5ba4 100644
--- a/src/battle_controller_pokedude.c
+++ b/src/battle_controller_pokedude.c
@@ -23,6 +23,7 @@
#include "battle_interface.h"
#include "battle_message.h"
#include "reshow_battle_screen.h"
+#include "teachy_tv.h"
#include "constants/songs.h"
#include "constants/items.h"
#include "constants/moves.h"
@@ -733,15 +734,15 @@ static void OpenBagAndChooseItem(void)
FreeAllWindowBuffers();
switch (gSpecialVar_0x8004)
{
- case 1:
+ case TTVSCR_STATUS:
default:
- callbackId = 7;
+ callbackId = ITEMMENULOCATION_TTVSCR_STATUS;
break;
- case 3:
- callbackId = 8;
+ case TTVSCR_CATCHING:
+ callbackId = ITEMMENULOCATION_TTVSCR_CATCHING;
break;
}
- sub_810B108(callbackId);
+ InitPokedudeBag(callbackId);
}
}
diff --git a/src/battle_main.c b/src/battle_main.c
index 9f3477659..15c264369 100644
--- a/src/battle_main.c
+++ b/src/battle_main.c
@@ -86,7 +86,7 @@ static u8 CreateNPCTrainerParty(struct Pokemon *party, u16 trainerNum);
static void CB2_HandleStartBattle(void);
static void TryCorrectShedinjaLanguage(struct Pokemon *mon);
static void BattleMainCB1(void);
-static void CB2_QuitPokeDudeBattle(void);
+static void CB2_QuitPokedudeBattle(void);
static void sub_80111FC(struct Sprite *sprite);
static void sub_8011B94(void);
static void sub_8011BB0(void);
@@ -1438,7 +1438,7 @@ void BattleMainCB2(void)
gSpecialVar_Result = gBattleOutcome = B_OUTCOME_DREW;
ResetPaletteFadeControl();
BeginNormalPaletteFade(0xFFFFFFFF, 0, 0, 0x10, RGB_BLACK);
- SetMainCallback2(CB2_QuitPokeDudeBattle);
+ SetMainCallback2(CB2_QuitPokedudeBattle);
}
}
@@ -1454,7 +1454,7 @@ void FreeRestoreBattleData(void)
FreeBattleResources();
}
-static void CB2_QuitPokeDudeBattle(void)
+static void CB2_QuitPokedudeBattle(void)
{
UpdatePaletteFade();
if (!gPaletteFade.active)
diff --git a/src/battle_message.c b/src/battle_message.c
index 568682031..5bc0f113f 100644
--- a/src/battle_message.c
+++ b/src/battle_message.c
@@ -463,7 +463,7 @@ const u8 *const gPokeblockWasTooXStringTable[] = {
static const u8 sText_PlayerUsedItem[] = _("{B_PLAYER_NAME} used\n{B_LAST_ITEM}!");
static const u8 sText_OldManUsedItem[] = _("The old man used\n{B_LAST_ITEM}!");
-static const u8 sText_PokeDudeUsedItem[] = _("The POKé DUDE used\n{B_LAST_ITEM}!");
+static const u8 sText_PokedudeUsedItem[] = _("The POKé DUDE used\n{B_LAST_ITEM}!");
static const u8 sText_Trainer1UsedItem[] = _("{B_TRAINER1_CLASS} {B_TRAINER1_NAME}\nused {B_LAST_ITEM}!");
static const u8 sText_TrainerBlockedBall[] = _("The TRAINER blocked the BALL!");
static const u8 sText_DontBeAThief[] = _("Don't be a thief!");
@@ -876,7 +876,7 @@ const u8 *const gBattleStringsTable[] = {
Text_1A5D31,
Text_1A5D6E,
Text_1A5DB1,
- sText_PokeDudeUsedItem,
+ sText_PokedudeUsedItem,
gUnknown_83FDA4D,
gUnknown_83FDA7A,
gUnknown_83FDA8C,
diff --git a/src/berry_pouch.c b/src/berry_pouch.c
index 711a17768..63677574b 100644
--- a/src/berry_pouch.c
+++ b/src/berry_pouch.c
@@ -1269,7 +1269,7 @@ static void Task_ContextMenu_Sell(u8 taskId)
{
CopyItemName(gSpecialVar_ItemId, gStringVar1);
StringExpandPlaceholders(gStringVar4, gText_OhNoICantBuyThat);
- DisplayItemMessageInBerryPouch(taskId, sub_80BF8E4(), gStringVar4, Task_BerryPouch_DestroyDialogueWindowAndRefreshListMenu);
+ DisplayItemMessageInBerryPouch(taskId, GetDialogBoxFontId(), gStringVar4, Task_BerryPouch_DestroyDialogueWindowAndRefreshListMenu);
}
else
{
@@ -1285,7 +1285,7 @@ static void Task_ContextMenu_Sell(u8 taskId)
data[2] = 99;
CopyItemName(gSpecialVar_ItemId, gStringVar1);
StringExpandPlaceholders(gStringVar4, gText_HowManyWouldYouLikeToSell);
- DisplayItemMessageInBerryPouch(taskId, sub_80BF8E4(), gStringVar4, Task_Sell_PrintSelectMultipleUI);
+ DisplayItemMessageInBerryPouch(taskId, GetDialogBoxFontId(), gStringVar4, Task_Sell_PrintSelectMultipleUI);
}
}
}
@@ -1295,7 +1295,7 @@ static void Task_AskSellMultiple(u8 taskId)
s16 * data = gTasks[taskId].data;
ConvertIntToDecimalStringN(gStringVar3, itemid_get_market_price(BagGetItemIdByPocketPosition(POCKET_BERRY_POUCH, data[1])) / 2 * data[8], STR_CONV_MODE_LEFT_ALIGN, 6);
StringExpandPlaceholders(gStringVar4, gText_ICanPayThisMuch_WouldThatBeOkay);
- DisplayItemMessageInBerryPouch(taskId, sub_80BF8E4(), gStringVar4, Task_SellMultiple_CreateYesNoMenu);
+ DisplayItemMessageInBerryPouch(taskId, GetDialogBoxFontId(), gStringVar4, Task_SellMultiple_CreateYesNoMenu);
}
static void Task_SellMultiple_CreateYesNoMenu(u8 taskId)
diff --git a/src/data.c b/src/data.c
index dddeeac51..891c9f94f 100644
--- a/src/data.c
+++ b/src/data.c
@@ -60,12 +60,12 @@ const struct SpriteFrameImage gTrainerBackPicTable_Leaf[] =
gTrainerBackPic_Leaf + 0x2000, 0x0800,
};
-const struct SpriteFrameImage gTrainerBackPicTable_PokeDude[] =
+const struct SpriteFrameImage gTrainerBackPicTable_Pokedude[] =
{
- gTrainerBackPic_PokeDude, 0x0800,
- gTrainerBackPic_PokeDude + 0x0800, 0x0800,
- gTrainerBackPic_PokeDude + 0x1000, 0x0800,
- gTrainerBackPic_PokeDude + 0x1800, 0x0800,
+ gTrainerBackPic_Pokedude, 0x0800,
+ gTrainerBackPic_Pokedude + 0x0800, 0x0800,
+ gTrainerBackPic_Pokedude + 0x1000, 0x0800,
+ gTrainerBackPic_Pokedude + 0x1800, 0x0800,
};
const struct SpriteFrameImage gTrainerBackPicTable_OldMan[] =
diff --git a/src/data/trainer_graphics/back_pic_anims.h b/src/data/trainer_graphics/back_pic_anims.h
index 2e107c21e..833a0cb28 100644
--- a/src/data/trainer_graphics/back_pic_anims.h
+++ b/src/data/trainer_graphics/back_pic_anims.h
@@ -16,7 +16,7 @@ static const union AnimCmd sAnimCmd_Leaf_1[] = {
ANIMCMD_END
};
-static const union AnimCmd sAnimCmd_PokeDude_1[] = {
+static const union AnimCmd sAnimCmd_Pokedude_1[] = {
ANIMCMD_FRAME(1, 24),
ANIMCMD_FRAME(2, 9),
ANIMCMD_FRAME(3, 24),
@@ -60,9 +60,9 @@ const union AnimCmd *const sBackAnims_Leaf[] = {
sAnimCmd_Leaf_1
};
-const union AnimCmd *const sBackAnims_PokeDude[] = {
+const union AnimCmd *const sBackAnims_Pokedude[] = {
sAnim_GeneralFrame0,
- sAnimCmd_PokeDude_1
+ sAnimCmd_Pokedude_1
};
const union AnimCmd *const sBackAnims_OldMan[] = {
@@ -85,6 +85,6 @@ const union AnimCmd *const *const gTrainerBackAnimsPtrTable[] = {
sBackAnims_Leaf,
sBackAnims_RSBrendan,
sBackAnims_RSMay,
- sBackAnims_PokeDude,
+ sBackAnims_Pokedude,
sBackAnims_OldMan
};
diff --git a/src/data/trainer_graphics/back_pic_tables.h b/src/data/trainer_graphics/back_pic_tables.h
index 86e7824c1..4d0c129a8 100644
--- a/src/data/trainer_graphics/back_pic_tables.h
+++ b/src/data/trainer_graphics/back_pic_tables.h
@@ -12,7 +12,7 @@ const struct CompressedSpriteSheet gTrainerBackPicTable[] = {
{ (const u32 *)gTrainerBackPic_Leaf, 0x2800, 1 },
{ (const u32 *)gTrainerBackPic_RSBrendan, 0x2000, 2 },
{ (const u32 *)gTrainerBackPic_RSMay, 0x2000, 3 },
- { (const u32 *)gTrainerBackPic_PokeDude, 0x2000, 4 },
+ { (const u32 *)gTrainerBackPic_Pokedude, 0x2000, 4 },
{ (const u32 *)gTrainerBackPic_OldMan, 0x2000, 5 }
};
@@ -21,6 +21,6 @@ const struct CompressedSpritePalette gTrainerBackPicPaletteTable[] = {
{ gTrainerPalette_LeafBackPic, 1 },
{ gTrainerPalette_RSBrendan1, 2 },
{ gTrainerPalette_RSMay1, 3 },
- { gTrainerPalette_PokeDudeBackPic, 4 },
+ { gTrainerPalette_PokedudeBackPic, 4 },
{ gTrainerPalette_OldManBackPic, 5 }
};
diff --git a/src/graphics.c b/src/graphics.c
new file mode 100644
index 000000000..e69de29bb
--- /dev/null
+++ b/src/graphics.c
diff --git a/src/item_menu.c b/src/item_menu.c
new file mode 100644
index 000000000..ffba2eae9
--- /dev/null
+++ b/src/item_menu.c
@@ -0,0 +1,2400 @@
+#include "global.h"
+#include "gflib.h"
+#include "bag.h"
+#include "battle_controllers.h"
+#include "berry_pouch.h"
+#include "decompress.h"
+#include "event_scripts.h"
+#include "event_object_80688E4.h"
+#include "field_player_avatar.h"
+#include "graphics.h"
+#include "help_system.h"
+#include "item.h"
+#include "item_menu.h"
+#include "item_menu_icons.h"
+#include "item_use.h"
+#include "link.h"
+#include "list_menu.h"
+#include "load_save.h"
+#include "mail_data.h"
+#include "map_name_popup.h"
+#include "menu.h"
+#include "menu_indicators.h"
+#include "money.h"
+#include "new_menu_helpers.h"
+#include "overworld.h"
+#include "party_menu.h"
+#include "pokemon_storage_system.h"
+#include "scanline_effect.h"
+#include "script.h"
+#include "shop.h"
+#include "strings.h"
+#include "teachy_tv.h"
+#include "tm_case.h"
+#include "constants/items.h"
+#include "constants/songs.h"
+
+#define FREE_IF_SET(ptr) ({ if (ptr) Free(ptr); })
+
+struct BagMenuAlloc
+{
+ MainCallback exitCB;
+ u8 itemOriginalLocation;
+ u8 pocketSwitchMode:4;
+ u8 itemMenuIcon:2;
+ u8 inhibitItemDescriptionPrint:2;
+ u16 contextMenuSelectedItem;
+ u8 pocketScrollArrowsTask;
+ u8 pocketSwitchArrowsTask;
+ u8 nItems[3];
+ u8 maxShowed[3];
+ u8 data[4];
+};
+
+struct BagSlots
+{
+ struct ItemSlot bagPocket_Items[BAG_ITEMS_COUNT];
+ struct ItemSlot bagPocket_KeyItems[BAG_KEYITEMS_COUNT];
+ struct ItemSlot bagPocket_PokeBalls[BAG_POKEBALLS_COUNT];
+ u16 itemsAbove[3];
+ u16 cursorPos[3];
+ u16 registeredItem;
+ u16 pocket;
+};
+
+EWRAM_DATA struct BagStruct gBagMenuState = {};
+static EWRAM_DATA struct BagMenuAlloc * sBagMenuDisplay = NULL;
+static EWRAM_DATA void * sBagBgTilemapBuffer = NULL;
+static EWRAM_DATA struct ListMenuItem * sListMenuItems = NULL;
+static EWRAM_DATA u8 (*sListMenuItemStrings)[19] = NULL;
+static EWRAM_DATA u8 sContextMenuItemsBuffer[4] = {};
+static EWRAM_DATA const u8 *sContextMenuItemsPtr = NULL;
+static EWRAM_DATA u8 sContextMenuNumItems = 0;
+static EWRAM_DATA struct BagSlots * sBackupPlayerBag = NULL;
+EWRAM_DATA u16 gSpecialVar_ItemId = ITEM_NONE;
+
+static void CB2_OpenBagMenu(void);
+static bool8 LoadBagMenuGraphics(void);
+static void FadeOutOfBagMenu(void);
+static void Task_WaitFadeOutOfBagMenu(u8 taskId);
+static void NullBagMenuBufferPtrs(void);
+static bool8 BagMenuInitBgsAndAllocTilemapBuffer(void);
+static bool8 DoLoadBagGraphics(void);
+static u8 CreateBagInputHandlerTask(u8 location);
+static bool8 TryAllocListMenuBuffers(void);
+static void Bag_BuildListMenuTemplate(u8 pocket);
+static void BagListMenuGetItemNameColored(u8 *dest, u16 itemId);
+static void BagListMenuMoveCursorFunc(s32 itemIndex, bool8 onInit, struct ListMenu *list);
+static void BagListMenuItemPrintFunc(u8 windowId, s32 itemId, u8 y);
+static void bag_menu_print_cursor(u8 y, u8 colorIdx);
+static void PrintBagPocketName(void);
+static void PrintItemDescriptionOnMessageWindow(s32 itemIndex);
+static void CreatePocketScrollArrowPair(void);
+static void CreatePocketSwitchArrowPair(void);
+static void BagDestroyPocketSwitchArrowPair(void);
+static void CalculateInitialCursorPosAndItemsAbove(void);
+static void UpdatePocketScrollPositions(void);
+static void DestroyBagMenuResources(void);
+static void Task_ItemMenu_WaitFadeAndSwitchToExitCallback(u8 taskId);
+static void Task_AnimateWin0v(u8 taskId);
+static void ShowBagOrBeginWin0OpenTask(void);
+static void All_CalculateNItemsAndMaxShowed(void);
+static void Task_BagMenu_HandleInput(u8 taskId);
+static void Task_ItemContextMenuByLocation(u8 taskId);
+static void Bag_FillMessageBoxWithPalette(u32 a0);
+static u8 ProcessPocketSwitchInput(u8 taskId, u8 pocketId);
+static void SwitchPockets(u8 taskId, s16 direction, bool16 a2);
+static void Task_AnimateSwitchPockets(u8 taskId);
+static void BeginMovingItemInPocket(u8 taskId, s16 itemIndex);
+static void Task_MoveItemInPocket_HandleInput(u8 taskId);
+static void ExecuteMoveItemInPocket(u8 taskId, u32 itemIndex);
+static void AbortMovingItemInPocket(u8 taskId, u32 itemIndex);
+static void CopyBagListBgTileRowToTilemapBuffer(u8 a0);
+static void Task_ItemContext_FieldOrBattle(u8 taskId);
+static void Task_FieldItemContextMenuHandleInput(u8 taskId);
+static void Task_ItemMenuAction_Use(u8 taskId);
+static void Task_ItemMenuAction_Toss(u8 taskId);
+static void Task_ConfirmTossItems(u8 taskId);
+static void Task_TossItem_No(u8 taskId);
+static void Task_SelectQuantityToToss(u8 taskId);
+static void Task_TossItem_Yes(u8 taskId);
+static void Task_WaitAB_RedrawAndReturnToBag(u8 taskId);
+static void Task_ItemMenuAction_ToggleSelect(u8 taskId);
+static void Task_ItemMenuAction_Give(u8 taskId);
+static void Task_PrintThereIsNoPokemon(u8 taskId);
+static void Task_ItemMenuAction_Cancel(u8 taskId);
+static void Task_PrintItemCantBeHeld(u8 taskId);
+static void Task_WaitAButtonAndCloseContextMenu(u8 taskId);
+static void Task_ItemMenuAction_BattleUse(u8 taskId);
+static void Task_ItemContext_FieldGive(u8 taskId);
+static void GoToTMCase_Give(void);
+static void GoToBerryPouch_Give(void);
+static void ReturnToBagMenuFromSubmenu_Give(void);
+static void Task_ItemContext_PcBoxGive(u8 taskId);
+static void GoToTMCase_PCBox(void);
+static void GoToBerryPouch_PCBox(void);
+static void ReturnToBagMenuFromSubmenu_PCBox(void);
+static void Task_ItemContext_Sell(u8 taskId);
+static void GoToTMCase_Sell(void);
+static void GoToBerryPouch_Sell(void);
+static void ReturnToBagMenuFromSubmenu_Sell(void);
+static void Task_PrintSaleConfirmationText(u8 taskId);
+static void Task_ShowSellYesNoMenu(u8 taskId);
+static void Task_SellItem_No(u8 taskId);
+static void Task_InitSaleQuantitySelectInterface(u8 taskId);
+static void UpdateSalePriceDisplay(s32 price);
+static void Task_SelectQuantityToSell(u8 taskId);
+static void Task_SellItem_Yes(u8 taskId);
+static void Task_FinalizeSaleToShop(u8 taskId);
+static void Task_WaitPressAB_AfterSell(u8 taskId);
+static void Task_ItemContext_Deposit(u8 taskId);
+static void Task_SelectQuantityToDeposit(u8 taskId);
+static void Task_TryDoItemDeposit(u8 taskId);
+static bool8 BagIsTutorial(void);
+static void Task_Bag_OldManTutorial(u8 taskId);
+static void Task_Pokedude_FadeFromBag(u8 taskId);
+static void Task_Pokedude_WaitFadeAndExitBag(u8 taskId);
+static void Task_Bag_TeachyTvRegister(u8 taskId);
+static void Task_Bag_TeachyTvCatching(u8 taskId);
+static void Task_Bag_TeachyTvStatus(u8 taskId);
+static void Task_Bag_TeachyTvTMs(u8 taskId);
+
+static const struct BgTemplate sBgTemplates[2] = {
+ {
+ .bg = 0,
+ .charBaseIndex = 0,
+ .mapBaseIndex = 31,
+ .screenSize = 0,
+ .paletteMode = 0,
+ .priority = 0,
+ .baseTile = 0x000
+ }, {
+ .bg = 1,
+ .charBaseIndex = 3,
+ .mapBaseIndex = 30,
+ .screenSize = 0,
+ .paletteMode = 0,
+ .priority = 1,
+ .baseTile = 0x000
+ }
+};
+
+static const u8 *const sPocketNames[] = {
+ gText_Items2,
+ gText_KeyItems2,
+ gText_PokeBalls2
+};
+
+static const u16 sBagListBgTiles[][18] = {
+ INCBIN_U16("graphics/item_menu/bagmap_0.bin"),
+ INCBIN_U16("graphics/item_menu/bagmap_1.bin"),
+ INCBIN_U16("graphics/item_menu/bagmap_2.bin"),
+ INCBIN_U16("graphics/item_menu/bagmap_3.bin"),
+ INCBIN_U16("graphics/item_menu/bagmap_4.bin"),
+ INCBIN_U16("graphics/item_menu/bagmap_5.bin"),
+ INCBIN_U16("graphics/item_menu/bagmap_6.bin"),
+ INCBIN_U16("graphics/item_menu/bagmap_7.bin"),
+ INCBIN_U16("graphics/item_menu/bagmap_8.bin"),
+ INCBIN_U16("graphics/item_menu/bagmap_9.bin"),
+ INCBIN_U16("graphics/item_menu/bagmap_A.bin"),
+ INCBIN_U16("graphics/item_menu/bagmap_B.bin")
+};
+
+static const struct MenuAction sItemMenuContextActions[] = {
+ [ITEMMENUACTION_USE] = {gOtherText_Use, {.void_u8 = Task_ItemMenuAction_Use}},
+ [ITEMMENUACTION_TOSS] = {gOtherText_Toss, {.void_u8 = Task_ItemMenuAction_Toss}},
+ [ITEMMENUACTION_REGISTER] = {gOtherText_Register, {.void_u8 = Task_ItemMenuAction_ToggleSelect}},
+ [ITEMMENUACTION_GIVE] = {gOtherText_Give, {.void_u8 = Task_ItemMenuAction_Give}},
+ [ITEMMENUACTION_CANCEL] = {gFameCheckerText_Cancel, {.void_u8 = Task_ItemMenuAction_Cancel}},
+ [ITEMMENUACTION_BATTLE_USE] = {gOtherText_Use, {.void_u8 = Task_ItemMenuAction_BattleUse}},
+ [ITEMMENUACTION_CHECK] = {gOtherText_Check, {.void_u8 = Task_ItemMenuAction_Use}},
+ [ITEMMENUACTION_OPEN] = {gOtherText_Open, {.void_u8 = Task_ItemMenuAction_Use}},
+ [ITEMMENUACTION_OPEN_BERRIES] = {gOtherText_Open, {.void_u8 = Task_ItemMenuAction_BattleUse}},
+ [ITEMMENUACTION_WALK] = {gOtherText_Walk, {.void_u8 = Task_ItemMenuAction_Use}},
+ [ITEMMENUACTION_DESELECT] = {gOtherText_Deselect, {.void_u8 = Task_ItemMenuAction_ToggleSelect}},
+ [ITEMMENUACTION_DUMMY] = {gString_Dummy, {.void_u8 = NULL}}
+};
+
+static const u8 sContextMenuItems_Field[][4] = {
+ {
+ ITEMMENUACTION_USE,
+ ITEMMENUACTION_GIVE,
+ ITEMMENUACTION_TOSS,
+ ITEMMENUACTION_CANCEL
+ }, {
+ ITEMMENUACTION_USE,
+ ITEMMENUACTION_REGISTER,
+ ITEMMENUACTION_CANCEL,
+ ITEMMENUACTION_DUMMY
+ }, {
+ ITEMMENUACTION_GIVE,
+ ITEMMENUACTION_TOSS,
+ ITEMMENUACTION_CANCEL,
+ ITEMMENUACTION_DUMMY
+ }
+};
+
+static const u8 sContextMenuItems_CheckGiveTossCancel[] = {
+ ITEMMENUACTION_CHECK,
+ ITEMMENUACTION_GIVE,
+ ITEMMENUACTION_TOSS,
+ ITEMMENUACTION_CANCEL
+};
+
+static const u8 sContextMenuItems_GiveIfNotKeyItemPocket[][2] = {
+ {
+ ITEMMENUACTION_GIVE,
+ ITEMMENUACTION_CANCEL
+ }, {
+ ITEMMENUACTION_CANCEL,
+ ITEMMENUACTION_DUMMY
+ }, {
+ ITEMMENUACTION_GIVE,
+ ITEMMENUACTION_CANCEL
+ }
+};
+
+static const u8 sContextMenuItems_Open[] = {
+ ITEMMENUACTION_OPEN,
+ ITEMMENUACTION_CANCEL
+};
+
+static const u8 sContextMenuItems_BattleUse[] = {
+ ITEMMENUACTION_BATTLE_USE,
+ ITEMMENUACTION_CANCEL
+};
+
+static const u8 sContextMenuItems_Cancel[] = {
+ ITEMMENUACTION_CANCEL,
+ ITEMMENUACTION_DUMMY
+};
+
+static const TaskFunc sItemContextTaskFuncs[] = {
+ [ITEMMENULOCATION_FIELD] = Task_ItemContext_FieldOrBattle,
+ [ITEMMENULOCATION_PARTY] = Task_ItemContext_FieldGive,
+ [ITEMMENULOCATION_SHOP] = Task_ItemContext_Sell,
+ [ITEMMENULOCATION_ITEMPC] = Task_ItemContext_Deposit,
+ [ITEMMENULOCATION_PCBOX] = Task_ItemContext_PcBoxGive,
+ [ITEMMENULOCATION_BATTLE] = Task_ItemContext_FieldOrBattle,
+ [ITEMMENULOCATION_OLD_MAN] = NULL
+};
+
+static const struct YesNoFuncTable sYesNoMenu_Toss = {
+ Task_TossItem_Yes,
+ Task_TossItem_No
+};
+
+static const struct YesNoFuncTable sYesNoMenu_Sell = {
+ Task_SellItem_Yes,
+ Task_SellItem_No
+};
+
+static const u8 sListItemTextColor_RegularItem[] = _("{COLOR_HIGHLIGHT_SHADOW RED TRANSPARENT GREEN}");
+
+static const u8 sListItemTextColor_TmCase_BerryPouch[] = _("{COLOR_HIGHLIGHT_SHADOW LIGHT_GRAY TRANSPARENT BLACK}");
+
+static const struct ScrollArrowsTemplate sPocketSwitchArrowPairTemplate = {
+ .firstArrowType = SCROLL_ARROW_LEFT,
+ .firstX = 8,
+ .firstY = 72,
+ .secondArrowType = SCROLL_ARROW_RIGHT,
+ .secondX = 72,
+ .secondY = 72,
+ .fullyUpThreshold = 0,
+ .fullyDownThreshold = 2,
+ .tileTag = 111,
+ .palTag = 111,
+ .palNum = 0,
+};
+
+static const u8 sBlit_SelectButton[] = INCBIN_U8("graphics/interface/select_button.4bpp");
+
+void GoToBagMenu(u8 location, u8 pocket, MainCallback bagCallback)
+{
+ u8 i;
+
+ NullBagMenuBufferPtrs();
+ sBagMenuDisplay = Alloc(sizeof(struct BagMenuAlloc));
+ if (sBagMenuDisplay == NULL)
+ SetMainCallback2(bagCallback);
+ else
+ {
+ if (location != ITEMMENULOCATION_LAST)
+ gBagMenuState.location = location;
+ if (bagCallback != NULL)
+ gBagMenuState.bagCallback = bagCallback;
+ sBagMenuDisplay->exitCB = NULL;
+ sBagMenuDisplay->itemOriginalLocation = 0xFF;
+ sBagMenuDisplay->itemMenuIcon = 0;
+ sBagMenuDisplay->inhibitItemDescriptionPrint = FALSE;
+ sBagMenuDisplay->pocketScrollArrowsTask = 0xFF;
+ sBagMenuDisplay->pocketSwitchArrowsTask = 0xFF;
+ if (location == ITEMMENULOCATION_ITEMPC)
+ sBagMenuDisplay->pocketSwitchMode = 1;
+ else if (location == ITEMMENULOCATION_OLD_MAN)
+ sBagMenuDisplay->pocketSwitchMode = 2;
+ else
+ sBagMenuDisplay->pocketSwitchMode = 0;
+ for (i = 0; i < 4; i++)
+ {
+ sBagMenuDisplay->data[i] = 0;
+ }
+ if (pocket == OPEN_BAG_ITEMS || pocket == OPEN_BAG_KEYITEMS || pocket == OPEN_BAG_POKEBALLS)
+ gBagMenuState.pocket = pocket;
+ gTextFlags.autoScroll = FALSE;
+ gSpecialVar_ItemId = ITEM_NONE;
+ SetMainCallback2(CB2_OpenBagMenu);
+ }
+}
+
+void CB2_BagMenuFromStartMenu(void)
+{
+ GoToBagMenu(ITEMMENULOCATION_FIELD, OPEN_BAG_LAST, CB2_ReturnToFieldWithOpenMenu);
+}
+
+void CB2_BagMenuFromBattle(void)
+{
+ GoToBagMenu(ITEMMENULOCATION_BATTLE, OPEN_BAG_LAST, SetCB2ToReshowScreenAfterMenu2);
+}
+
+static void CB2_BagMenuRun(void)
+{
+ RunTasks();
+ AnimateSprites();
+ BuildOamBuffer();
+ DoScheduledBgTilemapCopiesToVram();
+ UpdatePaletteFade();
+}
+
+static void VBlankCB_BagMenuRun(void)
+{
+ LoadOam();
+ ProcessSpriteCopyRequests();
+ TransferPlttBuffer();
+}
+
+static void CB2_OpenBagMenu(void)
+{
+ while (1)
+ {
+ if ((u8)sub_80BF72C() == TRUE)
+ break;
+ if (LoadBagMenuGraphics() == TRUE)
+ break;
+ if (MenuHelpers_LinkSomething() == TRUE)
+ break;
+ }
+}
+
+static bool8 LoadBagMenuGraphics(void)
+{
+ u8 taskId;
+
+ switch (gMain.state)
+ {
+ case 0:
+ SetVBlankHBlankCallbacksToNull();
+ ClearScheduledBgCopiesToVram();
+ 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:
+ ResetItemMenuIconState();
+ gMain.state++;
+ break;
+ case 6:
+ if (!MenuHelpers_LinkSomething())
+ {
+ ResetTasks();
+ }
+ gMain.state++;
+ break;
+ case 7:
+ if (BagMenuInitBgsAndAllocTilemapBuffer())
+ {
+ sBagMenuDisplay->data[0] = 0;
+ gMain.state++;
+ }
+ else
+ {
+ FadeOutOfBagMenu();
+ return TRUE;
+ }
+ break;
+ case 8:
+ if (DoLoadBagGraphics() == TRUE)
+ gMain.state++;
+ break;
+ case 9:
+ InitBagWindows();
+ gMain.state++;
+ break;
+ case 10:
+ All_CalculateNItemsAndMaxShowed();
+ CalculateInitialCursorPosAndItemsAbove();
+ UpdatePocketScrollPositions();
+ gMain.state++;
+ break;
+ case 11:
+ if (!TryAllocListMenuBuffers())
+ {
+ FadeOutOfBagMenu();
+ return TRUE;
+ }
+ gMain.state++;
+ break;
+ case 12:
+ Bag_BuildListMenuTemplate(gBagMenuState.pocket);
+ gMain.state++;
+ break;
+ case 13:
+ if (gBagMenuState.location != ITEMMENULOCATION_ITEMPC)
+ PrintBagPocketName();
+ else
+ BagDrawDepositItemTextBox();
+ gMain.state++;
+ break;
+ case 14:
+ taskId = CreateBagInputHandlerTask(gBagMenuState.location);
+ gTasks[taskId].data[0] = ListMenuInit(&gMultiuseListMenuTemplate, gBagMenuState.cursorPos[gBagMenuState.pocket], gBagMenuState.itemsAbove[gBagMenuState.pocket]);
+ gTasks[taskId].data[3] = 0;
+ gTasks[taskId].data[8] = 0;
+ gMain.state++;
+ break;
+ case 15:
+ CreateBagOrSatchelSprite(gBagMenuState.pocket);
+ gMain.state++;
+ break;
+ case 16:
+ CreatePocketScrollArrowPair();
+ CreatePocketSwitchArrowPair();
+ gMain.state++;
+ break;
+ case 17:
+ ItemMenuIcons_CreateInsertIndicatorBarHidden();
+ gMain.state++;
+ break;
+ case 18:
+ ShowBagOrBeginWin0OpenTask();
+ gMain.state++;
+ break;
+ case 19:
+ if (gBagMenuState.location == ITEMMENULOCATION_ITEMPC)
+ HelpSystem_SetSomeVariable2(29);
+ else
+ HelpSystem_SetSomeVariable2(9);
+ gPaletteFade.bufferTransferDisabled = FALSE;
+ gMain.state++;
+ break;
+ default:
+ SetVBlankCallback(VBlankCB_BagMenuRun);
+ SetMainCallback2(CB2_BagMenuRun);
+ return TRUE;
+ }
+ return FALSE;
+}
+
+static void FadeOutOfBagMenu(void)
+{
+ BeginNormalPaletteFade(0xFFFFFFFF, -2, 0, 16, RGB_BLACK);
+ CreateTask(Task_WaitFadeOutOfBagMenu, 0);
+ SetVBlankCallback(VBlankCB_BagMenuRun);
+ SetMainCallback2(CB2_BagMenuRun);
+}
+
+static void Task_WaitFadeOutOfBagMenu(u8 taskId)
+{
+ if (!gPaletteFade.active)
+ {
+ SetMainCallback2(gBagMenuState.bagCallback);
+ DestroyBagMenuResources();
+ DestroyTask(taskId);
+ }
+}
+
+static void NullBagMenuBufferPtrs(void)
+{
+ sBagMenuDisplay = NULL;
+ sBagBgTilemapBuffer = NULL;
+ sListMenuItems = NULL;
+ sListMenuItemStrings = NULL;
+}
+
+static bool8 BagMenuInitBgsAndAllocTilemapBuffer(void)
+{
+ void **buff;
+ ResetAllBgsCoordinatesAndBgCntRegs();
+ buff = &sBagBgTilemapBuffer;
+ *buff = Alloc(0x800);
+ if (*buff == NULL)
+ return FALSE;
+ memset(*buff, 0, 0x800);
+ ResetBgsAndClearDma3BusyFlags(FALSE);
+ InitBgsFromTemplates(0, sBgTemplates, NELEMS(sBgTemplates));
+ SetBgTilemapBuffer(1, *buff);
+ ScheduleBgCopyTilemapToVram(1);
+ SetGpuReg(REG_OFFSET_DISPCNT, DISPCNT_OBJ_1D_MAP | DISPCNT_OBJ_ON | DISPCNT_WIN0_ON);
+ ShowBg(0);
+ ShowBg(1);
+ SetGpuReg(REG_OFFSET_BLDCNT, 0);
+ return TRUE;
+}
+
+static bool8 DoLoadBagGraphics(void)
+{
+ switch (sBagMenuDisplay->data[0])
+ {
+ case 0:
+ ResetTempTileDataBuffers();
+ DecompressAndCopyTileDataToVram(1, gUnknown_8E830CC, 0, 0, 0);
+ sBagMenuDisplay->data[0]++;
+ break;
+ case 1:
+ if (FreeTempTileDataBuffersIfPossible() != TRUE)
+ {
+ if (gBagMenuState.location != ITEMMENULOCATION_ITEMPC)
+ LZDecompressWram(gUnknown_8E832C0, sBagBgTilemapBuffer);
+ else
+ LZDecompressWram(gUnknown_8E83444, sBagBgTilemapBuffer);
+ sBagMenuDisplay->data[0]++;
+ }
+ break;
+ case 2:
+ LoadCompressedPalette(gBagBgPalette, 0x00, 0x60);
+ if (!BagIsTutorial() && gSaveBlock2Ptr->playerGender != MALE)
+ LoadCompressedPalette(gBagBgPalette_FemaleOverride, 0x00, 0x20);
+ sBagMenuDisplay->data[0]++;
+ break;
+ case 3:
+ if (BagIsTutorial() == TRUE || gSaveBlock2Ptr->playerGender == MALE)
+ LoadCompressedSpriteSheet(&gSpriteSheet_Backpack);
+ else
+ LoadCompressedSpriteSheet(&gSpriteSheet_Satchel);
+ sBagMenuDisplay->data[0]++;
+ break;
+ case 4:
+ LoadCompressedSpritePalette(&gSpritePalette_BagOrSatchel);
+ sBagMenuDisplay->data[0]++;
+ break;
+ case 5:
+ LoadCompressedSpriteSheet(&gBagSwapSpriteSheet);
+ sBagMenuDisplay->data[0]++;
+ break;
+ default:
+ LoadCompressedSpritePalette(&gBagSwapSpritePalette);
+ sBagMenuDisplay->data[0] = 0;
+ return TRUE;
+ }
+
+ return FALSE;
+}
+
+static u8 CreateBagInputHandlerTask(u8 location)
+{
+ switch (location)
+ {
+ case ITEMMENULOCATION_OLD_MAN:
+ return CreateTask(Task_Bag_OldManTutorial, 0);
+ case ITEMMENULOCATION_TTVSCR_REGISTER:
+ return CreateTask(Task_Bag_TeachyTvRegister, 0);
+ case ITEMMENULOCATION_TTVSCR_TMS:
+ return CreateTask(Task_Bag_TeachyTvTMs, 0);
+ case ITEMMENULOCATION_TTVSCR_STATUS:
+ return CreateTask(Task_Bag_TeachyTvStatus, 0);
+ case ITEMMENULOCATION_TTVSCR_CATCHING:
+ return CreateTask(Task_Bag_TeachyTvCatching, 0);
+ default:
+ return CreateTask(Task_BagMenu_HandleInput, 0);
+ }
+}
+
+static bool8 TryAllocListMenuBuffers(void)
+{
+ // The items pocket has the highest capacity, + 1 for CANCEL
+ sListMenuItems = Alloc((BAG_ITEMS_COUNT + 1) * sizeof(struct ListMenuItem));
+ if (sListMenuItems == NULL)
+ return FALSE;
+ sListMenuItemStrings = Alloc((BAG_ITEMS_COUNT + 1) * sizeof(*sListMenuItemStrings));
+ if (sListMenuItemStrings == NULL)
+ return FALSE;
+ return TRUE;
+}
+
+static void Bag_BuildListMenuTemplate(u8 pocket)
+{
+ u16 i;
+ struct BagPocket * bagPocket = &gBagPockets[pocket];
+ for (i = 0; i < sBagMenuDisplay->nItems[pocket]; i++)
+ {
+ BagListMenuGetItemNameColored(sListMenuItemStrings[i], bagPocket->itemSlots[i].itemId);
+ sListMenuItems[i].label = sListMenuItemStrings[i];
+ sListMenuItems[i].index = i;
+ }
+ StringCopy(sListMenuItemStrings[i], sListItemTextColor_RegularItem);
+ StringAppend(sListMenuItemStrings[i], gFameCheckerText_Cancel);
+ sListMenuItems[i].label = sListMenuItemStrings[i];
+ sListMenuItems[i].index = i;
+ gMultiuseListMenuTemplate.items = sListMenuItems;
+ gMultiuseListMenuTemplate.totalItems = sBagMenuDisplay->nItems[pocket] + 1;
+ gMultiuseListMenuTemplate.windowId = 0;
+ gMultiuseListMenuTemplate.header_X = 0;
+ gMultiuseListMenuTemplate.item_X = 9;
+ gMultiuseListMenuTemplate.cursor_X = 1;
+ gMultiuseListMenuTemplate.lettersSpacing = 0;
+ gMultiuseListMenuTemplate.itemVerticalPadding = 2;
+ gMultiuseListMenuTemplate.upText_Y = 2;
+ gMultiuseListMenuTemplate.maxShowed = sBagMenuDisplay->maxShowed[pocket];
+ gMultiuseListMenuTemplate.fontId = 2;
+ gMultiuseListMenuTemplate.cursorPal = 2;
+ gMultiuseListMenuTemplate.fillValue = 0;
+ gMultiuseListMenuTemplate.cursorShadowPal = 3;
+ gMultiuseListMenuTemplate.moveCursorFunc = BagListMenuMoveCursorFunc;
+ gMultiuseListMenuTemplate.itemPrintFunc = BagListMenuItemPrintFunc;
+ gMultiuseListMenuTemplate.cursorKind = 0;
+ gMultiuseListMenuTemplate.scrollMultiple = 0;
+}
+
+static void BagListMenuGetItemNameColored(u8 *dest, u16 itemId)
+{
+ if (itemId == ITEM_TM_CASE || itemId == ITEM_BERRY_POUCH)
+ StringCopy(dest, sListItemTextColor_TmCase_BerryPouch);
+ else
+ StringCopy(dest, sListItemTextColor_RegularItem);
+ StringAppend(dest, ItemId_GetName(itemId));
+}
+
+static void BagListMenuMoveCursorFunc(s32 itemIndex, bool8 onInit, struct ListMenu *list)
+{
+ if (onInit != TRUE)
+ {
+ PlaySE(SE_BAG1);
+ sub_8098580();
+ }
+ if (sBagMenuDisplay->itemOriginalLocation == 0xFF)
+ {
+ DestroyItemMenuIcon(sBagMenuDisplay->itemMenuIcon ^ 1);
+ if (sBagMenuDisplay->nItems[gBagMenuState.pocket] != itemIndex)
+ CreateItemMenuIcon(BagGetItemIdByPocketPosition(gBagMenuState.pocket + 1, itemIndex), sBagMenuDisplay->itemMenuIcon);
+ else
+ CreateItemMenuIcon(ITEM_N_A, sBagMenuDisplay->itemMenuIcon);
+ sBagMenuDisplay->itemMenuIcon ^= 1;
+ if (!sBagMenuDisplay->inhibitItemDescriptionPrint)
+ PrintItemDescriptionOnMessageWindow(itemIndex);
+ }
+}
+
+static void BagListMenuItemPrintFunc(u8 windowId, s32 itemId, u8 y)
+{
+ u16 bagItemId;
+ u16 bagItemQuantity;
+ if (sBagMenuDisplay->itemOriginalLocation != 0xFF)
+ {
+ if (sBagMenuDisplay->itemOriginalLocation == (u8)itemId)
+ bag_menu_print_cursor(y, 2);
+ else
+ bag_menu_print_cursor(y, 0xFF);
+ }
+ if (itemId != -2 && sBagMenuDisplay->nItems[gBagMenuState.pocket] != itemId)
+ {
+ bagItemId = BagGetItemIdByPocketPosition(gBagMenuState.pocket + 1, itemId);
+ bagItemQuantity = BagGetQuantityByPocketPosition(gBagMenuState.pocket + 1, itemId);
+ if (gBagMenuState.pocket != POCKET_KEY_ITEMS - 1 && !itemid_is_unique(bagItemId))
+ {
+ ConvertIntToDecimalStringN(gStringVar1, bagItemQuantity, STR_CONV_MODE_RIGHT_ALIGN, 3);
+ StringExpandPlaceholders(gStringVar4, gText_TimesStrVar1);
+ BagPrintTextOnWindow(windowId, 0, gStringVar4, 0x6e, y, 0, 0, 0xFF, 1);
+ }
+ else if (gSaveBlock1Ptr->registeredItem != ITEM_NONE && gSaveBlock1Ptr->registeredItem == bagItemId)
+ {
+ BlitBitmapToWindow(windowId, sBlit_SelectButton, 0x70, y, 0x18, 0x10);
+ }
+ }
+}
+
+static void bag_menu_print_cursor_(u8 taskId, u8 colorIdx)
+{
+ bag_menu_print_cursor(ListMenuGetYCoordForPrintingArrowCursor(taskId), colorIdx);
+}
+
+static void bag_menu_print_cursor(u8 y, u8 colorIdx)
+{
+ if (colorIdx == 0xFF)
+ {
+ FillWindowPixelRect(0, PIXEL_FILL(0), 1, y, GetMenuCursorDimensionByFont(2, 0), GetMenuCursorDimensionByFont(2, 1));
+ }
+ else
+ {
+ BagPrintTextOnWindow(0, 2, gFameCheckerText_ListMenuCursor, 1, y, 0, 0, 0, colorIdx);
+ }
+}
+
+static void PrintBagPocketName(void)
+{
+ FillWindowPixelBuffer(2, PIXEL_FILL(0));
+ BagPrintTextOnWin1CenteredColor0(sPocketNames[gBagMenuState.pocket], gBagMenuState.pocket);
+}
+
+static void PrintItemDescriptionOnMessageWindow(s32 itemIndex)
+{
+ const u8 *description;
+ if (itemIndex != sBagMenuDisplay->nItems[gBagMenuState.pocket])
+ description = ItemId_GetDescription(BagGetItemIdByPocketPosition(gBagMenuState.pocket + 1, itemIndex));
+ else
+ description = gText_CloseBag;
+ FillWindowPixelBuffer(1, PIXEL_FILL(0));
+ BagPrintTextOnWindow(1, 2, description, 0, 3, 2, 0, 0, 0);
+}
+
+static void CreatePocketScrollArrowPair(void)
+{
+ sBagMenuDisplay->pocketScrollArrowsTask = AddScrollIndicatorArrowPairParameterized(
+ SCROLL_ARROW_UP,
+ 160,
+ 8,
+ 104,
+ sBagMenuDisplay->nItems[gBagMenuState.pocket] - sBagMenuDisplay->maxShowed[gBagMenuState.pocket] + 1,
+ 110,
+ 110,
+ &gBagMenuState.cursorPos[gBagMenuState.pocket]
+ );
+}
+
+static void CreatePocketSwitchArrowPair(void)
+{
+ if (sBagMenuDisplay->pocketSwitchMode != 1)
+ {
+ sBagMenuDisplay->pocketSwitchArrowsTask = AddScrollIndicatorArrowPair(&sPocketSwitchArrowPairTemplate, &gBagMenuState.pocket);
+ }
+}
+
+static void CreatePocketScrollArrowPair_SellQuantity(void)
+{
+ sBagMenuDisplay->contextMenuSelectedItem = 1;
+ sBagMenuDisplay->pocketScrollArrowsTask = AddScrollIndicatorArrowPairParameterized(
+ SCROLL_ARROW_UP,
+ 152,
+ 72,
+ 104,
+ 2,
+ 110,
+ 110,
+ &sBagMenuDisplay->contextMenuSelectedItem
+ );
+}
+
+static void CreateArrowPair_QuantitySelect(void)
+{
+ sBagMenuDisplay->contextMenuSelectedItem = 1;
+ sBagMenuDisplay->pocketScrollArrowsTask = AddScrollIndicatorArrowPairParameterized(
+ SCROLL_ARROW_UP,
+ 212,
+ 120,
+ 152,
+ 2,
+ 110,
+ 110,
+ &sBagMenuDisplay->contextMenuSelectedItem
+ );
+}
+
+static void BagDestroyPocketScrollArrowPair(void)
+{
+ if (sBagMenuDisplay->pocketScrollArrowsTask != 0xFF)
+ {
+ RemoveScrollIndicatorArrowPair(sBagMenuDisplay->pocketScrollArrowsTask);
+ sBagMenuDisplay->pocketScrollArrowsTask = 0xFF;
+ }
+ BagDestroyPocketSwitchArrowPair();
+}
+
+static void BagDestroyPocketSwitchArrowPair(void)
+{
+ if (sBagMenuDisplay->pocketSwitchArrowsTask != 0xFF)
+ {
+ RemoveScrollIndicatorArrowPair(sBagMenuDisplay->pocketSwitchArrowsTask);
+ sBagMenuDisplay->pocketSwitchArrowsTask = 0xFF;
+ }
+}
+
+void ResetBagCursorPositions(void)
+{
+ u8 i;
+ gBagMenuState.pocket = POCKET_ITEMS - 1;
+ gBagMenuState.bagOpen = FALSE;
+ for (i = 0; i < 3; i++)
+ {
+ gBagMenuState.itemsAbove[i] = 0;
+ gBagMenuState.cursorPos[i] = 0;
+ }
+}
+
+void PocketCalculateInitialCursorPosAndItemsAbove(u8 pocketId)
+{
+ if (gBagMenuState.cursorPos[pocketId] != 0 && gBagMenuState.cursorPos[pocketId] + sBagMenuDisplay->maxShowed[pocketId] > sBagMenuDisplay->nItems[pocketId] + 1)
+ {
+ gBagMenuState.cursorPos[pocketId] = (sBagMenuDisplay->nItems[pocketId] + 1) - sBagMenuDisplay->maxShowed[pocketId];
+ }
+ if (gBagMenuState.cursorPos[pocketId] + gBagMenuState.itemsAbove[pocketId] >= sBagMenuDisplay->nItems[pocketId] + 1)
+ {
+ if (sBagMenuDisplay->nItems[pocketId] + 1 < 2)
+ gBagMenuState.itemsAbove[pocketId] = 0;
+ else
+ gBagMenuState.itemsAbove[pocketId] = sBagMenuDisplay->nItems[pocketId];
+ }
+}
+
+static void CalculateInitialCursorPosAndItemsAbove(void)
+{
+ u8 i;
+ for (i = 0; i < 3; i++)
+ {
+ PocketCalculateInitialCursorPosAndItemsAbove(i);
+ }
+}
+
+static void UpdatePocketScrollPositions(void)
+{
+ u8 i;
+ u8 j;
+
+ for (i = 0; i < 3; i++)
+ {
+ if (gBagMenuState.itemsAbove[i] > 3)
+ {
+ for (j = 0; j <= gBagMenuState.itemsAbove[i] - 3; gBagMenuState.itemsAbove[i]--, gBagMenuState.cursorPos[i]++, j++)
+ {
+ if (gBagMenuState.cursorPos[i] + sBagMenuDisplay->maxShowed[i] == sBagMenuDisplay->nItems[i] + 1)
+ break;
+ }
+ }
+ }
+}
+
+static void DestroyBagMenuResources(void)
+{
+ FREE_IF_SET(sBagMenuDisplay);
+ FREE_IF_SET(sBagBgTilemapBuffer);
+ FREE_IF_SET(sListMenuItems);
+ FREE_IF_SET(sListMenuItemStrings);
+ FreeAllWindowBuffers();
+}
+
+void ItemMenu_StartFadeToExitCallback(u8 taskId)
+{
+ BeginNormalPaletteFade(0xFFFFFFFF, -2, 0, 16, RGB_BLACK);
+ gTasks[taskId].func = Task_ItemMenu_WaitFadeAndSwitchToExitCallback;
+}
+
+static void Task_ItemMenu_WaitFadeAndSwitchToExitCallback(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ if (!gPaletteFade.active && FuncIsActiveTask(Task_AnimateWin0v) != TRUE)
+ {
+ DestroyListMenuTask(data[0], &gBagMenuState.cursorPos[gBagMenuState.pocket], &gBagMenuState.itemsAbove[gBagMenuState.pocket]);
+ if (sBagMenuDisplay->exitCB != NULL)
+ SetMainCallback2(sBagMenuDisplay->exitCB);
+ else
+ SetMainCallback2(gBagMenuState.bagCallback);
+ BagDestroyPocketScrollArrowPair();
+ DestroyBagMenuResources();
+ DestroyTask(taskId);
+ }
+}
+
+static void ShowBagOrBeginWin0OpenTask(void)
+{
+ u16 paldata = RGB_BLACK;
+ u8 taskId;
+
+ LoadPalette(&paldata, 0x00, 0x02);
+ SetGpuReg(REG_OFFSET_WININ, 0);
+ SetGpuReg(REG_OFFSET_WINOUT, WININ_WIN0_BG_ALL | WININ_WIN0_OBJ | WININ_WIN0_CLR);
+ BlendPalettes(0xFFFFFFFF, 16, RGB_BLACK);
+ BeginNormalPaletteFade(0xFFFFFFFF, 0, 16, 0, RGB_BLACK);
+ if (gBagMenuState.bagOpen == TRUE)
+ {
+ SetGpuReg(REG_OFFSET_WIN0H, WIN_RANGE(0, 240));
+ SetGpuReg(REG_OFFSET_WIN0V, WIN_RANGE(0, 0));
+ }
+ else
+ {
+ SetGpuReg(REG_OFFSET_WIN0H, WIN_RANGE(0, 240));
+ SetGpuReg(REG_OFFSET_WIN0V, WIN_RANGE(0, 160));
+ taskId = CreateTask(Task_AnimateWin0v, 0);
+ gTasks[taskId].data[0] = 192;
+ gTasks[taskId].data[1] = -16;
+ gBagMenuState.bagOpen = TRUE;
+ }
+}
+
+void Bag_BeginCloseWin0Animation(void)
+{
+
+ u8 taskId = CreateTask(Task_AnimateWin0v, 0);
+ gTasks[taskId].data[0] = -16;
+ gTasks[taskId].data[1] = 16;
+ gBagMenuState.bagOpen = FALSE;
+}
+
+void CB2_SetUpReshowBattleScreenAfterMenu(void)
+{
+ gBagMenuState.bagOpen = FALSE;
+}
+
+static void Task_AnimateWin0v(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ data[0] += data[1];
+ if (data[0] > 160)
+ SetGpuReg(REG_OFFSET_WIN0V, WIN_RANGE(0, 160));
+ else
+ SetGpuReg(REG_OFFSET_WIN0V, data[0]);
+ if ((data[1] == 16 && data[0] == 160) || (data[1] == -16 && data[0] == 0))
+ DestroyTask(taskId);
+}
+
+void MoveItemSlotInList(struct ItemSlot * itemSlots_, u32 from, u32 to_)
+{
+ // dumb assignments needed to match
+ struct ItemSlot *itemSlots = itemSlots_;
+ u32 to = to_;
+
+ if (from != to)
+ {
+ s16 i, count;
+ struct ItemSlot firstSlot = itemSlots[from];
+
+ if (to > from)
+ {
+ to--;
+ for (i = from, count = to; i < count; i++)
+ itemSlots[i] = itemSlots[i + 1];
+ }
+ else
+ {
+ for (i = from, count = to; i > count; i--)
+ itemSlots[i] = itemSlots[i - 1];
+ }
+ itemSlots[to] = firstSlot;
+ }
+}
+
+void Pocket_CalculateNItemsAndMaxShowed(u8 pocketId)
+{
+ u16 i;
+ struct BagPocket * pocket = &gBagPockets[pocketId];
+ BagPocketCompaction(pocket->itemSlots, pocket->capacity);
+ sBagMenuDisplay->nItems[pocketId] = 0;
+ for (i = 0; i < pocket->capacity; i++)
+ {
+ if (pocket->itemSlots[i].itemId == ITEM_NONE)
+ break;
+ sBagMenuDisplay->nItems[pocketId]++;
+ }
+ if (sBagMenuDisplay->nItems[pocketId] + 1 > 6)
+ sBagMenuDisplay->maxShowed[pocketId] = 6;
+ else
+ sBagMenuDisplay->maxShowed[pocketId] = sBagMenuDisplay->nItems[pocketId] + 1;
+}
+
+static void All_CalculateNItemsAndMaxShowed(void)
+{
+ u8 i;
+ for (i = 0; i < 3; i++)
+ Pocket_CalculateNItemsAndMaxShowed(i);
+}
+
+void DisplayItemMessageInBag(u8 taskId, u8 fontId, const u8 * string, TaskFunc followUpFunc)
+{
+ s16 *data = gTasks[taskId].data;
+ data[10] = OpenBagWindow(5);
+ FillWindowPixelBuffer(data[10], PIXEL_FILL(1));
+ DisplayMessageAndContinueTask(taskId, data[10], 0x06D, 0x0D, fontId, GetTextSpeedSetting(), string, followUpFunc);
+ ScheduleBgCopyTilemapToVram(0);
+}
+
+void ItemMenu_SetExitCallback(MainCallback cb)
+{
+ sBagMenuDisplay->exitCB = cb;
+}
+
+static u8 GetSelectedItemIndex(u8 pocket)
+{
+ return gBagMenuState.cursorPos[pocket] + gBagMenuState.itemsAbove[pocket];
+}
+
+static void Task_BagMenu_HandleInput(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ u16 cursorPos;
+ u16 itemsAbove;
+ s32 input;
+
+ if (gPaletteFade.active)
+ return;
+ if (FuncIsActiveTask(Task_AnimateWin0v) == TRUE)
+ return;
+ if ((u8)sub_80BF72C() == TRUE)
+ return;
+ switch (ProcessPocketSwitchInput(taskId, gBagMenuState.pocket))
+ {
+ case 1:
+ SwitchPockets(taskId, -1, FALSE);
+ return;
+ case 2:
+ SwitchPockets(taskId, 1, FALSE);
+ return;
+ default:
+ if (JOY_NEW(SELECT_BUTTON) && gBagMenuState.location == ITEMMENULOCATION_FIELD)
+ {
+ ListMenuGetScrollAndRow(data[0], &cursorPos, &itemsAbove);
+ if (cursorPos + itemsAbove != sBagMenuDisplay->nItems[gBagMenuState.pocket])
+ {
+ PlaySE(SE_SELECT);
+ BeginMovingItemInPocket(taskId, cursorPos + itemsAbove);
+ return;
+ }
+ }
+ break;
+ }
+ input = ListMenu_ProcessInput(data[0]);
+ ListMenuGetScrollAndRow(data[0], &gBagMenuState.cursorPos[gBagMenuState.pocket], &gBagMenuState.itemsAbove[gBagMenuState.pocket]);
+ switch (input)
+ {
+ case LIST_NOTHING_CHOSEN:
+ return;
+ case LIST_CANCEL:
+ PlaySE(SE_SELECT);
+ gSpecialVar_ItemId = ITEM_NONE;
+ Bag_BeginCloseWin0Animation();
+ gTasks[taskId].func = ItemMenu_StartFadeToExitCallback;
+ break;
+ default:
+ PlaySE(SE_SELECT);
+ if (input == sBagMenuDisplay->nItems[gBagMenuState.pocket])
+ {
+ gSpecialVar_ItemId = ITEM_NONE;
+ Bag_BeginCloseWin0Animation();
+ gTasks[taskId].func = ItemMenu_StartFadeToExitCallback;
+ }
+ else
+ {
+ BagDestroyPocketScrollArrowPair();
+ bag_menu_print_cursor_(data[0], 2);
+ data[1] = input;
+ data[2] = BagGetQuantityByPocketPosition(gBagMenuState.pocket + 1, input);
+ gSpecialVar_ItemId = BagGetItemIdByPocketPosition(gBagMenuState.pocket + 1, input);
+ gTasks[taskId].func = Task_ItemContextMenuByLocation;
+ }
+ break;
+ }
+}
+
+static void Task_ItemContextMenuByLocation(u8 taskId)
+{
+ Bag_FillMessageBoxWithPalette(1);
+ sItemContextTaskFuncs[gBagMenuState.location](taskId);
+}
+
+static void Task_RedrawArrowsAndReturnToBagMenuSelect(u8 taskId)
+{
+ Bag_FillMessageBoxWithPalette(0);
+ CreatePocketScrollArrowPair();
+ CreatePocketSwitchArrowPair();
+ gTasks[taskId].func = Task_BagMenu_HandleInput;
+}
+
+static void Bag_FillMessageBoxWithPalette(u32 a0)
+{
+ SetBgTilemapPalette(1, 0, 14, 30, 6, a0 + 1);
+ ScheduleBgCopyTilemapToVram(1);
+}
+
+static u8 ProcessPocketSwitchInput(u8 taskId, u8 pocketId)
+{
+ u8 lrState;
+ if (sBagMenuDisplay->pocketSwitchMode != 0)
+ return 0;
+ lrState = GetLRKeysState();
+ if (JOY_NEW(DPAD_LEFT) || lrState == 1)
+ {
+ if (pocketId == POCKET_ITEMS - 1)
+ return 0;
+ PlaySE(SE_BAG2);
+ return 1;
+ }
+ if (JOY_NEW(DPAD_RIGHT) || lrState == 2)
+ {
+ if (pocketId >= POCKET_POKE_BALLS - 1)
+ return 0;
+ PlaySE(SE_BAG2);
+ return 2;
+ }
+ return 0;
+}
+
+static void SwitchPockets(u8 taskId, s16 direction, bool16 a2)
+{
+ s16 *data = gTasks[taskId].data;
+ data[13] = 0;
+ data[12] = 0;
+ data[11] = direction;
+ if (!a2)
+ {
+ ClearWindowTilemap(0);
+ ClearWindowTilemap(1);
+ ClearWindowTilemap(2);
+ DestroyListMenuTask(data[0], &gBagMenuState.cursorPos[gBagMenuState.pocket], &gBagMenuState.itemsAbove[gBagMenuState.pocket]);
+ ScheduleBgCopyTilemapToVram(0);
+ DestroyItemMenuIcon(sBagMenuDisplay->itemMenuIcon ^ 1);
+ BagDestroyPocketScrollArrowPair();
+ }
+ FillBgTilemapBufferRect_Palette0(1, 0x02D, 11, 1, 18, 12);
+ ScheduleBgCopyTilemapToVram(1);
+ sub_8098528(gBagMenuState.pocket + direction);
+ SetTaskFuncWithFollowupFunc(taskId, Task_AnimateSwitchPockets, gTasks[taskId].func);
+}
+
+static void Task_AnimateSwitchPockets(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ if (!MenuHelpers_LinkSomething() && !BagIsTutorial())
+ {
+ switch (ProcessPocketSwitchInput(taskId, gBagMenuState.pocket + data[11]))
+ {
+ case 1:
+ gBagMenuState.pocket += data[11];
+ SwitchTaskToFollowupFunc(taskId);
+ SwitchPockets(taskId, -1, TRUE);
+ return;
+ case 2:
+ gBagMenuState.pocket += data[11];
+ SwitchTaskToFollowupFunc(taskId);
+ SwitchPockets(taskId, 1, TRUE);
+ return;
+ }
+ }
+ switch (data[13])
+ {
+ case 0:
+ if (data[12] != 0x7FFF)
+ {
+ data[12]++;
+ CopyBagListBgTileRowToTilemapBuffer(data[12]);
+ if (data[12] == 12)
+ data[12] = 0x7FFF;
+ }
+ if (data[12] == 0x7FFF)
+ data[13]++;
+ break;
+ case 1:
+ gBagMenuState.pocket += data[11];
+ PrintBagPocketName();
+ Bag_BuildListMenuTemplate(gBagMenuState.pocket);
+ data[0] = ListMenuInit(&gMultiuseListMenuTemplate, gBagMenuState.cursorPos[gBagMenuState.pocket], gBagMenuState.itemsAbove[gBagMenuState.pocket]);
+ PutWindowTilemap(1);
+ PutWindowTilemap(2);
+ ScheduleBgCopyTilemapToVram(0);
+ CreatePocketScrollArrowPair();
+ CreatePocketSwitchArrowPair();
+ SwitchTaskToFollowupFunc(taskId);
+ break;
+ }
+}
+
+static void BeginMovingItemInPocket(u8 taskId, s16 itemIndex)
+{
+ u16 itemsAbove;
+ u16 cursorPos;
+ s16 *data = gTasks[taskId].data;
+ ListMenuGetScrollAndRow(data[0], &cursorPos, &itemsAbove);
+ ListMenuSetUnkIndicatorsStructField(data[0], 0x10, 1);
+ data[1] = itemIndex;
+ sBagMenuDisplay->itemOriginalLocation = itemIndex;
+ StringCopy(gStringVar1, ItemId_GetName(BagGetItemIdByPocketPosition(gBagMenuState.pocket + 1, data[1])));
+ StringExpandPlaceholders(gStringVar4, gOtherText_WhereShouldTheStrVar1BePlaced);
+ FillWindowPixelBuffer(1, PIXEL_FILL(0));
+ BagPrintTextOnWindow(1, 2, gStringVar4, 0, 3, 2, 0, 0, 0);
+ ItemMenuIcons_MoveInsertIndicatorBar(0, ListMenuGetYCoordForPrintingArrowCursor(data[0]));
+ ItemMenuIcons_ToggleInsertIndicatorBarVisibility(FALSE);
+ BagDestroyPocketSwitchArrowPair();
+ bag_menu_print_cursor_(data[0], 2);
+ gTasks[taskId].func = Task_MoveItemInPocket_HandleInput;
+}
+
+static void Task_MoveItemInPocket_HandleInput(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ s32 input;
+ u16 itemsAbove;
+ u16 cursorPos;
+ if ((u8)sub_80BF72C() == TRUE)
+ return;
+ input = ListMenu_ProcessInput(data[0]);
+ ListMenuGetScrollAndRow(data[0], &gBagMenuState.cursorPos[gBagMenuState.pocket], &gBagMenuState.itemsAbove[gBagMenuState.pocket]);
+ ItemMenuIcons_MoveInsertIndicatorBar(0, ListMenuGetYCoordForPrintingArrowCursor(data[0]));
+ if (JOY_NEW(SELECT_BUTTON))
+ {
+ PlaySE(SE_SELECT);
+ sBagMenuDisplay->itemOriginalLocation = 0xFF;
+ ListMenuGetScrollAndRow(data[0], &cursorPos, &itemsAbove);
+ ExecuteMoveItemInPocket(taskId, cursorPos + itemsAbove);
+ return;
+ }
+ switch (input)
+ {
+ case LIST_NOTHING_CHOSEN:
+ return;
+ case LIST_CANCEL:
+ PlaySE(SE_SELECT);
+ sBagMenuDisplay->itemOriginalLocation = 0xFF;
+ ListMenuGetScrollAndRow(data[0], &cursorPos, &itemsAbove);
+ AbortMovingItemInPocket(taskId, cursorPos + itemsAbove);
+ break;
+ default:
+ PlaySE(SE_SELECT);
+ sBagMenuDisplay->itemOriginalLocation = 0xFF;
+ ExecuteMoveItemInPocket(taskId, input);
+ break;
+ }
+}
+
+static void ExecuteMoveItemInPocket(u8 taskId, u32 itemIndex)
+{
+ s16 *data = gTasks[taskId].data;
+ if (data[1] == itemIndex || data[1] == itemIndex - 1)
+ {
+ AbortMovingItemInPocket(taskId, itemIndex);
+ }
+ else
+ {
+ MoveItemSlotInList(gBagPockets[gBagMenuState.pocket].itemSlots, data[1], itemIndex);
+ DestroyListMenuTask(data[0], &gBagMenuState.cursorPos[gBagMenuState.pocket], &gBagMenuState.itemsAbove[gBagMenuState.pocket]);
+ if (data[1] < itemIndex)
+ gBagMenuState.itemsAbove[gBagMenuState.pocket]--;
+ Bag_BuildListMenuTemplate(gBagMenuState.pocket);
+ data[0] = ListMenuInit(&gMultiuseListMenuTemplate, gBagMenuState.cursorPos[gBagMenuState.pocket], gBagMenuState.itemsAbove[gBagMenuState.pocket]);
+ ItemMenuIcons_ToggleInsertIndicatorBarVisibility(TRUE);
+ CreatePocketSwitchArrowPair();
+ gTasks[taskId].func = Task_BagMenu_HandleInput;
+ }
+}
+
+static void AbortMovingItemInPocket(u8 taskId, u32 itemIndex)
+{
+ s16 *data = gTasks[taskId].data;
+ DestroyListMenuTask(data[0], &gBagMenuState.cursorPos[gBagMenuState.pocket], &gBagMenuState.itemsAbove[gBagMenuState.pocket]);
+ if (data[1] < itemIndex)
+ gBagMenuState.itemsAbove[gBagMenuState.pocket]--;
+ Bag_BuildListMenuTemplate(gBagMenuState.pocket);
+ data[0] = ListMenuInit(&gMultiuseListMenuTemplate, gBagMenuState.cursorPos[gBagMenuState.pocket], gBagMenuState.itemsAbove[gBagMenuState.pocket]);
+ ItemMenuIcons_ToggleInsertIndicatorBarVisibility(TRUE);
+ CreatePocketSwitchArrowPair();
+ gTasks[taskId].func = Task_BagMenu_HandleInput;
+}
+
+static void InitQuantityToTossOrDeposit(u16 cursorPos, const u8 *str)
+{
+ u8 r4;
+ u8 r5 = ShowBagWindow(6, 2);
+ CopyItemName(BagGetItemIdByPocketPosition(gBagMenuState.pocket + 1, cursorPos), gStringVar1);
+ StringExpandPlaceholders(gStringVar4, str);
+ BagPrintTextOnWindow(r5, 2, gStringVar4, 0, 2, 1, 0, 0, 1);
+ r4 = ShowBagWindow(0, 0);
+ ConvertIntToDecimalStringN(gStringVar1, 1, STR_CONV_MODE_LEADING_ZEROS, 3);
+ StringExpandPlaceholders(gStringVar4, gText_TimesStrVar1);
+ BagPrintTextOnWindow(r4, 0, gStringVar4, 4, 10, 1, 0, 0, 1);
+ CreateArrowPair_QuantitySelect();
+}
+
+static void UpdateQuantityToTossOrDeposit(s16 value, u8 ndigits)
+{
+ u8 r6 = GetBagWindow(0);
+ FillWindowPixelBuffer(r6, PIXEL_FILL(1));
+ ConvertIntToDecimalStringN(gStringVar1, value, STR_CONV_MODE_LEADING_ZEROS, ndigits);
+ StringExpandPlaceholders(gStringVar4, gText_TimesStrVar1);
+ BagPrintTextOnWindow(r6, 0, gStringVar4, 4, 10, 1, 0, 0, 1);
+}
+
+static void CopyBagListBgTileRowToTilemapBuffer(u8 frame)
+{
+ CopyToBgTilemapBufferRect(1, sBagListBgTiles[12 - frame], 11, 13 - frame, 18, 1);
+ ScheduleBgCopyTilemapToVram(1);
+}
+
+static void OpenContextMenu(u8 taskId)
+{
+ u8 r6;
+ u8 r4;
+ switch (gBagMenuState.location)
+ {
+ case ITEMMENULOCATION_BATTLE:
+ case ITEMMENULOCATION_TTVSCR_STATUS:
+ if (gSpecialVar_ItemId == ITEM_BERRY_POUCH)
+ {
+ sContextMenuItemsBuffer[0] = ITEMMENUACTION_OPEN_BERRIES;
+ sContextMenuItemsBuffer[1] = ITEMMENUACTION_CANCEL;
+ sContextMenuItemsPtr = sContextMenuItemsBuffer;
+ sContextMenuNumItems = 2;
+ }
+ else if (ItemId_GetBattleUsage(gSpecialVar_ItemId))
+ {
+ sContextMenuItemsPtr = sContextMenuItems_BattleUse;
+ sContextMenuNumItems = 2;
+ }
+ else
+ {
+ sContextMenuItemsPtr = sContextMenuItems_Cancel;
+ sContextMenuNumItems = 1;
+ }
+ break;
+ case ITEMMENULOCATION_OLD_MAN:
+ case ITEMMENULOCATION_TTVSCR_CATCHING:
+ sContextMenuItemsPtr = sContextMenuItems_BattleUse;
+ sContextMenuNumItems = 2;
+ break;
+ default:
+ if (MenuHelpers_LinkSomething() == TRUE || InUnionRoom() == TRUE)
+ {
+ if (gSpecialVar_ItemId == ITEM_TM_CASE || gSpecialVar_ItemId == ITEM_BERRY_POUCH)
+ {
+ sContextMenuItemsPtr = sContextMenuItems_Open;
+ sContextMenuNumItems = 2;
+ }
+ else
+ {
+ if (gBagMenuState.pocket == POCKET_KEY_ITEMS - 1)
+ sContextMenuNumItems = 1;
+ else
+ sContextMenuNumItems = 2;
+ sContextMenuItemsPtr = sContextMenuItems_GiveIfNotKeyItemPocket[gBagMenuState.pocket];
+ }
+ }
+ else
+ {
+ switch (gBagMenuState.pocket)
+ {
+ case OPEN_BAG_ITEMS:
+ sContextMenuNumItems = 4;
+ if (ItemIsMail(gSpecialVar_ItemId) == TRUE)
+ sContextMenuItemsPtr = sContextMenuItems_CheckGiveTossCancel;
+ else
+ sContextMenuItemsPtr = sContextMenuItems_Field[gBagMenuState.pocket];
+ break;
+ case OPEN_BAG_KEYITEMS:
+ sContextMenuItemsPtr = sContextMenuItemsBuffer;
+ sContextMenuNumItems = 3;
+ sContextMenuItemsBuffer[2] = ITEMMENUACTION_CANCEL;
+ if (gSaveBlock1Ptr->registeredItem == gSpecialVar_ItemId)
+ sContextMenuItemsBuffer[1] = ITEMMENUACTION_DESELECT;
+ else
+ sContextMenuItemsBuffer[1] = ITEMMENUACTION_REGISTER;
+ if (gSpecialVar_ItemId == ITEM_TM_CASE || gSpecialVar_ItemId == ITEM_BERRY_POUCH)
+ sContextMenuItemsBuffer[0] = ITEMMENUACTION_OPEN;
+ else if (gSpecialVar_ItemId == ITEM_BICYCLE && TestPlayerAvatarFlags(PLAYER_AVATAR_FLAG_ACRO_BIKE | PLAYER_AVATAR_FLAG_MACH_BIKE))
+ sContextMenuItemsBuffer[0] = ITEMMENUACTION_WALK;
+ else
+ sContextMenuItemsBuffer[0] = ITEMMENUACTION_USE;
+ break;
+ case OPEN_BAG_POKEBALLS:
+ sContextMenuItemsPtr = sContextMenuItems_Field[gBagMenuState.pocket];
+ sContextMenuNumItems = 3;
+ break;
+ }
+ }
+ }
+ r6 = ShowBagWindow(10, sContextMenuNumItems - 1);
+ AddItemMenuActionTextPrinters(
+ r6,
+ 2,
+ GetMenuCursorDimensionByFont(2, 0),
+ 2,
+ GetFontAttribute(2, FONTATTR_LETTER_SPACING),
+ GetFontAttribute(2, FONTATTR_MAX_LETTER_HEIGHT) + 2,
+ sContextMenuNumItems,
+ sItemMenuContextActions,
+ sContextMenuItemsPtr
+ );
+ Menu_InitCursor(r6, 2, 0, 2, GetFontAttribute(2, FONTATTR_MAX_LETTER_HEIGHT) + 2, sContextMenuNumItems, 0);
+ r4 = ShowBagWindow(6, 0);
+ CopyItemName(gSpecialVar_ItemId, gStringVar1);
+ StringExpandPlaceholders(gStringVar4, gOtherText_StrVar1);
+ BagPrintTextOnWindow(r4, 2, gStringVar4, 0, 2, 1, 0, 0, 1);
+}
+
+static void Task_ItemContext_FieldOrBattle(u8 taskId)
+{
+ OpenContextMenu(taskId);
+ gTasks[taskId].func = Task_FieldItemContextMenuHandleInput;
+}
+
+static void Task_FieldItemContextMenuHandleInput(u8 taskId)
+{
+ s8 input;
+ if ((u8)sub_80BF72C() != TRUE)
+ {
+ input = Menu_ProcessInputNoWrapAround();
+ switch (input)
+ {
+ case -1:
+ PlaySE(SE_SELECT);
+ sItemMenuContextActions[ITEMMENUACTION_CANCEL].func.void_u8(taskId);
+ break;
+ case -2:
+ break;
+ default:
+ PlaySE(SE_SELECT);
+ sItemMenuContextActions[sContextMenuItemsPtr[input]].func.void_u8(taskId);
+ break;
+ }
+ }
+}
+
+static void Task_ItemMenuAction_Use(u8 taskId)
+{
+ if (ItemId_GetFieldFunc(gSpecialVar_ItemId) != NULL)
+ {
+ HideBagWindow(10);
+ HideBagWindow(6);
+ PutWindowTilemap(0);
+ PutWindowTilemap(1);
+ ScheduleBgCopyTilemapToVram(0);
+ if (CalculatePlayerPartyCount() == 0 && ItemId_GetType(gSpecialVar_ItemId) == 1)
+ Task_PrintThereIsNoPokemon(taskId);
+ else
+ ItemId_GetFieldFunc(gSpecialVar_ItemId)(taskId);
+ }
+}
+
+static void Task_ItemMenuAction_Toss(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ ClearWindowTilemap(GetBagWindow(10));
+ ClearWindowTilemap(GetBagWindow(6));
+ HideBagWindow(10);
+ HideBagWindow(6);
+ PutWindowTilemap(0);
+ data[8] = 1;
+ if (data[2] == 1)
+ {
+ Task_ConfirmTossItems(taskId);
+ }
+ else
+ {
+ InitQuantityToTossOrDeposit(data[1], gText_TossOutHowManyStrVar1s);
+ gTasks[taskId].func = Task_SelectQuantityToToss;
+ }
+}
+
+static void Task_ConfirmTossItems(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ ConvertIntToDecimalStringN(gStringVar2, data[8], STR_CONV_MODE_LEFT_ALIGN, 3);
+ StringExpandPlaceholders(gStringVar4, gText_ThrowAwayStrVar2OfThisItemQM);
+ BagPrintTextOnWindow(ShowBagWindow(6, 1), 2, gStringVar4, 0, 2, 1, 0, 0, 1);
+ BagCreateYesNoMenuBottomRight(taskId, &sYesNoMenu_Toss);
+}
+
+static void Task_TossItem_No(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ HideBagWindow(6);
+ PutWindowTilemap(1);
+ ScheduleBgCopyTilemapToVram(0);
+ bag_menu_print_cursor_(data[0], 1);
+ Task_RedrawArrowsAndReturnToBagMenuSelect(taskId);
+}
+
+static void Task_SelectQuantityToToss(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ if (AdjustQuantityAccordingToDPadInput(&data[8], data[2]) == TRUE)
+ {
+ UpdateQuantityToTossOrDeposit(data[8], 3);
+ }
+ else if (JOY_NEW(A_BUTTON))
+ {
+ PlaySE(SE_SELECT);
+ ClearWindowTilemap(GetBagWindow(6));
+ HideBagWindow(6);
+ HideBagWindow(0);
+ ScheduleBgCopyTilemapToVram(0);
+ BagDestroyPocketScrollArrowPair();
+ Task_ConfirmTossItems(taskId);
+ }
+ else if (JOY_NEW(B_BUTTON))
+ {
+ PlaySE(SE_SELECT);
+ HideBagWindow(6);
+ HideBagWindow(0);
+ PutWindowTilemap(0);
+ PutWindowTilemap(1);
+ ScheduleBgCopyTilemapToVram(0);
+ bag_menu_print_cursor_(data[0], 1);
+ BagDestroyPocketScrollArrowPair();
+ Task_RedrawArrowsAndReturnToBagMenuSelect(taskId);
+ }
+}
+
+static void Task_TossItem_Yes(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ HideBagWindow(6);
+ CopyItemName(BagGetItemIdByPocketPosition(gBagMenuState.pocket + 1, data[1]), gStringVar1);
+ ConvertIntToDecimalStringN(gStringVar2, data[8], STR_CONV_MODE_LEFT_ALIGN, 3);
+ StringExpandPlaceholders(gStringVar4, gText_ThrewAwayStrVar2StrVar1s);
+ BagPrintTextOnWindow(ShowBagWindow(6, 3), 2, gStringVar4, 0, 2, 1, 0, 0, 1);
+ gTasks[taskId].func = Task_WaitAB_RedrawAndReturnToBag;
+}
+
+static void Task_WaitAB_RedrawAndReturnToBag(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ if (JOY_NEW(A_BUTTON) || JOY_NEW(B_BUTTON))
+ {
+ PlaySE(SE_SELECT);
+ RemoveBagItem(gSpecialVar_ItemId, data[8]);
+ HideBagWindow(6);
+ DestroyListMenuTask(data[0], &gBagMenuState.cursorPos[gBagMenuState.pocket], &gBagMenuState.itemsAbove[gBagMenuState.pocket]);
+ Pocket_CalculateNItemsAndMaxShowed(gBagMenuState.pocket);
+ PocketCalculateInitialCursorPosAndItemsAbove(gBagMenuState.pocket);
+ Bag_BuildListMenuTemplate(gBagMenuState.pocket);
+ data[0] = ListMenuInit(&gMultiuseListMenuTemplate, gBagMenuState.cursorPos[gBagMenuState.pocket], gBagMenuState.itemsAbove[gBagMenuState.pocket]);
+ PutWindowTilemap(1);
+ ScheduleBgCopyTilemapToVram(0);
+ bag_menu_print_cursor_(data[0], 1);
+ Task_RedrawArrowsAndReturnToBagMenuSelect(taskId);
+ }
+}
+
+static void Task_ItemMenuAction_ToggleSelect(u8 taskId)
+{
+ u16 itemId;
+ s16 *data = gTasks[taskId].data;
+ itemId = BagGetItemIdByPocketPosition(gBagMenuState.pocket + 1, data[1]);
+ if (gSaveBlock1Ptr->registeredItem == itemId)
+ gSaveBlock1Ptr->registeredItem = ITEM_NONE;
+ else
+ gSaveBlock1Ptr->registeredItem = itemId;
+
+ DestroyListMenuTask(data[0], &gBagMenuState.cursorPos[gBagMenuState.pocket], &gBagMenuState.itemsAbove[gBagMenuState.pocket]);
+ Bag_BuildListMenuTemplate(gBagMenuState.pocket);
+ data[0] = ListMenuInit(&gMultiuseListMenuTemplate, gBagMenuState.cursorPos[gBagMenuState.pocket], gBagMenuState.itemsAbove[gBagMenuState.pocket]);
+ CopyWindowToVram(0, 1);
+ Task_ItemMenuAction_Cancel(taskId);
+}
+
+static void Task_ItemMenuAction_Give(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ u16 itemId = BagGetItemIdByPocketPosition(gBagMenuState.pocket + 1, data[1]);
+ HideBagWindow(10);
+ HideBagWindow(6);
+ PutWindowTilemap(0);
+ PutWindowTilemap(1);
+ CopyWindowToVram(0, 1);
+ if (!CanWriteMailHere(itemId))
+ DisplayItemMessageInBag(taskId, 2, gText_CantWriteMailHere, Task_WaitAButtonAndCloseContextMenu);
+ else if (!itemid_is_unique(itemId))
+ {
+ if (CalculatePlayerPartyCount() == 0)
+ {
+ Task_PrintThereIsNoPokemon(taskId);
+ }
+ else
+ {
+ sBagMenuDisplay->exitCB = CB2_ChooseMonToGiveItem;
+ gTasks[taskId].func = ItemMenu_StartFadeToExitCallback;
+ }
+ }
+ else
+ Task_PrintItemCantBeHeld(taskId);
+}
+
+static void Task_PrintThereIsNoPokemon(u8 taskId)
+{
+ DisplayItemMessageInBag(taskId, 2, gText_ThereIsNoPokemon, Task_WaitAButtonAndCloseContextMenu);
+}
+
+static void Task_PrintItemCantBeHeld(u8 taskId)
+{
+ CopyItemName(gSpecialVar_ItemId, gStringVar1);
+ StringExpandPlaceholders(gStringVar4, gText_ItemCantBeHeld);
+ DisplayItemMessageInBag(taskId, 2, gStringVar4, Task_WaitAButtonAndCloseContextMenu);
+}
+
+static void Task_WaitAButtonAndCloseContextMenu(u8 taskId)
+{
+ if (JOY_NEW(A_BUTTON))
+ {
+ PlaySE(SE_SELECT);
+ Task_ReturnToBagFromContextMenu(taskId);
+ }
+}
+
+void Task_ReturnToBagFromContextMenu(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ CloseBagWindow(5);
+ DestroyListMenuTask(data[0], &gBagMenuState.cursorPos[gBagMenuState.pocket], &gBagMenuState.itemsAbove[gBagMenuState.pocket]);
+ Pocket_CalculateNItemsAndMaxShowed(gBagMenuState.pocket);
+ PocketCalculateInitialCursorPosAndItemsAbove(gBagMenuState.pocket);
+ Bag_BuildListMenuTemplate(gBagMenuState.pocket);
+ data[0] = ListMenuInit(&gMultiuseListMenuTemplate, gBagMenuState.cursorPos[gBagMenuState.pocket], gBagMenuState.itemsAbove[gBagMenuState.pocket]);
+ ScheduleBgCopyTilemapToVram(0);
+ bag_menu_print_cursor_(data[0], 1);
+ Task_RedrawArrowsAndReturnToBagMenuSelect(taskId);
+}
+
+static void unref_sub_810A288(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ u16 itemsAbove;
+ u16 cursorPos;
+ ListMenuGetScrollAndRow(data[0], &cursorPos, &itemsAbove);
+ PrintItemDescriptionOnMessageWindow(cursorPos + itemsAbove);
+ PutWindowTilemap(0);
+ ScheduleBgCopyTilemapToVram(0);
+ bag_menu_print_cursor_(data[0], 1);
+ Task_RedrawArrowsAndReturnToBagMenuSelect(taskId);
+}
+
+static void Task_ItemMenuAction_Cancel(u8 taskId)
+{
+ HideBagWindow(10);
+ HideBagWindow(6);
+ PutWindowTilemap(0);
+ PutWindowTilemap(1);
+ ScheduleBgCopyTilemapToVram(0);
+ bag_menu_print_cursor_(gTasks[taskId].data[0], 1);
+ Task_RedrawArrowsAndReturnToBagMenuSelect(taskId);
+}
+
+static void Task_ItemMenuAction_BattleUse(u8 taskId)
+{
+ if (ItemId_GetBattleFunc(gSpecialVar_ItemId) != NULL)
+ {
+ HideBagWindow(10);
+ HideBagWindow(6);
+ PutWindowTilemap(0);
+ PutWindowTilemap(1);
+ CopyWindowToVram(0, 1);
+ ItemId_GetBattleFunc(gSpecialVar_ItemId)(taskId);
+ }
+}
+
+static void Task_ItemContext_FieldGive(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ u16 itemId = BagGetItemIdByPocketPosition(gBagMenuState.pocket + 1, data[1]);
+ if (!CanWriteMailHere(itemId))
+ {
+ DisplayItemMessageInBag(taskId, 2, gText_CantWriteMailHere, Task_WaitAButtonAndCloseContextMenu);
+ }
+ else if (itemId == ITEM_TM_CASE)
+ {
+ ItemMenu_SetExitCallback(GoToTMCase_Give);
+ ItemMenu_StartFadeToExitCallback(taskId);
+ }
+ else if (itemId == ITEM_BERRY_POUCH)
+ {
+ ItemMenu_SetExitCallback(GoToBerryPouch_Give);
+ ItemMenu_StartFadeToExitCallback(taskId);
+ }
+ else if (gBagMenuState.pocket != POCKET_KEY_ITEMS - 1 && !itemid_is_unique(itemId))
+ {
+ Bag_BeginCloseWin0Animation();
+ gTasks[taskId].func = ItemMenu_StartFadeToExitCallback;
+ }
+ else
+ {
+ Task_PrintItemCantBeHeld(taskId);
+ }
+}
+
+static void GoToTMCase_Give(void)
+{
+ InitTMCase(TMCASE_FROMPARTYGIVE, ReturnToBagMenuFromSubmenu_Give, FALSE);
+}
+
+static void GoToBerryPouch_Give(void)
+{
+ InitBerryPouch(BERRYPOUCH_FROMPARTYGIVE, ReturnToBagMenuFromSubmenu_Give, FALSE);
+}
+
+static void ReturnToBagMenuFromSubmenu_Give(void)
+{
+ CB2_SelectBagItemToGive();
+}
+
+static void Task_ItemContext_PcBoxGive(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ u16 itemId = BagGetItemIdByPocketPosition(gBagMenuState.pocket + 1, data[1]);
+ if (ItemIsMail(itemId) == TRUE)
+ {
+ DisplayItemMessageInBag(taskId, 2, gText_CantWriteMailHere, Task_WaitAButtonAndCloseContextMenu);
+ }
+ else if (itemId == ITEM_TM_CASE)
+ {
+ ItemMenu_SetExitCallback(GoToTMCase_PCBox);
+ ItemMenu_StartFadeToExitCallback(taskId);
+ }
+ else if (itemId == ITEM_BERRY_POUCH)
+ {
+ ItemMenu_SetExitCallback(GoToBerryPouch_PCBox);
+ ItemMenu_StartFadeToExitCallback(taskId);
+ }
+ else if (gBagMenuState.pocket != POCKET_KEY_ITEMS - 1 && !itemid_is_unique(itemId))
+ {
+ Bag_BeginCloseWin0Animation();
+ gTasks[taskId].func = ItemMenu_StartFadeToExitCallback;
+ }
+ else
+ {
+ Task_PrintItemCantBeHeld(taskId);
+ }
+}
+
+static void GoToTMCase_PCBox(void)
+{
+ InitTMCase(TMCASE_FROMPOKEMONSTORAGEPC, ReturnToBagMenuFromSubmenu_PCBox, FALSE);
+}
+
+static void GoToBerryPouch_PCBox(void)
+{
+ InitBerryPouch(BERRYPOUCH_FROMPOKEMONSTORAGEPC, ReturnToBagMenuFromSubmenu_PCBox, FALSE);
+}
+
+static void ReturnToBagMenuFromSubmenu_PCBox(void)
+{
+ GoToBagMenu(ITEMMENULOCATION_PCBOX, OPEN_BAG_LAST, sub_808CE60);
+}
+
+static void Task_ItemContext_Sell(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ if (gSpecialVar_ItemId == ITEM_TM_CASE)
+ {
+ ItemMenu_SetExitCallback(GoToTMCase_Sell);
+ ItemMenu_StartFadeToExitCallback(taskId);
+ }
+ else if (gSpecialVar_ItemId == ITEM_BERRY_POUCH)
+ {
+ ItemMenu_SetExitCallback(GoToBerryPouch_Sell);
+ ItemMenu_StartFadeToExitCallback(taskId);
+ }
+ else if (itemid_get_market_price(gSpecialVar_ItemId) == 0)
+ {
+ CopyItemName(gSpecialVar_ItemId, gStringVar1);
+ StringExpandPlaceholders(gStringVar4, gText_OhNoICantBuyThat);
+ DisplayItemMessageInBag(taskId, GetDialogBoxFontId(), gStringVar4, Task_ReturnToBagFromContextMenu);
+ }
+ else
+ {
+ data[8] = 1;
+ if (data[2] == 1)
+ {
+ BagPrintMoneyAmount();
+ Task_PrintSaleConfirmationText(taskId);
+ }
+ else
+ {
+ if (data[2] > 99)
+ data[2] = 99;
+ CopyItemName(gSpecialVar_ItemId, gStringVar1);
+ StringExpandPlaceholders(gStringVar4, gText_HowManyWouldYouLikeToSell);
+ DisplayItemMessageInBag(taskId, GetDialogBoxFontId(), gStringVar4, Task_InitSaleQuantitySelectInterface);
+ }
+ }
+}
+
+static void GoToTMCase_Sell(void)
+{
+ InitTMCase(TMCASE_FROMMARTSELL, ReturnToBagMenuFromSubmenu_Sell, FALSE);
+}
+
+static void GoToBerryPouch_Sell(void)
+{
+ InitBerryPouch(BERRYPOUCH_FROMMARTSELL, ReturnToBagMenuFromSubmenu_Sell, FALSE);
+}
+
+static void ReturnToBagMenuFromSubmenu_Sell(void)
+{
+ GoToBagMenu(ITEMMENULOCATION_SHOP, OPEN_BAG_LAST, CB2_ReturnToField);
+}
+
+static void Task_PrintSaleConfirmationText(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ ConvertIntToDecimalStringN(gStringVar3, itemid_get_market_price(BagGetItemIdByPocketPosition(gBagMenuState.pocket + 1, data[1])) / 2 * data[8], STR_CONV_MODE_LEFT_ALIGN, 6);
+ StringExpandPlaceholders(gStringVar4, gText_ICanPayThisMuch_WouldThatBeOkay);
+ DisplayItemMessageInBag(taskId, GetDialogBoxFontId(), gStringVar4, Task_ShowSellYesNoMenu);
+}
+
+static void Task_ShowSellYesNoMenu(u8 taskId)
+{
+ BagCreateYesNoMenuTopRight(taskId, &sYesNoMenu_Sell);
+}
+
+static void Task_SellItem_No(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ HideBagWindow(2);
+ CloseBagWindow(5);
+ PutWindowTilemap(2);
+ PutWindowTilemap(0);
+ PutWindowTilemap(1);
+ ScheduleBgCopyTilemapToVram(0);
+ bag_menu_print_cursor_(data[0], 1);
+ Task_RedrawArrowsAndReturnToBagMenuSelect(taskId);
+}
+
+static void Task_InitSaleQuantitySelectInterface(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ u8 r4 = ShowBagWindow(0, 1);
+ ConvertIntToDecimalStringN(gStringVar1, 1, STR_CONV_MODE_LEADING_ZEROS, 2);
+ StringExpandPlaceholders(gStringVar4, gText_TimesStrVar1);
+ BagPrintTextOnWindow(r4, 0, gStringVar4, 4, 10, 1, 0, 0xFF, 1);
+ UpdateSalePriceDisplay(itemid_get_market_price(BagGetItemIdByPocketPosition(gBagMenuState.pocket + 1, data[1])) / 2 * data[8]);
+ BagPrintMoneyAmount();
+ CreatePocketScrollArrowPair_SellQuantity();
+ gTasks[taskId].func = Task_SelectQuantityToSell;
+}
+
+static void UpdateSalePriceDisplay(s32 amount)
+{
+ PrintMoneyAmount(GetBagWindow(0), 56, 10, amount, 0);
+}
+
+static void Task_SelectQuantityToSell(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ if (AdjustQuantityAccordingToDPadInput(&data[8], data[2]) == TRUE)
+ {
+ UpdateQuantityToTossOrDeposit(data[8], 2);
+ UpdateSalePriceDisplay(itemid_get_market_price(BagGetItemIdByPocketPosition(gBagMenuState.pocket + 1, data[1])) / 2 * data[8]);
+ }
+ else if (JOY_NEW(A_BUTTON))
+ {
+ PlaySE(SE_SELECT);
+ HideBagWindow(0);
+ PutWindowTilemap(0);
+ ScheduleBgCopyTilemapToVram(0);
+ BagDestroyPocketScrollArrowPair();
+ Task_PrintSaleConfirmationText(taskId);
+ }
+ else if (JOY_NEW(B_BUTTON))
+ {
+ PlaySE(SE_SELECT);
+ HideBagWindow(0);
+ HideBagWindow(2);
+ CloseBagWindow(5);
+ PutWindowTilemap(2);
+ PutWindowTilemap(0);
+ PutWindowTilemap(1);
+ ScheduleBgCopyTilemapToVram(0);
+ BagDestroyPocketScrollArrowPair();
+ bag_menu_print_cursor_(data[0], 1);
+ Task_RedrawArrowsAndReturnToBagMenuSelect(taskId);
+ }
+}
+
+static void Task_SellItem_Yes(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ PutWindowTilemap(0);
+ ScheduleBgCopyTilemapToVram(0);
+ CopyItemName(gSpecialVar_ItemId, gStringVar1);
+ ConvertIntToDecimalStringN(gStringVar3, itemid_get_market_price(BagGetItemIdByPocketPosition(gBagMenuState.pocket + 1, data[1])) / 2 * data[8], STR_CONV_MODE_LEFT_ALIGN, 6);
+ StringExpandPlaceholders(gStringVar4, gText_TurnedOverItemsWorthYen);
+ DisplayItemMessageInBag(taskId, 2, gStringVar4, Task_FinalizeSaleToShop);
+}
+
+static void Task_FinalizeSaleToShop(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ PlaySE(SE_SHOP);
+ RemoveBagItem(gSpecialVar_ItemId, data[8]);
+ AddMoney(&gSaveBlock1Ptr->money, itemid_get_market_price(gSpecialVar_ItemId) / 2 * data[8]);
+ RecordItemPurchase(gSpecialVar_ItemId, data[8], 2);
+ DestroyListMenuTask(data[0], &gBagMenuState.cursorPos[gBagMenuState.pocket], &gBagMenuState.itemsAbove[gBagMenuState.pocket]);
+ Pocket_CalculateNItemsAndMaxShowed(gBagMenuState.pocket);
+ PocketCalculateInitialCursorPosAndItemsAbove(gBagMenuState.pocket);
+ sBagMenuDisplay->inhibitItemDescriptionPrint = TRUE;
+ Bag_BuildListMenuTemplate(gBagMenuState.pocket);
+ data[0] = ListMenuInit(&gMultiuseListMenuTemplate, gBagMenuState.cursorPos[gBagMenuState.pocket], gBagMenuState.itemsAbove[gBagMenuState.pocket]);
+ bag_menu_print_cursor_(data[0], 2);
+ BagDrawTextBoxOnWindow(GetBagWindow(2));
+ PrintMoneyAmountInMoneyBox(GetBagWindow(2), GetMoney(&gSaveBlock1Ptr->money), 0);
+ gTasks[taskId].func = Task_WaitPressAB_AfterSell;
+}
+
+static void Task_WaitPressAB_AfterSell(u8 taskId)
+{
+ if (JOY_NEW(A_BUTTON) || JOY_NEW(B_BUTTON))
+ {
+ PlaySE(SE_SELECT);
+ HideBagWindow(2);
+ PutWindowTilemap(2);
+ sBagMenuDisplay->inhibitItemDescriptionPrint = FALSE;
+ Task_ReturnToBagFromContextMenu(taskId);
+ }
+}
+
+static void Task_ItemContext_Deposit(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ data[8] = 1;
+ if (data[2] == 1)
+ {
+ Task_TryDoItemDeposit(taskId);
+ }
+ else
+ {
+ InitQuantityToTossOrDeposit(data[1], gText_DepositHowManyStrVars1);
+ gTasks[taskId].func = Task_SelectQuantityToDeposit;
+ }
+}
+
+static void Task_SelectQuantityToDeposit(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ if (AdjustQuantityAccordingToDPadInput(&data[8], data[2]) == TRUE)
+ {
+ UpdateQuantityToTossOrDeposit(data[8], 3);
+ }
+ else if (JOY_NEW(A_BUTTON))
+ {
+ PlaySE(SE_SELECT);
+ ClearWindowTilemap(GetBagWindow(6));
+ HideBagWindow(6);
+ HideBagWindow(0);
+ ScheduleBgCopyTilemapToVram(0);
+ BagDestroyPocketScrollArrowPair();
+ Task_TryDoItemDeposit(taskId);
+ }
+ else if (JOY_NEW(B_BUTTON))
+ {
+ PlaySE(SE_SELECT);
+ HideBagWindow(6);
+ HideBagWindow(0);
+ PutWindowTilemap(1);
+ ScheduleBgCopyTilemapToVram(0);
+ bag_menu_print_cursor_(data[0], 1);
+ BagDestroyPocketScrollArrowPair();
+ Task_RedrawArrowsAndReturnToBagMenuSelect(taskId);
+ }
+}
+
+static void Task_TryDoItemDeposit(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ if (AddPCItem(gSpecialVar_ItemId, data[8]) == TRUE)
+ {
+ ItemUse_SetQuestLogEvent(28, 0, gSpecialVar_ItemId, 0xFFFF);
+ CopyItemName(gSpecialVar_ItemId, gStringVar1);
+ ConvertIntToDecimalStringN(gStringVar2, data[8], STR_CONV_MODE_LEFT_ALIGN, 3);
+ StringExpandPlaceholders(gStringVar4, gText_DepositedStrVar2StrVar1s);
+ BagPrintTextOnWindow(ShowBagWindow(6, 3), 2, gStringVar4, 0, 2, 1, 0, 0, 1);
+ gTasks[taskId].func = Task_WaitAB_RedrawAndReturnToBag;
+ }
+ else
+ {
+ DisplayItemMessageInBag(taskId, 2, gText_NoRoomToStoreItems, Task_WaitAButtonAndCloseContextMenu);
+ }
+}
+
+bool8 UseRegisteredKeyItemOnField(void)
+{
+ u8 taskId;
+ if (InUnionRoom() == TRUE)
+ return FALSE;
+ DismissMapNamePopup();
+ ChangeBgY(0, 0, 0);
+ if (gSaveBlock1Ptr->registeredItem != ITEM_NONE)
+ {
+ if (CheckBagHasItem(gSaveBlock1Ptr->registeredItem, 1) == TRUE)
+ {
+ ScriptContext2_Enable();
+ FreezeObjectEvents();
+ sub_805C270();
+ sub_805C780();
+ gSpecialVar_ItemId = gSaveBlock1Ptr->registeredItem;
+ taskId = CreateTask(ItemId_GetFieldFunc(gSaveBlock1Ptr->registeredItem), 8);
+ gTasks[taskId].data[3] = 1;
+ return TRUE;
+ }
+ gSaveBlock1Ptr->registeredItem = ITEM_NONE;
+ }
+ ScriptContext1_SetupScript(EventScript_BagItemCanBeRegistered);
+ return TRUE;
+}
+
+static bool8 BagIsTutorial(void)
+{
+ if (
+ gBagMenuState.location == ITEMMENULOCATION_OLD_MAN
+ || gBagMenuState.location == ITEMMENULOCATION_TTVSCR_CATCHING
+ || gBagMenuState.location == ITEMMENULOCATION_TTVSCR_STATUS
+ || gBagMenuState.location == ITEMMENULOCATION_TTVSCR_REGISTER
+ || gBagMenuState.location == ITEMMENULOCATION_TTVSCR_TMS
+ )
+ return TRUE;
+ return FALSE;
+}
+
+static void BackUpPlayerBag(void)
+{
+ u32 i;
+ sBackupPlayerBag = AllocZeroed(sizeof(struct BagSlots));
+ memcpy(sBackupPlayerBag->bagPocket_Items, gSaveBlock1Ptr->bagPocket_Items, BAG_ITEMS_COUNT * sizeof(struct ItemSlot));
+ memcpy(sBackupPlayerBag->bagPocket_KeyItems, gSaveBlock1Ptr->bagPocket_KeyItems, BAG_KEYITEMS_COUNT * sizeof(struct ItemSlot));
+ memcpy(sBackupPlayerBag->bagPocket_PokeBalls, gSaveBlock1Ptr->bagPocket_PokeBalls, BAG_POKEBALLS_COUNT * sizeof(struct ItemSlot));
+ sBackupPlayerBag->registeredItem = gSaveBlock1Ptr->registeredItem;
+ sBackupPlayerBag->pocket = gBagMenuState.pocket;
+ for (i = 0; i < 3; i++)
+ {
+ sBackupPlayerBag->itemsAbove[i] = gBagMenuState.itemsAbove[i];
+ sBackupPlayerBag->cursorPos[i] = gBagMenuState.cursorPos[i];
+ }
+ ClearItemSlots(gSaveBlock1Ptr->bagPocket_Items, BAG_ITEMS_COUNT);
+ ClearItemSlots(gSaveBlock1Ptr->bagPocket_KeyItems, BAG_KEYITEMS_COUNT);
+ ClearItemSlots(gSaveBlock1Ptr->bagPocket_PokeBalls, BAG_POKEBALLS_COUNT);
+ gSaveBlock1Ptr->registeredItem = ITEM_NONE;
+ ResetBagCursorPositions();
+}
+
+static void RestorePlayerBag(void)
+{
+ u32 i;
+ memcpy(gSaveBlock1Ptr->bagPocket_Items, sBackupPlayerBag->bagPocket_Items, BAG_ITEMS_COUNT * sizeof(struct ItemSlot));
+ memcpy(gSaveBlock1Ptr->bagPocket_KeyItems, sBackupPlayerBag->bagPocket_KeyItems, BAG_KEYITEMS_COUNT * sizeof(struct ItemSlot));
+ memcpy(gSaveBlock1Ptr->bagPocket_PokeBalls, sBackupPlayerBag->bagPocket_PokeBalls, BAG_POKEBALLS_COUNT * sizeof(struct ItemSlot));
+ gSaveBlock1Ptr->registeredItem = sBackupPlayerBag->registeredItem;
+ gBagMenuState.pocket = sBackupPlayerBag->pocket;
+ for (i = 0; i < 3; i++)
+ {
+ gBagMenuState.itemsAbove[i] = sBackupPlayerBag->itemsAbove[i];
+ gBagMenuState.cursorPos[i] = sBackupPlayerBag->cursorPos[i];
+ }
+ Free(sBackupPlayerBag);
+}
+
+void InitOldManBag(void)
+{
+ BackUpPlayerBag();
+ AddBagItem(ITEM_POTION, 1);
+ AddBagItem(ITEM_POKE_BALL, 1);
+ GoToBagMenu(ITEMMENULOCATION_OLD_MAN, OPEN_BAG_ITEMS, SetCB2ToReshowScreenAfterMenu2);
+}
+
+static void Task_Bag_OldManTutorial(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ if (!gPaletteFade.active)
+ {
+ switch (data[8])
+ {
+ case 102:
+ case 204:
+ PlaySE(SE_BAG2);
+ SwitchPockets(taskId, 1, FALSE);
+ break;
+ case 306:
+ PlaySE(SE_SELECT);
+ bag_menu_print_cursor_(data[0], 2);
+ Bag_FillMessageBoxWithPalette(1);
+ gSpecialVar_ItemId = ITEM_POKE_BALL;
+ OpenContextMenu(taskId);
+ break;
+ case 408:
+ PlaySE(SE_SELECT);
+ HideBagWindow(10);
+ HideBagWindow(6);
+ PutWindowTilemap(0);
+ PutWindowTilemap(1);
+ CopyWindowToVram(0, 1);
+ DestroyListMenuTask(data[0], NULL, NULL);
+ RestorePlayerBag();
+ Bag_BeginCloseWin0Animation();
+ gTasks[taskId].func = Task_Pokedude_FadeFromBag;
+ return;
+ }
+ data[8]++;
+ }
+}
+
+static void Task_Pokedude_FadeFromBag(u8 taskId)
+{
+ BeginNormalPaletteFade(0xFFFFFFFF, -2, 0, 16, RGB_BLACK);
+ gTasks[taskId].func = Task_Pokedude_WaitFadeAndExitBag;
+}
+
+static void Task_Pokedude_WaitFadeAndExitBag(u8 taskId)
+{
+ if (!gPaletteFade.active && FuncIsActiveTask(Task_AnimateWin0v) != TRUE)
+ {
+ if (sBagMenuDisplay->exitCB != NULL)
+ SetMainCallback2(sBagMenuDisplay->exitCB);
+ else
+ SetMainCallback2(gBagMenuState.bagCallback);
+ BagDestroyPocketScrollArrowPair();
+ DestroyBagMenuResources();
+ DestroyTask(taskId);
+ }
+}
+
+void InitPokedudeBag(u8 a0)
+{
+ MainCallback cb2;
+ u8 location;
+ BackUpPlayerBag();
+ AddBagItem(ITEM_POTION, 1);
+ AddBagItem(ITEM_ANTIDOTE, 1);
+ AddBagItem(ITEM_TEACHY_TV, 1);
+ AddBagItem(ITEM_TM_CASE, 1);
+ AddBagItem(ITEM_POKE_BALL, 5);
+ AddBagItem(ITEM_GREAT_BALL, 1);
+ AddBagItem(ITEM_NEST_BALL, 1);
+ switch (a0)
+ {
+ default:
+ cb2 = CB2_ReturnToTeachyTV;
+ location = a0;
+ break;
+ case 7:
+ cb2 = SetCB2ToReshowScreenAfterMenu2;
+ location = ITEMMENULOCATION_TTVSCR_STATUS;
+ break;
+ case 8:
+ cb2 = SetCB2ToReshowScreenAfterMenu2;
+ location = ITEMMENULOCATION_TTVSCR_CATCHING;
+ break;
+ }
+ GoToBagMenu(location, OPEN_BAG_ITEMS, cb2);
+}
+
+static bool8 Task_BButtonInterruptTeachyTv(u8 taskId)
+{
+ if (JOY_NEW(B_BUTTON))
+ {
+ RestorePlayerBag();
+ SetTeachyTvControllerModeToResume();
+ sBagMenuDisplay->exitCB = CB2_ReturnToTeachyTV;
+ gTasks[taskId].func = Task_Pokedude_FadeFromBag;
+ return TRUE;
+ }
+ else
+ {
+ return FALSE;
+ }
+}
+
+static void Task_Bag_TeachyTvRegister(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ if (!gPaletteFade.active && Task_BButtonInterruptTeachyTv(taskId) != TRUE)
+ {
+ switch (data[8])
+ {
+ case 102:
+ PlaySE(SE_BAG2);
+ SwitchPockets(taskId, 1, FALSE);
+ break;
+ case 204:
+ PlaySE(SE_SELECT);
+ bag_menu_print_cursor_(data[0], 2);
+ Bag_FillMessageBoxWithPalette(1);
+ gSpecialVar_ItemId = ITEM_TEACHY_TV;
+ OpenContextMenu(taskId);
+ break;
+ case 306:
+ PlaySE(SE_SELECT);
+ Menu_MoveCursorNoWrapAround(1);
+ break;
+ case 408:
+ PlaySE(SE_SELECT);
+ gSaveBlock1Ptr->registeredItem = gSpecialVar_ItemId;
+ HideBagWindow(10);
+ HideBagWindow(6);
+ PutWindowTilemap(0);
+ PutWindowTilemap(1);
+ DestroyListMenuTask(data[0], &gBagMenuState.cursorPos[gBagMenuState.pocket], &gBagMenuState.itemsAbove[gBagMenuState.pocket]);
+ Bag_BuildListMenuTemplate(gBagMenuState.pocket);
+ data[0] = ListMenuInit(&gMultiuseListMenuTemplate, gBagMenuState.cursorPos[gBagMenuState.pocket], gBagMenuState.itemsAbove[gBagMenuState.pocket]);
+ Bag_FillMessageBoxWithPalette(0);
+ bag_menu_print_cursor_(data[0], 1);
+ CopyWindowToVram(0, 1);
+ break;
+ case 510:
+ case 612:
+ gMain.newKeys = 0;
+ gMain.newAndRepeatedKeys = DPAD_DOWN;
+ ListMenu_ProcessInput(data[0]);
+ break;
+ case 714:
+ PlaySE(SE_SELECT);
+ DestroyListMenuTask(data[0], NULL, NULL);
+ RestorePlayerBag();
+ Bag_BeginCloseWin0Animation();
+ gTasks[taskId].func = Task_Pokedude_FadeFromBag;
+ return;
+ }
+ data[8]++;
+ }
+}
+
+static void Task_Bag_TeachyTvCatching(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ if (!gPaletteFade.active)
+ {
+ if (Task_BButtonInterruptTeachyTv(taskId) == TRUE)
+ {
+ FreeRestoreBattleData();
+ LoadPlayerParty();
+ return;
+ }
+ switch (data[8])
+ {
+ case 102:
+ case 204:
+ PlaySE(SE_BAG2);
+ SwitchPockets(taskId, 1, FALSE);
+ break;
+ case 306:
+ case 408:
+ gMain.newKeys = 0;
+ gMain.newAndRepeatedKeys = DPAD_DOWN;
+ ListMenu_ProcessInput(data[0]);
+ break;
+ case 510:
+ case 612:
+ gMain.newKeys = 0;
+ gMain.newAndRepeatedKeys = DPAD_UP;
+ ListMenu_ProcessInput(data[0]);
+ break;
+ case 714:
+ PlaySE(SE_SELECT);
+ bag_menu_print_cursor_(data[0], 2);
+ Bag_FillMessageBoxWithPalette(1);
+ gSpecialVar_ItemId = ITEM_POKE_BALL;
+ OpenContextMenu(taskId);
+ break;
+ case 816:
+ PlaySE(SE_SELECT);
+ HideBagWindow(10);
+ HideBagWindow(6);
+ PutWindowTilemap(0);
+ PutWindowTilemap(1);
+ CopyWindowToVram(0, 1);
+ DestroyListMenuTask(data[0], NULL, NULL);
+ RestorePlayerBag();
+ Bag_BeginCloseWin0Animation();
+ gTasks[taskId].func = Task_Pokedude_FadeFromBag;
+ return;
+ }
+ data[8]++;
+ }
+}
+
+static void Task_Bag_TeachyTvStatus(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ if (!gPaletteFade.active)
+ {
+ if (Task_BButtonInterruptTeachyTv(taskId) == TRUE)
+ {
+ FreeRestoreBattleData();
+ LoadPlayerParty();
+ return;
+ }
+ switch (data[8])
+ {
+ case 102:
+ gMain.newKeys = 0;
+ gMain.newAndRepeatedKeys = DPAD_DOWN;
+ ListMenu_ProcessInput(data[0]);
+ break;
+ case 204:
+ PlaySE(SE_SELECT);
+ bag_menu_print_cursor_(data[0], 2);
+ Bag_FillMessageBoxWithPalette(1);
+ gSpecialVar_ItemId = ITEM_ANTIDOTE;
+ OpenContextMenu(taskId);
+ break;
+ case 306:
+ PlaySE(SE_SELECT);
+ HideBagWindow(10);
+ HideBagWindow(6);
+ PutWindowTilemap(0);
+ PutWindowTilemap(1);
+ CopyWindowToVram(0, 1);
+ DestroyListMenuTask(data[0], NULL, NULL);
+ RestorePlayerBag();
+ gItemUseCB = ItemUseCB_MedicineStep;
+ ItemMenu_SetExitCallback(ChooseMonForInBattleItem);
+ gTasks[taskId].func = Task_Pokedude_FadeFromBag;
+ return;
+ }
+ data[8]++;
+ }
+}
+
+static void Task_Bag_TeachyTvTMs(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ if (!gPaletteFade.active && Task_BButtonInterruptTeachyTv(taskId) != TRUE)
+ {
+ switch (data[8])
+ {
+ case 102:
+ PlaySE(SE_BAG2);
+ SwitchPockets(taskId, 1, 0);
+ break;
+ case 204:
+ gMain.newKeys = 0;
+ gMain.newAndRepeatedKeys = DPAD_DOWN;
+ ListMenu_ProcessInput(data[0]);
+ break;
+ case 306:
+ PlaySE(SE_SELECT);
+ bag_menu_print_cursor_(data[0], 2);
+ Bag_FillMessageBoxWithPalette(1);
+ gSpecialVar_ItemId = ITEM_TM_CASE;
+ OpenContextMenu(taskId);
+ break;
+ case 408:
+ PlaySE(SE_SELECT);
+ HideBagWindow(10);
+ HideBagWindow(6);
+ PutWindowTilemap(0);
+ PutWindowTilemap(1);
+ CopyWindowToVram(0, 1);
+ DestroyListMenuTask(data[0], NULL, NULL);
+ RestorePlayerBag();
+ sBagMenuDisplay->exitCB = Pokedude_InitTMCase;
+ gTasks[taskId].func = Task_Pokedude_FadeFromBag;
+ return;
+ }
+ data[8]++;
+ }
+}
diff --git a/src/item_menu_icons.c b/src/item_menu_icons.c
index 0c2c60437..d389c7781 100644
--- a/src/item_menu_icons.c
+++ b/src/item_menu_icons.c
@@ -5,14 +5,14 @@
#include "malloc.h"
#include "constants/items.h"
-static EWRAM_DATA u8 gUnknown_2039878[12] = {0};
-EWRAM_DATA void * gUnknown_2039884 = NULL;
-static EWRAM_DATA void * gUnknown_2039888 = NULL;
+static EWRAM_DATA u8 sItemMenuIconSpriteIds[12] = {0};
+static EWRAM_DATA void * sItemIconTilesBuffer = NULL;
+static EWRAM_DATA void * sItemIconTilesBufferPadded = NULL;
static void sub_8098560(struct Sprite * sprite);
static void sub_80985BC(struct Sprite * sprite);
-static const struct OamData gUnknown_83D416C = {
+static const struct OamData sOamData_BagOrSatchel = {
.affineMode = ST_OAM_AFFINE_NORMAL,
.shape = ST_OAM_SQUARE,
.size = 3,
@@ -20,36 +20,36 @@ static const struct OamData gUnknown_83D416C = {
.paletteNum = 0
};
-static const union AnimCmd gUnknown_83D4174[] = {
+static const union AnimCmd sAnim_BagOrSatchel_OpenItemPocket[] = {
ANIMCMD_FRAME( 0, 5),
ANIMCMD_FRAME(0x40, 0),
ANIMCMD_END
};
-static const union AnimCmd gUnknown_83D4180[] = {
+static const union AnimCmd sAnim_BagOrSatchel_OpenKeyItemPocket[] = {
ANIMCMD_FRAME( 0, 5),
ANIMCMD_FRAME(0x80, 0),
ANIMCMD_END
};
-static const union AnimCmd gUnknown_83D418C[] = {
+static const union AnimCmd sAnim_BagOrSatchel_OpenPokeBallsPocket[] = {
ANIMCMD_FRAME( 0, 5),
ANIMCMD_FRAME(0xc0, 0),
ANIMCMD_END
};
-static const union AnimCmd *const gUnknown_83D4198[] = {
- gUnknown_83D4180,
- gUnknown_83D418C,
- gUnknown_83D4174
+static const union AnimCmd *const sAnimTable_BagOrSatchel[] = {
+ sAnim_BagOrSatchel_OpenKeyItemPocket,
+ sAnim_BagOrSatchel_OpenPokeBallsPocket,
+ sAnim_BagOrSatchel_OpenItemPocket
};
-static const union AffineAnimCmd gUnknown_83D41A4[] = {
+static const union AffineAnimCmd sAffineAnim_Idle[] = {
AFFINEANIMCMD_FRAME(0x100, 0x100, 0, 0),
AFFINEANIMCMD_END
};
-static const union AffineAnimCmd gUnknown_83D41B4[] = {
+static const union AffineAnimCmd sAffineAnim_Wobble[] = {
AFFINEANIMCMD_FRAME(0, 0, -2, 2),
AFFINEANIMCMD_FRAME(0, 0, 2, 4),
AFFINEANIMCMD_FRAME(0, 0, -2, 4),
@@ -57,35 +57,35 @@ static const union AffineAnimCmd gUnknown_83D41B4[] = {
AFFINEANIMCMD_END
};
-static const union AffineAnimCmd *const gUnknown_83D41DC[] = {
- gUnknown_83D41A4,
- gUnknown_83D41B4
+static const union AffineAnimCmd *const sAffineAnimTable_BagOrSatchel[] = {
+ sAffineAnim_Idle,
+ sAffineAnim_Wobble
};
-const struct CompressedSpriteSheet gUnknown_83D41E4 = {
+const struct CompressedSpriteSheet gSpriteSheet_Backpack = {
gUnknown_8E8362C,
0x2000,
100
};
-const struct CompressedSpriteSheet gUnknown_83D41EC = {
+const struct CompressedSpriteSheet gSpriteSheet_Satchel = {
gUnknown_8E83DBC,
0x2000,
100
};
-const struct CompressedSpritePalette gUnknown_83D41F4 = {
+const struct CompressedSpritePalette gSpritePalette_BagOrSatchel = {
gUnknown_8E84560,
100
};
-static const struct SpriteTemplate gUnknown_83D41FC = {
+static const struct SpriteTemplate sSpriteTemplate_BagOrSatchel = {
100,
100,
- &gUnknown_83D416C,
- gUnknown_83D4198,
+ &sOamData_BagOrSatchel,
+ sAnimTable_BagOrSatchel,
NULL,
- gUnknown_83D41DC,
+ sAffineAnimTable_BagOrSatchel,
SpriteCallbackDummy
};
@@ -139,7 +139,7 @@ static const struct SpriteTemplate gUnknown_83D4250 = {
SpriteCallbackDummy
};
-static const struct OamData gUnknown_83D4268 = {
+static const struct OamData sOamData_ItemIcon = {
.affineMode = ST_OAM_AFFINE_OFF,
.shape = ST_OAM_SQUARE,
.size = 2,
@@ -147,26 +147,26 @@ static const struct OamData gUnknown_83D4268 = {
.paletteNum = 2
};
-static const union AnimCmd gUnknown_83D4270[] = {
+static const union AnimCmd sAnim_ItemIcon_0[] = {
ANIMCMD_FRAME(0, 0),
ANIMCMD_END
};
-static const union AnimCmd *const gUnknown_83D4278[] = {
- gUnknown_83D4270
+static const union AnimCmd *const sAnimTable_ItemIcon[] = {
+ sAnim_ItemIcon_0
};
-static const struct SpriteTemplate gUnknown_83D427C = {
+static const struct SpriteTemplate sSpriteTemplate_ItemIcon = {
102,
102,
- &gUnknown_83D4268,
- gUnknown_83D4278,
+ &sOamData_ItemIcon,
+ sAnimTable_ItemIcon,
NULL,
gDummySpriteAffineAnimTable,
SpriteCallbackDummy
};
-static const void *const gUnknown_83D4294[][2] = {
+static const void *const sItemIconGfxPtrs[][2] = {
{gFile_graphics_items_icons_question_mark_sheet, gFile_graphics_items_icon_palettes_question_mark_palette},
{gFile_graphics_items_icons_master_ball_sheet, gFile_graphics_items_icon_palettes_master_ball_palette},
{gFile_graphics_items_icons_ultra_ball_sheet, gFile_graphics_items_icon_palettes_ultra_ball_palette},
@@ -549,19 +549,19 @@ void ResetItemMenuIconState(void)
{
u16 i;
- for (i = 0; i < NELEMS(gUnknown_2039878); i++)
- gUnknown_2039878[i] = 0xFF;
+ for (i = 0; i < NELEMS(sItemMenuIconSpriteIds); i++)
+ sItemMenuIconSpriteIds[i] = 0xFF;
}
-void sub_80984FC(u8 animNum)
+void CreateBagOrSatchelSprite(u8 animNum)
{
- gUnknown_2039878[0] = CreateSprite(&gUnknown_83D41FC, 40, 68, 0);
+ sItemMenuIconSpriteIds[0] = CreateSprite(&sSpriteTemplate_BagOrSatchel, 40, 68, 0);
sub_8098528(animNum);
}
void sub_8098528(u8 animNum)
{
- struct Sprite * sprite = &gSprites[gUnknown_2039878[0]];
+ struct Sprite * sprite = &gSprites[sItemMenuIconSpriteIds[0]];
sprite->pos2.y = -5;
sprite->callback = sub_8098560;
StartSpriteAnim(sprite, animNum);
@@ -577,7 +577,7 @@ static void sub_8098560(struct Sprite * sprite)
void sub_8098580(void)
{
- struct Sprite * sprite = &gSprites[gUnknown_2039878[0]];
+ struct Sprite * sprite = &gSprites[sItemMenuIconSpriteIds[0]];
if (sprite->affineAnimEnded)
{
StartSpriteAffineAnim(sprite, 1);
@@ -594,40 +594,44 @@ static void sub_80985BC(struct Sprite * sprite)
}
}
-void sub_80985E4(void)
+void ItemMenuIcons_CreateInsertIndicatorBarHidden(void)
{
u8 i;
- u8 * ptr = &gUnknown_2039878[1];
+ u8 * ptr = &sItemMenuIconSpriteIds[1];
for (i = 0; i < 9; i++)
{
ptr[i] = CreateSprite(&gUnknown_83D4250, i * 16 + 0x60, 7, 0);
- if (i != 0)
+ switch (i)
{
- if (i == 8)
- StartSpriteAnim(&gSprites[ptr[i]], 2);
- else
- StartSpriteAnim(&gSprites[ptr[i]], 1);
+ case 0:
+ break;
+ case 8:
+ StartSpriteAnim(&gSprites[ptr[i]], 2);
+ break;
+ default:
+ StartSpriteAnim(&gSprites[ptr[i]], 1);
+ break;
}
gSprites[ptr[i]].invisible = TRUE;
}
}
-void sub_8098660(u8 flag)
+void ItemMenuIcons_ToggleInsertIndicatorBarVisibility(bool8 invisible)
{
u8 i;
- u8 * ptr = &gUnknown_2039878[1];
+ u8 * ptr = &sItemMenuIconSpriteIds[1];
for (i = 0; i < 9; i++)
{
- gSprites[ptr[i]].invisible = flag;
+ gSprites[ptr[i]].invisible = invisible;
}
}
-void sub_80986A8(s16 x, u16 y)
+void ItemMenuIcons_MoveInsertIndicatorBar(s16 x, u16 y)
{
u8 i;
- u8 * ptr = &gUnknown_2039878[1];
+ u8 * ptr = &sItemMenuIconSpriteIds[1];
for (i = 0; i < 9; i++)
{
@@ -636,15 +640,15 @@ void sub_80986A8(s16 x, u16 y)
}
}
-static bool8 sub_80986EC(void)
+static bool8 TryAllocItemIconTilesBuffers(void)
{
void ** ptr1, ** ptr2;
- ptr1 = &gUnknown_2039884;
+ ptr1 = &sItemIconTilesBuffer;
*ptr1 = Alloc(0x120);
if (*ptr1 == NULL)
return FALSE;
- ptr2 = &gUnknown_2039888;
+ ptr2 = &sItemIconTilesBufferPadded;
*ptr2 = AllocZeroed(0x200);
if (*ptr2 == NULL)
{
@@ -671,27 +675,27 @@ u8 AddItemIconObject(u16 tilesTag, u16 paletteTag, u16 itemId)
struct CompressedSpritePalette spritePalette;
u8 spriteId;
- if (!sub_80986EC())
+ if (!TryAllocItemIconTilesBuffers())
return MAX_SPRITES;
- LZDecompressWram(sub_8098974(itemId, 0), gUnknown_2039884);
- CopyItemIconPicTo4x4Buffer(gUnknown_2039884, gUnknown_2039888);
- spriteSheet.data = gUnknown_2039888;
+ LZDecompressWram(GetItemIconGfxPtr(itemId, 0), sItemIconTilesBuffer);
+ CopyItemIconPicTo4x4Buffer(sItemIconTilesBuffer, sItemIconTilesBufferPadded);
+ spriteSheet.data = sItemIconTilesBufferPadded;
spriteSheet.size = 0x200;
spriteSheet.tag = tilesTag;
LoadSpriteSheet(&spriteSheet);
- spritePalette.data = sub_8098974(itemId, 1);
+ spritePalette.data = GetItemIconGfxPtr(itemId, 1);
spritePalette.tag = paletteTag;
LoadCompressedSpritePalette(&spritePalette);
- CpuCopy16(&gUnknown_83D427C, &template, sizeof(struct SpriteTemplate));
+ CpuCopy16(&sSpriteTemplate_ItemIcon, &template, sizeof(struct SpriteTemplate));
template.tileTag = tilesTag;
template.paletteTag = paletteTag;
spriteId = CreateSprite(&template, 0, 0, 0);
- Free(gUnknown_2039884);
- Free(gUnknown_2039888);
+ Free(sItemIconTilesBuffer);
+ Free(sItemIconTilesBufferPadded);
return spriteId;
}
@@ -702,17 +706,17 @@ u8 AddItemIconObjectWithCustomObjectTemplate(const struct SpriteTemplate * origT
struct CompressedSpritePalette spritePalette;
u8 spriteId;
- if (!sub_80986EC())
+ if (!TryAllocItemIconTilesBuffers())
return MAX_SPRITES;
- LZDecompressWram(sub_8098974(itemId, 0), gUnknown_2039884);
- CopyItemIconPicTo4x4Buffer(gUnknown_2039884, gUnknown_2039888);
- spriteSheet.data = gUnknown_2039888;
+ LZDecompressWram(GetItemIconGfxPtr(itemId, 0), sItemIconTilesBuffer);
+ CopyItemIconPicTo4x4Buffer(sItemIconTilesBuffer, sItemIconTilesBufferPadded);
+ spriteSheet.data = sItemIconTilesBufferPadded;
spriteSheet.size = 0x200;
spriteSheet.tag = tilesTag;
LoadSpriteSheet(&spriteSheet);
- spritePalette.data = sub_8098974(itemId, 1);
+ spritePalette.data = GetItemIconGfxPtr(itemId, 1);
spritePalette.tag = paletteTag;
LoadCompressedSpritePalette(&spritePalette);
@@ -721,14 +725,14 @@ u8 AddItemIconObjectWithCustomObjectTemplate(const struct SpriteTemplate * origT
template.paletteTag = paletteTag;
spriteId = CreateSprite(&template, 0, 0, 0);
- Free(gUnknown_2039884);
- Free(gUnknown_2039888);
+ Free(sItemIconTilesBuffer);
+ Free(sItemIconTilesBufferPadded);
return spriteId;
}
void CreateItemMenuIcon(u16 itemId, u8 idx)
{
- u8 * ptr = &gUnknown_2039878[10];
+ u8 * ptr = &sItemMenuIconSpriteIds[10];
u8 spriteId;
if (ptr[idx] == 0xFF)
@@ -747,7 +751,7 @@ void CreateItemMenuIcon(u16 itemId, u8 idx)
void DestroyItemMenuIcon(u8 idx)
{
- u8 * ptr = &gUnknown_2039878[10];
+ u8 * ptr = &sItemMenuIconSpriteIds[10];
if (ptr[idx] != 0xFF)
{
@@ -756,16 +760,16 @@ void DestroyItemMenuIcon(u8 idx)
}
}
-const void * sub_8098974(u16 itemId, u8 attrId)
+const void * GetItemIconGfxPtr(u16 itemId, u8 attrId)
{
if (itemId > ITEM_N_A)
itemId = ITEM_NONE;
- return gUnknown_83D4294[itemId][attrId];
+ return sItemIconGfxPtrs[itemId][attrId];
}
void sub_80989A0(u16 itemId, u8 idx)
{
- u8 * ptr = &gUnknown_2039878[10];
+ u8 * ptr = &sItemMenuIconSpriteIds[10];
u8 spriteId;
if (ptr[idx] == 0xFF)
diff --git a/src/item_pc.c b/src/item_pc.c
index 217acc829..7c7abdce3 100644
--- a/src/item_pc.c
+++ b/src/item_pc.c
@@ -348,7 +348,7 @@ static bool8 ItemPc_DoGfxSetup(void)
gMain.state++;
break;
case 14:
- sub_80985E4();
+ ItemMenuIcons_CreateInsertIndicatorBarHidden();
gMain.state++;
break;
case 15:
@@ -780,8 +780,8 @@ static void ItemPc_MoveItemModeInit(u8 taskId, s16 pos)
StringExpandPlaceholders(gStringVar4, gOtherText_WhereShouldTheStrVar1BePlaced);
FillWindowPixelBuffer(1, 0x00);
ItemPc_AddTextPrinterParameterized(1, 2, gStringVar4, 0, 3, 2, 3, 0, 0);
- sub_80986A8(-32, ListMenuGetYCoordForPrintingArrowCursor(data[0]));
- sub_8098660(0);
+ ItemMenuIcons_MoveInsertIndicatorBar(-32, ListMenuGetYCoordForPrintingArrowCursor(data[0]));
+ ItemMenuIcons_ToggleInsertIndicatorBarVisibility(FALSE);
ItemPc_PrintOrRemoveCursor(data[0], 2);
gTasks[taskId].func = Task_ItemPcMoveItemModeRun;
}
@@ -792,7 +792,7 @@ static void Task_ItemPcMoveItemModeRun(u8 taskId)
ListMenu_ProcessInput(data[0]);
ListMenuGetScrollAndRow(data[0], &sListMenuState.scroll, &sListMenuState.row);
- sub_80986A8(-32, ListMenuGetYCoordForPrintingArrowCursor(data[0]));
+ ItemMenuIcons_MoveInsertIndicatorBar(-32, ListMenuGetYCoordForPrintingArrowCursor(data[0]));
if (JOY_NEW(A_BUTTON | SELECT_BUTTON))
{
PlaySE(SE_SELECT);
@@ -814,13 +814,13 @@ static void ItemPc_InsertItemIntoNewSlot(u8 taskId, u32 pos)
ItemPc_MoveItemModeCancel(taskId, pos);
else
{
- ItemMenu_MoveItemSlotToNewPositionInArray(gSaveBlock1Ptr->pcItems, data[1], pos);
+ MoveItemSlotInList(gSaveBlock1Ptr->pcItems, data[1], pos);
DestroyListMenuTask(data[0], &sListMenuState.scroll, &sListMenuState.row);
if (data[1] < pos)
sListMenuState.row--;
ItemPc_BuildListMenuTemplate();
data[0] = ListMenuInit(&gMultiuseListMenuTemplate, sListMenuState.scroll, sListMenuState.row);
- sub_8098660(1);
+ ItemMenuIcons_ToggleInsertIndicatorBarVisibility(TRUE);
gTasks[taskId].func = Task_ItemPcMain;
}
}
@@ -834,7 +834,7 @@ static void ItemPc_MoveItemModeCancel(u8 taskId, u32 pos)
sListMenuState.row--;
ItemPc_BuildListMenuTemplate();
data[0] = ListMenuInit(&gMultiuseListMenuTemplate, sListMenuState.scroll, sListMenuState.row);
- sub_8098660(1);
+ ItemMenuIcons_ToggleInsertIndicatorBarVisibility(TRUE);
gTasks[taskId].func = Task_ItemPcMain;
}
diff --git a/src/item_use.c b/src/item_use.c
index d5db22ca1..fc5703a75 100644
--- a/src/item_use.c
+++ b/src/item_use.c
@@ -154,7 +154,7 @@ static void sub_80A0FBC(u8 taskId)
{
ItemMenu_SetExitCallback(gUnknown_83E2954[itemType]);
if (itemType == 1)
- sub_8108CB4();
+ Bag_BeginCloseWin0Animation();
ItemMenu_StartFadeToExitCallback(taskId);
}
}
@@ -188,7 +188,7 @@ static void sub_80A10C4(u8 taskId, bool8 a1, u8 a2, const u8 * str)
{
StringExpandPlaceholders(gStringVar4, str);
if (a1 == FALSE)
- DisplayItemMessageInBag(taskId, a2, gStringVar4, sub_810A1F8);
+ DisplayItemMessageInBag(taskId, a2, gStringVar4, Task_ReturnToBagFromContextMenu);
else
DisplayItemMessageOnField(taskId, a2, gStringVar4, sub_80A112C);
}
@@ -345,7 +345,7 @@ void FieldUseFunc_CoinCase(u8 taskId)
StringExpandPlaceholders(gStringVar4, gUnknown_8416537);
ItemUse_SetQuestLogEvent(QL_EVENT_USED_ITEM, NULL, gSpecialVar_ItemId, 0xFFFF);
if (gTasks[taskId].data[3] == 0)
- DisplayItemMessageInBag(taskId, 2, gStringVar4, sub_810A1F8);
+ DisplayItemMessageInBag(taskId, 2, gStringVar4, Task_ReturnToBagFromContextMenu);
else
DisplayItemMessageOnField(taskId, 2, gStringVar4, sub_80A112C);
}
@@ -356,7 +356,7 @@ void FieldUseFunc_PowderJar(u8 taskId)
StringExpandPlaceholders(gStringVar4, gUnknown_8416644);
ItemUse_SetQuestLogEvent(QL_EVENT_USED_ITEM, NULL, gSpecialVar_ItemId, 0xFFFF);
if (gTasks[taskId].data[3] == 0)
- DisplayItemMessageInBag(taskId, 2, gStringVar4, sub_810A1F8);
+ DisplayItemMessageInBag(taskId, 2, gStringVar4, Task_ReturnToBagFromContextMenu);
else
DisplayItemMessageOnField(taskId, 2, gStringVar4, sub_80A112C);
}
@@ -384,7 +384,7 @@ void FieldUseFunc_PokeFlute(u8 taskId)
{
// Now that's a catchy tune!
if (gTasks[taskId].data[3] == 0)
- DisplayItemMessageInBag(taskId, 2, gUnknown_841665C, sub_810A1F8);
+ DisplayItemMessageInBag(taskId, 2, gUnknown_841665C, Task_ReturnToBagFromContextMenu);
else
DisplayItemMessageOnField(taskId, 2, gUnknown_841665C, sub_80A112C);
}
@@ -401,7 +401,7 @@ static void sub_80A1674(u8 taskId)
if (WaitFanfare(FALSE))
{
if (gTasks[taskId].data[3] == 0)
- DisplayItemMessageInBag(taskId, 2, gUnknown_84166A7, sub_810A1F8);
+ DisplayItemMessageInBag(taskId, 2, gUnknown_84166A7, Task_ReturnToBagFromContextMenu);
else
DisplayItemMessageOnField(taskId, 2, gUnknown_84166A7, sub_80A112C);
}
@@ -518,7 +518,7 @@ void BattleUseFunc_BerryPouch(u8 taskId)
static void InitBerryPouchFromBattle(void)
{
- InitBerryPouch(BERRYPOUCH_FROMBATTLE, sub_8107ECC, 0);
+ InitBerryPouch(BERRYPOUCH_FROMBATTLE, CB2_BagMenuFromBattle, 0);
}
void FieldUseFunc_TeachyTv(u8 taskId)
@@ -562,7 +562,7 @@ void FieldUseFunc_SuperRepel(u8 taskId)
}
else
// An earlier repel is still in effect
- DisplayItemMessageInBag(taskId, 2, gUnknown_841659E, sub_810A1F8);
+ DisplayItemMessageInBag(taskId, 2, gUnknown_841659E, Task_ReturnToBagFromContextMenu);
}
static void sub_80A19E8(u8 taskId)
@@ -572,15 +572,15 @@ static void sub_80A19E8(u8 taskId)
ItemUse_SetQuestLogEvent(QL_EVENT_USED_ITEM, NULL, gSpecialVar_ItemId, 0xFFFF);
VarSet(VAR_REPEL_STEP_COUNT, ItemId_GetHoldEffectParam(gSpecialVar_ItemId));
sub_80A1A44();
- DisplayItemMessageInBag(taskId, 2, gStringVar4, sub_810A1F8);
+ DisplayItemMessageInBag(taskId, 2, gStringVar4, Task_ReturnToBagFromContextMenu);
}
}
static void sub_80A1A44(void)
{
RemoveBagItem(gSpecialVar_ItemId, 1);
- sub_8108DC8(ItemId_GetPocket(gSpecialVar_ItemId));
- sub_81089F4(ItemId_GetPocket(gSpecialVar_ItemId));
+ Pocket_CalculateNItemsAndMaxShowed(ItemId_GetPocket(gSpecialVar_ItemId));
+ PocketCalculateInitialCursorPosAndItemsAbove(ItemId_GetPocket(gSpecialVar_ItemId));
CopyItemName(gSpecialVar_ItemId, gStringVar2);
StringExpandPlaceholders(gStringVar4, gUnknown_841658C);
}
@@ -613,7 +613,7 @@ static void sub_80A1B48(u8 taskId)
if (++gTasks[taskId].data[8] > 7)
{
PlaySE(SE_BIDORO);
- DisplayItemMessageInBag(taskId, 2, gStringVar4, sub_810A1F8);
+ DisplayItemMessageInBag(taskId, 2, gStringVar4, Task_ReturnToBagFromContextMenu);
}
}
@@ -745,18 +745,18 @@ void BattleUseFunc_PokeBallEtc(u8 taskId)
if (!IsPlayerPartyAndPokemonStorageFull())
{
RemoveBagItem(gSpecialVar_ItemId, 1);
- sub_8108CB4();
+ Bag_BeginCloseWin0Animation();
ItemMenu_StartFadeToExitCallback(taskId);
}
else
{
- DisplayItemMessageInBag(taskId, 2, gUnknown_8416631, sub_810A1F8);
+ DisplayItemMessageInBag(taskId, 2, gUnknown_8416631, Task_ReturnToBagFromContextMenu);
}
}
void BattleUseFunc_PokeFlute(u8 taskId)
{
- sub_8108CB4();
+ Bag_BeginCloseWin0Animation();
ItemMenu_StartFadeToExitCallback(taskId);
}
@@ -764,7 +764,7 @@ void BattleUseFunc_GuardSpec(u8 taskId)
{
if (ExecuteTableBasedItemEffect(&gPlayerParty[gBattlerPartyIndexes[gBattlerInMenuId]], gSpecialVar_ItemId, gBattlerPartyIndexes[gBattlerInMenuId], 0))
{
- DisplayItemMessageInBag(taskId, 2, gText_WontHaveEffect, sub_810A1F8);
+ DisplayItemMessageInBag(taskId, 2, gText_WontHaveEffect, Task_ReturnToBagFromContextMenu);
}
else
{
@@ -790,7 +790,7 @@ static void Task_BattleUse_StatBooster_WaitButton_ReturnToBattle(u8 taskId)
{
if (JOY_NEW(A_BUTTON) || JOY_NEW(B_BUTTON))
{
- sub_8108CB4();
+ Bag_BeginCloseWin0Animation();
ItemMenu_StartFadeToExitCallback(taskId);
}
}
diff --git a/src/menu_helpers.c b/src/menu_helpers.c
index 905e3c1ea..dedd7aa9e 100644
--- a/src/menu_helpers.c
+++ b/src/menu_helpers.c
@@ -107,7 +107,7 @@ bool8 itemid_link_can_give_berry(u16 itemId)
return FALSE;
}
-bool8 itemid_80BF6D8_mail_related(u16 itemId)
+bool8 CanWriteMailHere(u16 itemId)
{
if (IsUpdateLinkStateCBActive() != TRUE && InUnionRoom() != TRUE)
return TRUE;
@@ -242,7 +242,7 @@ bool8 AdjustQuantityAccordingToDPadInput(s16 *arg0, u16 arg1)
return FALSE;
}
-u8 sub_80BF8E4(void)
+u8 GetDialogBoxFontId(void)
{
if (!ContextNpcGetTextColor())
return 4;
diff --git a/src/new_game.c b/src/new_game.c
index 471c49e67..381ba28c8 100644
--- a/src/new_game.c
+++ b/src/new_game.c
@@ -98,7 +98,7 @@ void ResetMenuAndMonGlobals(void)
gDifferentSaveFile = FALSE;
ZeroPlayerPartyMons();
ZeroEnemyPartyMons();
- sub_81089BC();
+ ResetBagCursorPositions();
ResetTMCaseCursorPos();
BerryPouch_CursorResetToTop();
ResetQuestLog();
diff --git a/src/party_menu.c b/src/party_menu.c
index d12a17e6c..b6ec995ff 100644
--- a/src/party_menu.c
+++ b/src/party_menu.c
@@ -3451,7 +3451,7 @@ static void CursorCB_Give(u8 taskId)
void CB2_SelectBagItemToGive(void)
{
- GoToBagMenu(1, 3, CB2_GiveHoldItem);
+ GoToBagMenu(ITEMMENULOCATION_PARTY, OPEN_BAG_LAST, CB2_GiveHoldItem);
}
void CB2_GiveHoldItem(void)
@@ -4283,12 +4283,12 @@ void CB2_ShowPartyMenuForItemUse(void)
static void CB2_ReturnToBagMenu(void)
{
- GoToBagMenu(11, 3, NULL);
+ GoToBagMenu(ITEMMENULOCATION_LAST, OPEN_BAG_LAST, NULL);
}
static void CB2_ReturnToTMCaseMenu(void)
{
- InitTMCase(5, NULL, 0xFF);
+ InitTMCase(TMCASE_NA, NULL, 0xFF);
}
static void CB2_ReturnToBerryPouchMenu(void)
@@ -5904,7 +5904,7 @@ void OpenPartyMenuInBattle(void)
void ChooseMonForInBattleItem(void)
{
- InitPartyMenu(PARTY_MENU_TYPE_IN_BATTLE, GetPartyLayoutFromBattleType(), PARTY_ACTION_REUSABLE_ITEM, FALSE, PARTY_MSG_USE_ON_WHICH_MON, sub_8120FCC, sub_8107ECC);
+ InitPartyMenu(PARTY_MENU_TYPE_IN_BATTLE, GetPartyLayoutFromBattleType(), PARTY_ACTION_REUSABLE_ITEM, FALSE, PARTY_MSG_USE_ON_WHICH_MON, sub_8120FCC, CB2_BagMenuFromBattle);
nullsub_44();
UpdatePartyToBattleOrder();
}
@@ -5919,7 +5919,7 @@ void sub_81279E0(void)
FALSE,
PARTY_MSG_NONE,
sub_8120C3C,
- sub_8107ECC);
+ CB2_BagMenuFromBattle);
sub_80EB2F4(8);
}
else
@@ -5929,7 +5929,7 @@ void sub_81279E0(void)
if (GetPocketByItemId(gSpecialVar_ItemId) == POCKET_BERRY_POUCH)
callback = CB2_ReturnToBerryPouchMenu;
else
- callback = sub_8107ECC;
+ callback = CB2_BagMenuFromBattle;
InitPartyMenu(PARTY_MENU_TYPE_IN_BATTLE,
GetPartyLayoutFromBattleType(),
PARTY_ACTION_USE_ITEM,
diff --git a/src/player_pc.c b/src/player_pc.c
index 00d41abe6..63870c86a 100644
--- a/src/player_pc.c
+++ b/src/player_pc.c
@@ -322,7 +322,7 @@ static void Task_DepositItem_WaitFadeAndGoToBag(u8 taskId)
if (!gPaletteFade.active)
{
CleanupOverworldWindowsAndTilemaps();
- GoToBagMenu(3, POCKET_ITEMS - 1, CB2_ReturnToField);
+ GoToBagMenu(ITEMMENULOCATION_ITEMPC, OPEN_BAG_ITEMS, CB2_ReturnToField);
gFieldCallback = CB2_ReturnFromDepositMenu;
DestroyTask(taskId);
}
diff --git a/src/pokemon.c b/src/pokemon.c
index 1270a25ed..5b715133b 100644
--- a/src/pokemon.c
+++ b/src/pokemon.c
@@ -1547,7 +1547,7 @@ const struct SpriteTemplate gUnknown_825DF50[] =
.paletteTag = 0,
.oam = &gOamData_824F018,
.anims = NULL,
- .images = gTrainerBackPicTable_PokeDude,
+ .images = gTrainerBackPicTable_Pokedude,
.affineAnims = gSpriteAffineAnimTable_82348C8,
.callback = sub_80120C4,
},
diff --git a/src/shop.c b/src/shop.c
index b410b32b9..865688928 100644
--- a/src/shop.c
+++ b/src/shop.c
@@ -307,7 +307,7 @@ static void Task_HandleShopMenuSell(u8 taskId)
static void CB2_GoToSellMenu(void)
{
- GoToBagMenu(2, POCKET_POKE_BALLS, CB2_ReturnToField);
+ GoToBagMenu(ITEMMENULOCATION_SHOP, OPEN_BAG_LAST, CB2_ReturnToField);
gFieldCallback = MapPostLoadHook_ReturnToShopMenu;
}
diff --git a/src/teachy_tv.c b/src/teachy_tv.c
index 11d4a80b1..1467131b0 100644
--- a/src/teachy_tv.c
+++ b/src/teachy_tv.c
@@ -34,16 +34,6 @@
#include "fieldmap.h"
#include "strings.h"
-enum TeachyTvScript
-{
- TTVSCR_BATTLE,
- TTVSCR_STATUS,
- TTVSCR_MATCHUPS,
- TTVSCR_CATCHING,
- TTVSCR_TMS,
- TTVSCR_REGISTER
-};
-
struct TeachyTvCtrlBlk
{
MainCallback callback;
@@ -805,7 +795,7 @@ static void TTVcmd_NpcMoveAndSetupTextPrinter(u8 taskId)
if (spriteAddr->pos2.x == 0x78)
{
StartSpriteAnim(&gSprites[data[1]], 0);
- TeachyTvInitTextPrinter(gTeachyTvText_PokeDudeSaysHello);
+ TeachyTvInitTextPrinter(gTeachyTvText_PokedudeSaysHello);
data[2] = 0;
++data[3];
}
@@ -1103,9 +1093,9 @@ static void TTVcmd_TaskBattleOrFadeByOptionChosen(u8 taskId)
static void TeachyTvSetupBagItemsByOptionChosen(void)
{
if (sStaticResources.whichScript == TTVSCR_TMS)
- sub_810B108(10);
+ InitPokedudeBag(ITEMMENULOCATION_TTVSCR_TMS);
else
- sub_810B108(9);
+ InitPokedudeBag(ITEMMENULOCATION_TTVSCR_REGISTER);
}
static void TeachyTvPostBattleFadeControl(u8 taskId)
diff --git a/src/tm_case.c b/src/tm_case.c
index 40509ed1b..d45061bde 100644
--- a/src/tm_case.c
+++ b/src/tm_case.c
@@ -67,7 +67,7 @@ struct UnkStruct_203B11C
static EWRAM_DATA struct UnkStruct_203B10C sTMCaseStaticResources = {};
static EWRAM_DATA struct UnkStruct_203B118 * sTMCaseDynamicResources = NULL;
-static EWRAM_DATA struct UnkStruct_203B11C * sPokeDudePackBackup = NULL;
+static EWRAM_DATA struct UnkStruct_203B11C * sPokedudePackBackup = NULL;
static EWRAM_DATA void * sTilemapBuffer = NULL; // tilemap buffer
static EWRAM_DATA struct ListMenuItem * sListMenuItemsBuffer = NULL;
static EWRAM_DATA u8 (* sListMenuStringsBuffer)[29] = NULL;
@@ -977,7 +977,7 @@ static void Task_SelectTMAction_FromSellMenu(u8 taskId)
{
CopyItemName(gSpecialVar_ItemId, gStringVar1);
StringExpandPlaceholders(gStringVar4, gText_OhNoICantBuyThat);
- TMCase_PrintMessageWithFollowupTask(taskId, sub_80BF8E4(), gStringVar4, Subtask_CloseContextMenuAndReturnToMain);
+ TMCase_PrintMessageWithFollowupTask(taskId, GetDialogBoxFontId(), gStringVar4, Subtask_CloseContextMenuAndReturnToMain);
}
else
{
@@ -993,7 +993,7 @@ static void Task_SelectTMAction_FromSellMenu(u8 taskId)
data[2] = 99;
CopyItemName(gSpecialVar_ItemId, gStringVar1);
StringExpandPlaceholders(gStringVar4, gText_HowManyWouldYouLikeToSell);
- TMCase_PrintMessageWithFollowupTask(taskId, sub_80BF8E4(), gStringVar4, Task_InitQuantitySelectUI);
+ TMCase_PrintMessageWithFollowupTask(taskId, GetDialogBoxFontId(), gStringVar4, Task_InitQuantitySelectUI);
}
}
}
@@ -1004,7 +1004,7 @@ static void Task_AskConfirmSaleWithAmount(u8 taskId)
ConvertIntToDecimalStringN(gStringVar3, itemid_get_market_price(BagGetItemIdByPocketPosition(POCKET_TM_CASE, data[1])) / 2 * data[8], STR_CONV_MODE_LEFT_ALIGN, 6);
StringExpandPlaceholders(gStringVar4, gText_ICanPayThisMuch_WouldThatBeOkay);
- TMCase_PrintMessageWithFollowupTask(taskId, sub_80BF8E4(), gStringVar4, Task_PlaceYesNoBox);
+ TMCase_PrintMessageWithFollowupTask(taskId, GetDialogBoxFontId(), gStringVar4, Task_PlaceYesNoBox);
}
static void Task_PlaceYesNoBox(u8 taskId)
@@ -1133,13 +1133,13 @@ static void Task_AfterSale_ReturnToList(u8 taskId)
}
}
-void PokeDude_InitTMCase(void)
+void Pokedude_InitTMCase(void)
{
- sPokeDudePackBackup = AllocZeroed(sizeof(*sPokeDudePackBackup));
- memcpy(sPokeDudePackBackup->bagPocket_TMHM, gSaveBlock1Ptr->bagPocket_TMHM, sizeof(gSaveBlock1Ptr->bagPocket_TMHM));
- memcpy(sPokeDudePackBackup->bagPocket_KeyItems, gSaveBlock1Ptr->bagPocket_KeyItems, sizeof(gSaveBlock1Ptr->bagPocket_KeyItems));
- sPokeDudePackBackup->unk_160 = sTMCaseStaticResources.selectedRow;
- sPokeDudePackBackup->unk_162 = sTMCaseStaticResources.scrollOffset;
+ sPokedudePackBackup = AllocZeroed(sizeof(*sPokedudePackBackup));
+ memcpy(sPokedudePackBackup->bagPocket_TMHM, gSaveBlock1Ptr->bagPocket_TMHM, sizeof(gSaveBlock1Ptr->bagPocket_TMHM));
+ memcpy(sPokedudePackBackup->bagPocket_KeyItems, gSaveBlock1Ptr->bagPocket_KeyItems, sizeof(gSaveBlock1Ptr->bagPocket_KeyItems));
+ sPokedudePackBackup->unk_160 = sTMCaseStaticResources.selectedRow;
+ sPokedudePackBackup->unk_162 = sTMCaseStaticResources.scrollOffset;
ClearItemSlots(gSaveBlock1Ptr->bagPocket_TMHM, NELEMS(gSaveBlock1Ptr->bagPocket_TMHM));
ClearItemSlots(gSaveBlock1Ptr->bagPocket_KeyItems, NELEMS(gSaveBlock1Ptr->bagPocket_KeyItems));
ResetTMCaseCursorPos();
@@ -1234,7 +1234,7 @@ static void Task_TMCaseDude_Playback(u8 taskId)
break;
case 8:
FillBG2RowWithPalette_2timesNplus1(1);
- TMCase_PrintMessageWithFollowupTask(taskId, 4, gPokeDudeText_TMTypes, 0);
+ TMCase_PrintMessageWithFollowupTask(taskId, 4, gPokedudeText_TMTypes, 0);
gTasks[taskId].func = Task_TMCaseDude_Playback;
data[8]++;
break;
@@ -1256,7 +1256,7 @@ static void Task_TMCaseDude_Playback(u8 taskId)
break;
case 18:
FillBG2RowWithPalette_2timesNplus1(1);
- TMCase_PrintMessageWithFollowupTask(taskId, 4, gPokeDudeText_ReadTMDescription, NULL);
+ TMCase_PrintMessageWithFollowupTask(taskId, 4, gPokedudeText_ReadTMDescription, NULL);
gTasks[taskId].func = Task_TMCaseDude_Playback; // this function
data[8]++;
break;
@@ -1267,12 +1267,12 @@ static void Task_TMCaseDude_Playback(u8 taskId)
case 21:
if (!gPaletteFade.active)
{
- memcpy(gSaveBlock1Ptr->bagPocket_TMHM, sPokeDudePackBackup->bagPocket_TMHM, sizeof(gSaveBlock1Ptr->bagPocket_TMHM));
- memcpy(gSaveBlock1Ptr->bagPocket_KeyItems, sPokeDudePackBackup->bagPocket_KeyItems, sizeof(gSaveBlock1Ptr->bagPocket_KeyItems));
+ memcpy(gSaveBlock1Ptr->bagPocket_TMHM, sPokedudePackBackup->bagPocket_TMHM, sizeof(gSaveBlock1Ptr->bagPocket_TMHM));
+ memcpy(gSaveBlock1Ptr->bagPocket_KeyItems, sPokedudePackBackup->bagPocket_KeyItems, sizeof(gSaveBlock1Ptr->bagPocket_KeyItems));
DestroyListMenuTask(data[0], NULL, NULL);
- sTMCaseStaticResources.selectedRow = sPokeDudePackBackup->unk_160;
- sTMCaseStaticResources.scrollOffset = sPokeDudePackBackup->unk_162;
- Free(sPokeDudePackBackup);
+ sTMCaseStaticResources.selectedRow = sPokedudePackBackup->unk_160;
+ sTMCaseStaticResources.scrollOffset = sPokedudePackBackup->unk_162;
+ Free(sPokedudePackBackup);
CpuFastCopy(gPlttBufferFaded, gPlttBufferUnfaded, 0x400);
CB2_SetUpReshowBattleScreenAfterMenu();
BeginNormalPaletteFade(0xFFFFFFFF, -2, 0, 16, 0);