@@ -26,6 +26,7 @@ ld_script_sapphire.txt
|
||||
*.id2
|
||||
*.nam
|
||||
*.til
|
||||
.fuse*
|
||||
*.ld
|
||||
tags
|
||||
types_*.taghl
|
||||
|
||||
+3
-3
@@ -183,7 +183,7 @@ _0813CE84:
|
||||
.4byte _0813CFB0
|
||||
.4byte _0813CFBE
|
||||
_0813CED0:
|
||||
bl sub_80BF768
|
||||
bl VblankHblankHandlerSetZero
|
||||
bl clear_scheduled_bg_copies_to_vram
|
||||
b _0813CFD2
|
||||
_0813CEDA:
|
||||
@@ -386,7 +386,7 @@ _0813D078: .4byte gUnknown_203F370
|
||||
thumb_func_start sub_813D07C
|
||||
sub_813D07C: @ 813D07C
|
||||
push {r4,lr}
|
||||
bl sub_80BF7C8
|
||||
bl InitBgReg
|
||||
ldr r4, _0813D0DC @ =gUnknown_203F36C
|
||||
ldr r0, [r4]
|
||||
adds r0, 0xC
|
||||
@@ -1694,7 +1694,7 @@ _0813DA9E:
|
||||
ldr r4, _0813DAE0 @ =gUnknown_203F37A
|
||||
subs r2, r4, 0x2
|
||||
adds r1, r4, 0
|
||||
bl get_coro_args_x18_x1A
|
||||
bl ListMenuGetScrollAndRow
|
||||
ldr r0, _0813DAE4 @ =gMain
|
||||
ldrh r1, [r0, 0x2E]
|
||||
movs r0, 0x4
|
||||
|
||||
+3
-3
@@ -1550,8 +1550,8 @@ MakeObjectTemplateFromFieldObjectTemplate: @ 805E960
|
||||
bx r0
|
||||
thumb_func_end MakeObjectTemplateFromFieldObjectTemplate
|
||||
|
||||
thumb_func_start AddPseudoFieldObject
|
||||
AddPseudoFieldObject: @ 805E978
|
||||
thumb_func_start AddPseudoEventObject
|
||||
AddPseudoEventObject: @ 805E978
|
||||
push {r4-r6,lr}
|
||||
sub sp, 0x1C
|
||||
ldr r4, [sp, 0x2C]
|
||||
@@ -1612,7 +1612,7 @@ _0805E9E4:
|
||||
.align 2, 0
|
||||
_0805E9F0: .4byte 0x0000ffff
|
||||
_0805E9F4: .4byte gSprites
|
||||
thumb_func_end AddPseudoFieldObject
|
||||
thumb_func_end AddPseudoEventObject
|
||||
|
||||
thumb_func_start sprite_new
|
||||
sprite_new: @ 805E9F8
|
||||
|
||||
@@ -2753,7 +2753,7 @@ sub_80CBADC: @ 80CBADC
|
||||
ldr r4, _080CBB20 @ =gUnknown_3005378
|
||||
adds r1, r4, 0
|
||||
movs r2, 0
|
||||
bl get_coro_args_x18_x1A
|
||||
bl ListMenuGetScrollAndRow
|
||||
ldr r1, _080CBB24 @ =gUnknown_2039A18
|
||||
ldrh r0, [r4]
|
||||
strh r0, [r1]
|
||||
|
||||
+9
-9
@@ -253,7 +253,7 @@ _08107F60:
|
||||
.4byte _081080D8
|
||||
.4byte _081080DE
|
||||
_08107FB0:
|
||||
bl sub_80BF768
|
||||
bl VblankHblankHandlerSetZero
|
||||
bl clear_scheduled_bg_copies_to_vram
|
||||
b _08108104
|
||||
_08107FBA:
|
||||
@@ -520,7 +520,7 @@ _081081CC: .4byte gUnknown_203AD1C
|
||||
thumb_func_start sub_81081D0
|
||||
sub_81081D0: @ 81081D0
|
||||
push {r4,r5,lr}
|
||||
bl sub_80BF7C8
|
||||
bl InitBgReg
|
||||
ldr r5, _08108230 @ =gUnknown_203AD14
|
||||
movs r4, 0x80
|
||||
lsls r4, 4
|
||||
@@ -2313,7 +2313,7 @@ _08108FA0:
|
||||
adds r4, 0x2
|
||||
mov r1, sp
|
||||
adds r2, r4, 0
|
||||
bl get_coro_args_x18_x1A
|
||||
bl ListMenuGetScrollAndRow
|
||||
mov r0, sp
|
||||
ldrh r1, [r0]
|
||||
ldrh r0, [r4]
|
||||
@@ -2353,7 +2353,7 @@ _08108FE4:
|
||||
adds r3, r5, 0
|
||||
adds r3, 0x8
|
||||
adds r2, r3
|
||||
bl get_coro_args_x18_x1A
|
||||
bl ListMenuGetScrollAndRow
|
||||
movs r0, 0x2
|
||||
negs r0, r0
|
||||
cmp r4, r0
|
||||
@@ -2830,7 +2830,7 @@ sub_81093B8: @ 81093B8
|
||||
mov r2, sp
|
||||
adds r2, 0x16
|
||||
add r1, sp, 0x14
|
||||
bl get_coro_args_x18_x1A
|
||||
bl ListMenuGetScrollAndRow
|
||||
mov r2, r8
|
||||
ldrb r0, [r2]
|
||||
movs r1, 0x10
|
||||
@@ -2942,7 +2942,7 @@ sub_81094B0: @ 81094B0
|
||||
adds r1, r2, r1
|
||||
adds r3, 0x8
|
||||
adds r2, r3
|
||||
bl get_coro_args_x18_x1A
|
||||
bl ListMenuGetScrollAndRow
|
||||
ldrb r0, [r4]
|
||||
bl ListMenuGetYCoordForPrintingArrowCursor
|
||||
adds r1, r0, 0
|
||||
@@ -2967,7 +2967,7 @@ sub_81094B0: @ 81094B0
|
||||
adds r4, 0x2
|
||||
mov r1, sp
|
||||
adds r2, r4, 0
|
||||
bl get_coro_args_x18_x1A
|
||||
bl ListMenuGetScrollAndRow
|
||||
mov r0, sp
|
||||
ldrh r1, [r0]
|
||||
ldrh r0, [r4]
|
||||
@@ -3001,7 +3001,7 @@ _08109558:
|
||||
adds r4, 0x2
|
||||
mov r1, sp
|
||||
adds r2, r4, 0
|
||||
bl get_coro_args_x18_x1A
|
||||
bl ListMenuGetScrollAndRow
|
||||
mov r0, sp
|
||||
ldrh r1, [r0]
|
||||
ldrh r0, [r4]
|
||||
@@ -4573,7 +4573,7 @@ sub_810A288: @ 810A288
|
||||
adds r6, 0x2
|
||||
mov r1, sp
|
||||
adds r2, r6, 0
|
||||
bl get_coro_args_x18_x1A
|
||||
bl ListMenuGetScrollAndRow
|
||||
mov r0, sp
|
||||
ldrh r0, [r0]
|
||||
ldrh r1, [r6]
|
||||
|
||||
+5
-5
@@ -158,7 +158,7 @@ _0810D4E8:
|
||||
.4byte _0810D630
|
||||
.4byte _0810D668
|
||||
_0810D53C:
|
||||
bl sub_80BF768
|
||||
bl VblankHblankHandlerSetZero
|
||||
bl clear_scheduled_bg_copies_to_vram
|
||||
b _0810D674
|
||||
_0810D546:
|
||||
@@ -389,7 +389,7 @@ _0810D718: .4byte gUnknown_203ADCC
|
||||
thumb_func_start sub_810D71C
|
||||
sub_810D71C: @ 810D71C
|
||||
push {r4,r5,lr}
|
||||
bl sub_80BF7C8
|
||||
bl InitBgReg
|
||||
ldr r5, _0810D77C @ =gUnknown_203ADC0
|
||||
movs r4, 0x80
|
||||
lsls r4, 4
|
||||
@@ -1403,7 +1403,7 @@ sub_810DEA0: @ 810DEA0
|
||||
adds r4, 0x2
|
||||
mov r1, sp
|
||||
adds r2, r4, 0
|
||||
bl get_coro_args_x18_x1A
|
||||
bl ListMenuGetScrollAndRow
|
||||
mov r0, sp
|
||||
ldrh r1, [r0]
|
||||
ldrh r0, [r4]
|
||||
@@ -1436,7 +1436,7 @@ _0810DF20:
|
||||
ldrb r0, [r6]
|
||||
ldr r1, _0810DF44 @ =gUnknown_203ADD0
|
||||
adds r2, r1, 0x2
|
||||
bl get_coro_args_x18_x1A
|
||||
bl ListMenuGetScrollAndRow
|
||||
movs r0, 0x2
|
||||
negs r0, r0
|
||||
cmp r4, r0
|
||||
@@ -1630,7 +1630,7 @@ sub_810E0B4: @ 810E0B4
|
||||
ldr r7, _0810E120 @ =gUnknown_203ADD0
|
||||
adds r2, r7, 0x2
|
||||
adds r1, r7, 0
|
||||
bl get_coro_args_x18_x1A
|
||||
bl ListMenuGetScrollAndRow
|
||||
movs r5, 0x20
|
||||
negs r5, r5
|
||||
ldrb r0, [r4]
|
||||
|
||||
+1
-1
@@ -736,7 +736,7 @@ _080E4C7E:
|
||||
adds r1, r2, r3
|
||||
ldr r6, _080E4CD4 @ =0x00000a6a
|
||||
adds r2, r6
|
||||
bl get_coro_args_x18_x1A
|
||||
bl ListMenuGetScrollAndRow
|
||||
bl FreeAllWindowBuffers
|
||||
ldr r0, _080E4CD8 @ =gPlayerParty
|
||||
ldr r5, [r7]
|
||||
|
||||
+3
-3
@@ -563,8 +563,8 @@ _081072CA:
|
||||
_081072D0: .4byte gTasks+0x8
|
||||
thumb_func_end sub_81072AC
|
||||
|
||||
thumb_func_start get_coro_args_x18_x1A
|
||||
get_coro_args_x18_x1A: @ 81072D4
|
||||
thumb_func_start ListMenuGetScrollAndRow
|
||||
ListMenuGetScrollAndRow: @ 81072D4
|
||||
push {lr}
|
||||
adds r3, r1, 0
|
||||
lsls r0, 24
|
||||
@@ -588,7 +588,7 @@ _081072F6:
|
||||
bx r0
|
||||
.align 2, 0
|
||||
_081072FC: .4byte gTasks+0x8
|
||||
thumb_func_end get_coro_args_x18_x1A
|
||||
thumb_func_end ListMenuGetScrollAndRow
|
||||
|
||||
thumb_func_start ListMenuGetYCoordForPrintingArrowCursor
|
||||
ListMenuGetYCoordForPrintingArrowCursor: @ 8107300
|
||||
|
||||
+7
-7
@@ -418,8 +418,8 @@ _080BF764:
|
||||
bx r1
|
||||
thumb_func_end sub_80BF748
|
||||
|
||||
thumb_func_start sub_80BF768
|
||||
sub_80BF768: @ 80BF768
|
||||
thumb_func_start VblankHblankHandlerSetZero
|
||||
VblankHblankHandlerSetZero: @ 80BF768
|
||||
push {lr}
|
||||
movs r0, 0
|
||||
bl SetVBlankCallback
|
||||
@@ -427,13 +427,13 @@ sub_80BF768: @ 80BF768
|
||||
bl SetHBlankCallback
|
||||
pop {r0}
|
||||
bx r0
|
||||
thumb_func_end sub_80BF768
|
||||
thumb_func_end VblankHblankHandlerSetZero
|
||||
|
||||
thumb_func_start sub_80BF77C
|
||||
sub_80BF77C: @ 80BF77C
|
||||
push {r4,lr}
|
||||
sub sp, 0xC
|
||||
bl sub_80BF7C8
|
||||
bl InitBgReg
|
||||
mov r1, sp
|
||||
movs r0, 0
|
||||
strh r0, [r1]
|
||||
@@ -465,8 +465,8 @@ _080BF7C0: .4byte 0x05000100
|
||||
_080BF7C4: .4byte 0x01000200
|
||||
thumb_func_end sub_80BF77C
|
||||
|
||||
thumb_func_start sub_80BF7C8
|
||||
sub_80BF7C8: @ 80BF7C8
|
||||
thumb_func_start InitBgReg
|
||||
InitBgReg: @ 80BF7C8
|
||||
push {lr}
|
||||
movs r0, 0
|
||||
movs r1, 0
|
||||
@@ -517,7 +517,7 @@ sub_80BF7C8: @ 80BF7C8
|
||||
bl ChangeBgY
|
||||
pop {r0}
|
||||
bx r0
|
||||
thumb_func_end sub_80BF7C8
|
||||
thumb_func_end InitBgReg
|
||||
|
||||
thumb_func_start sub_80BF848
|
||||
sub_80BF848: @ 80BF848
|
||||
|
||||
+1
-1
@@ -2789,7 +2789,7 @@ sub_809EF54: @ 809EF54
|
||||
str r2, [sp]
|
||||
movs r2, 0x38
|
||||
movs r3, 0x25
|
||||
bl AddPseudoFieldObject
|
||||
bl AddPseudoEventObject
|
||||
adds r1, r0, 0
|
||||
lsls r1, 24
|
||||
lsrs r1, 24
|
||||
|
||||
+1
-1
@@ -7888,7 +7888,7 @@ _080588C6:
|
||||
movs r2, 0
|
||||
str r2, [sp]
|
||||
movs r3, 0
|
||||
bl AddPseudoFieldObject
|
||||
bl AddPseudoEventObject
|
||||
strb r0, [r4, 0x4]
|
||||
ldrb r1, [r4, 0x4]
|
||||
lsls r0, r1, 4
|
||||
|
||||
+2
-2
@@ -276,7 +276,7 @@ _0811EC24:
|
||||
.4byte _0811EDD0
|
||||
.4byte _0811EDDE
|
||||
_0811EC80:
|
||||
bl sub_80BF768
|
||||
bl VblankHblankHandlerSetZero
|
||||
bl sub_80BF77C
|
||||
bl clear_scheduled_bg_copies_to_vram
|
||||
b _0811EDFC
|
||||
@@ -565,7 +565,7 @@ _0811EEC8: .4byte gUnknown_203B0B8
|
||||
thumb_func_start sub_811EECC
|
||||
sub_811EECC: @ 811EECC
|
||||
push {r4,r5,lr}
|
||||
bl sub_80BF7C8
|
||||
bl InitBgReg
|
||||
ldr r5, _0811EF34 @ =gUnknown_203B0BC
|
||||
movs r4, 0x80
|
||||
lsls r4, 4
|
||||
|
||||
+1
-1
@@ -1142,7 +1142,7 @@ sub_80EBF40: @ 80EBF40
|
||||
mov r8, r1
|
||||
adds r1, r7, 0
|
||||
mov r2, r8
|
||||
bl get_coro_args_x18_x1A
|
||||
bl ListMenuGetScrollAndRow
|
||||
movs r0, 0x2
|
||||
negs r0, r0
|
||||
cmp r6, r0
|
||||
|
||||
@@ -593,7 +593,7 @@ _081029D0:
|
||||
ldrb r0, [r1, 0x17]
|
||||
adds r1, 0x62
|
||||
movs r2, 0
|
||||
bl get_coro_args_x18_x1A
|
||||
bl ListMenuGetScrollAndRow
|
||||
bl sub_806E25C
|
||||
cmp r0, 0
|
||||
beq _081029F4
|
||||
@@ -627,7 +627,7 @@ _08102A14:
|
||||
ldrb r0, [r1, 0x17]
|
||||
adds r1, 0x62
|
||||
movs r2, 0
|
||||
bl get_coro_args_x18_x1A
|
||||
bl ListMenuGetScrollAndRow
|
||||
ldr r0, _08102A4C @ =gMain
|
||||
ldrh r1, [r0, 0x2E]
|
||||
movs r3, 0x1
|
||||
@@ -1367,7 +1367,7 @@ _0810307C:
|
||||
ldrb r0, [r1, 0x17]
|
||||
adds r1, 0x62
|
||||
movs r2, 0
|
||||
bl get_coro_args_x18_x1A
|
||||
bl ListMenuGetScrollAndRow
|
||||
bl sub_81039F0
|
||||
ldr r1, [r4]
|
||||
adds r1, 0x60
|
||||
@@ -1385,7 +1385,7 @@ _08103098:
|
||||
ldrb r0, [r1, 0x17]
|
||||
adds r1, 0x62
|
||||
movs r2, 0
|
||||
bl get_coro_args_x18_x1A
|
||||
bl ListMenuGetScrollAndRow
|
||||
ldr r0, _081030F0 @ =gMain
|
||||
ldrh r1, [r0, 0x2E]
|
||||
movs r3, 0x1
|
||||
@@ -1687,7 +1687,7 @@ _08103344:
|
||||
ldrb r0, [r1, 0x17]
|
||||
adds r1, 0x62
|
||||
movs r2, 0
|
||||
bl get_coro_args_x18_x1A
|
||||
bl ListMenuGetScrollAndRow
|
||||
bl sub_81039F0
|
||||
ldr r1, [r4]
|
||||
adds r1, 0x60
|
||||
@@ -1706,7 +1706,7 @@ _08103362:
|
||||
ldrb r0, [r1, 0x17]
|
||||
adds r1, 0x62
|
||||
movs r2, 0
|
||||
bl get_coro_args_x18_x1A
|
||||
bl ListMenuGetScrollAndRow
|
||||
ldr r0, _081033C4 @ =gMain
|
||||
ldrh r1, [r0, 0x2E]
|
||||
movs r2, 0x1
|
||||
|
||||
+3
-3
@@ -515,7 +515,7 @@ _0809AEA0: .4byte gTasks
|
||||
_0809AEA4: .4byte sub_809AE00
|
||||
_0809AEA8: .4byte sub_809ADE4
|
||||
_0809AEAC:
|
||||
bl sub_80BF768
|
||||
bl VblankHblankHandlerSetZero
|
||||
str r4, [sp, 0x8]
|
||||
movs r1, 0xE0
|
||||
lsls r1, 19
|
||||
@@ -2017,7 +2017,7 @@ _0809BA56:
|
||||
str r0, [sp]
|
||||
adds r0, r4, 0
|
||||
ldr r1, _0809BAF4 @ =SpriteCallbackDummy
|
||||
bl AddPseudoFieldObject
|
||||
bl AddPseudoEventObject
|
||||
lsls r0, 24
|
||||
lsrs r0, 24
|
||||
lsls r2, r0, 4
|
||||
@@ -2170,7 +2170,7 @@ sub_809BBC0: @ 809BBC0
|
||||
ldr r7, _0809BC08 @ =gUnknown_2039942
|
||||
subs r2, r7, 0x2
|
||||
adds r1, r7, 0
|
||||
bl get_coro_args_x18_x1A
|
||||
bl ListMenuGetScrollAndRow
|
||||
movs r0, 0x2
|
||||
negs r0, r0
|
||||
cmp r4, r0
|
||||
|
||||
-2912
File diff suppressed because it is too large
Load Diff
+22
-1
@@ -1903,7 +1903,28 @@ gUnknown_841B76B:: @ 841B76B
|
||||
.incbin "baserom.gba", 0x41B76B, 0xE
|
||||
|
||||
gUnknown_841B779:: @ 841B779
|
||||
.incbin "baserom.gba", 0x41B779, 0xC4
|
||||
.incbin "baserom.gba", 0x41B779, 0x2B
|
||||
|
||||
gUnknown_841B7A4:: @ 841B7A4
|
||||
.string "Teach me how to battle.$"
|
||||
|
||||
gUnknown_841B7BC:: @ 841B7BC
|
||||
.string "What are status problems?$"
|
||||
|
||||
gUnknown_841B7D6:: @ 841B7D6
|
||||
.string "What are type matchups?$"
|
||||
|
||||
gUnknown_841B7EE:: @ 841B7EE
|
||||
.string "I want to catch POKéMON.$"
|
||||
|
||||
gUnknown_841B807:: @ 841B807
|
||||
.string "Teach me about TMs.$"
|
||||
|
||||
gUnknown_841B81B:: @ 841B81B
|
||||
.string "How do I register an item?$"
|
||||
|
||||
gUnknown_841B836:: @ 841B836
|
||||
.string "CANCEL$"
|
||||
|
||||
gUnknown_841B83D:: @ 841B83D
|
||||
.string "Hey, all you TRAINERS out there!\n"
|
||||
|
||||
@@ -215,47 +215,6 @@ gUnknown_84791E8:: @ 84791E8
|
||||
gUnknown_84792D0:: @ 84792D0
|
||||
.incbin "baserom.gba", 0x4792D0, 0x10
|
||||
|
||||
gUnknown_84792E0:: @ 84792E0
|
||||
.incbin "baserom.gba", 0x4792E0, 0x10
|
||||
|
||||
gUnknown_84792F0:: @ 84792F0
|
||||
.incbin "baserom.gba", 0x4792F0, 0x50
|
||||
|
||||
gUnknown_8479340:: @ 8479340
|
||||
.incbin "baserom.gba", 0x479340, 0x28
|
||||
|
||||
gUnknown_8479368:: @ 8479368
|
||||
.incbin "baserom.gba", 0x479368, 0x18
|
||||
|
||||
gUnknown_8479380:: @ 8479380
|
||||
.incbin "baserom.gba", 0x479380, 0x10
|
||||
|
||||
gUnknown_8479390:: @ 8479390
|
||||
.incbin "baserom.gba", 0x479390, 0x1B8
|
||||
|
||||
gUnknown_8479548:: @ 8479548
|
||||
.incbin "baserom.gba", 0x479548, 0x18
|
||||
|
||||
gUnknown_8479560:: @ 8479560
|
||||
.4byte gUnknown_841B8BF
|
||||
.4byte gUnknown_841BB40
|
||||
.4byte gUnknown_841BE76
|
||||
.4byte gUnknown_841C23B
|
||||
.4byte gUnknown_841C459
|
||||
.4byte gUnknown_841C82A
|
||||
|
||||
gUnknown_8479578:: @ 8479578
|
||||
.incbin "baserom.gba", 0x479578, 0x18
|
||||
|
||||
gUnknown_8479590:: @ 8479590
|
||||
.incbin "baserom.gba", 0x479590, 0x28
|
||||
|
||||
gUnknown_84795B8:: @ 84795B8
|
||||
.incbin "baserom.gba", 0x4795B8, 0x10
|
||||
|
||||
gUnknown_84795C8:: @ 84795C8
|
||||
.incbin "baserom.gba", 0x4795C8, 0x90
|
||||
|
||||
.section .rodata.8479668
|
||||
|
||||
.align 2
|
||||
|
||||
@@ -46,7 +46,7 @@ void FieldObjectClearAnim(struct MapObject *);
|
||||
void FieldObjectClearAnimIfSpecialAnimActive(struct MapObject *);
|
||||
void SpawnFieldObjectsInView(s16, s16);
|
||||
u8 sprite_new(u8, u8, s16, s16, u8, u8);
|
||||
u8 AddPseudoFieldObject(u16, void (*)(struct Sprite *), s16, s16, u8);
|
||||
u8 AddPseudoEventObject(u16, SpriteCallback, s16, s16, u8);
|
||||
u8 show_sprite(u8, u8, u8);
|
||||
u8 SpawnSpecialFieldObjectParameterized(u8, u8, u8, s16, s16, u8);
|
||||
u8 SpawnSpecialFieldObject(struct MapObjectTemplate *);
|
||||
@@ -92,5 +92,7 @@ void npc_paltag_set_load(u8 mode);
|
||||
// Exported data declarations
|
||||
|
||||
extern const struct SpriteTemplate *const gFieldEffectObjectTemplatePointers[];
|
||||
extern const struct SpritePalette gUnknown_83A5348;
|
||||
extern const struct SpriteTemplate * const gUnknown_83A0010[];
|
||||
|
||||
#endif //GUARD_FIELD_MAP_OBJ_H
|
||||
|
||||
@@ -12,6 +12,7 @@
|
||||
#define VIRTUAL_MAP_SIZE 0x2800
|
||||
|
||||
extern struct BackupMapData VMap;
|
||||
extern const struct MapData Route1_Layout;
|
||||
|
||||
u32 MapGridGetMetatileIdAt(int, int);
|
||||
u32 MapGridGetMetatileBehaviorAt(int, int);
|
||||
|
||||
@@ -51,8 +51,8 @@ struct Tileset
|
||||
/*0x04*/ void *tiles;
|
||||
/*0x08*/ void *palettes;
|
||||
/*0x0c*/ void *metatiles;
|
||||
/*0x14*/ TilesetCB callback;
|
||||
/*0x10*/ void *metatileAttributes;
|
||||
/*0x10*/ TilesetCB callback;
|
||||
/*0x14*/ void *metatileAttributes;
|
||||
};
|
||||
|
||||
struct MapData
|
||||
|
||||
@@ -160,6 +160,7 @@ extern const u32 gTMCase_TMSpriteGfx[];
|
||||
extern const u32 gUnknown_8E84F20[];
|
||||
extern const u32 gUnknown_8E85068[];
|
||||
extern const u8 gUnknown_8E99118[];
|
||||
extern const u16 gTMCaseMainWindowPalette[];
|
||||
|
||||
// egg_hatch
|
||||
extern const u32 gBattleTextboxTiles[];
|
||||
@@ -168,4 +169,10 @@ extern const u32 gBattleTextboxPalette[];
|
||||
extern const u32 gTradeGba2_Pal[];
|
||||
extern const u32 gTradeGba_Gfx[];
|
||||
|
||||
// teachy_tv
|
||||
extern const u8 gUnknown_8E86240[];
|
||||
extern const u8 gUnknown_8E86BE8[];
|
||||
extern const u8 gUnknown_8E86D6C[];
|
||||
extern const u8 gUnknown_8E86F98[];
|
||||
|
||||
#endif //GUARD_GRAPHICS_H
|
||||
|
||||
@@ -5,6 +5,7 @@
|
||||
|
||||
extern bool8 gUnknown_3005ECC;
|
||||
|
||||
void sub_812B1E0(u16);
|
||||
void sub_812B484(void);
|
||||
void HelpSystem_SetSomeVariable2(u8);
|
||||
void sub_812B478(void);
|
||||
|
||||
@@ -25,6 +25,7 @@ extern u16 gSpecialVar_ItemId;
|
||||
void sub_81AAC50(void);
|
||||
void sub_81AAC70(void);
|
||||
void sub_8108CF0(void);
|
||||
void sub_810B108(u8);
|
||||
void UseFameCheckerFromMenu(void);
|
||||
|
||||
#endif //GUARD_ITEM_MENU_H
|
||||
|
||||
+4
-4
@@ -9,8 +9,8 @@
|
||||
|
||||
struct ListMenuItem
|
||||
{
|
||||
const u8 *unk_00;
|
||||
s32 unk_04;
|
||||
const u8 *label;
|
||||
s32 index;
|
||||
};
|
||||
|
||||
struct ListMenu;
|
||||
@@ -43,7 +43,7 @@ struct ListMenu {
|
||||
u16 selectedRow;
|
||||
u8 unk_1C;
|
||||
u8 unk_1D;
|
||||
u8 unk_1E;
|
||||
u8 taskId;
|
||||
u8 unk_1F;
|
||||
};
|
||||
|
||||
@@ -54,7 +54,7 @@ extern struct ListMenuTemplate gMultiuseListMenuTemplate;
|
||||
|
||||
u8 ListMenuInit(struct ListMenuTemplate *template, u16 a1, u16 a2);
|
||||
s32 ListMenuHandleInput(u8 id);
|
||||
void get_coro_args_x18_x1A(u8 a0, u16 *a1, u16 *a2);
|
||||
void ListMenuGetScrollAndRow(u8 a0, u16 *a1, u16 *a2);
|
||||
void sub_81AE6C8(u8 a0, u16 *a1, u16 *a2);
|
||||
void DestroyListMenu(u8, u16 *, u16 *);
|
||||
u16 ListMenuGetYCoordForPrintingArrowCursor(u8);
|
||||
|
||||
@@ -3,8 +3,6 @@
|
||||
|
||||
#include "global.h"
|
||||
|
||||
#include "global.h"
|
||||
|
||||
typedef void (*MainCallback)(void);
|
||||
typedef void (*IntrCallback)(void);
|
||||
typedef void (*IntrFunc)(void);
|
||||
|
||||
@@ -18,10 +18,11 @@ void sub_812225C(u16 *, u16 *, u8, u8);
|
||||
void sub_8122298(u16 *, u16 *, u8, u8, u8);
|
||||
void sub_8121F68(u8 taskId, const struct YesNoFuncTable *data);
|
||||
bool8 sub_81221AC(void);
|
||||
bool16 sub_80BF518(u8 textPrinterId);
|
||||
bool8 sub_80BF72C(void);
|
||||
bool8 sub_80BF708(void);
|
||||
void sub_80BF768(void);
|
||||
void sub_80BF7C8(void);
|
||||
void VblankHblankHandlerSetZero(void);
|
||||
void InitBgReg(void);
|
||||
u8 sub_80BF8E4(void);
|
||||
u8 sub_80BF848(s16 * a0, u16 a1);
|
||||
void DisplayMessageAndContinueTask(u8 taskId, u8 windowId, u16 arg2, u8 arg3, u8 fontId, u8 textSpeed, const u8 *string, void *taskFunc);
|
||||
|
||||
+13
-14
@@ -7,25 +7,24 @@
|
||||
|
||||
// Exported RAM declarations
|
||||
|
||||
struct ScrollIndicatorArrowPairTemplate
|
||||
struct ScrollArrowsTemplate
|
||||
{
|
||||
u8 unk_00;
|
||||
u8 unk_01;
|
||||
u8 unk_02;
|
||||
u8 unk_03;
|
||||
u8 unk_04;
|
||||
u8 unk_05;
|
||||
u16 unk_06;
|
||||
u16 unk_08;
|
||||
u16 unk_0a;
|
||||
u16 unk_0c;
|
||||
u16 unk_0e_0:4;
|
||||
u16 unk_0e_4:12;
|
||||
u8 firstArrowType;
|
||||
u8 firstX;
|
||||
u8 firstY;
|
||||
u8 secondArrowType;
|
||||
u8 secondX;
|
||||
u8 secondY;
|
||||
u16 fullyUpThreshold;
|
||||
u16 fullyDownThreshold;
|
||||
u16 tileTag;
|
||||
u16 palTag;
|
||||
u8 palNum;
|
||||
};
|
||||
|
||||
// Exported ROM declarations
|
||||
u8 AddScrollIndicatorArrowPairParameterized(u8, u8, u8, u8, s32, u16, u16, u16 *);
|
||||
u8 AddScrollIndicatorArrowPair(const struct ScrollIndicatorArrowPairTemplate * template, u16 * a1);
|
||||
u8 AddScrollIndicatorArrowPair(const struct ScrollArrowsTemplate * template, u16 * a1);
|
||||
void RemoveScrollIndicatorArrowPair(u8);
|
||||
|
||||
#endif //GUARD_MENU_INDICATORS_H
|
||||
|
||||
@@ -109,6 +109,7 @@ void Overworld_ResetStateAfterTeleport(void);
|
||||
|
||||
void Overworld_FadeOutMapMusic(void);
|
||||
void sub_805671C(void);
|
||||
void sub_8055DC4(void);
|
||||
bool8 sub_8055FC4(void);
|
||||
|
||||
#endif //GUARD_ROM4_H
|
||||
|
||||
@@ -232,6 +232,8 @@ struct OamMatrix
|
||||
s16 d;
|
||||
};
|
||||
|
||||
typedef void (*SpriteCallback)(struct Sprite *);
|
||||
|
||||
extern const struct OamData gDummyOamData;
|
||||
extern const union AnimCmd *const gDummySpriteAnimTable[];
|
||||
extern const union AffineAnimCmd *const gDummySpriteAffineAnimTable[];
|
||||
|
||||
+22
-1
@@ -113,6 +113,27 @@ extern const u8 gText_ICanPayThisMuch_WouldThatBeOkay[];
|
||||
extern const u8 gText_TurnedOverItemsWorthYen[];
|
||||
extern const u8 gPokeDudeText_TMTypes[];
|
||||
extern const u8 gPokeDudeText_ReadTMDescription[];
|
||||
extern const u16 gTMCaseMainWindowPalette[];
|
||||
|
||||
// teachy_tv
|
||||
extern const u8 gUnknown_841B7A4[];
|
||||
extern const u8 gUnknown_841B7BC[];
|
||||
extern const u8 gUnknown_841B7D6[];
|
||||
extern const u8 gUnknown_841B7EE[];
|
||||
extern const u8 gUnknown_841B807[];
|
||||
extern const u8 gUnknown_841B81B[];
|
||||
extern const u8 gUnknown_841B836[];
|
||||
extern const u8 gUnknown_841B83D[];
|
||||
extern const u8 gUnknown_841B8BF[];
|
||||
extern const u8 gUnknown_841BB40[];
|
||||
extern const u8 gUnknown_841BE76[];
|
||||
extern const u8 gUnknown_841C23B[];
|
||||
extern const u8 gUnknown_841C459[];
|
||||
extern const u8 gUnknown_841C82A[];
|
||||
extern const u8 gUnknown_841BA41[];
|
||||
extern const u8 gUnknown_841BD10[];
|
||||
extern const u8 gUnknown_841C0AF[];
|
||||
extern const u8 gUnknown_841C384[];
|
||||
extern const u8 gUnknown_841C7B4[];
|
||||
extern const u8 gUnknown_841C994[];
|
||||
|
||||
#endif //GUARD_STRINGS_H
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
#ifndef GUARD_TEACHY_TV_H
|
||||
#define GUARD_TEACHY_TV_H
|
||||
|
||||
void sub_815ABC4(u8 mode, void (*cb)());
|
||||
void CB2_ReturnToTeachyTV(void);
|
||||
void sub_815AC20(void);
|
||||
|
||||
|
||||
@@ -3,6 +3,7 @@
|
||||
|
||||
#include "global.h"
|
||||
|
||||
void sub_8159F40(void);
|
||||
void sub_815A008(struct QuestLog *);
|
||||
void sub_815A1F8(struct QuestLog *, struct MapObjectTemplate *);
|
||||
|
||||
|
||||
+2
-1
@@ -277,7 +277,7 @@ SECTIONS {
|
||||
src/unk_8159F40.o(.text);
|
||||
src/dodrio_berry_picking_2.o(.text);
|
||||
asm/dodrio_berry_picking_2.o(.text);
|
||||
asm/teachy_tv.o(.text);
|
||||
src/teachy_tv.o(.text);
|
||||
asm/ereader_helpers.o(.text);
|
||||
src/unk_815C980.o(.text);
|
||||
asm/ss_anne.o(.text);
|
||||
@@ -450,6 +450,7 @@ SECTIONS {
|
||||
src/text_window_graphics.o(.rodata);
|
||||
src/quest_log_8150454.o(.rodata);
|
||||
data/data_8471F00.o(.rodata);
|
||||
src/teachy_tv.o(.rodata);
|
||||
src/unk_815C980.o(.rodata);
|
||||
data/data_8471F00.o(.rodata.8479668);
|
||||
src/trainer_tower.o(.rodata);
|
||||
|
||||
+1
-1
@@ -3,8 +3,8 @@
|
||||
#include "text.h"
|
||||
#include "menu.h"
|
||||
#include "text_window.h"
|
||||
#include "strings.h"
|
||||
|
||||
extern const u8 gText_Coins[];
|
||||
extern const u8 gUnknown_8417C2D[];
|
||||
|
||||
EWRAM_DATA static u8 sCoinsWindowId = 0;
|
||||
|
||||
+14
-15
@@ -1270,7 +1270,7 @@ static void FC_MoveCursorFunc(s32 itemIndex, bool8 onInit, struct ListMenu *list
|
||||
struct Task *task = &gTasks[taskId];
|
||||
PlaySE(SE_SELECT);
|
||||
task->data[1] = 0;
|
||||
get_coro_args_x18_x1A(sFameCheckerData->listMenuTaskId, &listMenuTopIdx, NULL);
|
||||
ListMenuGetScrollAndRow(sFameCheckerData->listMenuTaskId, &listMenuTopIdx, NULL);
|
||||
sFameCheckerData->listMenuTopIdx = listMenuTopIdx;
|
||||
if (itemIndex != sFameCheckerData->numUnlockedPersons - 1)
|
||||
{
|
||||
@@ -1339,16 +1339,16 @@ static void FC_DoMoveCursor(s32 itemIndex, bool8 onInit)
|
||||
u16 listY;
|
||||
u16 cursorY;
|
||||
u16 who;
|
||||
get_coro_args_x18_x1A(sFameCheckerData->listMenuTaskId, &listY, &cursorY);
|
||||
ListMenuGetScrollAndRow(sFameCheckerData->listMenuTaskId, &listY, &cursorY);
|
||||
who = listY + cursorY;
|
||||
AddTextPrinterParameterized4(FCWINDOWID_LIST, 2, 8, 14 * cursorY + 4, 0, 0, &sTextColor_Green, 0, sListMenuItems[itemIndex].unk_00);
|
||||
AddTextPrinterParameterized4(FCWINDOWID_LIST, 2, 8, 14 * cursorY + 4, 0, 0, &sTextColor_Green, 0, sListMenuItems[itemIndex].label);
|
||||
if (!onInit)
|
||||
{
|
||||
if (listY < sFameCheckerData->listMenuTopIdx2)
|
||||
sFameCheckerData->listMenuDrawnSelIdx++;
|
||||
else if (listY > sFameCheckerData->listMenuTopIdx2 && who != sFameCheckerData->numUnlockedPersons - 1)
|
||||
sFameCheckerData->listMenuDrawnSelIdx--;
|
||||
AddTextPrinterParameterized4(FCWINDOWID_LIST, 2, 8, 14 * sFameCheckerData->listMenuDrawnSelIdx + 4, 0, 0, &sTextColor_DkGrey, 0, sListMenuItems[sFameCheckerData->listMenuCurIdx].unk_00);
|
||||
AddTextPrinterParameterized4(FCWINDOWID_LIST, 2, 8, 14 * sFameCheckerData->listMenuDrawnSelIdx + 4, 0, 0, &sTextColor_DkGrey, 0, sListMenuItems[sFameCheckerData->listMenuCurIdx].label);
|
||||
|
||||
}
|
||||
sFameCheckerData->listMenuCurIdx = itemIndex;
|
||||
@@ -1368,20 +1368,20 @@ static u8 FC_PopulateListMenu(void)
|
||||
{
|
||||
if (sTrainerIdxs[fameCheckerIdx] < FC_NONTRAINER_START)
|
||||
{
|
||||
sListMenuItems[nitems].unk_00 = gTrainers[sTrainerIdxs[fameCheckerIdx]].trainerName;
|
||||
sListMenuItems[nitems].unk_04 = nitems;
|
||||
sListMenuItems[nitems].label = gTrainers[sTrainerIdxs[fameCheckerIdx]].trainerName;
|
||||
sListMenuItems[nitems].index = nitems;
|
||||
}
|
||||
else
|
||||
{
|
||||
sListMenuItems[nitems].unk_00 = sNonTrainerNamePointers[sTrainerIdxs[fameCheckerIdx] - FC_NONTRAINER_START];
|
||||
sListMenuItems[nitems].unk_04 = nitems;
|
||||
sListMenuItems[nitems].label = sNonTrainerNamePointers[sTrainerIdxs[fameCheckerIdx] - FC_NONTRAINER_START];
|
||||
sListMenuItems[nitems].index = nitems;
|
||||
}
|
||||
sFameCheckerData->unlockedPersons[nitems] = fameCheckerIdx;
|
||||
nitems++;
|
||||
}
|
||||
}
|
||||
sListMenuItems[nitems].unk_00 = gFameCheckerText_Cancel;
|
||||
sListMenuItems[nitems].unk_04 = nitems;
|
||||
sListMenuItems[nitems].label = gFameCheckerText_Cancel;
|
||||
sListMenuItems[nitems].index = nitems;
|
||||
sFameCheckerData->unlockedPersons[nitems] = 0xFF;
|
||||
nitems++;
|
||||
gFameChecker_ListMenuTemplate.totalItems = nitems;
|
||||
@@ -1400,7 +1400,7 @@ static void FC_PutWindowTilemapAndCopyWindowToVramMode3_2(u8 windowId)
|
||||
|
||||
static void FC_CreateScrollIndicatorArrowPair(void)
|
||||
{
|
||||
struct ScrollIndicatorArrowPairTemplate template = {
|
||||
struct ScrollArrowsTemplate template = {
|
||||
2,
|
||||
40,
|
||||
26,
|
||||
@@ -1412,13 +1412,12 @@ static void FC_CreateScrollIndicatorArrowPair(void)
|
||||
SPRITETAG_SCROLL_INDICATORS,
|
||||
0xFFFF,
|
||||
1,
|
||||
0
|
||||
};
|
||||
|
||||
if (sFameCheckerData->numUnlockedPersons > 5)
|
||||
{
|
||||
template.unk_06 = 0;
|
||||
template.unk_08 = sFameCheckerData->numUnlockedPersons - 5;
|
||||
template.fullyUpThreshold = 0;
|
||||
template.fullyDownThreshold = sFameCheckerData->numUnlockedPersons - 5;
|
||||
sFameCheckerData->scrollIndicatorPairTaskId = AddScrollIndicatorArrowPair(&template, &sFameCheckerData->listMenuTopIdx);
|
||||
}
|
||||
}
|
||||
@@ -1432,7 +1431,7 @@ static void FreeListMenuSelectorArrowPairResources(void)
|
||||
static u16 FameCheckerGetCursorY(void)
|
||||
{
|
||||
u16 listY, cursorY;
|
||||
get_coro_args_x18_x1A(sFameCheckerData->listMenuTaskId, &listY, &cursorY);
|
||||
ListMenuGetScrollAndRow(sFameCheckerData->listMenuTaskId, &listY, &cursorY);
|
||||
return listY + cursorY;
|
||||
}
|
||||
|
||||
|
||||
@@ -460,7 +460,7 @@ struct UnkStruct_203F3CC
|
||||
/*01cc*/ u8 filler_01CC[2];
|
||||
/*01ce*/ u8 unk_01CE[41];
|
||||
/*01f7*/ u8 unk_01F7[10][41];
|
||||
/*0394*/ struct ScrollIndicatorArrowPairTemplate unk_0394;
|
||||
/*0394*/ struct ScrollArrowsTemplate unk_0394;
|
||||
/*03a4*/ u8 buffer_03A4[0x1000];
|
||||
};
|
||||
|
||||
@@ -478,9 +478,9 @@ const struct WindowTemplate gUnknown_8468040[] = {
|
||||
{0, 1, 0, 28, 3, 15, 0x000},
|
||||
{2, 1, 3, 28, 20, 15, 0x000}
|
||||
};
|
||||
const struct ScrollIndicatorArrowPairTemplate gUnknown_8468050 = {
|
||||
const struct ScrollArrowsTemplate gUnknown_8468050 = {
|
||||
0x02, 0xe8, 0x18, 0x03, 0xe8, 0x98,
|
||||
0x0000, 0x0002, 0x1000, 0x1000, 0x0, 0x000
|
||||
0x0000, 0x0002, 0x1000, 0x1000, 0x0,
|
||||
};
|
||||
|
||||
const u16 gUnknown_8468060[] = INCBIN_U16("data/graphics/mevent/pal_468060.gbapal");
|
||||
@@ -743,7 +743,7 @@ void sub_8146980(void)
|
||||
++gUnknown_203F3CC->unk_01C4;
|
||||
}
|
||||
gUnknown_203F3CC->unk_0394 = gUnknown_8468050;
|
||||
gUnknown_203F3CC->unk_0394.unk_08 = gUnknown_203F3CC->unk_01C4;
|
||||
gUnknown_203F3CC->unk_0394.fullyDownThreshold = gUnknown_203F3CC->unk_01C4;
|
||||
}
|
||||
|
||||
void sub_8146A30(void)
|
||||
|
||||
@@ -703,7 +703,7 @@ u32 MysteryGift_HandleThreeOptionMenu(u8 * unused0, u16 * unused1, u8 whichMenu)
|
||||
width = 0;
|
||||
for (i = 0; i < listMenuTemplate.totalItems; i++)
|
||||
{
|
||||
u32 curWidth = GetStringWidth(2, listMenuTemplate.items[i].unk_00, listMenuTemplate.lettersSpacing);
|
||||
u32 curWidth = GetStringWidth(2, listMenuTemplate.items[i].label, listMenuTemplate.lettersSpacing);
|
||||
if (curWidth > width)
|
||||
width = curWidth;
|
||||
}
|
||||
|
||||
+1688
File diff suppressed because it is too large
Load Diff
+7
-7
@@ -321,7 +321,7 @@ static bool8 DoSetUpTMCaseUI(void)
|
||||
switch (gMain.state)
|
||||
{
|
||||
case 0:
|
||||
sub_80BF768();
|
||||
VblankHblankHandlerSetZero();
|
||||
clear_scheduled_bg_copies_to_vram();
|
||||
gMain.state++;
|
||||
break;
|
||||
@@ -426,7 +426,7 @@ static void ResetBufferPointers_NoFree(void)
|
||||
static void LoadBGTemplates(void)
|
||||
{
|
||||
void ** ptr;
|
||||
sub_80BF7C8();
|
||||
InitBgReg();
|
||||
ptr = &sTilemapBuffer;
|
||||
*ptr = AllocZeroed(0x800);
|
||||
ResetBgsAndClearDma3BusyFlags(0);
|
||||
@@ -496,11 +496,11 @@ static void InitTMCaseListMenuItems(void)
|
||||
for (i = 0; i < sTMCaseDynamicResources->numTMs; i++)
|
||||
{
|
||||
GetTMNumberAndMoveString(sListMenuStringsBuffer[i], pocket->itemSlots[i].itemId);
|
||||
sListMenuItemsBuffer[i].unk_00 = sListMenuStringsBuffer[i];
|
||||
sListMenuItemsBuffer[i].unk_04 = i;
|
||||
sListMenuItemsBuffer[i].label = sListMenuStringsBuffer[i];
|
||||
sListMenuItemsBuffer[i].index = i;
|
||||
}
|
||||
sListMenuItemsBuffer[i].unk_00 = gText_Close;
|
||||
sListMenuItemsBuffer[i].unk_04 = -2;
|
||||
sListMenuItemsBuffer[i].label = gText_Close;
|
||||
sListMenuItemsBuffer[i].index = -2;
|
||||
gMultiuseListMenuTemplate.items = sListMenuItemsBuffer;
|
||||
gMultiuseListMenuTemplate.totalItems = sTMCaseDynamicResources->numTMs + 1;
|
||||
gMultiuseListMenuTemplate.windowId = 0;
|
||||
@@ -737,7 +737,7 @@ static void Task_TMCaseMain(u8 taskId)
|
||||
if (sub_80BF72C() != TRUE)
|
||||
{
|
||||
input = ListMenuHandleInput(data[0]);
|
||||
get_coro_args_x18_x1A(data[0], &sTMCaseStaticResources.scrollOffset, &sTMCaseStaticResources.selectedRow);
|
||||
ListMenuGetScrollAndRow(data[0], &sTMCaseStaticResources.scrollOffset, &sTMCaseStaticResources.selectedRow);
|
||||
if (JOY_NEW(SELECT_BUTTON) && sTMCaseStaticResources.unk_05 == 1)
|
||||
{
|
||||
PlaySE(SE_SELECT);
|
||||
|
||||
+1
-4
@@ -1639,10 +1639,7 @@ gUnknown_203F440: @ 203F440
|
||||
.space 0x4
|
||||
|
||||
gTeachyTV_StaticResources: @ 203F444
|
||||
.space 0x6
|
||||
|
||||
gUnknown_203F44A: @ 203F44A
|
||||
.space 0x6
|
||||
.space 12
|
||||
|
||||
gUnknown_203F450: @ 203F450
|
||||
.space 0x4
|
||||
|
||||
Reference in New Issue
Block a user