summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/battle_controller_player.c4
-rw-r--r--src/battle_controller_safari.c2
-rw-r--r--src/battle_controller_wally.c2
-rw-r--r--src/battle_dome.c13
-rw-r--r--src/battle_main.c11
-rw-r--r--src/battle_pyramid_bag.c1320
-rw-r--r--src/item.c8
-rwxr-xr-xsrc/item_use.c46
-rw-r--r--src/start_menu.c9
9 files changed, 1284 insertions, 131 deletions
diff --git a/src/battle_controller_player.c b/src/battle_controller_player.c
index ffe8936a0..7f038a0c3 100644
--- a/src/battle_controller_player.c
+++ b/src/battle_controller_player.c
@@ -28,7 +28,7 @@
#include "pokeball.h"
#include "data2.h"
#include "battle_setup.h"
-#include "item_use.h"
+#include "item_menu.h"
#include "recorded_battle.h"
#include "party_menu.h"
#include "battle_dome.h"
@@ -40,7 +40,6 @@ extern u16 gBattle_BG0_X;
extern u16 gBattle_BG0_Y;
extern struct UnusedControllerStruct gUnknown_02022D0C;
extern struct MusicPlayerInfo gMPlayInfo_BGM;
-extern struct SpriteTemplate gMultiuseSpriteTemplate;
extern const struct CompressedSpritePalette gTrainerFrontPicPaletteTable[];
extern const struct CompressedSpritePalette gTrainerBackPicPaletteTable[];
@@ -52,7 +51,6 @@ extern void sub_81851A8(u8 *);
// this file's functions
static void PlayerHandleGetMonData(void);
-void PlayerHandleGetRawMonData(void);
static void PlayerHandleSetMonData(void);
static void PlayerHandleSetRawMonData(void);
static void PlayerHandleLoadMonSprite(void);
diff --git a/src/battle_controller_safari.c b/src/battle_controller_safari.c
index bc97c01f9..aab804b41 100644
--- a/src/battle_controller_safari.c
+++ b/src/battle_controller_safari.c
@@ -21,7 +21,7 @@
#include "pokeball.h"
#include "data2.h"
#include "pokeblock.h"
-#include "item_use.h"
+#include "item_menu.h"
extern u16 gBattle_BG0_X;
extern u16 gBattle_BG0_Y;
diff --git a/src/battle_controller_wally.c b/src/battle_controller_wally.c
index 960181fbc..4faf78681 100644
--- a/src/battle_controller_wally.c
+++ b/src/battle_controller_wally.c
@@ -29,7 +29,7 @@
#include "data2.h"
#include "party_menu.h"
#include "battle_setup.h"
-#include "item_use.h"
+#include "item_menu.h"
extern u16 gBattle_BG0_X;
extern u16 gBattle_BG0_Y;
diff --git a/src/battle_dome.c b/src/battle_dome.c
index 0183811cd..9f400bc7a 100644
--- a/src/battle_dome.c
+++ b/src/battle_dome.c
@@ -2810,23 +2810,16 @@ static void CalcDomeMonStats(u16 species, s32 level, s32 ivs, u8 evBits, u8 natu
CALC_STAT(baseSpDefense, STAT_SPDEF);
}
-#define SWAP_16(x, y) \
-{ \
- temp = x; \
- x = y; \
- y = temp; \
-}
-
static void SwapDomeTrainers(s32 id1, s32 id2, u16 *statsArray)
{
s32 i;
u16 temp;
- SWAP_16(statsArray[id1], statsArray[id2]);
- SWAP_16(gSaveBlock2Ptr->frontier.domeTrainers[id1].trainerId, gSaveBlock2Ptr->frontier.domeTrainers[id2].trainerId);
+ SWAP(statsArray[id1], statsArray[id2], temp);
+ SWAP(gSaveBlock2Ptr->frontier.domeTrainers[id1].trainerId, gSaveBlock2Ptr->frontier.domeTrainers[id2].trainerId, temp);
for (i = 0; i < 3; i++)
- SWAP_16(gSaveBlock2Ptr->frontier.domeMonId[id1][i], gSaveBlock2Ptr->frontier.domeMonId[id2][i]);
+ SWAP(gSaveBlock2Ptr->frontier.domeMonId[id1][i], gSaveBlock2Ptr->frontier.domeMonId[id2][i], temp);
}
static void sub_818F9B0(void)
diff --git a/src/battle_main.c b/src/battle_main.c
index 9f9511c38..c31fb48d5 100644
--- a/src/battle_main.c
+++ b/src/battle_main.c
@@ -4596,13 +4596,10 @@ static void sub_803CDF8(void)
void SwapTurnOrder(u8 id1, u8 id2)
{
- u32 temp = gActionsByTurnOrder[id1];
- gActionsByTurnOrder[id1] = gActionsByTurnOrder[id2];
- gActionsByTurnOrder[id2] = temp;
-
- temp = gBattlerByTurnOrder[id1];
- gBattlerByTurnOrder[id1] = gBattlerByTurnOrder[id2];
- gBattlerByTurnOrder[id2] = temp;
+ u32 temp;
+
+ SWAP(gActionsByTurnOrder[id1], gActionsByTurnOrder[id2], temp);
+ SWAP(gBattlerByTurnOrder[id1], gBattlerByTurnOrder[id2], temp);
}
u8 GetWhoStrikesFirst(u8 battler1, u8 battler2, bool8 ignoreChosenMoves)
diff --git a/src/battle_pyramid_bag.c b/src/battle_pyramid_bag.c
index f9cc48a9a..8a5ce7a99 100644
--- a/src/battle_pyramid_bag.c
+++ b/src/battle_pyramid_bag.c
@@ -1,4 +1,5 @@
#include "global.h"
+#include "battle_pyramid_bag.h"
#include "main.h"
#include "battle_controllers.h"
#include "bg.h"
@@ -7,6 +8,7 @@
#include "gpu_regs.h"
#include "malloc.h"
#include "menu.h"
+#include "overworld.h"
#include "menu_helpers.h"
#include "overworld.h"
#include "palette.h"
@@ -14,59 +16,215 @@
#include "scanline_effect.h"
#include "script.h"
#include "task.h"
+#include "decompress.h"
+#include "graphics.h"
+#include "string_util.h"
+#include "list_menu.h"
+#include "strings.h"
+#include "item.h"
+#include "sound.h"
+#include "item_menu.h"
+#include "mail.h"
+#include "item_use.h"
+#include "event_data.h"
+#include "text_window.h"
+#include "international_string_util.h"
+#include "item_icon.h"
+#include "constants/items.h"
#include "constants/rgb.h"
+#include "constants/songs.h"
+
+EWRAM_DATA struct PyramidBagResources *gPyramidBagResources = NULL;
+EWRAM_DATA struct PyramidBagCursorData gPyramidBagCursorData = {0};
+
+// gfx
+extern const u8 gUnknown_08D9ADD0[];
+extern const u8 gUnknown_08D9AE04[];
+extern const u8 gUnknown_08D9AF44[];
+extern const u16 gUnknown_0860F074[];
+
+// This file's functions.
+static void Task_HandlePyramidBagInput(u8 taskId);
+static void sub_81C4F44(u8 taskId);
+static void sub_81C5B4C(u8 taskId);
+static void Task_BeginItemSwap(u8 taskId);
+static void sub_81C5D20(u8 taskId);
+static void sub_81C674C(u8 taskId);
+static void HandleMenuActionInput(u8 taskId);
+static void HandleFewMenuActionsInput(u8 taskId);
+static void sub_81C66EC(u8 taskId);
+static void SetTaskToMainPyramidBagInputHandler(u8 taskId);
+static void sub_81C6350(u8 taskId);
+static void sub_81C64B4(u8 taskId);
+static void sub_81C65CC(u8 taskId);
+static void sub_81C66AC(u8 taskId);
+static void PerformItemSwap(u8 taskId);
+static void Task_ItemSwapHandleInput(u8 taskId);
+static void sub_81C6A14(u8 taskId);
+static void SetBagItemsListTemplate(void);
+static void sub_81C504C(void);
+static void sub_81C51DC(void);
+static void AddScrollArrow(void);
+static void sub_81C56F8(void);
+static void sub_81C5A20(void);
+static void sub_81C6BD8(void);
+static void sub_81C6EF4(void);
+static void sub_81C700C(void);
+static void sub_81C6E98(void);
+static void sub_81C6F20(void);
+static void sub_81C6404(void);
+static void sub_81C6E1C(void);
+static bool8 sub_81C5238(void);
+static bool8 sub_81C5078(void);
+static void ShowItemImage(u16 itemId, u8 itemSpriteArrayId);
+static void PyramidBag_CopyItemName(u8 *dst, u16 itemId);
+static void sub_81C6FF8(u8 arg0);
+static void PrintItemDescription(s32 listMenuId);
+static void sub_81C5AB8(u8 y, u8 arg1);
+static void PrintOnWindow_Font1(u8 windowId, const u8 *src, u8 x, u8 y, u8 letterSpacing, u8 lineSpacing, u8 speed, u8 colorTableId);
+static void PrintOnWindow_Font7(u8 windowId, const u8 *src, u8 x, u8 y, u8 letterSpacing, u8 lineSpacing, u8 speed, u8 colorTableId);
+static u8 sub_81C6D24(u8 windowArrayId);
+static void sub_81C6D6C(u8 windowArrayId);
+static void sub_81C5EAC(u8 windowId);
+static void sub_81C5F08(u8 windowId, u8 horizontalCount, u8 verticalCount);
+static bool8 IsValidMenuAction(s8 arg0);
+static void sub_81C6DAC(u8 taskId, const struct YesNoFuncTable *yesNoTable);
+static void sub_81C6CEC(u8 windowId);
+static void sub_81C704C(u8 y);
+static void sub_81C7028(bool8 invisible);
+static void sub_81C6F68(struct Sprite *sprite);
+static void BagAction_UseOnField(u8 taskId);
+static void BagAction_Toss(u8 taskId);
+static void BagAction_Give(u8 taskId);
+static void BagAction_Cancel(u8 taskId);
+static void BagAction_UseInBattle(u8 taskId);
+static void PyramidBagMoveCursorFunc(s32 itemIndex, bool8 onInit, struct ListMenu *list);
+static void PrintItemQuantity(u8 windowId, s32 itemIndex, u8 y);
+static void TossItem(u8 taskId);
+static void DontTossItem(u8 taskId);
-EWRAM_DATA struct
-{
- u32 unk0;
- u8 filler4[0x804 - 0x4];
- u8 unk804[11];
- u8 unk80F[5];
- u8 unk814;
- u8 filler815;
- s8 unk816;
- u8 filler817[0x984 - 0x817];
- u16 unk984;
- u8 filler986[0x98C - 0x986];
-} *gUnknown_0203CF2C = NULL;
-EWRAM_DATA struct
-{
- void (*callback)(void);
- u8 unk4;
- u16 unk6;
- u16 unk8;
-} gUnknown_0203CF30 = {0};
-
-extern const struct BgTemplate gUnknown_0861F2B4[3];
-
-void sub_81C4F98(u8 a0, void (*callback)(void));
-void sub_81C4F44(u8 taskId);
-void sub_81C504C(void);
-bool8 sub_81C5078(void);
-void sub_81C51DC(void);
-bool8 sub_81C5238(void);
-void sub_81C5314(void);
-void sub_81C5674(void);
-void sub_81C56F8(void);
-void sub_81C5924(void);
-void sub_81C59BC(void);
-void sub_81C5A20(void);
-void sub_81C6BD8(void);
-void sub_81C6EF4(void);
-void sub_81C700C(void);
+// Const rom data.
+static const struct BgTemplate gUnknown_0861F2B4[] =
+{
+ {
+ .bg = 0,
+ .charBaseIndex = 0,
+ .mapBaseIndex = 31,
+ .screenSize = 0,
+ .paletteMode = 0,
+ .priority = 1,
+ .baseTile = 0
+ },
+ {
+ .bg = 1,
+ .charBaseIndex = 0,
+ .mapBaseIndex = 30,
+ .screenSize = 0,
+ .paletteMode = 0,
+ .priority = 0,
+ .baseTile = 0
+ },
+ {
+ .bg = 2,
+ .charBaseIndex = 3,
+ .mapBaseIndex = 29,
+ .screenSize = 0,
+ .paletteMode = 0,
+ .priority = 2,
+ .baseTile = 0
+ },
+};
+
+static const struct ListMenuTemplate gUnknown_0861F2C0 =
+{
+ .items = NULL,
+ .moveCursorFunc = PyramidBagMoveCursorFunc,
+ .itemPrintFunc = PrintItemQuantity,
+ .totalItems = 0,
+ .maxShowed = 0,
+ .windowId = 0,
+ .header_X = 0,
+ .item_X = 8,
+ .cursor_X = 0,
+ .upText_Y = 1,
+ .cursorPal = 2,
+ .fillValue = 0,
+ .cursorShadowPal = 3,
+ .lettersSpacing = 0,
+ .itemVerticalPadding = 0,
+ .scrollMultiple = LIST_NO_MULTIPLE_SCROLL,
+ .fontId = 7,
+ .cursorKind = 0
+};
+
+#define ACTION_USE_FIELD 0
+#define ACTION_TOSS 1
+#define ACTION_GIVE 2
+#define ACTION_CANCEL 3
+#define ACTION_USE_BATTLE 4
+#define ACTION_DUMMY 5
+
+static const struct MenuAction sMenuActions[] =
+{
+ [ACTION_USE_FIELD] = { gMenuText_Use, BagAction_UseOnField },
+ [ACTION_TOSS] = { gMenuText_Toss, BagAction_Toss },
+ [ACTION_GIVE] = { gMenuText_Give, BagAction_Give },
+ [ACTION_CANCEL] = { gText_Cancel2, BagAction_Cancel },
+ [ACTION_USE_BATTLE] = { gMenuText_Use, BagAction_UseInBattle },
+ [ACTION_DUMMY] = { gText_EmptyString2, NULL },
+};
+static const u8 sFieldMenuActionIds[] = {ACTION_USE_FIELD, ACTION_GIVE, ACTION_TOSS, ACTION_CANCEL};
+static const u8 gUnknown_0861F30C[] = {ACTION_TOSS, ACTION_CANCEL};
+static const u8 sBattleMenuActionIds[] = {ACTION_USE_BATTLE, ACTION_CANCEL};
+static const u8 gUnknown_0861F310[] = {ACTION_CANCEL};
+
+static const struct YesNoFuncTable sYesNoTossFuncions =
+{
+ TossItem, DontTossItem
+};
+
+static const u8 sColorTable[][3] =
+{
+ {0, 2, 3},
+ {0, 3, 1},
+ {1, 2, 3},
+};
+
+static const struct WindowTemplate gUnknown_0861F328[] =
+{
+ {0x00, 0x0e, 0x02, 0x0f, 0x10, 0x0f, 0x001e},
+ {0x00, 0x00, 0x0d, 0x0e, 0x06, 0x0f, 0x010e},
+ {0x01, 0x02, 0x0f, 0x1b, 0x04, 0x0f, 0x0162},
+ {0x01, 0x18, 0x11, 0x05, 0x02, 0x0f, 0x01ce},
+ DUMMY_WIN_TEMPLATE,
+};
+
+static const struct WindowTemplate gUnknown_0861F350[] =
+{
+ {0x01, 0x16, 0x11, 0x07, 0x02, 0x0f, 0x01d8},
+ {0x01, 0x16, 0x0f, 0x07, 0x04, 0x0f, 0x01d8},
+ {0x01, 0x0f, 0x0f, 0x0e, 0x04, 0x0f, 0x01d8},
+ {0x01, 0x0f, 0x0d, 0x0e, 0x06, 0x0f, 0x01d8},
+ {0x01, 0x18, 0x0f, 0x05, 0x04, 0x0f, 0x01d8},
+};
+
+extern const struct CompressedSpriteSheet gUnknown_0861F3CC;
+extern const struct SpriteTemplate gUnknown_0861F3D4;
+
+// code
void sub_81C4EEC(void)
{
- gUnknown_0203CF30.unk6 = 0;
- gUnknown_0203CF30.unk8 = 0;
+ gPyramidBagCursorData.cursorPosition = 0;
+ gPyramidBagCursorData.scrollPosition = 0;
}
-void sub_81C4EFC(void)
+void CB2_PyramidBagMenuFromStartMenu(void)
{
sub_81C4F98(0, CB2_ReturnToFieldWithOpenMenu);
}
-void sub_81C4F10(void)
+static void sub_81C4F10(void)
{
sub_81C4F98(1, SetCB2ToReshowScreenAfterMenu2);
}
@@ -78,7 +236,7 @@ void sub_81C4F24(void)
CreateTask(sub_81C4F44, 10);
}
-void sub_81C4F44(u8 taskId)
+static void sub_81C4F44(u8 taskId)
{
if (!gPaletteFade.active)
{
@@ -91,34 +249,30 @@ void sub_81C4F44(u8 taskId)
void sub_81C4F84(void)
{
- sub_81C4F98(4, gUnknown_0203CF30.callback);
+ sub_81C4F98(4, gPyramidBagCursorData.callback);
}
void sub_81C4F98(u8 a0, void (*callback)(void))
{
- gUnknown_0203CF2C = AllocZeroed(sizeof(*gUnknown_0203CF2C));
+ gPyramidBagResources = AllocZeroed(sizeof(*gPyramidBagResources));
if (a0 != 4)
- {
- gUnknown_0203CF30.unk4 = a0;
- }
+ gPyramidBagCursorData.unk4 = a0;
if (callback != NULL)
- {
- gUnknown_0203CF30.callback = callback;
- }
+ gPyramidBagCursorData.callback = callback;
+
+ gPyramidBagResources->callback2 = NULL;
+ gPyramidBagResources->unk814 = 0xFF;
+ gPyramidBagResources->scrollArrowSpriteId = 0xFF;
- gUnknown_0203CF2C->unk0 = 0;
- gUnknown_0203CF2C->unk814 = -1;
- gUnknown_0203CF2C->unk816 = -1;
+ memset(gPyramidBagResources->itemsSpriteIds, 0xFF, sizeof(gPyramidBagResources->itemsSpriteIds));
+ memset(gPyramidBagResources->windowIds, 0xFF, sizeof(gPyramidBagResources->windowIds));
- memset(gUnknown_0203CF2C->unk804, 0xFF, sizeof(gUnknown_0203CF2C->unk804));
- memset(gUnknown_0203CF2C->unk80F, 0xFF, sizeof(gUnknown_0203CF2C->unk80F));
-
SetMainCallback2(sub_81C504C);
}
-void sub_81C501C(void)
+static void sub_81C501C(void)
{
RunTasks();
AnimateSprites();
@@ -127,19 +281,19 @@ void sub_81C501C(void)
UpdatePaletteFade();
}
-void sub_81C5038(void)
+static void sub_81C5038(void)
{
LoadOam();
ProcessSpriteCopyRequests();
TransferPlttBuffer();
}
-void sub_81C504C(void)
+static void sub_81C504C(void)
{
while (sub_81221EC() != TRUE && sub_81C5078() != TRUE && sub_81221AC() != TRUE);
}
-bool8 sub_81C5078(void)
+static bool8 sub_81C5078(void)
{
switch (gMain.state)
{
@@ -174,7 +328,7 @@ bool8 sub_81C5078(void)
break;
case 6:
sub_81C51DC();
- gUnknown_0203CF2C->unk984 = 0;
+ gPyramidBagResources->state = 0;
gMain.state++;
break;
case 7:
@@ -194,7 +348,7 @@ bool8 sub_81C5078(void)
gMain.state++;
break;
case 10:
- sub_81C5314();
+ SetBagItemsListTemplate();
gMain.state++;
break;
case 11:
@@ -206,7 +360,7 @@ bool8 sub_81C5078(void)
gMain.state++;
break;
case 13:
- sub_81C5674();
+ AddScrollArrow();
gMain.state++;
break;
case 14:
@@ -230,19 +384,1051 @@ bool8 sub_81C5078(void)
return FALSE;
}
-void sub_81C51DC(void)
+static void sub_81C51DC(void)
{
ResetVramOamAndBgCntRegs();
ResetBgsAndClearDma3BusyFlags(0);
InitBgsFromTemplates(0, gUnknown_0861F2B4, ARRAY_COUNT(gUnknown_0861F2B4));
- SetBgTilemapBuffer(2, gUnknown_0203CF2C->filler4);
+ SetBgTilemapBuffer(2, gPyramidBagResources->tilemapBuffer);
ResetAllBgsCoordinates();
schedule_bg_copy_tilemap_to_vram(2);
SetGpuReg(REG_OFFSET_DISPCNT, DISPCNT_MODE_0 |
- DISPCNT_OBJ_1D_MAP |
+ DISPCNT_OBJ_1D_MAP |
DISPCNT_OBJ_ON);
ShowBg(0);
ShowBg(1);
ShowBg(2);
SetGpuReg(REG_OFFSET_BLDCNT, 0);
}
+
+static bool8 sub_81C5238(void)
+{
+ switch (gPyramidBagResources->state)
+ {
+ case 0:
+ reset_temp_tile_data_buffers();
+ decompress_and_copy_tile_data_to_vram(2, gBagScreen_Gfx, 0, 0, 0);
+ gPyramidBagResources->state++;
+ break;
+ case 1:
+ if (free_temp_tile_data_buffers_if_possible() != TRUE)
+ {
+ LZDecompressWram(gUnknown_08D9AE04, gPyramidBagResources->tilemapBuffer);
+ gPyramidBagResources->state++;
+ }
+ break;
+ case 2:
+ LoadCompressedPalette(gUnknown_08D9AF44, 0, 0x20);
+ gPyramidBagResources->state++;
+ break;
+ case 3:
+ LoadCompressedObjectPic(&gUnknown_0861F3CC);
+ gPyramidBagResources->state++;
+ break;
+ case 4:
+ sub_81C6E98();
+ gPyramidBagResources->state++;
+ break;
+ default:
+ LoadListMenuArrowsGfx();
+ gPyramidBagResources->state = 0;
+ return TRUE;
+ }
+
+ return FALSE;
+}
+
+static void SetBagItemsListTemplate(void)
+{
+ u16 i;
+ u16 *pyramidItems = gSaveBlock2Ptr->frontier.pyramidBag.itemId[gSaveBlock2Ptr->frontier.lvlMode];
+
+ for (i = 0; i < gPyramidBagResources->listMenuCount - 1; i++)
+ {
+ PyramidBag_CopyItemName(gPyramidBagResources->itemStrings[i], pyramidItems[i]);
+ gPyramidBagResources->bagListItems[i].name = gPyramidBagResources->itemStrings[i];
+ gPyramidBagResources->bagListItems[i].id = i;
+ }
+ StringCopy(gPyramidBagResources->itemStrings[i], gText_CloseBag);
+ gPyramidBagResources->bagListItems[i].name = gPyramidBagResources->itemStrings[i];
+ gPyramidBagResources->bagListItems[i].id = LIST_B_PRESSED;
+ gMultiuseListMenuTemplate = gUnknown_0861F2C0;
+ gMultiuseListMenuTemplate.totalItems = gPyramidBagResources->listMenuCount;
+ gMultiuseListMenuTemplate.items = gPyramidBagResources->bagListItems;
+ gMultiuseListMenuTemplate.maxShowed = gPyramidBagResources->listMenuMaxShown;
+}
+
+static void PyramidBag_CopyItemName(u8 *dst, u16 itemId)
+{
+ if (ItemId_GetPocket(itemId) == POCKET_BERRIES)
+ {
+ ConvertIntToDecimalStringN(gStringVar1, ITEM_TO_BERRY(itemId), STR_CONV_MODE_LEADING_ZEROS, 2);
+ CopyItemName(itemId, gStringVar2);
+ StringExpandPlaceholders(dst, gText_UnkF908Var1Clear7Var2);
+ }
+ else
+ {
+ CopyItemName(itemId, dst);
+ }
+}
+
+static void PyramidBagMoveCursorFunc(s32 itemIndex, bool8 onInit, struct ListMenu *list)
+{
+ if (onInit != TRUE)
+ {
+ PlaySE(SE_SELECT);
+ sub_81C6F20();
+ }
+ if (gPyramidBagResources->unk814 == 0xFF)
+ {
+ sub_81C6FF8(gPyramidBagResources->unk815 ^ 1);
+ if (itemIndex != LIST_B_PRESSED)
+ ShowItemImage(gSaveBlock2Ptr->frontier.pyramidBag.itemId[gSaveBlock2Ptr->frontier.lvlMode][itemIndex], gPyramidBagResources->unk815);
+ else
+ ShowItemImage(0xFFFF, gPyramidBagResources->unk815);
+ gPyramidBagResources->unk815 ^= 1;
+ PrintItemDescription(itemIndex);
+ }
+}
+
+static void PrintItemQuantity(u8 windowId, s32 itemIndex, u8 y)
+{
+ s32 xAlign;
+ if (itemIndex == LIST_B_PRESSED)
+ return;
+
+ if (gPyramidBagResources->unk814 != 0xFF)
+ {
+ if (gPyramidBagResources->unk814 == (u8)(itemIndex))
+ sub_81C5AB8(y, 1);
+ else
+ sub_81C5AB8(y, 0xFF);
+ }
+ ConvertIntToDecimalStringN(gStringVar1,
+ gSaveBlock2Ptr->frontier.pyramidBag.quantity[gSaveBlock2Ptr->frontier.lvlMode][itemIndex],
+ STR_CONV_MODE_RIGHT_ALIGN,
+ 2);
+ StringExpandPlaceholders(gStringVar4, gText_xVar1);
+ xAlign = GetStringRightAlignXOffset(7, gStringVar4, 0x77);
+ PrintOnWindow_Font7(windowId, gStringVar4, xAlign, y, 0, 0, TEXT_SPEED_FF, 0);
+}
+
+static void PrintItemDescription(s32 listMenuId)
+{
+ const u8 *desc;
+ if (listMenuId != LIST_B_PRESSED)
+ {
+ desc = ItemId_GetDescription(gSaveBlock2Ptr->frontier.pyramidBag.itemId[gSaveBlock2Ptr->frontier.lvlMode][listMenuId]);
+ }
+ else
+ {
+ StringCopy(gStringVar1, gReturnToXStringsTable2[gPyramidBagCursorData.unk4]);
+ StringExpandPlaceholders(gStringVar4, gText_ReturnToVar1);
+ desc = gStringVar4;
+ }
+ FillWindowPixelBuffer(1, 0);
+ PrintOnWindow_Font1(1, desc, 3, 0, 0, 1, 0, 0);
+}
+
+static void AddScrollArrow(void)
+{
+ if (gPyramidBagResources->scrollArrowSpriteId == 0xFF)
+ gPyramidBagResources->scrollArrowSpriteId = AddScrollIndicatorArrowPairParameterized(2, 172, 12, 148, gPyramidBagResources->listMenuCount - gPyramidBagResources->listMenuMaxShown, 0xB5E, 0xB5E, &gPyramidBagCursorData.scrollPosition);
+}
+
+static void RemoveScrollArrow(void)
+{
+ if (gPyramidBagResources->scrollArrowSpriteId != 0xFF)
+ {
+ RemoveScrollIndicatorArrowPair(gPyramidBagResources->scrollArrowSpriteId);
+ gPyramidBagResources->scrollArrowSpriteId = 0xFF;
+ }
+}
+
+static void sub_81C56F8(void)
+{
+ u8 taskId = CreateTask(Task_HandlePyramidBagInput, 0);
+ s16 *data = gTasks[taskId].data;
+ data[0] = ListMenuInit(&gMultiuseListMenuTemplate, gPyramidBagCursorData.scrollPosition, gPyramidBagCursorData.cursorPosition);
+}
+
+static void SwapItems(u8 id1, u8 id2)
+{
+ u16 temp;
+ u16 *itemIds = gSaveBlock2Ptr->frontier.pyramidBag.itemId[gSaveBlock2Ptr->frontier.lvlMode];
+ u8 *quantities = gSaveBlock2Ptr->frontier.pyramidBag.quantity[gSaveBlock2Ptr->frontier.lvlMode];
+
+ SWAP(itemIds[id1], itemIds[id2], temp);
+ SWAP(quantities[id1], quantities[id2], temp);
+}
+
+static void MovePyramidBagItemSlotInList(u8 from, u8 to)
+{
+ u16 *itemIds = gSaveBlock2Ptr->frontier.pyramidBag.itemId[gSaveBlock2Ptr->frontier.lvlMode];
+ u8 *quantities = gSaveBlock2Ptr->frontier.pyramidBag.quantity[gSaveBlock2Ptr->frontier.lvlMode];
+
+ if (from != to)
+ {
+ s16 i;
+ u16 firstSlotItemId = itemIds[from];
+ u8 firstSlotQuantity = quantities[from];
+
+ if (to > from)
+ {
+ to--;
+ for (i = from; i < to; i++)
+ {
+ itemIds[i] = itemIds[i + 1];
+ quantities[i] = quantities[i + 1];
+ }
+ }
+ else
+ {
+ for (i = from; i > to; i--)
+ {
+ itemIds[i] = itemIds[i - 1];
+ quantities[i] = quantities[i - 1];
+ }
+ }
+ itemIds[to] = firstSlotItemId;
+ quantities[to] = firstSlotQuantity;
+ }
+}
+
+static void CompactItems(void)
+{
+ u8 i, j;
+ u16 *itemIds = gSaveBlock2Ptr->frontier.pyramidBag.itemId[gSaveBlock2Ptr->frontier.lvlMode];
+ u8 *quantities = gSaveBlock2Ptr->frontier.pyramidBag.quantity[gSaveBlock2Ptr->frontier.lvlMode];
+
+ for (i = 0; i < PYRAMID_BAG_ITEMS_COUNT; i++)
+ {
+ if (itemIds[i] == 0 || quantities[i] == 0)
+ {
+ itemIds[i] = 0;
+ quantities[i] = 0;
+ }
+ }
+ for (i = 0; i < PYRAMID_BAG_ITEMS_COUNT - 1; i++)
+ {
+ for (j = i + 1; j < PYRAMID_BAG_ITEMS_COUNT; j++)
+ {
+ if (itemIds[i] == 0 || quantities[i] == 0)
+ SwapItems(i, j);
+ }
+ }
+}
+
+void sub_81C5924(void)
+{
+ u16 i;
+ u16 *itemIds = gSaveBlock2Ptr->frontier.pyramidBag.itemId[gSaveBlock2Ptr->frontier.lvlMode];
+
+ CompactItems();
+ gPyramidBagResources->listMenuCount = 0;
+ for (i = 0; i < PYRAMID_BAG_ITEMS_COUNT; i++)
+ {
+ if (itemIds[i] != 0)
+ gPyramidBagResources->listMenuCount++;
+ }
+ gPyramidBagResources->listMenuCount++;
+ if (gPyramidBagResources->listMenuCount > 8)
+ gPyramidBagResources->listMenuMaxShown = 8;
+ else
+ gPyramidBagResources->listMenuMaxShown = gPyramidBagResources->listMenuCount;
+}
+
+void sub_81C59BC(void)
+{
+ if (gPyramidBagCursorData.scrollPosition != 0 && gPyramidBagCursorData.scrollPosition + gPyramidBagResources->listMenuMaxShown > gPyramidBagResources->listMenuCount)
+ gPyramidBagCursorData.scrollPosition = gPyramidBagResources->listMenuCount - gPyramidBagResources->listMenuMaxShown;
+ if (gPyramidBagCursorData.scrollPosition + gPyramidBagCursorData.cursorPosition >= gPyramidBagResources->listMenuCount)
+ {
+ if (gPyramidBagResources->listMenuCount == 0)
+ gPyramidBagCursorData.cursorPosition = 0;
+ else
+ gPyramidBagCursorData.cursorPosition = gPyramidBagResources->listMenuCount - 1;
+ }
+}
+
+static void sub_81C5A20(void)
+{
+ u8 i;
+
+ if (gPyramidBagCursorData.cursorPosition > 4)
+ {
+ for (i = 0; i <= gPyramidBagCursorData.cursorPosition - 4; i++)
+ {
+ if (gPyramidBagCursorData.scrollPosition + gPyramidBagResources->listMenuMaxShown == gPyramidBagResources->listMenuCount)
+ {
+ // daycare.c sends its regards.
+ break;
+ }
+ gPyramidBagCursorData.cursorPosition--;
+ gPyramidBagCursorData.scrollPosition++;
+ }
+ }
+}
+
+static void sub_81C5A98(u8 listMenuTaskId, u8 arg1)
+{
+ u8 y = ListMenuGetYCoordForPrintingArrowCursor(listMenuTaskId);
+ sub_81C5AB8(y, arg1);
+}
+
+static void sub_81C5AB8(u8 y, u8 arg1)
+{
+ if (arg1 == 0xFF)
+ FillWindowPixelRect(0, 0, 0, y, GetMenuCursorDimensionByFont(1, 0), GetMenuCursorDimensionByFont(1, 1));
+ else
+ PrintOnWindow_Font1(0, gText_SelectorArrow2, 0, y, 0, 0, 0, arg1);
+}
+
+void sub_81C5B14(u8 taskId)
+{
+ BeginNormalPaletteFade(0xFFFFFFFF, 0, 0, 0x10, RGB_BLACK);
+ gTasks[taskId].func = sub_81C5B4C;
+}
+
+static void sub_81C5B4C(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ if (!gPaletteFade.active)
+ {
+ DestroyListMenuTask(data[0], &gPyramidBagCursorData.scrollPosition, &gPyramidBagCursorData.cursorPosition);
+ if (gPyramidBagResources->callback2 != NULL)
+ SetMainCallback2(gPyramidBagResources->callback2);
+ else
+ SetMainCallback2(gPyramidBagCursorData.callback);
+ RemoveScrollArrow();
+ ResetSpriteData();
+ FreeAllSpritePalettes();
+ FreeAllWindowBuffers();
+ Free(gPyramidBagResources);
+ DestroyTask(taskId);
+ }
+}
+
+static void Task_HandlePyramidBagInput(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ if (sub_81221EC() != TRUE && !gPaletteFade.active)
+ {
+ if (gMain.newKeys & SELECT_BUTTON)
+ {
+ if (gPyramidBagCursorData.unk4 != 2)
+ {
+ ListMenuGetScrollAndRow(data[0], &gPyramidBagCursorData.scrollPosition, &gPyramidBagCursorData.cursorPosition);
+ if (gPyramidBagCursorData.scrollPosition + gPyramidBagCursorData.cursorPosition != gPyramidBagResources->listMenuCount - 1)
+ {
+ PlaySE(SE_SELECT);
+ Task_BeginItemSwap(taskId);
+ }
+ }
+ }
+ else
+ {
+ s32 listId = ListMenuHandleInputGetItemId(data[0]);
+ ListMenuGetScrollAndRow(data[0], &gPyramidBagCursorData.scrollPosition, &gPyramidBagCursorData.cursorPosition);
+ switch (listId)
+ {
+ case LIST_NOTHING_CHOSEN:
+ break;
+ case LIST_B_PRESSED:
+ PlaySE(SE_SELECT);
+ gSpecialVar_ItemId = 0;
+ sub_81C5B14(taskId);
+ break;
+ default:
+ PlaySE(SE_SELECT);
+ gSpecialVar_ItemId = gSaveBlock2Ptr->frontier.pyramidBag.itemId[gSaveBlock2Ptr->frontier.lvlMode][listId];
+ data[1] = listId;
+ data[2] = gSaveBlock2Ptr->frontier.pyramidBag.quantity[gSaveBlock2Ptr->frontier.lvlMode][listId];
+ if (gPyramidBagCursorData.unk4 == 2)
+ sub_81C674C(taskId);
+ else
+ sub_81C5D20(taskId);
+ break;
+ }
+ }
+ }
+}
+
+static void sub_81C5D20(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+
+ RemoveScrollArrow();
+ sub_81C5A98(data[0], 1);
+ switch (gPyramidBagCursorData.unk4)
+ {
+ default:
+ gPyramidBagResources->menuActionIds = sFieldMenuActionIds;
+ gPyramidBagResources->menuActionsCount = ARRAY_COUNT(sFieldMenuActionIds);
+ break;
+ case 1:
+ if (ItemId_GetBattleUsage(gSpecialVar_ItemId))
+ {
+ gPyramidBagResources->menuActionIds = sBattleMenuActionIds;
+ gPyramidBagResources->menuActionsCount = ARRAY_COUNT(sBattleMenuActionIds);
+ }
+ else
+ {
+ gPyramidBagResources->menuActionIds = gUnknown_0861F310;
+ gPyramidBagResources->menuActionsCount = ARRAY_COUNT(gUnknown_0861F310);
+ }
+ break;
+ case 3:
+ gPyramidBagResources->menuActionIds = gUnknown_0861F30C;
+ gPyramidBagResources->menuActionsCount = ARRAY_COUNT(gUnknown_0861F30C);
+ break;
+ }
+
+ CopyItemName(gSpecialVar_ItemId, gStringVar1);
+ StringExpandPlaceholders(gStringVar4, gText_Var1IsSelected);
+ FillWindowPixelBuffer(1, 0);
+ PrintOnWindow_Font1(1, gStringVar4, 3, 0, 0, 1, 0, 0);
+ if (gPyramidBagResources->menuActionsCount == 1)
+ sub_81C5EAC(sub_81C6D24(0));
+ else if (gPyramidBagResources->menuActionsCount == 2)
+ sub_81C5EAC(sub_81C6D24(1));
+ else
+ sub_81C5F08(sub_81C6D24(2), 2, 2);
+
+ if (gPyramidBagResources->menuActionsCount == 4)
+ gTasks[taskId].func = HandleMenuActionInput;
+ else
+ gTasks[taskId].func = HandleFewMenuActionsInput;
+}
+
+static void sub_81C5EAC(u8 windowId)
+{
+ AddItemMenuActionTextPrinters(windowId, 7, 8, 1, 0, 0x10, gPyramidBagResources->menuActionsCount, sMenuActions, gPyramidBagResources->menuActionIds);
+ InitMenuInUpperLeftCornerPlaySoundWhenAPressed(windowId, gPyramidBagResources->menuActionsCount, 0);
+}
+
+static void sub_81C5F08(u8 windowId, u8 horizontalCount, u8 verticalCount)
+{
+ sub_8198DBC(windowId, 7, 8, 1, 0x38, horizontalCount, verticalCount, sMenuActions, gPyramidBagResources->menuActionIds);
+ sub_8199944(windowId, 0x38, horizontalCount, verticalCount, 0);
+}
+
+static void HandleFewMenuActionsInput(u8 taskId)
+{
+ if (sub_81221EC() != TRUE)
+ {
+ s32 id = Menu_ProcessInputNoWrapAround();
+ switch (id)
+ {
+ case -2:
+ break;
+ case -1:
+ PlaySE(SE_SELECT);
+ sMenuActions[ACTION_CANCEL].func.void_u8(taskId);
+ break;
+ default:
+ PlaySE(SE_SELECT);
+ if (sMenuActions[gPyramidBagResources->menuActionIds[id]].func.void_u8 != NULL)
+ sMenuActions[gPyramidBagResources->menuActionIds[id]].func.void_u8(taskId);
+ break;
+ }
+ }
+}
+
+static void HandleMenuActionInput(u8 taskId)
+{
+ if (sub_81221EC() != TRUE)
+ {
+ s8 id = GetMenuCursorPos();
+ if (gMain.newKeys & DPAD_UP)
+ {
+ if (id > 0 && IsValidMenuAction(id - 2))
+ {
+ PlaySE(SE_SELECT);
+ sub_8199134(0, -1);
+ }
+ }
+ else if (gMain.newKeys & DPAD_DOWN)
+ {
+ if (id < gPyramidBagResources->menuActionsCount - 2 && IsValidMenuAction(id + 2))
+ {
+ PlaySE(SE_SELECT);
+ sub_8199134(0, 1);
+ }
+ }
+ else if (gMain.newKeys & DPAD_LEFT || GetLRKeysState() == 1)
+ {
+ if (id & 1 && IsValidMenuAction(id - 1))
+ {
+ PlaySE(SE_SELECT);
+ sub_8199134(-1, 0);
+ }
+ }
+ else if (gMain.newKeys & DPAD_RIGHT || GetLRKeysState() == 2)
+ {
+ if (!(id & 1) && IsValidMenuAction(id + 1))
+ {
+ PlaySE(SE_SELECT);
+ sub_8199134(1, 0);
+ }
+ }
+ else if (gMain.newKeys & A_BUTTON)
+ {
+ PlaySE(SE_SELECT);
+ if (sMenuActions[gPyramidBagResources->menuActionIds[id]].func.void_u8 != NULL)
+ sMenuActions[gPyramidBagResources->menuActionIds[id]].func.void_u8(taskId);
+ }
+ else if (gMain.newKeys & B_BUTTON)
+ {
+ PlaySE(SE_SELECT);
+ sMenuActions[ACTION_CANCEL].func.void_u8(taskId);
+ }
+ }
+}
+
+static bool8 IsValidMenuAction(s8 actionTableId)
+{
+ if (actionTableId < 0)
+ return FALSE;
+ else if (actionTableId > gPyramidBagResources->menuActionsCount)
+ return FALSE;
+ else if (gPyramidBagResources->menuActionIds[actionTableId] == ACTION_DUMMY)
+ return FALSE;
+ else
+ return TRUE;
+}
+
+static void sub_81C61A8(void)
+{
+ if (gPyramidBagResources->menuActionsCount == 1)
+ sub_81C6D6C(0);
+ else if (gPyramidBagResources->menuActionsCount == 2)
+ sub_81C6D6C(1);
+ else
+ sub_81C6D6C(2);
+}
+
+static void BagAction_UseOnField(u8 taskId)
+{
+ u8 pocketId = ItemId_GetPocket(gSpecialVar_ItemId);
+
+ if (pocketId == POCKET_KEY_ITEMS
+ || pocketId == POCKET_POKE_BALLS
+ || pocketId == POCKET_TM_HM
+ || ItemIsMail(gSpecialVar_ItemId) == TRUE)
+ {
+ sub_81C61A8();
+ DisplayItemMessageInBattlePyramid(taskId, gText_DadsAdvice, sub_81C6714);
+ }
+ else if (ItemId_GetFieldFunc(gSpecialVar_ItemId) != NULL)
+ {
+ sub_81C61A8();
+ FillWindowPixelBuffer(1, 0);
+ schedule_bg_copy_tilemap_to_vram(0);
+ ItemId_GetFieldFunc(gSpecialVar_ItemId)(taskId);
+ }
+}
+
+static void BagAction_Cancel(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+
+ sub_81C61A8();
+ PrintItemDescription(data[1]);
+ schedule_bg_copy_tilemap_to_vram(0);
+ schedule_bg_copy_tilemap_to_vram(1);
+ sub_81C5A98(data[0], 0);
+ SetTaskToMainPyramidBagInputHandler(taskId);
+}
+
+static void SetTaskToMainPyramidBagInputHandler(u8 taskId)
+{
+ AddScrollArrow();
+ gTasks[taskId].func = Task_HandlePyramidBagInput;
+}
+
+static void BagAction_Toss(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+
+ sub_81C61A8();
+ data[8] = 1;
+ if (data[2] == 1)
+ {
+ sub_81C6350(taskId);
+ }
+ else
+ {
+ CopyItemName(gSpecialVar_ItemId, gStringVar1);
+ StringExpandPlaceholders(gStringVar4, gText_TossHowManyVar1s);
+ FillWindowPixelBuffer(1, 0);
+ PrintOnWindow_Font1(1, gStringVar4, 3, 0, 0, 1, 0, 0);
+ sub_81C6404();
+ gTasks[taskId].func = sub_81C64B4;
+ }
+}
+
+static void sub_81C6350(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+
+ CopyItemName(gSpecialVar_ItemId, gStringVar1);
+ ConvertIntToDecimalStringN(gStringVar2, data[8], STR_CONV_MODE_LEFT_ALIGN, 2);
+ StringExpandPlaceholders(gStringVar4, gText_ConfirmTossItems);
+ FillWindowPixelBuffer(1, 0);
+ PrintOnWindow_Font1(1, gStringVar4, 3, 0, 0, 1, 0, 0);
+ sub_81C6DAC(taskId, &sYesNoTossFuncions);
+}
+
+static void DontTossItem(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+
+ PrintItemDescription(data[1]);
+ sub_81C5A98(data[0], 0);
+ SetTaskToMainPyramidBagInputHandler(taskId);
+}
+
+static void sub_81C6404(void)
+{
+ s32 x;
+
+ ConvertIntToDecimalStringN(gStringVar1, 1, STR_CONV_MODE_LEADING_ZEROS, 2);
+ StringExpandPlaceholders(gStringVar4, gText_xVar1);
+ sub_81C6CEC(3);
+ x = GetStringCenterAlignXOffset(1, gStringVar4, 0x28);
+ PrintTextOnWindow(3, 1, gStringVar4, x, 2, 0, NULL);
+}
+
+static void sub_81C645C(s16 value)
+{
+ s32 x;
+
+ ConvertIntToDecimalStringN(gStringVar1, value, STR_CONV_MODE_LEADING_ZEROS, 2);
+ StringExpandPlaceholders(gStringVar4, gText_xVar1);
+ x = GetStringCenterAlignXOffset(1, gStringVar4, 0x28);
+ PrintTextOnWindow(3, 1, gStringVar4, x, 2, 0, NULL);
+}
+
+static void sub_81C64B4(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+
+ if (AdjustQuantityAccordingToDPadInput(&data[8], data[2]) == TRUE)
+ {
+ sub_81C645C(data[8]);
+ }
+ else if (gMain.newKeys & A_BUTTON)
+ {
+ PlaySE(SE_SELECT);
+ sub_8198070(3, 0);
+ ClearWindowTilemap(3);
+ schedule_bg_copy_tilemap_to_vram(1);
+ sub_81C6350(taskId);
+ }
+ else if (gMain.newKeys & B_BUTTON)
+ {
+ PlaySE(SE_SELECT);
+ sub_8198070(3, 0);
+ ClearWindowTilemap(3);
+ schedule_bg_copy_tilemap_to_vram(1);
+ DontTossItem(taskId);
+ }
+}
+
+static void TossItem(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+
+ CopyItemName(gSpecialVar_ItemId, gStringVar1);
+ ConvertIntToDecimalStringN(gStringVar2, data[8], STR_CONV_MODE_LEFT_ALIGN, 2);
+ StringExpandPlaceholders(gStringVar4, gText_ThrewAwayVar2Var1s);
+ FillWindowPixelBuffer(1, 0);
+ PrintOnWindow_Font1(1, gStringVar4, 3, 0, 0, 1, 0, 0);
+ gTasks[taskId].func = sub_81C65CC;
+}
+
+static void sub_81C65CC(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ u16 *scrollOffset = &gPyramidBagCursorData.scrollPosition;
+ u16 *selectedRow = &gPyramidBagCursorData.cursorPosition;
+
+ if (gMain.newKeys & (A_BUTTON | B_BUTTON))
+ {
+ PlaySE(SE_SELECT);
+ RemovePyramidBagItem(gSpecialVar_ItemId, data[8]);
+ DestroyListMenuTask(data[0], scrollOffset, selectedRow);
+ sub_81C5924();
+ sub_81C59BC();
+ SetBagItemsListTemplate();
+ data[0] = ListMenuInit(&gMultiuseListMenuTemplate, *scrollOffset, *selectedRow);
+ schedule_bg_copy_tilemap_to_vram(0);
+ SetTaskToMainPyramidBagInputHandler(taskId);
+ }
+}
+
+static void BagAction_Give(u8 taskId)
+{
+ sub_81C61A8();
+ if (ItemIsMail(gSpecialVar_ItemId) == TRUE)
+ {
+ DisplayItemMessageInBattlePyramid(taskId, gText_CantWriteMail, sub_81C66EC);
+ }
+ else if (!ItemId_GetImportance(gSpecialVar_ItemId))
+ {
+ gPyramidBagResources->callback2 = sub_81B7F60;
+ sub_81C5B14(taskId);
+ }
+ else
+ {
+ sub_81C66AC(taskId);
+ }
+}
+
+static void sub_81C66AC(u8 taskId)
+{
+ CopyItemName(gSpecialVar_ItemId, gStringVar1);
+ StringExpandPlaceholders(gStringVar4, gText_Var1CantBeHeld);
+ DisplayItemMessageInBattlePyramid(taskId, gStringVar4, sub_81C66EC);
+}
+
+static void sub_81C66EC(u8 taskId)
+{
+ if (gMain.newKeys & A_BUTTON)
+ {
+ PlaySE(SE_SELECT);
+ sub_81C6714(taskId);
+ }
+}
+
+void sub_81C6714(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+
+ sub_81C6E1C();
+ PrintItemDescription(data[1]);
+ sub_81C5A98(data[0], 0);
+ SetTaskToMainPyramidBagInputHandler(taskId);
+}
+
+static void sub_81C674C(u8 taskId)
+{
+ if (!itemid_80BF6D8_mail_related(gSpecialVar_ItemId))
+ DisplayItemMessageInBattlePyramid(taskId, gText_CantWriteMail, sub_81C66EC);
+ else if (!ItemId_GetImportance(gSpecialVar_ItemId))
+ sub_81C5B14(taskId);
+ else
+ sub_81C66AC(taskId);
+}
+
+static void BagAction_UseInBattle(u8 taskId)
+{
+ if (ItemId_GetBattleFunc(gSpecialVar_ItemId) != NULL)
+ {
+ sub_81C61A8();
+ ItemId_GetBattleFunc(gSpecialVar_ItemId)(taskId);
+ }
+}
+
+static void Task_BeginItemSwap(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+
+ data[1] = gPyramidBagCursorData.scrollPosition + gPyramidBagCursorData.cursorPosition;
+ gPyramidBagResources->unk814 = data[1];
+ ListMenuSetUnkIndicatorsStructField(data[0], 0x10, 1);
+ CopyItemName(gSaveBlock2Ptr->frontier.pyramidBag.itemId[gSaveBlock2Ptr->frontier.lvlMode][data[1]], gStringVar1);
+ StringExpandPlaceholders(gStringVar4, gText_MoveVar1Where);
+ FillWindowPixelBuffer(1, 0);
+ PrintOnWindow_Font1(1, gStringVar4, 3, 0, 0, 1, 0, 0);
+ sub_81C5A98(data[0], 1);
+ sub_81C704C(data[1]);
+ gTasks[taskId].func = Task_ItemSwapHandleInput;
+}
+
+static void Task_ItemSwapHandleInput(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ if (sub_81221EC() != TRUE)
+ {
+ if (gMain.newKeys & SELECT_BUTTON)
+ {
+ PlaySE(SE_SELECT);
+ ListMenuGetScrollAndRow(data[0], &gPyramidBagCursorData.scrollPosition, &gPyramidBagCursorData.cursorPosition);
+ PerformItemSwap(taskId);
+ }
+ else
+ {
+ s32 id = ListMenuHandleInputGetItemId(data[0]);
+ ListMenuGetScrollAndRow(data[0], &gPyramidBagCursorData.scrollPosition, &gPyramidBagCursorData.cursorPosition);
+ sub_81C7028(FALSE);
+ sub_81C704C(gPyramidBagCursorData.cursorPosition);
+ switch (id)
+ {
+ case LIST_NOTHING_CHOSEN:
+ break;
+ case LIST_B_PRESSED:
+ PlaySE(SE_SELECT);
+ if (gMain.newKeys & A_BUTTON)
+ PerformItemSwap(taskId);
+ else
+ sub_81C6A14(taskId);
+ break;
+ default:
+ PlaySE(SE_SELECT);
+ PerformItemSwap(taskId);
+ break;
+ }
+ }
+ }
+}
+
+static void PerformItemSwap(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ u16 *scrollOffset = &gPyramidBagCursorData.scrollPosition;
+ u16 *selectedRow = &gPyramidBagCursorData.cursorPosition;
+ u16 var = *scrollOffset + *selectedRow;
+
+ if (data[1] == var || data[1] == var - 1)
+ {
+ sub_81C6A14(taskId);
+ }
+ else
+ {
+ MovePyramidBagItemSlotInList(data[1], var);
+ gPyramidBagResources->unk814 = 0xFF;
+ sub_81C7028(TRUE);
+ DestroyListMenuTask(data[0], scrollOffset, selectedRow);
+ if (data[1] < var)
+ gPyramidBagCursorData.cursorPosition--;
+ SetBagItemsListTemplate();
+ data[0] = ListMenuInit(&gMultiuseListMenuTemplate, *scrollOffset, *selectedRow);
+ SetTaskToMainPyramidBagInputHandler(taskId);
+ }
+}
+
+static void sub_81C6A14(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ u16 *scrollOffset = &gPyramidBagCursorData.scrollPosition;
+ u16 *selectedRow = &gPyramidBagCursorData.cursorPosition;
+
+ gPyramidBagResources->unk814 = 0xFF;
+ sub_81C7028(TRUE);
+ DestroyListMenuTask(data[0], scrollOffset, selectedRow);
+ if (data[1] < *scrollOffset + *selectedRow)
+ gPyramidBagCursorData.cursorPosition--;
+ SetBagItemsListTemplate();
+ data[0] = ListMenuInit(&gMultiuseListMenuTemplate, *scrollOffset, *selectedRow);
+ SetTaskToMainPyramidBagInputHandler(taskId);
+}
+
+void sub_81C6A94(void)
+{
+ u8 i;
+ struct Pokemon *party = gPlayerParty;
+ u16 *newItems = Alloc(PYRAMID_BAG_ITEMS_COUNT * sizeof(u16));
+ u8 *newQuantities = Alloc(PYRAMID_BAG_ITEMS_COUNT * sizeof(u8));
+ u16 heldItem;
+
+ memcpy(newItems, gSaveBlock2Ptr->frontier.pyramidBag.itemId[gSaveBlock2Ptr->frontier.lvlMode], PYRAMID_BAG_ITEMS_COUNT * sizeof(u16));
+ memcpy(newQuantities, gSaveBlock2Ptr->frontier.pyramidBag.quantity[gSaveBlock2Ptr->frontier.lvlMode], PYRAMID_BAG_ITEMS_COUNT * sizeof(u8));
+ for (i = 0; i < 3; i++)
+ {
+ heldItem = GetMonData(&party[i], MON_DATA_HELD_ITEM);
+ if (heldItem != 0 && !AddBagItem(heldItem, 1))
+ {
+ memcpy(gSaveBlock2Ptr->frontier.pyramidBag.itemId[gSaveBlock2Ptr->frontier.lvlMode], newItems, PYRAMID_BAG_ITEMS_COUNT * sizeof(u16));
+ memcpy(gSaveBlock2Ptr->frontier.pyramidBag.quantity[gSaveBlock2Ptr->frontier.lvlMode], newQuantities, PYRAMID_BAG_ITEMS_COUNT * sizeof(u8));
+ Free(newItems);
+ Free(newQuantities);
+ gSpecialVar_Result = 1;
+ return;
+ }
+ }
+
+ heldItem = 0;
+ for (i = 0; i < 3; i++)
+ {
+ SetMonData(&party[i], MON_DATA_HELD_ITEM, &heldItem);
+ }
+ gSpecialVar_Result = 0;
+ Free(newItems);
+ Free(newQuantities);
+}
+
+static void sub_81C6BD8(void)
+{
+ u8 i;
+
+ InitWindows(gUnknown_0861F328);
+ DeactivateAllTextPrinters();
+ LoadUserWindowBorderGfx(0, 0x1, 0xE0);
+ LoadMessageBoxGfx(0, 0xA, 0xD0);
+ LoadPalette(gUnknown_0860F074, 0xF0, 0x20);
+
+ for (i = 0; i < 5; i++)
+ FillWindowPixelBuffer(i, 0);
+
+ PutWindowTilemap(0);
+ PutWindowTilemap(1);
+ schedule_bg_copy_tilemap_to_vram(0);
+ schedule_bg_copy_tilemap_to_vram(1);
+}
+
+static void PrintOnWindow_Font1(u8 windowId, const u8 *src, u8 x, u8 y, u8 letterSpacing, u8 lineSpacing, u8 speed, u8 colorTableId)
+{
+ AddTextPrinterParameterized2(windowId, 1, x, y, letterSpacing, lineSpacing, sColorTable[colorTableId], speed, src);
+}
+
+static void PrintOnWindow_Font7(u8 windowId, const u8 *src, u8 x, u8 y, u8 letterSpacing, u8 lineSpacing, u8 speed, u8 colorTableId)
+{
+ AddTextPrinterParameterized2(windowId, 7, x, y, letterSpacing, lineSpacing, sColorTable[colorTableId], speed, src);
+}
+
+static void sub_81C6CEC(u8 windowId)
+{
+ SetWindowBorderStyle(windowId, 0, 1, 0xE);
+ schedule_bg_copy_tilemap_to_vram(1);
+}
+
+static u8 sub_81C6D08(u8 windowArrayId)
+{
+ return gPyramidBagResources->windowIds[windowArrayId];
+}
+
+static u8 sub_81C6D24(u8 windowArrayId)
+{
+ u8 *windowId = &gPyramidBagResources->windowIds[windowArrayId];
+ if (*windowId == 0xFF)
+ {
+ *windowId = AddWindow(&gUnknown_0861F350[windowArrayId]);
+ SetWindowBorderStyle(*windowId, FALSE, 1, 0xE);
+ schedule_bg_copy_tilemap_to_vram(1);
+ }
+ return *windowId;
+}
+
+static void sub_81C6D6C(u8 windowArrayId)
+{
+ u8 *windowId = &gPyramidBagResources->windowIds[windowArrayId];
+ if (*windowId != 0xFF)
+ {
+ sub_8198070(*windowId, FALSE);
+ ClearWindowTilemap(*windowId);
+ RemoveWindow(*windowId);
+ schedule_bg_copy_tilemap_to_vram(1);
+ *windowId = 0xFF;
+ }
+}
+
+static void sub_81C6DAC(u8 taskId, const struct YesNoFuncTable *yesNoTable)
+{
+ CreateYesNoMenuWithCallbacks(taskId, &gUnknown_0861F350[4], 1, 0, 2, 1, 0xE, yesNoTable);
+}
+
+void DisplayItemMessageInBattlePyramid(u8 taskId, const u8 *str, void (*callback)(u8 taskId))
+{
+ FillWindowPixelBuffer(2, 0x11);
+ DisplayMessageAndContinueTask(taskId, 2, 0xA, 0xD, 1, GetPlayerTextSpeed(), str, callback);
+ schedule_bg_copy_tilemap_to_vram(1);
+}
+
+static void sub_81C6E1C(void)
+{
+ sub_8197DF8(2, FALSE);
+ ClearWindowTilemap(2);
+ schedule_bg_copy_tilemap_to_vram(1);
+}
+
+#define ITEM_IMAGE_TAG 0x1024
+
+static void sub_81C6E38(u8 itemSpriteArrayId)
+{
+ u8 *spriteId = &gPyramidBagResources->itemsSpriteIds[itemSpriteArrayId];
+ if (*spriteId != 0xFF)
+ {
+ FreeSpriteTilesByTag(ITEM_IMAGE_TAG + itemSpriteArrayId);
+ FreeSpritePaletteByTag(ITEM_IMAGE_TAG + itemSpriteArrayId);
+ FreeSpriteOamMatrix(&gSprites[*spriteId]);
+ DestroySprite(&gSprites[*spriteId]);
+ *spriteId = 0xFF;
+ }
+}
+
+static void sub_81C6E98(void)
+{
+ struct SpritePalette spritePalette;
+ u16 *palPtr = Alloc(0x40);
+
+ LZDecompressWram(gUnknown_08D9ADD0, palPtr);
+ spritePalette.data = palPtr + (gSaveBlock2Ptr->frontier.lvlMode * 16);
+ spritePalette.tag = ITEM_IMAGE_TAG;
+ LoadSpritePalette(&spritePalette);
+ Free(palPtr);
+}
+
+static void sub_81C6EF4(void)
+{
+ u8 *spriteId = &gPyramidBagResources->itemsSpriteIds[0];
+ *spriteId = CreateSprite(&gUnknown_0861F3D4, 0x44, 0x38, 0);
+}
+
+static void sub_81C6F20(void)
+{
+ struct Sprite *sprite = &gSprites[gPyramidBagResources->itemsSpriteIds[0]];
+ if (sprite->affineAnimEnded)
+ {
+ StartSpriteAffineAnim(sprite, 1);
+ sprite->callback = sub_81C6F68;
+ }
+}
+
+static void sub_81C6F68(struct Sprite *sprite)
+{
+ if (sprite->affineAnimEnded)
+ {
+ StartSpriteAffineAnim(sprite, 0);
+ sprite->callback = SpriteCallbackDummy;
+ }
+}
+
+static void ShowItemImage(u16 itemId, u8 itemSpriteArrayId)
+{
+ u8 itemSpriteId;
+ u8 *spriteId = &gPyramidBagResources->itemsSpriteIds[itemSpriteArrayId + 1];
+ if (*spriteId == 0xFF)
+ {
+ FreeSpriteTilesByTag(ITEM_IMAGE_TAG + 1 + itemSpriteArrayId);
+ FreeSpritePaletteByTag(ITEM_IMAGE_TAG + 1 + itemSpriteArrayId);
+ itemSpriteId = AddItemIconSprite(ITEM_IMAGE_TAG + 1 + itemSpriteArrayId, ITEM_IMAGE_TAG + 1 + itemSpriteArrayId, itemId);
+ if (itemSpriteId != MAX_SPRITES)
+ {
+ *spriteId = itemSpriteId;
+ gSprites[itemSpriteId].pos2.x = 24;
+ gSprites[itemSpriteId].pos2.y = 88;
+ }
+ }
+}
+
+static void sub_81C6FF8(u8 itemSpriteArrayId)
+{
+ sub_81C6E38(itemSpriteArrayId + 1);
+}
+
+static void sub_81C700C(void)
+{
+ sub_8122344(&gPyramidBagResources->itemsSpriteIds[3], 8);
+}
+
+static void sub_81C7028(bool8 invisible)
+{
+ sub_81223FC(&gPyramidBagResources->itemsSpriteIds[3], 8, invisible);
+}
+
+static void sub_81C704C(u8 y)
+{
+ sub_8122448(&gPyramidBagResources->itemsSpriteIds[3], 8 | 0x80, 120, (y + 1) * 16);
+}
diff --git a/src/item.c b/src/item.c
index 22894bbff..b4a2fd6f0 100644
--- a/src/item.c
+++ b/src/item.c
@@ -10,6 +10,7 @@
#include "item_menu.h"
#include "strings.h"
#include "load_save.h"
+#include "battle_pyramid_bag.h"
extern bool8 InBattlePyramid(void);
extern u16 gUnknown_0203CF30[];
@@ -752,9 +753,8 @@ u16 BagGetQuantityByPocketPosition(u8 pocketId, u16 pocketPos)
static void SwapItemSlots(struct ItemSlot *a, struct ItemSlot *b)
{
- struct ItemSlot temp = *a;
- *a = *b;
- *b = temp;
+ struct ItemSlot temp;
+ SWAP(*a, *b, temp);
}
void CompactItemsInBagPocket(struct BagPocket *bagPocket)
@@ -966,7 +966,7 @@ bool8 RemovePyramidBagItem(u16 itemId, u16 count)
u16 *items = gSaveBlock2Ptr->frontier.pyramidBag.itemId[gSaveBlock2Ptr->frontier.lvlMode];
u8 *quantities = gSaveBlock2Ptr->frontier.pyramidBag.quantity[gSaveBlock2Ptr->frontier.lvlMode];
- i = gUnknown_0203CF30[3] + gUnknown_0203CF30[4];
+ i = gPyramidBagCursorData.cursorPosition + gPyramidBagCursorData.scrollPosition;
if (items[i] == itemId && quantities[i] >= count)
{
quantities[i] -= count;
diff --git a/src/item_use.c b/src/item_use.c
index 9031338dd..bf7c2a386 100755
--- a/src/item_use.c
+++ b/src/item_use.c
@@ -29,44 +29,26 @@
#include "string_util.h"
#include "task.h"
#include "text.h"
+#include "strings.h"
+#include "pokeblock.h"
+#include "menu.h"
+#include "item_menu.h"
+#include "battle_pyramid_bag.h"
-extern void(**gUnknown_0203CE54)(void);
-extern void(**gUnknown_0203CF2C)(void);
extern void(*gUnknown_0203A0F4)(u8 taskId);
extern void(*gUnknown_085920D8[])(void);
extern void (*gUnknown_03006328)(u8, u16, TaskFunc);
extern void unknown_ItemMenu_Confirm(u8 taskId);
extern void sub_81C5B14(u8 taskId);
-extern u8 gText_DadsAdvice[];
-extern u8 gText_CantDismountBike[];
-extern void sub_8197434(u8 a, u8 b);
extern void ScriptUnfreezeEventObjects(void);
extern void ItemUseOutOfBattle_TMHM(u8 a);
extern void ItemUseOutOfBattle_EvolutionStone(u8 b);
-extern void bag_menu_mail_related(void);
-extern void OpenPokeblockCase(u8 a, void(*b)(void));
-extern void overworld_free_bg_tilemaps(void);
-extern bool32 Overworld_IsBikingAllowed(void);
extern bool8 IsPlayerFacingSurfableFishableWater(void);
extern bool8 sub_81221AC(void);
-extern u8 gText_ItemFinderNothing[];
-extern u8 gText_ItemFinderNearby[];
-extern u8 gText_ItemFinderOnTop[];
-extern u8 gText_CoinCase[];
-extern u8 gText_PowderQty[];
extern u8 gUnknown_085920E4[];
extern u8 Route102_EventScript_274482[];
extern u8 Route102_EventScript_2744C0[];
extern u8 BattleFrontier_OutsideEast_EventScript_242CFC[];
-extern u8 gText_BootedUpHM[];
-extern u8 gText_BootedUpTM[];
-extern u8 gText_TMHMContainedVar1[];
-extern u8 gText_PlayerUsedVar2[];
-extern u8 gText_RepelEffectsLingered[];
-extern u8 gText_UsedVar2WildLured[];
-extern u8 gText_UsedVar2WildRepelled[];
-extern u8 gText_BoxFull[];
-extern u8 gText_WontHaveEffect[];
extern int sub_80247BC(void);
extern struct MapHeader* mapconnection_get_mapheader(struct MapConnection *connection);
extern void SetUpItemUseCallback(u8 taskId);
@@ -86,7 +68,6 @@ extern void sub_81C59BC(void);
extern void sub_81AB9A8(u8);
extern void sub_81ABA88(u8);
extern void sub_80B7CC8(void);
-extern void Overworld_ResetStateAfterDigEscRope(void);
extern u8* sub_806CF78(u16);
extern void sub_81B89F0(void);
extern u8 GetItemEffectType(u16);
@@ -115,8 +96,7 @@ void sub_80FE124(u8 taskId);
void sub_80FE164(u8 taskId);
void DisplayItemMessage(u8 taskId, u8 a, const u8* str, void(*callback)(u8 taskId));
-void DisplayItemMessageInBattlePyramid(u8 taskId, u8* str, void(*callback)(u8 taskId));
-void DisplayItemMessageOnField(u8 taskId, u8* str, void(*callback)(u8 taskId));
+void DisplayItemMessageOnField(u8 taskId, const u8* str, void(*callback)(u8 taskId));
void sub_81C6714(u8 taskId);
void CleanUpAfterFailingToUseRegisteredKeyItemOnField(u8 taskId);
void StartFishing(u8 a);
@@ -137,12 +117,12 @@ void SetUpItemUseCallback(u8 taskId)
type = ItemId_GetType(gSpecialVar_ItemId) - 1;
if (!InBattlePyramid())
{
- *gUnknown_0203CE54 = gUnknown_085920D8[type];
+ gUnknown_0203CE54->unk0 = gUnknown_085920D8[type];
unknown_ItemMenu_Confirm(taskId);
}
else
{
- *gUnknown_0203CF2C = gUnknown_085920D8[type];
+ gPyramidBagResources->callback2 = gUnknown_085920D8[type];
sub_81C5B14(taskId);
}
}
@@ -221,7 +201,7 @@ void sub_80FD254()
void ItemUseOutOfBattle_Mail(u8 taskId)
{
- *gUnknown_0203CE54 = sub_80FD254;
+ gUnknown_0203CE54->unk0 = sub_80FD254;
unknown_ItemMenu_Confirm(taskId);
}
@@ -617,7 +597,7 @@ void ItemUseOutOfBattle_PokeblockCase(u8 taskId)
}
else if (gTasks[taskId].data[3] != TRUE)
{
- *gUnknown_0203CE54 = sub_80FDBEC;
+ gUnknown_0203CE54->unk0 = sub_80FDBEC;
unknown_ItemMenu_Confirm(taskId);
}
else
@@ -679,7 +659,7 @@ void sub_80FDD10(u8 taskId)
{
gUnknown_0203A0F4 = sub_80FDD74;
gFieldCallback = MapPostLoadHook_UseItem;
- *gUnknown_0203CE54 = CB2_ReturnToField;
+ gUnknown_0203CE54->unk0 = CB2_ReturnToField;
unknown_ItemMenu_Confirm(taskId);
}
else
@@ -1002,12 +982,12 @@ void sub_80FE54C(u8 taskId)
{
if (!InBattlePyramid())
{
- *gUnknown_0203CE54 = sub_81B89F0;
+ gUnknown_0203CE54->unk0 = sub_81B89F0;
unknown_ItemMenu_Confirm(taskId);
}
else
{
- *gUnknown_0203CF2C = sub_81B89F0;
+ gPyramidBagResources->callback2 = sub_81B89F0;
sub_81C5B14(taskId);
}
}
diff --git a/src/start_menu.c b/src/start_menu.c
index 60271317a..4a58c146e 100644
--- a/src/start_menu.c
+++ b/src/start_menu.c
@@ -33,6 +33,7 @@
#include "international_string_util.h"
#include "constants/songs.h"
#include "field_player_avatar.h"
+#include "battle_pyramid_bag.h"
// Menu actions
enum
@@ -73,12 +74,11 @@ EWRAM_DATA static u8 sSaveDialogTimer = 0;
EWRAM_DATA static bool8 sSavingComplete = FALSE;
EWRAM_DATA static u8 sSaveInfoWindowId = 0;
-// Extern variables
+// Extern variables.
extern u8 gDifferentSaveFile;
-extern u16 gSaveFileStatus;
extern u8 gUnknown_03005DB4;
-// Extern functions in uncompiled files
+// Extern functions in not decompiled files.
extern void sub_80AF688(void);
extern void var_800D_set_xB(void);
extern void sub_808B864(void);
@@ -89,7 +89,6 @@ extern void CB2_PokeNav(void);
extern void sub_80C4DDC(void (*)(void));
extern void sub_80C51C4(void (*)(void));
extern void sub_80C4E74(u8, void (*)(void));
-extern void sub_81C4EFC(void);
extern void ScriptUnfreezeEventObjects(void);
extern void sub_81A9EC8(void);
extern void save_serialize_map(void);
@@ -781,7 +780,7 @@ static bool8 StartMenuBattlePyramidBagCallback(void)
play_some_sound();
RemoveExtraStartMenuWindows();
overworld_free_bg_tilemaps();
- SetMainCallback2(sub_81C4EFC); // Display battle pyramid bag
+ SetMainCallback2(CB2_PyramidBagMenuFromStartMenu);
return TRUE;
}