summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--asm/item_menu.s475
-rw-r--r--include/gflib.h18
-rw-r--r--include/graphics.h11
-rw-r--r--include/item_menu.h4
-rw-r--r--src/item_menu.c180
5 files changed, 196 insertions, 492 deletions
diff --git a/asm/item_menu.s b/asm/item_menu.s
index f3af32b36..c90b708cd 100644
--- a/asm/item_menu.s
+++ b/asm/item_menu.s
@@ -5,481 +5,6 @@
.text
- thumb_func_start sub_81081D0
-sub_81081D0: @ 81081D0
- push {r4,r5,lr}
- bl ResetAllBgsCoordinatesAndBgCntRegs
- ldr r5, _08108230 @ =gUnknown_203AD14
- movs r4, 0x80
- lsls r4, 4
- adds r0, r4, 0
- bl Alloc
- str r0, [r5]
- cmp r0, 0
- beq _08108238
- movs r1, 0
- adds r2, r4, 0
- bl memset
- movs r0, 0
- bl ResetBgsAndClearDma3BusyFlags
- ldr r1, _08108234 @ =gUnknown_8452CF4
- movs r0, 0
- movs r2, 0x2
- bl InitBgsFromTemplates
- ldr r1, [r5]
- movs r0, 0x1
- bl SetBgTilemapBuffer
- movs r0, 0x1
- bl ScheduleBgCopyTilemapToVram
- movs r1, 0xC1
- lsls r1, 6
- movs r0, 0
- bl SetGpuReg
- movs r0, 0
- bl ShowBg
- movs r0, 0x1
- bl ShowBg
- movs r0, 0x50
- movs r1, 0
- bl SetGpuReg
- movs r0, 0x1
- b _0810823A
- .align 2, 0
-_08108230: .4byte gUnknown_203AD14
-_08108234: .4byte gUnknown_8452CF4
-_08108238:
- movs r0, 0
-_0810823A:
- pop {r4,r5}
- pop {r1}
- bx r1
- thumb_func_end sub_81081D0
-
- thumb_func_start sub_8108240
-sub_8108240: @ 8108240
- push {r4,lr}
- sub sp, 0x4
- ldr r4, _0810825C @ =gUnknown_203AD10
- ldr r0, [r4]
- ldrb r0, [r0, 0x10]
- cmp r0, 0x5
- bls _08108250
- b _08108368
-_08108250:
- lsls r0, 2
- ldr r1, _08108260 @ =_08108264
- adds r0, r1
- ldr r0, [r0]
- mov pc, r0
- .align 2, 0
-_0810825C: .4byte gUnknown_203AD10
-_08108260: .4byte _08108264
- .align 2, 0
-_08108264:
- .4byte _0810827C
- .4byte _08108298
- .4byte _081082D8
- .4byte _08108310
- .4byte _08108340
- .4byte _0810834C
-_0810827C:
- bl ResetTempTileDataBuffers
- ldr r1, _08108294 @ =gUnknown_8E830CC
- movs r0, 0
- str r0, [sp]
- movs r0, 0x1
- movs r2, 0
- movs r3, 0
- bl DecompressAndCopyTileDataToVram
- b _08108352
- .align 2, 0
-_08108294: .4byte gUnknown_8E830CC
-_08108298:
- bl FreeTempTileDataBuffersIfPossible
- lsls r0, 24
- lsrs r0, 24
- cmp r0, 0x1
- beq _0810837C
- ldr r0, _081082B8 @ =gUnknown_203ACFC
- ldrb r0, [r0, 0x4]
- cmp r0, 0x3
- beq _081082C4
- ldr r0, _081082BC @ =gUnknown_8E832C0
- ldr r1, _081082C0 @ =gUnknown_203AD14
- ldr r1, [r1]
- bl LZDecompressWram
- b _08108352
- .align 2, 0
-_081082B8: .4byte gUnknown_203ACFC
-_081082BC: .4byte gUnknown_8E832C0
-_081082C0: .4byte gUnknown_203AD14
-_081082C4:
- ldr r0, _081082D0 @ =gUnknown_8E83444
- ldr r1, _081082D4 @ =gUnknown_203AD14
- ldr r1, [r1]
- bl LZDecompressWram
- b _08108352
- .align 2, 0
-_081082D0: .4byte gUnknown_8E83444
-_081082D4: .4byte gUnknown_203AD14
-_081082D8:
- ldr r0, _08108304 @ =gUnknown_8E835B4
- movs r1, 0
- movs r2, 0x60
- bl LoadCompressedPalette
- bl sub_810ADAC
- lsls r0, 24
- cmp r0, 0
- bne _08108352
- ldr r0, _08108308 @ =gSaveBlock2Ptr
- ldr r0, [r0]
- ldrb r0, [r0, 0x8]
- cmp r0, 0
- beq _08108352
- ldr r0, _0810830C @ =gUnknown_8E83604
- movs r1, 0
- movs r2, 0x20
- bl LoadCompressedPalette
- b _08108352
- .align 2, 0
-_08108304: .4byte gUnknown_8E835B4
-_08108308: .4byte gSaveBlock2Ptr
-_0810830C: .4byte gUnknown_8E83604
-_08108310:
- bl sub_810ADAC
- lsls r0, 24
- lsrs r0, 24
- cmp r0, 0x1
- beq _08108326
- ldr r0, _0810832C @ =gSaveBlock2Ptr
- ldr r0, [r0]
- ldrb r0, [r0, 0x8]
- cmp r0, 0
- bne _08108334
-_08108326:
- ldr r0, _08108330 @ =gUnknown_83D41E4
- b _0810834E
- .align 2, 0
-_0810832C: .4byte gSaveBlock2Ptr
-_08108330: .4byte gUnknown_83D41E4
-_08108334:
- ldr r0, _0810833C @ =gUnknown_83D41EC
- bl LoadCompressedSpriteSheet
- b _08108352
- .align 2, 0
-_0810833C: .4byte gUnknown_83D41EC
-_08108340:
- ldr r0, _08108348 @ =gUnknown_83D41F4
- bl LoadCompressedSpritePalette
- b _08108352
- .align 2, 0
-_08108348: .4byte gUnknown_83D41F4
-_0810834C:
- ldr r0, _08108360 @ =gBagSwapSpriteSheet
-_0810834E:
- bl LoadCompressedSpriteSheet
-_08108352:
- ldr r0, _08108364 @ =gUnknown_203AD10
- ldr r1, [r0]
- ldrb r0, [r1, 0x10]
- adds r0, 0x1
- strb r0, [r1, 0x10]
- b _0810837C
- .align 2, 0
-_08108360: .4byte gBagSwapSpriteSheet
-_08108364: .4byte gUnknown_203AD10
-_08108368:
- ldr r0, _08108378 @ =gBagSwapSpritePalette
- bl LoadCompressedSpritePalette
- ldr r1, [r4]
- movs r0, 0
- strb r0, [r1, 0x10]
- movs r0, 0x1
- b _0810837E
- .align 2, 0
-_08108378: .4byte gBagSwapSpritePalette
-_0810837C:
- movs r0, 0
-_0810837E:
- add sp, 0x4
- pop {r4}
- pop {r1}
- bx r1
- thumb_func_end sub_8108240
-
- thumb_func_start sub_8108388
-sub_8108388: @ 8108388
- push {lr}
- lsls r0, 24
- lsrs r0, 24
- subs r0, 0x6
- cmp r0, 0x4
- bhi _081083E0
- lsls r0, 2
- ldr r1, _081083A0 @ =_081083A4
- adds r0, r1
- ldr r0, [r0]
- mov pc, r0
- .align 2, 0
-_081083A0: .4byte _081083A4
- .align 2, 0
-_081083A4:
- .4byte _081083B8
- .4byte _081083D0
- .4byte _081083D8
- .4byte _081083C0
- .4byte _081083C8
-_081083B8:
- ldr r0, _081083BC @ =sub_810AF9C
- b _081083E2
- .align 2, 0
-_081083BC: .4byte sub_810AF9C
-_081083C0:
- ldr r0, _081083C4 @ =sub_810B1D4
- b _081083E2
- .align 2, 0
-_081083C4: .4byte sub_810B1D4
-_081083C8:
- ldr r0, _081083CC @ =sub_810B5D4
- b _081083E2
- .align 2, 0
-_081083CC: .4byte sub_810B5D4
-_081083D0:
- ldr r0, _081083D4 @ =sub_810B4BC
- b _081083E2
- .align 2, 0
-_081083D4: .4byte sub_810B4BC
-_081083D8:
- ldr r0, _081083DC @ =sub_810B378
- b _081083E2
- .align 2, 0
-_081083DC: .4byte sub_810B378
-_081083E0:
- ldr r0, _081083F0 @ =sub_8108F0C
-_081083E2:
- movs r1, 0
- bl CreateTask
- lsls r0, 24
- lsrs r0, 24
- pop {r1}
- bx r1
- .align 2, 0
-_081083F0: .4byte sub_8108F0C
- thumb_func_end sub_8108388
-
- thumb_func_start sub_81083F4
-sub_81083F4: @ 81083F4
- push {r4,lr}
- ldr r4, _08108418 @ =gUnknown_203AD18
- movs r0, 0xAC
- lsls r0, 1
- bl Alloc
- str r0, [r4]
- cmp r0, 0
- beq _08108424
- ldr r4, _0810841C @ =gUnknown_203AD1C
- ldr r0, _08108420 @ =0x00000331
- bl Alloc
- str r0, [r4]
- cmp r0, 0
- beq _08108424
- movs r0, 0x1
- b _08108426
- .align 2, 0
-_08108418: .4byte gUnknown_203AD18
-_0810841C: .4byte gUnknown_203AD1C
-_08108420: .4byte 0x00000331
-_08108424:
- movs r0, 0
-_08108426:
- pop {r4}
- pop {r1}
- bx r1
- thumb_func_end sub_81083F4
-
- thumb_func_start sub_810842C
-sub_810842C: @ 810842C
- push {r4-r7,lr}
- mov r7, r8
- push {r7}
- lsls r0, 24
- lsrs r7, r0, 24
- lsls r1, r7, 3
- ldr r0, _0810853C @ =gBagPockets
- adds r1, r0
- mov r8, r1
- movs r6, 0
- ldr r0, _08108540 @ =gUnknown_203AD10
- ldr r0, [r0]
- adds r0, 0xA
- adds r0, r7
- ldrb r0, [r0]
- cmp r6, r0
- bcs _0810848C
- ldr r5, _08108544 @ =gUnknown_203AD1C
-_08108450:
- lsls r2, r6, 2
- adds r4, r2, r6
- lsls r4, 2
- subs r4, r6
- ldr r0, [r5]
- adds r0, r4
- mov r3, r8
- ldr r1, [r3]
- adds r2, r1
- ldrh r1, [r2]
- bl sub_8108560
- ldr r0, _08108548 @ =gUnknown_203AD18
- ldr r0, [r0]
- lsls r1, r6, 3
- adds r1, r0
- ldr r0, [r5]
- adds r0, r4
- str r0, [r1]
- str r6, [r1, 0x4]
- adds r0, r6, 0x1
- lsls r0, 16
- lsrs r6, r0, 16
- ldr r0, _08108540 @ =gUnknown_203AD10
- ldr r0, [r0]
- adds r0, 0xA
- adds r0, r7
- ldrb r0, [r0]
- cmp r6, r0
- bcc _08108450
-_0810848C:
- ldr r5, _08108544 @ =gUnknown_203AD1C
- lsls r4, r6, 2
- adds r4, r6
- lsls r4, 2
- subs r4, r6
- ldr r0, [r5]
- adds r0, r4
- ldr r1, _0810854C @ =gUnknown_8452F60
- bl StringCopy
- ldr r0, [r5]
- adds r0, r4
- ldr r1, _08108550 @ =gFameCheckerText_Cancel
- bl StringAppend
- ldr r0, _08108548 @ =gUnknown_203AD18
- ldr r2, [r0]
- lsls r1, r6, 3
- adds r1, r2
- ldr r0, [r5]
- adds r0, r4
- str r0, [r1]
- str r6, [r1, 0x4]
- ldr r3, _08108554 @ =gMultiuseListMenuTemplate
- str r2, [r3]
- ldr r0, _08108540 @ =gUnknown_203AD10
- ldr r2, [r0]
- adds r0, r2, 0
- adds r0, 0xA
- adds r0, r7
- ldrb r0, [r0]
- adds r0, 0x1
- movs r1, 0
- strh r0, [r3, 0xC]
- strb r1, [r3, 0x10]
- strb r1, [r3, 0x11]
- movs r0, 0x9
- strb r0, [r3, 0x12]
- movs r0, 0x1
- strb r0, [r3, 0x13]
- ldrb r0, [r3, 0x16]
- movs r4, 0x8
- negs r4, r4
- ands r4, r0
- movs r0, 0x39
- negs r0, r0
- ands r4, r0
- movs r0, 0x10
- orrs r4, r0
- strb r4, [r3, 0x16]
- ldrb r0, [r3, 0x14]
- movs r1, 0x10
- negs r1, r1
- ands r1, r0
- movs r5, 0x2
- orrs r1, r5
- strb r1, [r3, 0x14]
- adds r2, 0xD
- adds r2, r7
- ldrb r0, [r2]
- strh r0, [r3, 0xE]
- ldrb r0, [r3, 0x17]
- movs r2, 0x40
- negs r2, r2
- ands r2, r0
- orrs r2, r5
- movs r0, 0xF
- ands r1, r0
- movs r0, 0x20
- orrs r1, r0
- strb r1, [r3, 0x14]
- movs r0, 0x30
- strb r0, [r3, 0x15]
- ldr r0, _08108558 @ =sub_81085A4
- str r0, [r3, 0x4]
- ldr r0, _0810855C @ =sub_8108654
- str r0, [r3, 0x8]
- movs r0, 0x3F
- ands r2, r0
- strb r2, [r3, 0x17]
- ands r4, r0
- strb r4, [r3, 0x16]
- pop {r3}
- mov r8, r3
- pop {r4-r7}
- pop {r0}
- bx r0
- .align 2, 0
-_0810853C: .4byte gBagPockets
-_08108540: .4byte gUnknown_203AD10
-_08108544: .4byte gUnknown_203AD1C
-_08108548: .4byte gUnknown_203AD18
-_0810854C: .4byte gUnknown_8452F60
-_08108550: .4byte gFameCheckerText_Cancel
-_08108554: .4byte gMultiuseListMenuTemplate
-_08108558: .4byte sub_81085A4
-_0810855C: .4byte sub_8108654
- thumb_func_end sub_810842C
-
- thumb_func_start sub_8108560
-sub_8108560: @ 8108560
- push {r4,r5,lr}
- adds r4, r0, 0
- lsls r1, 16
- lsrs r5, r1, 16
- ldr r0, _0810857C @ =0xfe940000
- adds r1, r0
- lsrs r1, 16
- cmp r1, 0x1
- bhi _08108584
- ldr r1, _08108580 @ =gUnknown_8452F66
- adds r0, r4, 0
- bl StringCopy
- b _0810858C
- .align 2, 0
-_0810857C: .4byte 0xfe940000
-_08108580: .4byte gUnknown_8452F66
-_08108584:
- ldr r1, _081085A0 @ =gUnknown_8452F60
- adds r0, r4, 0
- bl StringCopy
-_0810858C:
- adds r0, r5, 0
- bl ItemId_GetName
- adds r1, r0, 0
- adds r0, r4, 0
- bl StringAppend
- pop {r4,r5}
- pop {r0}
- bx r0
- .align 2, 0
-_081085A0: .4byte gUnknown_8452F60
- thumb_func_end sub_8108560
-
thumb_func_start sub_81085A4
sub_81085A4: @ 81085A4
push {r4,r5,lr}
diff --git a/include/gflib.h b/include/gflib.h
new file mode 100644
index 000000000..a6dfc62df
--- /dev/null
+++ b/include/gflib.h
@@ -0,0 +1,18 @@
+#ifndef GUARD_GFLIB_H
+#define GUARD_GFLIB_H
+
+#include "global.h"
+
+#include "bg.h"
+#include "palette.h"
+#include "gpu_regs.h"
+#include "dma3.h"
+#include "malloc.h"
+#include "sound.h"
+#include "text.h"
+#include "sprite.h"
+#include "window.h"
+#include "blit.h"
+#include "string_util.h"
+
+#endif //GUARD_GFLIB_H
diff --git a/include/graphics.h b/include/graphics.h
index a668364bd..eb9a9a20d 100644
--- a/include/graphics.h
+++ b/include/graphics.h
@@ -1,7 +1,3 @@
-//
-// Created by scott on 10/21/2017.
-//
-
#ifndef GUARD_GRAPHICS_H
#define GUARD_GRAPHICS_H
@@ -4861,4 +4857,11 @@ extern const u16 gBattleInterface_BallStatusBarPal[];
extern const u16 gBattleInterface_BallDisplayPal[];
extern const u16 gUnknown_8D12404[];
+// item_menu
+extern const u32 gUnknown_8E830CC[];
+extern const u32 gUnknown_8E832C0[];
+extern const u32 gUnknown_8E83444[];
+extern const u32 gUnknown_8E835B4[];
+extern const u32 gUnknown_8E83604[];
+
#endif //GUARD_GRAPHICS_H
diff --git a/include/item_menu.h b/include/item_menu.h
index d141c6601..343fae393 100644
--- a/include/item_menu.h
+++ b/include/item_menu.h
@@ -12,8 +12,8 @@ struct BagStruct
{
void (*bagCallback)(void);
u8 location;
- u8 pocket;
- u16 unk6;
+ u8 unk5;
+ u16 pocket;
u16 itemsAbove[3];
u16 cursorPos[3];
};
diff --git a/src/item_menu.c b/src/item_menu.c
index 9128d0856..ce964b647 100644
--- a/src/item_menu.c
+++ b/src/item_menu.c
@@ -1,17 +1,18 @@
#include "global.h"
+#include "gflib.h"
#include "bag.h"
#include "battle_controllers.h"
-#include "bg.h"
+#include "decompress.h"
+#include "graphics.h"
#include "help_system.h"
+#include "item.h"
#include "item_menu.h"
#include "item_menu_icons.h"
#include "list_menu.h"
-#include "malloc.h"
#include "new_menu_helpers.h"
#include "overworld.h"
-#include "palette.h"
#include "scanline_effect.h"
-#include "text.h"
+#include "strings.h"
#include "constants/items.h"
struct BagMenuAlloc
@@ -24,7 +25,8 @@ struct BagMenuAlloc
u16 field_06;
u8 field_08;
u8 field_09;
- u8 filler_0A[6];
+ u8 field_0A[3];
+ u8 field_0D[3];
u8 field_10[4];
};
@@ -32,7 +34,7 @@ EWRAM_DATA struct BagStruct gUnknown_203ACFC = {};
EWRAM_DATA struct BagMenuAlloc * gUnknown_203AD10 = NULL;
EWRAM_DATA void * gUnknown_203AD14 = NULL;
EWRAM_DATA struct ListMenuItem * gUnknown_203AD18 = NULL;
-EWRAM_DATA u8 (*gUnknown_203AD1C)[20] = NULL;
+EWRAM_DATA u8 (*gUnknown_203AD1C)[19] = NULL;
void sub_8107F10(void);
bool8 sub_8107F3C(void);
@@ -43,7 +45,10 @@ bool8 sub_81081D0(void);
bool8 sub_8108240(void);
u8 sub_8108388(u8 location);
bool8 sub_81083F4(void);
-void sub_810842C(u8 a0);
+void sub_810842C(u8 pocket);
+void sub_81085A4(s32 itemIndex, bool8 onInit, struct ListMenu *list);
+void sub_8108654(u8 windowId, s32 itemId, u8 y);
+void sub_8108560(u8 *dest, u16 itemId);
void sub_81087EC(void);
void sub_8108888(void);
void sub_81088D8(void);
@@ -52,6 +57,17 @@ void sub_8108A84(void);
void sub_8108B04(void);
void sub_8108C10(void);
void sub_8108E54(void);
+void sub_8108F0C(u8 taskId);
+bool8 sub_810ADAC(void);
+void sub_810AF9C(u8 taskId);
+void sub_810B1D4(u8 taskId);
+void sub_810B378(u8 taskId);
+void sub_810B4BC(u8 taskId);
+void sub_810B5D4(u8 taskId);
+
+extern const struct BgTemplate gUnknown_8452CF4[2];
+extern const u8 gUnknown_8452F60[];
+extern const u8 gUnknown_8452F66[];
void GoToBagMenu(u8 location, u8 a1, MainCallback a2)
{
@@ -84,7 +100,7 @@ void GoToBagMenu(u8 location, u8 a1, MainCallback a2)
gUnknown_203AD10->field_10[i] = 0;
}
if (a1 == 0 || a1 == 1 || a1 == 2)
- gUnknown_203ACFC.unk6 = a1;
+ gUnknown_203ACFC.pocket = a1;
gTextFlags.autoScroll = FALSE;
gSpecialVar_ItemId = ITEM_NONE;
SetMainCallback2(sub_8107F10);
@@ -204,7 +220,7 @@ bool8 sub_8107F3C(void)
gMain.state++;
break;
case 12:
- sub_810842C(gUnknown_203ACFC.unk6);
+ sub_810842C(gUnknown_203ACFC.pocket);
gMain.state++;
break;
case 13:
@@ -216,13 +232,13 @@ bool8 sub_8107F3C(void)
break;
case 14:
taskId = sub_8108388(gUnknown_203ACFC.location);
- gTasks[taskId].data[0] = ListMenuInit(&gMultiuseListMenuTemplate, gUnknown_203ACFC.cursorPos[gUnknown_203ACFC.unk6], gUnknown_203ACFC.itemsAbove[gUnknown_203ACFC.unk6]);
+ gTasks[taskId].data[0] = ListMenuInit(&gMultiuseListMenuTemplate, gUnknown_203ACFC.cursorPos[gUnknown_203ACFC.pocket], gUnknown_203ACFC.itemsAbove[gUnknown_203ACFC.pocket]);
gTasks[taskId].data[3] = 0;
gTasks[taskId].data[8] = 0;
gMain.state++;
break;
case 15:
- sub_80984FC(gUnknown_203ACFC.unk6);
+ sub_80984FC(gUnknown_203ACFC.pocket);
gMain.state++;
break;
case 16:
@@ -279,3 +295,145 @@ void sub_81081AC(void)
gUnknown_203AD18 = NULL;
gUnknown_203AD1C = NULL;
}
+
+bool8 sub_81081D0(void)
+{
+ void **buff;
+ ResetAllBgsCoordinatesAndBgCntRegs();
+ buff = &gUnknown_203AD14;
+ *buff = Alloc(0x800);
+ if (*buff == NULL)
+ return FALSE;
+ memset(*buff, 0, 0x800);
+ ResetBgsAndClearDma3BusyFlags(FALSE);
+ InitBgsFromTemplates(0, gUnknown_8452CF4, NELEMS(gUnknown_8452CF4));
+ 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;
+}
+
+bool8 sub_8108240(void)
+{
+ switch (gUnknown_203AD10->field_10[0])
+ {
+ case 0:
+ ResetTempTileDataBuffers();
+ DecompressAndCopyTileDataToVram(1, gUnknown_8E830CC, 0, 0, 0);
+ gUnknown_203AD10->field_10[0]++;
+ break;
+ case 1:
+ if (FreeTempTileDataBuffersIfPossible() != TRUE)
+ {
+ if (gUnknown_203ACFC.location != 3)
+ LZDecompressWram(gUnknown_8E832C0, gUnknown_203AD14);
+ else
+ LZDecompressWram(gUnknown_8E83444, gUnknown_203AD14);
+ gUnknown_203AD10->field_10[0]++;
+ }
+ break;
+ case 2:
+ LoadCompressedPalette(gUnknown_8E835B4, 0x00, 0x60);
+ if (!sub_810ADAC() && gSaveBlock2Ptr->playerGender != MALE)
+ LoadCompressedPalette(gUnknown_8E83604, 0x00, 0x20);
+ gUnknown_203AD10->field_10[0]++;
+ break;
+ case 3:
+ if (sub_810ADAC() == TRUE || gSaveBlock2Ptr->playerGender == MALE)
+ LoadCompressedSpriteSheet(&gUnknown_83D41E4);
+ else
+ LoadCompressedSpriteSheet(&gUnknown_83D41EC);
+ gUnknown_203AD10->field_10[0]++;
+ break;
+ case 4:
+ LoadCompressedSpritePalette(&gUnknown_83D41F4);
+ gUnknown_203AD10->field_10[0]++;
+ break;
+ case 5:
+ LoadCompressedSpriteSheet(&gBagSwapSpriteSheet);
+ gUnknown_203AD10->field_10[0]++;
+ break;
+ default:
+ LoadCompressedSpritePalette(&gBagSwapSpritePalette);
+ gUnknown_203AD10->field_10[0] = 0;
+ return TRUE;
+ }
+
+ return FALSE;
+}
+
+u8 sub_8108388(u8 location)
+{
+ switch (location)
+ {
+ case 6:
+ return CreateTask(sub_810AF9C, 0);
+ case 9:
+ return CreateTask(sub_810B1D4, 0);
+ case 10:
+ return CreateTask(sub_810B5D4, 0);
+ case 7:
+ return CreateTask(sub_810B4BC, 0);
+ case 8:
+ return CreateTask(sub_810B378, 0);
+ default:
+ return CreateTask(sub_8108F0C, 0);
+ }
+}
+
+bool8 sub_81083F4(void)
+{
+ gUnknown_203AD18 = Alloc(43 * sizeof(struct ListMenuItem));
+ if (gUnknown_203AD18 == NULL)
+ return FALSE;
+ gUnknown_203AD1C = Alloc(43 * 19);
+ if (gUnknown_203AD1C == NULL)
+ return FALSE;
+ return TRUE;
+}
+
+void sub_810842C(u8 pocket)
+{
+ u16 i;
+ struct BagPocket * bagPocket = &gBagPockets[pocket];
+ for (i = 0; i < gUnknown_203AD10->field_0A[pocket]; i++)
+ {
+ sub_8108560(gUnknown_203AD1C[i], bagPocket->itemSlots[i].itemId);
+ gUnknown_203AD18[i].label = gUnknown_203AD1C[i];
+ gUnknown_203AD18[i].index = i;
+ }
+ StringCopy(gUnknown_203AD1C[i], gUnknown_8452F60);
+ StringAppend(gUnknown_203AD1C[i], gFameCheckerText_Cancel);
+ gUnknown_203AD18[i].label = gUnknown_203AD1C[i];
+ gUnknown_203AD18[i].index = i;
+ gMultiuseListMenuTemplate.items = gUnknown_203AD18;
+ gMultiuseListMenuTemplate.totalItems = gUnknown_203AD10->field_0A[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 = gUnknown_203AD10->field_0D[pocket];
+ gMultiuseListMenuTemplate.fontId = 2;
+ gMultiuseListMenuTemplate.cursorPal = 2;
+ gMultiuseListMenuTemplate.fillValue = 0;
+ gMultiuseListMenuTemplate.cursorShadowPal = 3;
+ gMultiuseListMenuTemplate.moveCursorFunc = sub_81085A4;
+ gMultiuseListMenuTemplate.itemPrintFunc = sub_8108654;
+ gMultiuseListMenuTemplate.cursorKind = 0;
+ gMultiuseListMenuTemplate.scrollMultiple = 0;
+}
+
+void sub_8108560(u8 *dest, u16 itemId)
+{
+ if (itemId == ITEM_TM_CASE || itemId == ITEM_BERRY_POUCH)
+ StringCopy(dest, gUnknown_8452F66);
+ else
+ StringCopy(dest, gUnknown_8452F60);
+ StringAppend(dest, ItemId_GetName(itemId));
+}