summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPikalaxALT <PikalaxALT@users.noreply.github.com>2019-06-10 20:20:24 -0400
committerGitHub <noreply@github.com>2019-06-10 20:20:24 -0400
commit03e47515e153e7c8757bdb28de87f149d5022a82 (patch)
tree0ce0660fb0c4d3edc3bc21970357b506ff15dd49
parent19c9e0851a971061b3f9e7b7840cdd59ab538f72 (diff)
parent731b5e103a535086ebf99a2c3a032a7b0e30e74f (diff)
Merge pull request #62 from jiangzhengwenjz/teachy_tv
teachy_tv
-rw-r--r--.gitignore1
-rw-r--r--asm/berry_pouch.s6
-rw-r--r--asm/field_map_obj.s6
-rw-r--r--asm/field_specials.s2
-rw-r--r--asm/item_menu.s18
-rw-r--r--asm/item_pc.s10
-rw-r--r--asm/learn_move.s2
-rw-r--r--asm/list_menu.s6
-rw-r--r--asm/menu_helpers.s14
-rw-r--r--asm/naming_screen.s2
-rw-r--r--asm/overworld.s2
-rw-r--r--asm/party_menu.s4
-rw-r--r--asm/player_pc.s2
-rw-r--r--asm/pokedex_screen.s12
-rw-r--r--asm/shop.s6
-rw-r--r--asm/teachy_tv.s2912
-rw-r--r--data/data_83FECCC.s23
-rw-r--r--data/data_8471F00.s41
-rw-r--r--include/field_map_obj.h4
-rw-r--r--include/fieldmap.h1
-rw-r--r--include/global.fieldmap.h4
-rw-r--r--include/graphics.h7
-rw-r--r--include/help_system.h1
-rw-r--r--include/item_menu.h1
-rw-r--r--include/list_menu.h8
-rw-r--r--include/main.h2
-rw-r--r--include/menu_helpers.h5
-rw-r--r--include/menu_indicators.h27
-rw-r--r--include/overworld.h1
-rw-r--r--include/sprite.h2
-rw-r--r--include/strings.h23
-rw-r--r--include/teachy_tv.h1
-rw-r--r--include/unk_8159F40.h1
-rw-r--r--ld_script.txt3
-rw-r--r--src/coins.c2
-rw-r--r--src/fame_checker.c29
-rw-r--r--src/mevent_8145654.c8
-rw-r--r--src/mystery_gift_menu.c2
-rw-r--r--src/teachy_tv.c1688
-rw-r--r--src/tm_case.c14
-rw-r--r--sym_ewram.txt5
41 files changed, 1849 insertions, 3059 deletions
diff --git a/.gitignore b/.gitignore
index da2cb317c..fdc668785 100644
--- a/.gitignore
+++ b/.gitignore
@@ -26,6 +26,7 @@ ld_script_sapphire.txt
*.id2
*.nam
*.til
+.fuse*
*.ld
tags
types_*.taghl
diff --git a/asm/berry_pouch.s b/asm/berry_pouch.s
index 7813d1ade..556cccbe0 100644
--- a/asm/berry_pouch.s
+++ b/asm/berry_pouch.s
@@ -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
diff --git a/asm/field_map_obj.s b/asm/field_map_obj.s
index 77df1274b..1275f7471 100644
--- a/asm/field_map_obj.s
+++ b/asm/field_map_obj.s
@@ -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
diff --git a/asm/field_specials.s b/asm/field_specials.s
index d1302c8d2..7a0221941 100644
--- a/asm/field_specials.s
+++ b/asm/field_specials.s
@@ -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]
diff --git a/asm/item_menu.s b/asm/item_menu.s
index 53c92a8d3..b3169cdc3 100644
--- a/asm/item_menu.s
+++ b/asm/item_menu.s
@@ -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]
diff --git a/asm/item_pc.s b/asm/item_pc.s
index 87e64619e..93ca91ff9 100644
--- a/asm/item_pc.s
+++ b/asm/item_pc.s
@@ -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]
diff --git a/asm/learn_move.s b/asm/learn_move.s
index 47b5c74fe..e9041a9b2 100644
--- a/asm/learn_move.s
+++ b/asm/learn_move.s
@@ -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]
diff --git a/asm/list_menu.s b/asm/list_menu.s
index 3a215f799..9558ea323 100644
--- a/asm/list_menu.s
+++ b/asm/list_menu.s
@@ -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
diff --git a/asm/menu_helpers.s b/asm/menu_helpers.s
index 69567e0ca..7984a32c4 100644
--- a/asm/menu_helpers.s
+++ b/asm/menu_helpers.s
@@ -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
diff --git a/asm/naming_screen.s b/asm/naming_screen.s
index 36c3b1a75..ef692b052 100644
--- a/asm/naming_screen.s
+++ b/asm/naming_screen.s
@@ -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
diff --git a/asm/overworld.s b/asm/overworld.s
index 103ed2c46..87f146d39 100644
--- a/asm/overworld.s
+++ b/asm/overworld.s
@@ -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
diff --git a/asm/party_menu.s b/asm/party_menu.s
index bcf65c35b..2ce165ef2 100644
--- a/asm/party_menu.s
+++ b/asm/party_menu.s
@@ -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
diff --git a/asm/player_pc.s b/asm/player_pc.s
index b5149a435..cb6c9f9d0 100644
--- a/asm/player_pc.s
+++ b/asm/player_pc.s
@@ -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
diff --git a/asm/pokedex_screen.s b/asm/pokedex_screen.s
index 92a6b5f08..80cc1ab5d 100644
--- a/asm/pokedex_screen.s
+++ b/asm/pokedex_screen.s
@@ -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
diff --git a/asm/shop.s b/asm/shop.s
index 33f6bd225..d7188e66e 100644
--- a/asm/shop.s
+++ b/asm/shop.s
@@ -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
diff --git a/asm/teachy_tv.s b/asm/teachy_tv.s
deleted file mode 100644
index 418da67dd..000000000
--- a/asm/teachy_tv.s
+++ /dev/null
@@ -1,2912 +0,0 @@
- .include "asm/macros.inc"
- .include "constants/constants.inc"
-
- .syntax unified
-
- .text
-
- thumb_func_start sub_815AB94
-sub_815AB94: @ 815AB94
- push {lr}
- bl RunTasks
- bl AnimateSprites
- bl BuildOamBuffer
- bl do_scheduled_bg_tilemap_copies_to_vram
- bl UpdatePaletteFade
- pop {r0}
- bx r0
- thumb_func_end sub_815AB94
-
- thumb_func_start sub_815ABB0
-sub_815ABB0: @ 815ABB0
- push {lr}
- bl LoadOam
- bl ProcessSpriteCopyRequests
- bl TransferPlttBuffer
- pop {r0}
- bx r0
- thumb_func_end sub_815ABB0
-
- thumb_func_start sub_815ABC4
-sub_815ABC4: @ 815ABC4
- push {r4,lr}
- lsls r0, 24
- lsrs r0, 24
- adds r2, r0, 0
- ldr r3, _0815ABF4 @ =gTeachyTV_StaticResources
- movs r4, 0
- strb r2, [r3, 0x4]
- str r1, [r3]
- cmp r2, 0
- bne _0815ABE0
- movs r0, 0
- strh r4, [r3, 0x6]
- strh r4, [r3, 0x8]
- strb r0, [r3, 0x5]
-_0815ABE0:
- cmp r2, 0x1
- bne _0815ABE6
- strb r4, [r3, 0x4]
-_0815ABE6:
- ldr r0, _0815ABF8 @ =sub_815AC2C
- bl SetMainCallback2
- pop {r4}
- pop {r0}
- bx r0
- .align 2, 0
-_0815ABF4: .4byte gTeachyTV_StaticResources
-_0815ABF8: .4byte sub_815AC2C
- thumb_func_end sub_815ABC4
-
- thumb_func_start CB2_ReturnToTeachyTV
-CB2_ReturnToTeachyTV: @ 815ABFC
- push {lr}
- ldr r1, _0815AC10 @ =gTeachyTV_StaticResources
- ldrb r0, [r1, 0x4]
- cmp r0, 0x1
- bne _0815AC14
- ldr r1, [r1]
- movs r0, 0x1
- bl sub_815ABC4
- b _0815AC1C
- .align 2, 0
-_0815AC10: .4byte gTeachyTV_StaticResources
-_0815AC14:
- ldr r1, [r1]
- movs r0, 0x2
- bl sub_815ABC4
-_0815AC1C:
- pop {r0}
- bx r0
- thumb_func_end CB2_ReturnToTeachyTV
-
- thumb_func_start sub_815AC20
-sub_815AC20: @ 815AC20
- ldr r1, _0815AC28 @ =gTeachyTV_StaticResources
- movs r0, 0x1
- strb r0, [r1, 0x4]
- bx lr
- .align 2, 0
-_0815AC28: .4byte gTeachyTV_StaticResources
- thumb_func_end sub_815AC20
-
- thumb_func_start sub_815AC2C
-sub_815AC2C: @ 815AC2C
- push {r4-r6,lr}
- sub sp, 0x4
- ldr r0, _0815AC44 @ =gMain
- movs r1, 0x87
- lsls r1, 3
- adds r6, r0, r1
- ldrb r5, [r6]
- cmp r5, 0
- beq _0815AC48
- cmp r5, 0x1
- beq _0815AC9C
- b _0815AD6E
- .align 2, 0
-_0815AC44: .4byte gMain
-_0815AC48:
- ldr r4, _0815AC90 @ =gUnknown_203F450
- ldr r0, _0815AC94 @ =0x00004008
- bl AllocZeroed
- str r0, [r4]
- str r5, [r0]
- ldr r1, _0815AC98 @ =0x00004006
- adds r0, r1
- strb r5, [r0]
- ldr r0, [r4]
- adds r1, 0x1
- adds r0, r1
- movs r1, 0xFF
- strb r1, [r0]
- bl sub_80BF768
- bl clear_scheduled_bg_copies_to_vram
- bl ScanlineEffect_Stop
- bl FreeAllSpritePalettes
- bl ResetPaletteFade
- bl ResetSpriteData
- bl ResetTasks
- bl sub_815AD88
- bl sub_815AE38
- ldrb r0, [r6]
- adds r0, 0x1
- strb r0, [r6]
- b _0815AD6E
- .align 2, 0
-_0815AC90: .4byte gUnknown_203F450
-_0815AC94: .4byte 0x00004008
-_0815AC98: .4byte 0x00004006
-_0815AC9C:
- bl free_temp_tile_data_buffers_if_possible
- lsls r0, 24
- lsrs r0, 24
- cmp r0, 0x1
- beq _0815AD6E
- bl sub_815AEB8
- bl sub_815AFEC
- ldr r0, _0815ACE0 @ =gTeachyTV_StaticResources
- ldrb r0, [r0, 0x4]
- cmp r0, 0x2
- bne _0815ACEC
- ldr r0, _0815ACE4 @ =sub_815BA54
- movs r1, 0
- bl CreateTask
- lsls r0, 24
- lsrs r5, r0, 24
- bl sub_815B014
- ldr r2, _0815ACE8 @ =gTasks
- lsls r1, r5, 2
- adds r1, r5
- lsls r1, 3
- adds r1, r2
- lsls r0, 24
- lsrs r0, 24
- strh r0, [r1, 0xA]
- adds r0, r5, 0
- bl sub_815B118
- b _0815AD26
- .align 2, 0
-_0815ACE0: .4byte gTeachyTV_StaticResources
-_0815ACE4: .4byte sub_815BA54
-_0815ACE8: .4byte gTasks
-_0815ACEC:
- ldr r0, _0815AD78 @ =sub_815B2C0
- movs r1, 0
- bl CreateTask
- lsls r0, 24
- lsrs r5, r0, 24
- bl sub_815AEE8
- ldr r1, _0815AD7C @ =gTasks
- lsls r4, r5, 2
- adds r4, r5
- lsls r4, 3
- adds r4, r1
- lsls r0, 24
- lsrs r0, 24
- strh r0, [r4, 0x8]
- bl sub_815B014
- lsls r0, 24
- lsrs r0, 24
- strh r0, [r4, 0xA]
- bl sub_815AF5C
- movs r0, 0xAD
- lsls r0, 1
- bl PlayNewMapMusic
- bl sub_815B094
-_0815AD26:
- movs r0, 0
- bl schedule_bg_copy_tilemap_to_vram
- movs r0, 0x1
- bl schedule_bg_copy_tilemap_to_vram
- movs r0, 0x2
- bl schedule_bg_copy_tilemap_to_vram
- movs r0, 0x3
- bl schedule_bg_copy_tilemap_to_vram
- movs r0, 0x9
- bl sub_812B1E0
- movs r4, 0x1
- negs r4, r4
- adds r0, r4, 0
- movs r1, 0x10
- movs r2, 0
- bl BlendPalettes
- movs r0, 0
- str r0, [sp]
- adds r0, r4, 0
- movs r1, 0
- movs r2, 0x10
- movs r3, 0
- bl BeginNormalPaletteFade
- ldr r0, _0815AD80 @ =sub_815ABB0
- bl SetVBlankCallback
- ldr r0, _0815AD84 @ =sub_815AB94
- bl SetMainCallback2
-_0815AD6E:
- add sp, 0x4
- pop {r4-r6}
- pop {r0}
- bx r0
- .align 2, 0
-_0815AD78: .4byte sub_815B2C0
-_0815AD7C: .4byte gTasks
-_0815AD80: .4byte sub_815ABB0
-_0815AD84: .4byte sub_815AB94
- thumb_func_end sub_815AC2C
-
- thumb_func_start sub_815AD88
-sub_815AD88: @ 815AD88
- push {r4,lr}
- bl sub_80BF7C8
- movs r0, 0
- bl ResetBgsAndClearDma3BusyFlags
- ldr r1, _0815AE20 @ =gUnknown_84792E0
- movs r0, 0
- movs r2, 0x4
- bl InitBgsFromTemplates
- ldr r4, _0815AE24 @ =gUnknown_203F450
- ldr r1, [r4]
- adds r1, 0x4
- movs r0, 0x1
- bl SetBgTilemapBuffer
- ldr r1, [r4]
- ldr r0, _0815AE28 @ =0x00001004
- adds r1, r0
- movs r0, 0x2
- bl SetBgTilemapBuffer
- ldr r1, [r4]
- ldr r0, _0815AE2C @ =0x00002004
- adds r1, r0
- movs r0, 0x3
- bl SetBgTilemapBuffer
- movs r1, 0xC1
- lsls r1, 6
- movs r0, 0
- bl SetGpuReg
- movs r0, 0
- bl ShowBg
- movs r0, 0x1
- bl ShowBg
- movs r0, 0x2
- bl ShowBg
- movs r0, 0x3
- bl ShowBg
- movs r1, 0x80
- lsls r1, 5
- movs r0, 0x3
- movs r2, 0x2
- bl ChangeBgX
- movs r1, 0xA0
- lsls r1, 6
- movs r0, 0x3
- movs r2, 0x1
- bl ChangeBgY
- ldr r0, [r4]
- ldr r1, _0815AE30 @ =0x00004004
- adds r0, r1
- movs r1, 0
- strb r1, [r0]
- ldr r0, [r4]
- ldr r1, _0815AE34 @ =0x00004005
- adds r0, r1
- movs r1, 0x3
- strb r1, [r0]
- movs r0, 0x50
- movs r1, 0
- bl SetGpuReg
- pop {r4}
- pop {r0}
- bx r0
- .align 2, 0
-_0815AE20: .4byte gUnknown_84792E0
-_0815AE24: .4byte gUnknown_203F450
-_0815AE28: .4byte 0x00001004
-_0815AE2C: .4byte 0x00002004
-_0815AE30: .4byte 0x00004004
-_0815AE34: .4byte 0x00004005
- thumb_func_end sub_815AD88
-
- thumb_func_start sub_815AE38
-sub_815AE38: @ 815AE38
- push {r4,lr}
- sub sp, 0x8
- movs r4, 0
- add r0, sp, 0x4
- strh r4, [r0]
- bl reset_temp_tile_data_buffers
- ldr r1, _0815AE98 @ =gUnknown_8E86240
- str r4, [sp]
- movs r0, 0x1
- movs r2, 0
- movs r3, 0
- bl decompress_and_copy_tile_data_to_vram
- ldr r0, _0815AE9C @ =gUnknown_8E86BE8
- ldr r4, _0815AEA0 @ =gUnknown_203F450
- ldr r1, [r4]
- adds r1, 0x4
- bl LZDecompressWram
- ldr r0, _0815AEA4 @ =gUnknown_8E86D6C
- ldr r1, [r4]
- ldr r2, _0815AEA8 @ =0x00003004
- adds r1, r2
- bl LZDecompressWram
- ldr r0, _0815AEAC @ =gUnknown_8E86F98
- movs r1, 0
- movs r2, 0x80
- bl LoadCompressedPalette
- add r0, sp, 0x4
- movs r1, 0
- movs r2, 0x2
- bl LoadPalette
- ldr r0, _0815AEB0 @ =gUnknown_83A5348
- bl LoadSpritePalette
- ldr r0, [r4]
- ldr r1, _0815AEB4 @ =0x00002004
- adds r0, r1
- bl sub_815BD80
- add sp, 0x8
- pop {r4}
- pop {r0}
- bx r0
- .align 2, 0
-_0815AE98: .4byte gUnknown_8E86240
-_0815AE9C: .4byte gUnknown_8E86BE8
-_0815AEA0: .4byte gUnknown_203F450
-_0815AEA4: .4byte gUnknown_8E86D6C
-_0815AEA8: .4byte 0x00003004
-_0815AEAC: .4byte gUnknown_8E86F98
-_0815AEB0: .4byte gUnknown_83A5348
-_0815AEB4: .4byte 0x00002004
- thumb_func_end sub_815AE38
-
- thumb_func_start sub_815AEB8
-sub_815AEB8: @ 815AEB8
- push {lr}
- ldr r0, _0815AEE4 @ =gUnknown_84792F0
- bl InitWindows
- bl DeactivateAllTextPrinters
- movs r0, 0
- movs r1, 0xCC
- bl FillWindowPixelBuffer
- movs r0, 0
- bl PutWindowTilemap
- movs r0, 0x1
- bl PutWindowTilemap
- movs r0, 0
- movs r1, 0x2
- bl CopyWindowToVram
- pop {r0}
- bx r0
- .align 2, 0
-_0815AEE4: .4byte gUnknown_84792F0
- thumb_func_end sub_815AEB8
-
- thumb_func_start sub_815AEE8
-sub_815AEE8: @ 815AEE8
- push {r4,r5,lr}
- ldr r4, _0815AF48 @ =gMultiuseListMenuTemplate
- adds r1, r4, 0
- ldr r0, _0815AF4C @ =gUnknown_8479368
- ldm r0!, {r2,r3,r5}
- stm r1!, {r2,r3,r5}
- ldm r0!, {r2,r3,r5}
- stm r1!, {r2,r3,r5}
- movs r0, 0x1
- strb r0, [r4, 0x10]
- ldr r0, _0815AF50 @ =sub_815AFD8
- str r0, [r4, 0x4]
- movs r0, 0xB6
- lsls r0, 1
- movs r1, 0x1
- bl CheckBagHasItem
- lsls r0, 24
- cmp r0, 0
- bne _0815AF30
- ldr r0, _0815AF54 @ =gUnknown_8479340
- str r0, [r4]
- movs r0, 0x5
- strh r0, [r4, 0xC]
- strh r0, [r4, 0xE]
- ldrb r2, [r4, 0x14]
- lsls r1, r2, 28
- lsrs r1, 28
- adds r1, 0x8
- movs r0, 0xF
- ands r1, r0
- movs r0, 0x10
- negs r0, r0
- ands r0, r2
- orrs r0, r1
- strb r0, [r4, 0x14]
-_0815AF30:
- ldr r0, _0815AF58 @ =gTeachyTV_StaticResources
- ldrh r1, [r0, 0x6]
- ldrh r2, [r0, 0x8]
- adds r0, r4, 0
- bl ListMenuInit
- lsls r0, 24
- lsrs r0, 24
- pop {r4,r5}
- pop {r1}
- bx r1
- .align 2, 0
-_0815AF48: .4byte gMultiuseListMenuTemplate
-_0815AF4C: .4byte gUnknown_8479368
-_0815AF50: .4byte sub_815AFD8
-_0815AF54: .4byte gUnknown_8479340
-_0815AF58: .4byte gTeachyTV_StaticResources
- thumb_func_end sub_815AEE8
-
- thumb_func_start sub_815AF5C
-sub_815AF5C: @ 815AF5C
- push {lr}
- movs r0, 0xB6
- lsls r0, 1
- movs r1, 0x1
- bl CheckBagHasItem
- lsls r0, 24
- cmp r0, 0
- bne _0815AF84
- ldr r0, _0815AF7C @ =gUnknown_203F450
- ldr r0, [r0]
- ldr r1, _0815AF80 @ =0x00004007
- adds r0, r1
- movs r1, 0xFF
- strb r1, [r0]
- b _0815AF96
- .align 2, 0
-_0815AF7C: .4byte gUnknown_203F450
-_0815AF80: .4byte 0x00004007
-_0815AF84:
- ldr r0, _0815AF9C @ =gUnknown_8479380
- ldr r1, _0815AFA0 @ =gUnknown_203F44A
- bl AddScrollIndicatorArrowPair
- ldr r1, _0815AFA4 @ =gUnknown_203F450
- ldr r1, [r1]
- ldr r2, _0815AFA8 @ =0x00004007
- adds r1, r2
- strb r0, [r1]
-_0815AF96:
- pop {r0}
- bx r0
- .align 2, 0
-_0815AF9C: .4byte gUnknown_8479380
-_0815AFA0: .4byte gUnknown_203F44A
-_0815AFA4: .4byte gUnknown_203F450
-_0815AFA8: .4byte 0x00004007
- thumb_func_end sub_815AF5C
-
- thumb_func_start sub_815AFAC
-sub_815AFAC: @ 815AFAC
- push {r4,lr}
- ldr r4, _0815AFD0 @ =gUnknown_203F450
- ldr r0, [r4]
- ldr r2, _0815AFD4 @ =0x00004007
- adds r1, r0, r2
- ldrb r0, [r1]
- cmp r0, 0xFF
- beq _0815AFCA
- bl RemoveScrollIndicatorArrowPair
- ldr r0, [r4]
- ldr r1, _0815AFD4 @ =0x00004007
- adds r0, r1
- movs r1, 0xFF
- strb r1, [r0]
-_0815AFCA:
- pop {r4}
- pop {r0}
- bx r0
- .align 2, 0
-_0815AFD0: .4byte gUnknown_203F450
-_0815AFD4: .4byte 0x00004007
- thumb_func_end sub_815AFAC
-
- thumb_func_start sub_815AFD8
-sub_815AFD8: @ 815AFD8
- push {lr}
- lsls r1, 24
- lsrs r1, 24
- cmp r1, 0x1
- beq _0815AFE8
- movs r0, 0x5
- bl PlaySE
-_0815AFE8:
- pop {r0}
- bx r0
- thumb_func_end sub_815AFD8
-
- thumb_func_start sub_815AFEC
-sub_815AFEC: @ 815AFEC
- push {lr}
- movs r0, 0x48
- movs r1, 0x3F
- bl SetGpuReg
- movs r0, 0x4A
- movs r1, 0x1F
- bl SetGpuReg
- movs r0, 0x50
- movs r1, 0xCC
- bl SetGpuReg
- movs r0, 0x54
- movs r1, 0x5
- bl SetGpuReg
- pop {r0}
- bx r0
- thumb_func_end sub_815AFEC
-
- thumb_func_start sub_815B014
-sub_815B014: @ 815B014
- push {lr}
- sub sp, 0x4
- ldr r1, _0815B054 @ =SpriteCallbackDummy
- movs r0, 0x8
- str r0, [sp]
- movs r0, 0x5A
- movs r2, 0
- movs r3, 0
- bl AddPseudoFieldObject
- lsls r0, 24
- lsrs r0, 24
- ldr r1, _0815B058 @ =gSprites
- lsls r2, r0, 4
- adds r2, r0
- lsls r2, 2
- adds r2, r1
- ldrb r3, [r2, 0x5]
- movs r1, 0xD
- negs r1, r1
- ands r1, r3
- movs r3, 0x8
- orrs r1, r3
- strb r1, [r2, 0x5]
- adds r2, 0x3E
- ldrb r1, [r2]
- movs r3, 0x4
- orrs r1, r3
- strb r1, [r2]
- add sp, 0x4
- pop {r1}
- bx r1
- .align 2, 0
-_0815B054: .4byte SpriteCallbackDummy
-_0815B058: .4byte gSprites
- thumb_func_end sub_815B014
-
- thumb_func_start sub_815B05C
-sub_815B05C: @ 815B05C
- push {r4,r5,lr}
- adds r4, r0, 0
- lsls r4, 24
- lsrs r4, 24
- lsls r3, 24
- lsrs r3, 24
- ldr r5, _0815B090 @ =gSprites
- lsls r0, r4, 4
- adds r0, r4
- lsls r0, 2
- adds r0, r5
- strh r1, [r0, 0x24]
- strh r2, [r0, 0x26]
- adds r4, r0, 0
- adds r4, 0x3E
- ldrb r2, [r4]
- movs r1, 0x5
- negs r1, r1
- ands r1, r2
- strb r1, [r4]
- adds r1, r3, 0
- bl StartSpriteAnim
- pop {r4,r5}
- pop {r0}
- bx r0
- .align 2, 0
-_0815B090: .4byte gSprites
- thumb_func_end sub_815B05C
-
- thumb_func_start sub_815B094
-sub_815B094: @ 815B094
- push {lr}
- ldr r1, _0815B0AC @ =0x00000c64
- movs r0, 0x44
- bl SetGpuReg
- ldr r1, _0815B0B0 @ =0x00001cd4
- movs r0, 0x40
- bl SetGpuReg
- pop {r0}
- bx r0
- .align 2, 0
-_0815B0AC: .4byte 0x00000c64
-_0815B0B0: .4byte 0x00001cd4
- thumb_func_end sub_815B094
-
- thumb_func_start sub_815B0B4
-sub_815B0B4: @ 815B0B4
- push {lr}
- movs r0, 0x44
- movs r1, 0
- bl SetGpuReg
- movs r0, 0x40
- movs r1, 0
- bl SetGpuReg
- pop {r0}
- bx r0
- thumb_func_end sub_815B0B4
-
- thumb_func_start sub_815B0CC
-sub_815B0CC: @ 815B0CC
- push {r4-r7,lr}
- movs r0, 0x2
- bl GetBgTilemapBuffer
- adds r7, r0, 0
- movs r0, 0x1
-_0815B0D8:
- movs r4, 0x2
- lsls r5, r0, 5
- adds r6, r0, 0x1
-_0815B0DE:
- bl Random
- adds r2, r5, r4
- lsls r2, 1
- adds r2, r7
- movs r1, 0x3
- ands r1, r0
- lsls r1, 10
- ldr r3, _0815B114 @ =0x0000301f
- adds r0, r3, 0
- adds r1, r0
- strh r1, [r2]
- adds r0, r4, 0x1
- lsls r0, 24
- lsrs r4, r0, 24
- cmp r4, 0x1B
- bls _0815B0DE
- lsls r0, r6, 24
- lsrs r0, 24
- cmp r0, 0xC
- bls _0815B0D8
- movs r0, 0x2
- bl schedule_bg_copy_tilemap_to_vram
- pop {r4-r7}
- pop {r0}
- bx r0
- .align 2, 0
-_0815B114: .4byte 0x0000301f
- thumb_func_end sub_815B0CC
-
- thumb_func_start sub_815B118
-sub_815B118: @ 815B118
- push {r4-r7,lr}
- sub sp, 0x4
- lsls r0, 24
- lsrs r6, r0, 24
- lsls r0, r6, 2
- adds r0, r6
- lsls r0, 3
- ldr r1, _0815B190 @ =gTasks+0x8
- adds r5, r0, r1
- movs r0, 0x2
- ldrsh r1, [r5, r0]
- lsls r0, r1, 4
- adds r0, r1
- lsls r0, 2
- ldr r1, _0815B194 @ =gSprites
- adds r7, r0, r1
- movs r0, 0x1
- bl ClearWindowTilemap
- bl sub_815B0B4
- ldr r0, _0815B198 @ =gTeachyTV_StaticResources
- ldrb r0, [r0, 0x5]
- cmp r0, 0
- blt _0815B1B8
- cmp r0, 0x3
- bgt _0815B1A8
- ldrb r0, [r5, 0x2]
- movs r1, 0x78
- movs r2, 0x38
- movs r3, 0
- bl sub_815B05C
- movs r4, 0xC0
- lsls r4, 6
- movs r0, 0x3
- adds r1, r4, 0
- movs r2, 0x1
- bl ChangeBgX
- movs r0, 0x3
- adds r1, r4, 0
- movs r2, 0x2
- bl ChangeBgY
- ldr r2, _0815B19C @ =gUnknown_203F450
- ldr r1, [r2]
- ldr r0, _0815B1A0 @ =0x00004004
- adds r1, r0
- ldrb r0, [r1]
- adds r0, 0x3
- strb r0, [r1]
- ldr r1, [r2]
- ldr r0, _0815B1A4 @ =0x00004005
- adds r1, r0
- ldrb r0, [r1]
- subs r0, 0x3
- strb r0, [r1]
- b _0815B1B8
- .align 2, 0
-_0815B190: .4byte gTasks+0x8
-_0815B194: .4byte gSprites
-_0815B198: .4byte gTeachyTV_StaticResources
-_0815B19C: .4byte gUnknown_203F450
-_0815B1A0: .4byte 0x00004004
-_0815B1A4: .4byte 0x00004005
-_0815B1A8:
- cmp r0, 0x5
- bgt _0815B1B8
- ldrb r0, [r5, 0x2]
- movs r1, 0x78
- movs r2, 0x38
- movs r3, 0
- bl sub_815B05C
-_0815B1B8:
- movs r0, 0
- strh r0, [r5, 0x8]
- strh r0, [r5, 0xA]
- movs r0, 0x24
- ldrsh r1, [r7, r0]
- movs r0, 0x26
- ldrsh r2, [r7, r0]
- movs r0, 0x1
- str r0, [sp]
- adds r0, r6, 0
- movs r3, 0
- bl sub_815BAA0
- add sp, 0x4
- pop {r4-r7}
- pop {r0}
- bx r0
- thumb_func_end sub_815B118
-
- thumb_func_start sub_815B1DC
-sub_815B1DC: @ 815B1DC
- push {r4,lr}
- sub sp, 0x10
- adds r4, r0, 0
- ldr r2, _0815B21C @ =gTextFlags
- ldrb r1, [r2]
- movs r0, 0x5
- negs r0, r0
- ands r0, r1
- strb r0, [r2]
- bl GetTextSpeedSetting
- adds r3, r0, 0
- lsls r3, 24
- lsrs r3, 24
- movs r0, 0
- str r0, [sp]
- movs r0, 0x1
- str r0, [sp, 0x4]
- movs r0, 0xC
- str r0, [sp, 0x8]
- movs r0, 0x3
- str r0, [sp, 0xC]
- movs r0, 0
- movs r1, 0x4
- adds r2, r4, 0
- bl AddTextPrinterParameterized2
- add sp, 0x10
- pop {r4}
- pop {r0}
- bx r0
- .align 2, 0
-_0815B21C: .4byte gTextFlags
- thumb_func_end sub_815B1DC
-
- thumb_func_start sub_815B220
-sub_815B220: @ 815B220
- push {r4,lr}
- ldr r4, _0815B238 @ =gUnknown_203F450
- ldr r0, [r4]
- bl Free
- movs r0, 0
- str r0, [r4]
- bl FreeAllWindowBuffers
- pop {r4}
- pop {r0}
- bx r0
- .align 2, 0
-_0815B238: .4byte gUnknown_203F450
- thumb_func_end sub_815B220
-
- thumb_func_start sub_815B23C
-sub_815B23C: @ 815B23C
- push {r4,lr}
- sub sp, 0x4
- adds r4, r0, 0
- lsls r4, 24
- lsrs r4, 24
- movs r0, 0x1
- negs r0, r0
- movs r1, 0
- str r1, [sp]
- movs r2, 0
- movs r3, 0x10
- bl BeginNormalPaletteFade
- ldr r1, _0815B26C @ =gTasks
- lsls r0, r4, 2
- adds r0, r4
- lsls r0, 3
- adds r0, r1
- ldr r1, _0815B270 @ =sub_815B274
- str r1, [r0]
- add sp, 0x4
- pop {r4}
- pop {r0}
- bx r0
- .align 2, 0
-_0815B26C: .4byte gTasks
-_0815B270: .4byte sub_815B274
- thumb_func_end sub_815B23C
-
- thumb_func_start sub_815B274
-sub_815B274: @ 815B274
- push {r4,lr}
- lsls r0, 24
- lsrs r4, r0, 24
- ldr r0, _0815B298 @ =gPaletteFade
- ldrb r1, [r0, 0x7]
- movs r0, 0x80
- ands r0, r1
- cmp r0, 0
- bne _0815B2B6
- ldr r0, _0815B29C @ =gUnknown_203F450
- ldr r0, [r0]
- ldr r0, [r0]
- cmp r0, 0
- beq _0815B2A0
- bl SetMainCallback2
- b _0815B2AC
- .align 2, 0
-_0815B298: .4byte gPaletteFade
-_0815B29C: .4byte gUnknown_203F450
-_0815B2A0:
- bl sub_8055DC4
- ldr r0, _0815B2BC @ =gTeachyTV_StaticResources
- ldr r0, [r0]
- bl SetMainCallback2
-_0815B2AC:
- bl sub_815B220
- adds r0, r4, 0
- bl DestroyTask
-_0815B2B6:
- pop {r4}
- pop {r0}
- bx r0
- .align 2, 0
-_0815B2BC: .4byte gTeachyTV_StaticResources
- thumb_func_end sub_815B274
-
- thumb_func_start sub_815B2C0
-sub_815B2C0: @ 815B2C0
- push {r4-r7,lr}
- lsls r0, 24
- lsrs r7, r0, 24
- lsls r0, r7, 2
- adds r0, r7
- lsls r0, 3
- ldr r1, _0815B31C @ =gTasks+0x8
- adds r6, r0, r1
- bl sub_815B0CC
- ldr r0, _0815B320 @ =gPaletteFade
- ldrb r1, [r0, 0x7]
- movs r0, 0x80
- ands r0, r1
- cmp r0, 0
- bne _0815B37A
- ldrb r0, [r6]
- bl ListMenuHandleInput
- adds r5, r0, 0
- ldrb r0, [r6]
- ldr r4, _0815B324 @ =gUnknown_203F44A
- adds r2, r4, 0x2
- adds r1, r4, 0
- bl get_coro_args_x18_x1A
- ldr r0, _0815B328 @ =gMain
- ldrh r1, [r0, 0x2E]
- movs r0, 0x4
- ands r0, r1
- cmp r0, 0
- beq _0815B30A
- subs r0, r4, 0x6
- ldr r1, [r0]
- ldr r0, _0815B32C @ =UseFameCheckerFromMenu
- cmp r1, r0
- bne _0815B330
-_0815B30A:
- movs r0, 0x2
- negs r0, r0
- cmp r5, r0
- beq _0815B330
- adds r0, 0x1
- cmp r5, r0
- bne _0815B33E
- b _0815B37A
- .align 2, 0
-_0815B31C: .4byte gTasks+0x8
-_0815B320: .4byte gPaletteFade
-_0815B324: .4byte gUnknown_203F44A
-_0815B328: .4byte gMain
-_0815B32C: .4byte UseFameCheckerFromMenu
-_0815B330:
- movs r0, 0x5
- bl PlaySE
- adds r0, r7, 0
- bl sub_815B23C
- b _0815B37A
-_0815B33E:
- movs r0, 0x5
- bl PlaySE
- ldr r2, _0815B380 @ =gTeachyTV_StaticResources
- movs r4, 0
- strb r5, [r2, 0x5]
- ldrb r0, [r6]
- adds r1, r2, 0x6
- adds r2, 0x8
- bl DestroyListMenu
- bl sub_815B0B4
- movs r0, 0x1
- bl ClearWindowTilemap
- movs r0, 0
- bl schedule_bg_copy_tilemap_to_vram
- bl sub_815AFAC
- strh r4, [r6, 0x6]
- strh r4, [r6, 0x4]
- ldr r1, _0815B384 @ =gTasks
- lsls r0, r7, 2
- adds r0, r7
- lsls r0, 3
- adds r0, r1
- ldr r1, _0815B388 @ =sub_815B4EC
- str r1, [r0]
-_0815B37A:
- pop {r4-r7}
- pop {r0}
- bx r0
- .align 2, 0
-_0815B380: .4byte gTeachyTV_StaticResources
-_0815B384: .4byte gTasks
-_0815B388: .4byte sub_815B4EC
- thumb_func_end sub_815B2C0
-
- thumb_func_start sub_815B38C
-sub_815B38C: @ 815B38C
- push {r4,lr}
- sub sp, 0xC
- lsls r0, 24
- lsrs r0, 24
- lsls r1, r0, 2
- adds r1, r0
- lsls r1, 3
- ldr r0, _0815B3F8 @ =gTasks+0x8
- adds r4, r1, r0
- bl sub_815B0CC
- ldrh r0, [r4, 0x4]
- adds r0, 0x1
- strh r0, [r4, 0x4]
- lsls r0, 16
- asrs r0, 16
- cmp r0, 0x3F
- ble _0815B3F0
- ldr r0, _0815B3FC @ =gUnknown_203F450
- ldr r1, [r0]
- ldr r0, _0815B400 @ =0x00003004
- adds r1, r0
- movs r0, 0x20
- str r0, [sp]
- str r0, [sp, 0x4]
- movs r0, 0x11
- str r0, [sp, 0x8]
- movs r0, 0x2
- movs r2, 0
- movs r3, 0
- bl CopyToBgTilemapBufferRect_ChangePalette
- ldrb r0, [r4, 0x2]
- movs r1, 0x8
- movs r2, 0x38
- movs r3, 0x7
- bl sub_815B05C
- movs r0, 0x2
- bl schedule_bg_copy_tilemap_to_vram
- movs r0, 0
- strh r0, [r4, 0x4]
- ldrh r0, [r4, 0x6]
- adds r0, 0x1
- strh r0, [r4, 0x6]
- movs r0, 0x88
- lsls r0, 1
- bl PlayNewMapMusic
-_0815B3F0:
- add sp, 0xC
- pop {r4}
- pop {r0}
- bx r0
- .align 2, 0
-_0815B3F8: .4byte gTasks+0x8
-_0815B3FC: .4byte gUnknown_203F450
-_0815B400: .4byte 0x00003004
- thumb_func_end sub_815B38C
-
- thumb_func_start sub_815B404
-sub_815B404: @ 815B404
- push {r4,lr}
- sub sp, 0x8
- lsls r0, 24
- lsrs r0, 24
- lsls r1, r0, 2
- adds r1, r0
- lsls r1, 3
- ldr r0, _0815B450 @ =gTasks+0x8
- adds r4, r1, r0
- ldrh r0, [r4, 0x4]
- adds r0, 0x1
- strh r0, [r4, 0x4]
- lsls r0, 16
- asrs r0, 16
- cmp r0, 0x86
- bne _0815B448
- movs r0, 0x1A
- str r0, [sp]
- movs r0, 0xC
- str r0, [sp, 0x4]
- movs r0, 0x2
- movs r1, 0
- movs r2, 0x2
- movs r3, 0x1
- bl FillBgTilemapBufferRect_Palette0
- movs r0, 0x2
- bl schedule_bg_copy_tilemap_to_vram
- movs r0, 0
- strh r0, [r4, 0x4]
- ldrh r0, [r4, 0x6]
- adds r0, 0x1
- strh r0, [r4, 0x6]
-_0815B448:
- add sp, 0x8
- pop {r4}
- pop {r0}
- bx r0
- .align 2, 0
-_0815B450: .4byte gTasks+0x8
- thumb_func_end sub_815B404
-
- thumb_func_start sub_815B454
-sub_815B454: @ 815B454
- push {r4,lr}
- lsls r0, 24
- lsrs r0, 24
- lsls r1, r0, 2
- adds r1, r0
- lsls r1, 3
- ldr r0, _0815B484 @ =gTasks+0x8
- adds r4, r1, r0
- movs r0, 0x2
- ldrsh r1, [r4, r0]
- lsls r0, r1, 4
- adds r0, r1
- lsls r0, 2
- ldr r1, _0815B488 @ =gSprites
- adds r1, r0, r1
- ldrh r2, [r4, 0x4]
- movs r3, 0x4
- ldrsh r0, [r4, r3]
- cmp r0, 0x23
- beq _0815B48C
- adds r0, r2, 0x1
- strh r0, [r4, 0x4]
- b _0815B4B8
- .align 2, 0
-_0815B484: .4byte gTasks+0x8
-_0815B488: .4byte gSprites
-_0815B48C:
- ldrh r2, [r1, 0x24]
- movs r3, 0x24
- ldrsh r0, [r1, r3]
- cmp r0, 0x78
- bne _0815B4B4
- adds r0, r1, 0
- movs r1, 0
- bl StartSpriteAnim
- ldr r0, _0815B4B0 @ =gUnknown_841B83D
- bl sub_815B1DC
- movs r0, 0
- strh r0, [r4, 0x4]
- ldrh r0, [r4, 0x6]
- adds r0, 0x1
- strh r0, [r4, 0x6]
- b _0815B4B8
- .align 2, 0
-_0815B4B0: .4byte gUnknown_841B83D
-_0815B4B4:
- adds r0, r2, 0x1
- strh r0, [r1, 0x24]
-_0815B4B8:
- pop {r4}
- pop {r0}
- bx r0
- thumb_func_end sub_815B454
-
- thumb_func_start sub_815B4C0
-sub_815B4C0: @ 815B4C0
- push {r4,lr}
- lsls r0, 24
- lsrs r0, 24
- lsls r1, r0, 2
- adds r1, r0
- lsls r1, 3
- ldr r0, _0815B4E8 @ =gTasks+0x8
- adds r4, r1, r0
- movs r0, 0
- bl sub_80BF518
- lsls r0, 16
- cmp r0, 0
- bne _0815B4E2
- ldrh r0, [r4, 0x6]
- adds r0, 0x1
- strh r0, [r4, 0x6]
-_0815B4E2:
- pop {r4}
- pop {r0}
- bx r0
- .align 2, 0
-_0815B4E8: .4byte gTasks+0x8
- thumb_func_end sub_815B4C0
-
- thumb_func_start sub_815B4EC
-sub_815B4EC: @ 815B4EC
- push {r4-r7,lr}
- lsls r0, 24
- lsrs r2, r0, 24
- lsls r0, r2, 2
- adds r0, r2
- lsls r6, r0, 3
- ldr r7, _0815B548 @ =gTasks+0x8
- adds r5, r6, r7
- ldr r0, _0815B54C @ =gMain
- ldrh r1, [r0, 0x2E]
- movs r0, 0x2
- ands r0, r1
- cmp r0, 0
- beq _0815B55C
- ldr r0, _0815B550 @ =gUnknown_203F450
- ldr r0, [r0]
- ldr r1, _0815B554 @ =0x00004006
- adds r0, r1
- movs r4, 0
- movs r1, 0x1
- strb r1, [r0]
- ldrb r0, [r5, 0x2]
- movs r1, 0
- movs r2, 0
- movs r3, 0
- bl sub_815B05C
- movs r0, 0
- movs r1, 0xCC
- bl FillWindowPixelBuffer
- movs r0, 0
- movs r1, 0x2
- bl CopyWindowToVram
- bl sub_815B908
- strh r4, [r5, 0x4]
- strh r4, [r5, 0x6]
- adds r0, r7, 0
- subs r0, 0x8
- adds r0, r6, r0
- ldr r1, _0815B558 @ =sub_815B92C
- str r1, [r0]
- b _0815B578
- .align 2, 0
-_0815B548: .4byte gTasks+0x8
-_0815B54C: .4byte gMain
-_0815B550: .4byte gUnknown_203F450
-_0815B554: .4byte 0x00004006
-_0815B558: .4byte sub_815B92C
-_0815B55C:
- ldr r1, _0815B580 @ =gUnknown_8479548
- ldr r0, _0815B584 @ =gTeachyTV_StaticResources
- ldrb r0, [r0, 0x5]
- lsls r0, 2
- adds r0, r1
- ldr r1, [r0]
- movs r3, 0x6
- ldrsh r0, [r5, r3]
- lsls r0, 2
- adds r0, r1
- ldr r1, [r0]
- adds r0, r2, 0
- bl _call_via_r1
-_0815B578:
- pop {r4-r7}
- pop {r0}
- bx r0
- .align 2, 0
-_0815B580: .4byte gUnknown_8479548
-_0815B584: .4byte gTeachyTV_StaticResources
- thumb_func_end sub_815B4EC
-
- thumb_func_start sub_815B588
-sub_815B588: @ 815B588
- push {r4,lr}
- lsls r0, 24
- lsrs r0, 24
- lsls r4, r0, 2
- adds r4, r0
- lsls r4, 3
- ldr r0, _0815B5B4 @ =gTasks+0x8
- adds r4, r0
- ldr r1, _0815B5B8 @ =gUnknown_8479560
- ldr r0, _0815B5BC @ =gTeachyTV_StaticResources
- ldrb r0, [r0, 0x5]
- lsls r0, 2
- adds r0, r1
- ldr r0, [r0]
- bl sub_815B1DC
- ldrh r0, [r4, 0x6]
- adds r0, 0x1
- strh r0, [r4, 0x6]
- pop {r4}
- pop {r0}
- bx r0
- .align 2, 0
-_0815B5B4: .4byte gTasks+0x8
-_0815B5B8: .4byte gUnknown_8479560
-_0815B5BC: .4byte gTeachyTV_StaticResources
- thumb_func_end sub_815B588
-
- thumb_func_start sub_815B5C0
-sub_815B5C0: @ 815B5C0
- push {r4,lr}
- lsls r0, 24
- lsrs r0, 24
- lsls r4, r0, 2
- adds r4, r0
- lsls r4, 3
- ldr r0, _0815B5EC @ =gTasks+0x8
- adds r4, r0
- ldr r1, _0815B5F0 @ =gUnknown_8479578
- ldr r0, _0815B5F4 @ =gTeachyTV_StaticResources
- ldrb r0, [r0, 0x5]
- lsls r0, 2
- adds r0, r1
- ldr r0, [r0]
- bl sub_815B1DC
- ldrh r0, [r4, 0x6]
- adds r0, 0x1
- strh r0, [r4, 0x6]
- pop {r4}
- pop {r0}
- bx r0
- .align 2, 0
-_0815B5EC: .4byte gTasks+0x8
-_0815B5F0: .4byte gUnknown_8479578
-_0815B5F4: .4byte gTeachyTV_StaticResources
- thumb_func_end sub_815B5C0
-
- thumb_func_start sub_815B5F8
-sub_815B5F8: @ 815B5F8
- push {r4,lr}
- lsls r0, 24
- lsrs r0, 24
- lsls r1, r0, 2
- adds r1, r0
- lsls r1, 3
- ldr r0, _0815B620 @ =gTasks+0x8
- adds r4, r1, r0
- movs r0, 0
- bl sub_80BF518
- lsls r0, 16
- cmp r0, 0
- bne _0815B61A
- ldrh r0, [r4, 0x6]
- adds r0, 0x1
- strh r0, [r4, 0x6]
-_0815B61A:
- pop {r4}
- pop {r0}
- bx r0
- .align 2, 0
-_0815B620: .4byte gTasks+0x8
- thumb_func_end sub_815B5F8
-
- thumb_func_start sub_815B624
-sub_815B624: @ 815B624
- push {r4,lr}
- lsls r0, 24
- lsrs r0, 24
- lsls r1, r0, 2
- adds r1, r0
- lsls r1, 3
- ldr r0, _0815B65C @ =gTasks+0x8
- adds r4, r1, r0
- ldr r0, _0815B660 @ =gMain
- ldrh r1, [r0, 0x2E]
- movs r0, 0x3
- ands r0, r1
- cmp r0, 0
- beq _0815B656
- movs r0, 0
- movs r1, 0xCC
- bl FillWindowPixelBuffer
- movs r0, 0
- movs r1, 0x2
- bl CopyWindowToVram
- ldrh r0, [r4, 0x6]
- adds r0, 0x1
- strh r0, [r4, 0x6]
-_0815B656:
- pop {r4}
- pop {r0}
- bx r0
- .align 2, 0
-_0815B65C: .4byte gTasks+0x8
-_0815B660: .4byte gMain
- thumb_func_end sub_815B624
-
- thumb_func_start sub_815B664
-sub_815B664: @ 815B664
- push {r4,lr}
- lsls r0, 24
- lsrs r0, 24
- lsls r4, r0, 2
- adds r4, r0
- lsls r4, 3
- ldr r0, _0815B6A0 @ =gTasks+0x8
- adds r4, r0
- movs r0, 0x2
- ldrsh r1, [r4, r0]
- lsls r0, r1, 4
- adds r0, r1
- lsls r0, 2
- ldr r1, _0815B6A4 @ =gSprites
- adds r0, r1
- movs r1, 0x5
- bl StartSpriteAnim
- movs r0, 0
- strh r0, [r4, 0x4]
- strh r0, [r4, 0x8]
- movs r0, 0x1
- strh r0, [r4, 0xA]
- ldrh r0, [r4, 0x6]
- adds r0, 0x1
- strh r0, [r4, 0x6]
- pop {r4}
- pop {r0}
- bx r0
- .align 2, 0
-_0815B6A0: .4byte gTasks+0x8
-_0815B6A4: .4byte gSprites
- thumb_func_end sub_815B664
-
- thumb_func_start sub_815B6A8
-sub_815B6A8: @ 815B6A8
- push {r4-r6,lr}
- sub sp, 0x4
- lsls r0, 24
- lsrs r5, r0, 24
- lsls r0, r5, 2
- adds r0, r5
- lsls r0, 3
- ldr r1, _0815B730 @ =gTasks+0x8
- adds r4, r0, r1
- movs r0, 0x2
- ldrsh r1, [r4, r0]
- lsls r0, r1, 4
- adds r0, r1
- lsls r0, 2
- ldr r1, _0815B734 @ =gSprites
- adds r6, r0, r1
- movs r1, 0x80
- lsls r1, 1
- movs r0, 0x3
- movs r2, 0x2
- bl ChangeBgY
- ldrh r0, [r4, 0x4]
- adds r0, 0x1
- strh r0, [r4, 0x4]
- movs r3, 0xF
- ands r3, r0
- cmp r3, 0
- bne _0815B702
- ldr r0, _0815B738 @ =gUnknown_203F450
- ldr r1, [r0]
- ldr r2, _0815B73C @ =0x00004005
- adds r1, r2
- ldrb r0, [r1]
- subs r0, 0x1
- strb r0, [r1]
- movs r0, 0x24
- ldrsh r1, [r6, r0]
- movs r0, 0x26
- ldrsh r2, [r6, r0]
- str r3, [sp]
- adds r0, r5, 0
- movs r3, 0
- bl sub_815BAA0
-_0815B702:
- movs r1, 0x4
- ldrsh r0, [r4, r1]
- cmp r0, 0x30
- bne _0815B726
- movs r1, 0
- strh r1, [r4, 0x4]
- movs r2, 0x1
- negs r2, r2
- adds r0, r2, 0
- strh r0, [r4, 0x8]
- strh r1, [r4, 0xA]
- adds r0, r6, 0
- movs r1, 0x7
- bl StartSpriteAnim
- ldrh r0, [r4, 0x6]
- adds r0, 0x1
- strh r0, [r4, 0x6]
-_0815B726:
- add sp, 0x4
- pop {r4-r6}
- pop {r0}
- bx r0
- .align 2, 0
-_0815B730: .4byte gTasks+0x8
-_0815B734: .4byte gSprites
-_0815B738: .4byte gUnknown_203F450
-_0815B73C: .4byte 0x00004005
- thumb_func_end sub_815B6A8
-
- thumb_func_start sub_815B740
-sub_815B740: @ 815B740
- push {r4-r6,lr}
- sub sp, 0x4
- lsls r0, 24
- lsrs r0, 24
- adds r5, r0, 0
- lsls r0, r5, 2
- adds r0, r5
- lsls r0, 3
- ldr r1, _0815B7D4 @ =gTasks+0x8
- adds r4, r0, r1
- movs r0, 0x2
- ldrsh r1, [r4, r0]
- lsls r0, r1, 4
- adds r0, r1
- lsls r0, 2
- ldr r1, _0815B7D8 @ =gSprites
- adds r6, r0, r1
- movs r1, 0x80
- lsls r1, 1
- movs r0, 0x3
- movs r2, 0x1
- bl ChangeBgX
- ldrh r0, [r4, 0x4]
- adds r0, 0x1
- strh r0, [r4, 0x4]
- movs r2, 0xF
- ands r0, r2
- cmp r0, 0
- bne _0815B78A
- ldr r0, _0815B7DC @ =gUnknown_203F450
- ldr r1, [r0]
- ldr r3, _0815B7E0 @ =0x00004004
- adds r1, r3
- ldrb r0, [r1]
- adds r0, 0x1
- strb r0, [r1]
-_0815B78A:
- movs r1, 0x4
- ldrsh r0, [r4, r1]
- adds r0, 0x8
- ands r0, r2
- cmp r0, 0
- bne _0815B7AC
- ldrh r1, [r6, 0x24]
- adds r1, 0x8
- lsls r1, 16
- asrs r1, 16
- movs r3, 0x26
- ldrsh r2, [r6, r3]
- str r0, [sp]
- adds r0, r5, 0
- movs r3, 0
- bl sub_815BAA0
-_0815B7AC:
- movs r1, 0x4
- ldrsh r0, [r4, r1]
- cmp r0, 0x30
- bne _0815B7CA
- movs r0, 0
- strh r0, [r4, 0x4]
- strh r0, [r4, 0x8]
- strh r0, [r4, 0xA]
- adds r0, r6, 0
- movs r1, 0x3
- bl StartSpriteAnim
- ldrh r0, [r4, 0x6]
- adds r0, 0x1
- strh r0, [r4, 0x6]
-_0815B7CA:
- add sp, 0x4
- pop {r4-r6}
- pop {r0}
- bx r0
- .align 2, 0
-_0815B7D4: .4byte gTasks+0x8
-_0815B7D8: .4byte gSprites
-_0815B7DC: .4byte gUnknown_203F450
-_0815B7E0: .4byte 0x00004004
- thumb_func_end sub_815B740
-
- thumb_func_start sub_815B7E4
-sub_815B7E4: @ 815B7E4
- push {r4-r6,lr}
- sub sp, 0x4
- adds r6, r0, 0
- lsls r6, 24
- lsrs r6, 24
- lsls r5, r6, 2
- adds r5, r6
- lsls r5, 3
- ldr r0, _0815B838 @ =gTasks+0x8
- adds r5, r0
- movs r1, 0x2
- ldrsh r0, [r5, r1]
- lsls r4, r0, 4
- adds r4, r0
- lsls r4, 2
- ldr r0, _0815B83C @ =gSprites
- adds r4, r0
- adds r0, r4, 0
- movs r1, 0x6
- bl StartSpriteAnim
- ldrh r0, [r5, 0x6]
- adds r0, 0x1
- strh r0, [r5, 0x6]
- movs r0, 0
- strh r0, [r5, 0x8]
- strh r0, [r5, 0xA]
- movs r0, 0x24
- ldrsh r1, [r4, r0]
- movs r0, 0x26
- ldrsh r2, [r4, r0]
- movs r0, 0
- str r0, [sp]
- adds r0, r6, 0
- movs r3, 0
- bl sub_815BAA0
- add sp, 0x4
- pop {r4-r6}
- pop {r0}
- bx r0
- .align 2, 0
-_0815B838: .4byte gTasks+0x8
-_0815B83C: .4byte gSprites
- thumb_func_end sub_815B7E4
-
- thumb_func_start sub_815B840
-sub_815B840: @ 815B840
- push {r4-r6,lr}
- sub sp, 0x4
- lsls r0, 24
- lsrs r3, r0, 24
- lsls r0, r3, 2
- adds r0, r3
- lsls r0, 3
- ldr r1, _0815B890 @ =gTasks+0x8
- adds r5, r0, r1
- movs r0, 0x2
- ldrsh r1, [r5, r0]
- lsls r0, r1, 4
- adds r0, r1
- lsls r0, 2
- ldr r1, _0815B894 @ =gSprites
- adds r4, r0, r1
- ldrh r1, [r4, 0x24]
- movs r0, 0xF
- ands r0, r1
- cmp r0, 0
- bne _0815B87E
- subs r1, 0x8
- lsls r1, 16
- asrs r1, 16
- movs r6, 0x26
- ldrsh r2, [r4, r6]
- str r0, [sp]
- adds r0, r3, 0
- movs r3, 0
- bl sub_815BAA0
-_0815B87E:
- ldrh r1, [r4, 0x24]
- movs r2, 0x24
- ldrsh r0, [r4, r2]
- cmp r0, 0x8
- bne _0815B898
- ldrh r0, [r5, 0x6]
- adds r0, 0x1
- strh r0, [r5, 0x6]
- b _0815B89C
- .align 2, 0
-_0815B890: .4byte gTasks+0x8
-_0815B894: .4byte gSprites
-_0815B898:
- subs r0, r1, 0x1
- strh r0, [r4, 0x24]
-_0815B89C:
- add sp, 0x4
- pop {r4-r6}
- pop {r0}
- bx r0
- thumb_func_end sub_815B840
-
- thumb_func_start sub_815B8A4
-sub_815B8A4: @ 815B8A4
- push {r4,lr}
- sub sp, 0xC
- lsls r0, 24
- lsrs r0, 24
- lsls r1, r0, 2
- adds r1, r0
- lsls r1, 3
- ldr r0, _0815B900 @ =gTasks+0x8
- adds r4, r1, r0
- movs r1, 0x4
- ldrsh r0, [r4, r1]
- cmp r0, 0
- bne _0815B8DC
- ldr r1, _0815B904 @ =gUnknown_8479590
- movs r0, 0x8
- str r0, [sp]
- movs r0, 0x2
- str r0, [sp, 0x4]
- movs r0, 0x11
- str r0, [sp, 0x8]
- movs r0, 0x1
- movs r2, 0x14
- movs r3, 0xA
- bl CopyToBgTilemapBufferRect_ChangePalette
- movs r0, 0x1
- bl schedule_bg_copy_tilemap_to_vram
-_0815B8DC:
- ldrh r0, [r4, 0x4]
- adds r0, 0x1
- strh r0, [r4, 0x4]
- lsls r0, 16
- asrs r0, 16
- cmp r0, 0x7E
- ble _0815B8F8
- bl sub_815B908
- movs r0, 0
- strh r0, [r4, 0x4]
- ldrh r0, [r4, 0x6]
- adds r0, 0x1
- strh r0, [r4, 0x6]
-_0815B8F8:
- add sp, 0xC
- pop {r4}
- pop {r0}
- bx r0
- .align 2, 0
-_0815B900: .4byte gTasks+0x8
-_0815B904: .4byte gUnknown_8479590
- thumb_func_end sub_815B8A4
-
- thumb_func_start sub_815B908
-sub_815B908: @ 815B908
- push {lr}
- sub sp, 0x8
- movs r0, 0x8
- str r0, [sp]
- movs r0, 0x2
- str r0, [sp, 0x4]
- movs r0, 0x1
- movs r1, 0
- movs r2, 0x14
- movs r3, 0xA
- bl FillBgTilemapBufferRect_Palette0
- movs r0, 0x1
- bl schedule_bg_copy_tilemap_to_vram
- add sp, 0x8
- pop {r0}
- bx r0
- thumb_func_end sub_815B908
-
- thumb_func_start sub_815B92C
-sub_815B92C: @ 815B92C
- push {r4-r7,lr}
- lsls r0, 24
- lsrs r0, 24
- lsls r1, r0, 2
- adds r1, r0
- lsls r6, r1, 3
- ldr r7, _0815B9DC @ =gTasks+0x8
- adds r5, r6, r7
- movs r1, 0x4
- ldrsh r0, [r5, r1]
- cmp r0, 0
- bne _0815B94C
- movs r0, 0xAD
- lsls r0, 1
- bl PlayNewMapMusic
-_0815B94C:
- bl sub_815B0CC
- ldrh r0, [r5, 0x4]
- adds r0, 0x1
- strh r0, [r5, 0x4]
- lsls r0, 16
- asrs r0, 16
- cmp r0, 0x3F
- ble _0815B9D4
- movs r4, 0
- strh r4, [r5, 0x4]
- strh r4, [r5, 0x6]
- bl sub_815AEE8
- lsls r0, 24
- lsrs r0, 24
- strh r0, [r5]
- adds r0, r7, 0
- subs r0, 0x8
- adds r0, r6, r0
- ldr r1, _0815B9E0 @ =sub_815B2C0
- str r1, [r0]
- movs r0, 0
- bl PutWindowTilemap
- bl sub_815AF5C
- bl sub_815B094
- movs r0, 0
- bl schedule_bg_copy_tilemap_to_vram
- movs r0, 0x3
- movs r1, 0
- movs r2, 0
- bl ChangeBgX
- movs r0, 0x3
- movs r1, 0
- movs r2, 0
- bl ChangeBgY
- movs r1, 0x80
- lsls r1, 5
- movs r0, 0x3
- movs r2, 0x2
- bl ChangeBgX
- movs r1, 0xA0
- lsls r1, 6
- movs r0, 0x3
- movs r2, 0x1
- bl ChangeBgY
- ldr r2, _0815B9E4 @ =gUnknown_203F450
- ldr r0, [r2]
- ldr r1, _0815B9E8 @ =0x00004004
- adds r0, r1
- strb r4, [r0]
- ldr r0, [r2]
- adds r1, 0x1
- adds r0, r1
- movs r1, 0x3
- strb r1, [r0]
- ldr r0, [r2]
- ldr r1, _0815B9EC @ =0x00004006
- adds r0, r1
- strb r4, [r0]
-_0815B9D4:
- pop {r4-r7}
- pop {r0}
- bx r0
- .align 2, 0
-_0815B9DC: .4byte gTasks+0x8
-_0815B9E0: .4byte sub_815B2C0
-_0815B9E4: .4byte gUnknown_203F450
-_0815B9E8: .4byte 0x00004004
-_0815B9EC: .4byte 0x00004006
- thumb_func_end sub_815B92C
-
- thumb_func_start sub_815B9F0
-sub_815B9F0: @ 815B9F0
- push {lr}
- lsls r0, 24
- lsrs r1, r0, 24
- adds r2, r1, 0
- ldr r0, _0815BA0C @ =gTeachyTV_StaticResources
- ldrb r0, [r0, 0x5]
- cmp r0, 0
- blt _0815BA22
- cmp r0, 0x3
- bgt _0815BA10
- adds r0, r1, 0
- bl sub_815BC90
- b _0815BA22
- .align 2, 0
-_0815BA0C: .4byte gTeachyTV_StaticResources
-_0815BA10:
- cmp r0, 0x5
- bgt _0815BA22
- ldr r0, _0815BA28 @ =gUnknown_203F450
- ldr r1, [r0]
- ldr r0, _0815BA2C @ =sub_815BA30
- str r0, [r1]
- adds r0, r2, 0
- bl sub_815B23C
-_0815BA22:
- pop {r0}
- bx r0
- .align 2, 0
-_0815BA28: .4byte gUnknown_203F450
-_0815BA2C: .4byte sub_815BA30
- thumb_func_end sub_815B9F0
-
- thumb_func_start sub_815BA30
-sub_815BA30: @ 815BA30
- push {lr}
- ldr r0, _0815BA44 @ =gTeachyTV_StaticResources
- ldrb r0, [r0, 0x5]
- cmp r0, 0x4
- bne _0815BA48
- movs r0, 0xA
- bl sub_810B108
- b _0815BA4E
- .align 2, 0
-_0815BA44: .4byte gTeachyTV_StaticResources
-_0815BA48:
- movs r0, 0x9
- bl sub_810B108
-_0815BA4E:
- pop {r0}
- bx r0
- thumb_func_end sub_815BA30
-
- thumb_func_start sub_815BA54
-sub_815BA54: @ 815BA54
- push {r4,lr}
- lsls r0, 24
- lsrs r0, 24
- lsls r1, r0, 2
- adds r1, r0
- lsls r2, r1, 3
- ldr r4, _0815BA8C @ =gTasks+0x8
- adds r3, r2, r4
- ldr r0, _0815BA90 @ =gPaletteFade
- ldrb r1, [r0, 0x7]
- movs r0, 0x80
- ands r0, r1
- cmp r0, 0
- bne _0815BA86
- ldr r1, _0815BA94 @ =gUnknown_8479390
- ldr r0, _0815BA98 @ =gTeachyTV_StaticResources
- ldrb r0, [r0, 0x5]
- adds r0, r1
- ldrb r0, [r0]
- strh r0, [r3, 0x6]
- adds r0, r4, 0
- subs r0, 0x8
- adds r0, r2, r0
- ldr r1, _0815BA9C @ =sub_815B4EC
- str r1, [r0]
-_0815BA86:
- pop {r4}
- pop {r0}
- bx r0
- .align 2, 0
-_0815BA8C: .4byte gTasks+0x8
-_0815BA90: .4byte gPaletteFade
-_0815BA94: .4byte gUnknown_8479390
-_0815BA98: .4byte gTeachyTV_StaticResources
-_0815BA9C: .4byte sub_815B4EC
- thumb_func_end sub_815BA54
-
- thumb_func_start sub_815BAA0
-sub_815BAA0: @ 815BAA0
- push {r4-r7,lr}
- mov r7, r9
- mov r6, r8
- push {r6,r7}
- ldr r4, [sp, 0x1C]
- lsls r0, 24
- lsrs r0, 24
- mov r9, r0
- lsls r1, 16
- lsrs r6, r1, 16
- lsls r2, 16
- lsrs r1, r2, 16
- lsls r3, 24
- lsrs r7, r3, 24
- lsls r4, 24
- lsrs r4, 24
- mov r8, r4
- ldr r0, _0815BB34 @ =gUnknown_203F450
- ldr r0, [r0]
- ldr r2, _0815BB38 @ =0x00004006
- adds r0, r2
- ldrb r0, [r0]
- cmp r0, 0x1
- beq _0815BB5C
- lsls r0, r6, 16
- ldr r2, _0815BB3C @ =0xfff00000
- adds r0, r2
- asrs r0, 16
- lsls r1, 16
- asrs r5, r1, 16
- adds r1, r5, 0
- bl sub_815BC40
- lsls r0, 24
- cmp r0, 0
- beq _0815BB5C
- ldr r0, _0815BB40 @ =gUnknown_83A0010
- ldr r0, [r0, 0x10]
- movs r1, 0
- movs r2, 0
- adds r3, r7, 0
- bl CreateSprite
- lsls r0, 24
- lsrs r0, 24
- lsls r1, r0, 4
- adds r1, r0
- lsls r1, 2
- ldr r0, _0815BB44 @ =gSprites
- adds r4, r1, r0
- strh r6, [r4, 0x24]
- adds r0, r5, 0
- adds r0, 0x8
- strh r0, [r4, 0x26]
- ldr r0, _0815BB48 @ =sub_815BB6C
- str r0, [r4, 0x1C]
- mov r0, r9
- strh r0, [r4, 0x2E]
- mov r2, r8
- cmp r2, 0x1
- bne _0815BB4C
- adds r0, r4, 0
- movs r1, 0x4
- bl SeekSpriteAnim
- ldrb r0, [r4, 0x5]
- movs r1, 0xD
- negs r1, r1
- ands r1, r0
- movs r0, 0x8
- orrs r1, r0
- strb r1, [r4, 0x5]
- b _0815BB5C
- .align 2, 0
-_0815BB34: .4byte gUnknown_203F450
-_0815BB38: .4byte 0x00004006
-_0815BB3C: .4byte 0xfff00000
-_0815BB40: .4byte gUnknown_83A0010
-_0815BB44: .4byte gSprites
-_0815BB48: .4byte sub_815BB6C
-_0815BB4C:
- ldr r1, _0815BB68 @ =gUnknown_84795B8
- adds r0, r4, 0
- bl SetSubspriteTables
- adds r1, r4, 0
- adds r1, 0x42
- movs r0, 0x40
- strb r0, [r1]
-_0815BB5C:
- pop {r3,r4}
- mov r8, r3
- mov r9, r4
- pop {r4-r7}
- pop {r0}
- bx r0
- .align 2, 0
-_0815BB68: .4byte gUnknown_84795B8
- thumb_func_end sub_815BAA0
-
- thumb_func_start sub_815BB6C
-sub_815BB6C: @ 815BB6C
- push {r4,r5,lr}
- adds r3, r0, 0
- movs r0, 0x2E
- ldrsh r1, [r3, r0]
- lsls r0, r1, 2
- adds r0, r1
- lsls r0, 3
- ldr r1, _0815BBA4 @ =gTasks+0x8
- adds r4, r0, r1
- movs r2, 0x2
- ldrsh r1, [r4, r2]
- lsls r0, r1, 4
- adds r0, r1
- lsls r0, 2
- ldr r1, _0815BBA8 @ =gSprites
- adds r5, r0, r1
- ldr r0, _0815BBAC @ =gUnknown_203F450
- ldr r0, [r0]
- ldr r1, _0815BBB0 @ =0x00004006
- adds r0, r1
- ldrb r0, [r0]
- cmp r0, 0x1
- bne _0815BBB4
- adds r0, r3, 0
- bl DestroySprite
- b _0815BC3A
- .align 2, 0
-_0815BBA4: .4byte gTasks+0x8
-_0815BBA8: .4byte gSprites
-_0815BBAC: .4byte gUnknown_203F450
-_0815BBB0: .4byte 0x00004006
-_0815BBB4:
- adds r0, r3, 0
- adds r0, 0x2B
- ldrb r0, [r0]
- cmp r0, 0
- bne _0815BBD2
- adds r2, r3, 0
- adds r2, 0x42
- ldrb r0, [r2]
- movs r1, 0x40
- negs r1, r1
- ands r1, r0
- movs r0, 0x1
- orrs r1, r0
- strb r1, [r2]
- b _0815BBE0
-_0815BBD2:
- adds r2, r3, 0
- adds r2, 0x42
- ldrb r1, [r2]
- movs r0, 0x40
- negs r0, r0
- ands r0, r1
- strb r0, [r2]
-_0815BBE0:
- ldrh r0, [r4, 0x8]
- ldrh r2, [r3, 0x24]
- adds r0, r2
- strh r0, [r3, 0x24]
- ldrh r0, [r4, 0xA]
- ldrh r1, [r3, 0x26]
- adds r0, r1
- strh r0, [r3, 0x26]
- adds r0, r3, 0
- adds r0, 0x3F
- ldrb r1, [r0]
- movs r0, 0x10
- ands r0, r1
- cmp r0, 0
- beq _0815BC3A
- adds r1, r3, 0
- adds r1, 0x43
- movs r0, 0
- strb r0, [r1]
- ldrh r1, [r3, 0x24]
- ldrh r0, [r5, 0x24]
- subs r1, r0
- ldrh r0, [r3, 0x26]
- ldrh r2, [r5, 0x26]
- subs r0, r2
- lsls r0, 16
- lsrs r0, 16
- lsls r1, 16
- movs r2, 0xF0
- lsls r2, 12
- adds r1, r2
- lsrs r1, 16
- cmp r1, 0x1E
- bhi _0815BC34
- lsls r0, 16
- asrs r1, r0, 16
- movs r0, 0x10
- negs r0, r0
- cmp r1, r0
- ble _0815BC34
- cmp r1, 0x17
- ble _0815BC3A
-_0815BC34:
- adds r0, r3, 0
- bl DestroySprite
-_0815BC3A:
- pop {r4,r5}
- pop {r0}
- bx r0
- thumb_func_end sub_815BB6C
-
- thumb_func_start sub_815BC40
-sub_815BC40: @ 815BC40
- push {r4,r5,lr}
- lsls r1, 16
- lsrs r1, 16
- lsls r4, r0, 16
- cmp r4, 0
- blt _0815BC52
- lsls r1, 16
- cmp r1, 0
- bge _0815BC56
-_0815BC52:
- movs r0, 0
- b _0815BC78
-_0815BC56:
- ldr r3, _0815BC80 @ =gUnknown_84795C8
- ldr r0, _0815BC84 @ =gUnknown_203F450
- ldr r2, [r0]
- ldr r5, _0815BC88 @ =0x00004005
- adds r0, r2, r5
- asrs r1, 20
- ldrb r0, [r0]
- adds r1, r0
- lsls r1, 4
- ldr r0, _0815BC8C @ =0x00004004
- adds r2, r0
- asrs r0, r4, 20
- ldrb r2, [r2]
- adds r0, r2
- adds r1, r0
- adds r1, r3
- ldrb r0, [r1]
-_0815BC78:
- pop {r4,r5}
- pop {r1}
- bx r1
- .align 2, 0
-_0815BC80: .4byte gUnknown_84795C8
-_0815BC84: .4byte gUnknown_203F450
-_0815BC88: .4byte 0x00004005
-_0815BC8C: .4byte 0x00004004
- thumb_func_end sub_815BC40
-
- thumb_func_start sub_815BC90
-sub_815BC90: @ 815BC90
- push {r4-r6,lr}
- lsls r0, 24
- lsrs r6, r0, 24
- lsls r0, r6, 2
- adds r0, r6
- lsls r0, 3
- ldr r1, _0815BCCC @ =gTasks+0x8
- adds r5, r0, r1
- bl sub_815B220
- ldr r1, _0815BCD0 @ =gSpecialVar_0x8004
- ldr r4, _0815BCD4 @ =gTeachyTV_StaticResources
- ldrb r0, [r4, 0x5]
- strh r0, [r1]
- ldr r1, _0815BCD8 @ =gMain
- ldr r0, _0815BCDC @ =sub_815BD58
- str r0, [r1, 0x8]
- bl SavePlayerParty
- bl sub_8159F40
- movs r0, 0
- bl PlayMapChosenOrBattleBGM
- ldrb r0, [r4, 0x5]
- cmp r0, 0
- bne _0815BCE0
- movs r0, 0x9
- b _0815BCE2
- .align 2, 0
-_0815BCCC: .4byte gTasks+0x8
-_0815BCD0: .4byte gSpecialVar_0x8004
-_0815BCD4: .4byte gTeachyTV_StaticResources
-_0815BCD8: .4byte gMain
-_0815BCDC: .4byte sub_815BD58
-_0815BCE0:
- movs r0, 0x8
-_0815BCE2:
- strh r0, [r5, 0xC]
- movs r0, 0
- strh r0, [r5, 0xE]
- ldr r1, _0815BCFC @ =gTasks
- lsls r0, r6, 2
- adds r0, r6
- lsls r0, 3
- adds r0, r1
- ldr r1, _0815BD00 @ =sub_815BD04
- str r1, [r0]
- pop {r4-r6}
- pop {r0}
- bx r0
- .align 2, 0
-_0815BCFC: .4byte gTasks
-_0815BD00: .4byte sub_815BD04
- thumb_func_end sub_815BC90
-
- thumb_func_start sub_815BD04
-sub_815BD04: @ 815BD04
- push {r4,r5,lr}
- lsls r0, 24
- lsrs r5, r0, 24
- lsls r0, r5, 2
- adds r0, r5
- lsls r0, 3
- ldr r1, _0815BD24 @ =gTasks+0x8
- adds r4, r0, r1
- movs r1, 0xE
- ldrsh r0, [r4, r1]
- cmp r0, 0
- beq _0815BD28
- cmp r0, 0x1
- beq _0815BD36
- b _0815BD4C
- .align 2, 0
-_0815BD24: .4byte gTasks+0x8
-_0815BD28:
- ldrb r0, [r4, 0xC]
- bl sub_80D08B8
- ldrh r0, [r4, 0xE]
- adds r0, 0x1
- strh r0, [r4, 0xE]
- b _0815BD4C
-_0815BD36:
- bl sub_80D08F8
- lsls r0, 24
- cmp r0, 0
- beq _0815BD4C
- ldr r0, _0815BD54 @ =sub_800FD9C
- bl SetMainCallback2
- adds r0, r5, 0
- bl DestroyTask
-_0815BD4C:
- pop {r4,r5}
- pop {r0}
- bx r0
- .align 2, 0
-_0815BD54: .4byte sub_800FD9C
- thumb_func_end sub_815BD04
-
- thumb_func_start sub_815BD58
-sub_815BD58: @ 815BD58
- push {lr}
- bl LoadPlayerParty
- ldr r0, _0815BD6C @ =gUnknown_2023E8A
- ldrb r0, [r0]
- cmp r0, 0x3
- bne _0815BD70
- bl sub_815AC20
- b _0815BD78
- .align 2, 0
-_0815BD6C: .4byte gUnknown_2023E8A
-_0815BD70:
- movs r0, 0x88
- lsls r0, 1
- bl PlayNewMapMusic
-_0815BD78:
- bl CB2_ReturnToTeachyTV
- pop {r0}
- bx r0
- thumb_func_end sub_815BD58
-
- thumb_func_start sub_815BD80
-sub_815BD80: @ 815BD80
- push {r4-r7,lr}
- mov r7, r10
- mov r6, r9
- mov r5, r8
- push {r5-r7}
- sub sp, 0x1C
- str r0, [sp, 0x4]
- movs r0, 0
- str r0, [sp, 0x10]
- ldr r1, _0815BE1C @ =Route1_Layout
- mov r8, r1
- movs r0, 0x80
- lsls r0, 4
- bl AllocZeroed
- adds r6, r0, 0
- movs r0, 0x80
- lsls r0, 8
- bl AllocZeroed
- str r0, [sp, 0x8]
- movs r0, 0x10
- bl Alloc
- str r0, [sp, 0xC]
- movs r1, 0xFF
- movs r2, 0x10
- bl memset
- mov r2, r8
- ldr r0, [r2, 0x10]
- movs r2, 0xA0
- lsls r2, 2
- ldr r1, [sp, 0x8]
- bl sub_815BF48
- mov r3, r8
- ldr r0, [r3, 0x14]
- ldr r2, [sp, 0x8]
- movs r3, 0xA0
- lsls r3, 7
- adds r1, r2, r3
- movs r2, 0xC0
- lsls r2, 1
- bl sub_815BF48
- movs r4, 0
-_0815BDDE:
- movs r2, 0
- adds r0, r4, 0x6
- str r0, [sp, 0x18]
- lsls r1, r4, 4
- mov r10, r1
- lsls r3, r4, 6
- mov r9, r3
- adds r4, 0x1
- str r4, [sp, 0x14]
-_0815BDF0:
- mov r1, r8
- ldr r0, [r1]
- ldr r3, [sp, 0x18]
- muls r0, r3
- ldr r1, [r1, 0xC]
- adds r0, r2, r0
- lsls r0, 1
- adds r0, r1
- ldrh r1, [r0, 0x10]
- ldr r3, _0815BE20 @ =0x000003ff
- adds r0, r3, 0
- adds r4, r0, 0
- ands r4, r1
- movs r3, 0
- mov r0, r10
- adds r1, r0, r2
- lsls r5, r2, 1
- adds r7, r2, 0x1
- cmp r3, r1
- bge _0815BE3C
- ldrh r0, [r6]
- b _0815BE34
- .align 2, 0
-_0815BE1C: .4byte Route1_Layout
-_0815BE20: .4byte 0x000003ff
-_0815BE24:
- adds r0, r3, 0x1
- lsls r0, 16
- lsrs r3, r0, 16
- cmp r3, r1
- bge _0815BE3C
- lsls r0, r3, 1
- adds r0, r6
- ldrh r0, [r0]
-_0815BE34:
- cmp r0, 0
- beq _0815BE46
- cmp r0, r4
- bne _0815BE24
-_0815BE3C:
- lsls r0, r3, 1
- adds r0, r6
- ldrh r0, [r0]
- cmp r0, 0
- bne _0815BE56
-_0815BE46:
- lsls r0, r3, 1
- adds r0, r6
- strh r4, [r0]
- ldr r0, [sp, 0x10]
- adds r0, 0x1
- lsls r0, 16
- lsrs r0, 16
- str r0, [sp, 0x10]
-_0815BE56:
- mov r2, r9
- adds r1, r2, r5
- lsls r1, 1
- ldr r0, [sp, 0x4]
- adds r1, r0, r1
- str r3, [sp]
- mov r0, r8
- ldr r2, [sp, 0xC]
- adds r3, r4, 0
- bl sub_815BF70
- lsls r0, r7, 16
- lsrs r2, r0, 16
- cmp r2, 0xF
- bls _0815BDF0
- ldr r1, [sp, 0x14]
- lsls r0, r1, 16
- lsrs r4, r0, 16
- cmp r4, 0x8
- bls _0815BDDE
- ldr r2, [sp, 0x10]
- lsls r0, r2, 7
- bl Alloc
- adds r7, r0, 0
- movs r0, 0x80
- bl Alloc
- adds r5, r0, 0
- movs r4, 0
- ldr r3, [sp, 0x10]
- lsls r3, 23
- mov r9, r3
- ldr r0, [sp, 0x10]
- cmp r4, r0
- bcs _0815BF00
- ldr r1, _0815BECC @ =0x0000027f
- mov r10, r1
-_0815BEA2:
- adds r0, r5, 0
- movs r1, 0
- movs r2, 0x80
- bl memset
- lsls r0, r4, 1
- adds r1, r0, r6
- ldrh r0, [r1]
- cmp r0, r10
- bhi _0815BED0
- mov r2, r8
- ldr r0, [r2, 0x10]
- ldrh r1, [r1]
- lsls r1, 4
- ldr r0, [r0, 0xC]
- adds r0, r1
- adds r1, r5, 0
- ldr r2, [sp, 0x8]
- bl sub_815BFF0
- b _0815BEE8
- .align 2, 0
-_0815BECC: .4byte 0x0000027f
-_0815BED0:
- mov r3, r8
- ldr r0, [r3, 0x14]
- ldrh r1, [r1]
- ldr r2, _0815BF44 @ =0xfffffd80
- adds r1, r2
- lsls r1, 4
- ldr r0, [r0, 0xC]
- adds r0, r1
- adds r1, r5, 0
- ldr r2, [sp, 0x8]
- bl sub_815BFF0
-_0815BEE8:
- lsls r1, r4, 7
- adds r1, r7, r1
- adds r0, r5, 0
- movs r2, 0x20
- bl CpuFastSet
- adds r0, r4, 0x1
- lsls r0, 16
- lsrs r4, r0, 16
- ldr r3, [sp, 0x10]
- cmp r4, r3
- bcc _0815BEA2
-_0815BF00:
- mov r0, r9
- lsrs r2, r0, 16
- movs r0, 0x3
- adds r1, r7, 0
- movs r3, 0
- bl LoadBgTiles
- mov r0, r8
- ldr r1, [sp, 0xC]
- bl sub_815C230
- adds r0, r5, 0
- bl Free
- adds r0, r7, 0
- bl Free
- ldr r0, [sp, 0xC]
- bl Free
- ldr r0, [sp, 0x8]
- bl Free
- adds r0, r6, 0
- bl Free
- add sp, 0x1C
- pop {r3-r5}
- mov r8, r3
- mov r9, r4
- mov r10, r5
- pop {r4-r7}
- pop {r0}
- bx r0
- .align 2, 0
-_0815BF44: .4byte 0xfffffd80
- thumb_func_end sub_815BD80
-
- thumb_func_start sub_815BF48
-sub_815BF48: @ 815BF48
- push {lr}
- adds r3, r0, 0
- lsls r2, 16
- lsrs r2, 16
- cmp r3, 0
- beq _0815BF6A
- ldrb r0, [r3]
- cmp r0, 0
- bne _0815BF64
- ldr r0, [r3, 0x4]
- lsls r2, 3
- bl CpuFastSet
- b _0815BF6A
-_0815BF64:
- ldr r0, [r3, 0x4]
- bl LZDecompressWram
-_0815BF6A:
- pop {r0}
- bx r0
- thumb_func_end sub_815BF48
-
- thumb_func_start sub_815BF70
-sub_815BF70: @ 815BF70
- push {r4-r7,lr}
- adds r5, r0, 0
- adds r7, r1, 0
- adds r6, r2, 0
- ldr r0, [sp, 0x14]
- lsls r3, 16
- lsrs r1, r3, 16
- lsls r0, 16
- lsrs r4, r0, 16
- ldr r0, _0815BF8C @ =0x0000027f
- cmp r1, r0
- bhi _0815BF90
- ldr r0, [r5, 0x10]
- b _0815BF96
- .align 2, 0
-_0815BF8C: .4byte 0x0000027f
-_0815BF90:
- ldr r0, [r5, 0x14]
- ldr r2, _0815BFEC @ =0xfffffd80
- adds r1, r2
-_0815BF96:
- lsls r1, 4
- ldr r0, [r0, 0xC]
- adds r5, r0, r1
- ldrh r1, [r5]
- adds r0, r6, 0
- bl sub_815C1F0
- lsls r0, 12
- lsls r4, 2
- adds r0, r4
- strh r0, [r7]
- ldrh r1, [r5, 0x2]
- adds r0, r6, 0
- bl sub_815C1F0
- lsls r0, 12
- adds r0, r4
- adds r0, 0x1
- strh r0, [r7, 0x2]
- ldrh r1, [r5, 0x4]
- adds r0, r6, 0
- bl sub_815C1F0
- adds r1, r7, 0
- adds r1, 0x40
- lsls r0, 12
- adds r0, r4
- adds r0, 0x2
- strh r0, [r1]
- ldrh r1, [r5, 0x6]
- adds r0, r6, 0
- bl sub_815C1F0
- adds r1, r7, 0
- adds r1, 0x42
- lsls r0, 12
- adds r0, r4
- adds r0, 0x3
- strh r0, [r1]
- pop {r4-r7}
- pop {r0}
- bx r0
- .align 2, 0
-_0815BFEC: .4byte 0xfffffd80
- thumb_func_end sub_815BF70
-
- thumb_func_start sub_815BFF0
-sub_815BFF0: @ 815BFF0
- push {r4-r6,lr}
- mov r6, r10
- mov r5, r9
- mov r4, r8
- push {r4-r6}
- mov r8, r0
- mov r9, r1
- adds r5, r2, 0
- ldrh r2, [r0]
- ldr r4, _0815C0D0 @ =0x000003ff
- adds r1, r4, 0
- ands r1, r2
- lsls r1, 5
- adds r1, r5, r1
- lsrs r2, 10
- movs r6, 0x3
- ands r2, r6
- mov r0, r9
- bl sub_815C0D4
- mov r0, r8
- ldrh r2, [r0, 0x8]
- adds r1, r4, 0
- ands r1, r2
- lsls r1, 5
- adds r1, r5, r1
- lsrs r2, 10
- ands r2, r6
- mov r0, r9
- bl sub_815C0D4
- movs r0, 0x20
- add r0, r9
- mov r10, r0
- mov r0, r8
- ldrh r2, [r0, 0x2]
- adds r1, r4, 0
- ands r1, r2
- lsls r1, 5
- adds r1, r5, r1
- lsrs r2, 10
- ands r2, r6
- mov r0, r10
- bl sub_815C0D4
- mov r0, r8
- ldrh r2, [r0, 0xA]
- adds r1, r4, 0
- ands r1, r2
- lsls r1, 5
- adds r1, r5, r1
- lsrs r2, 10
- ands r2, r6
- mov r0, r10
- bl sub_815C0D4
- movs r0, 0x40
- add r0, r9
- mov r10, r0
- mov r0, r8
- ldrh r2, [r0, 0x4]
- adds r1, r4, 0
- ands r1, r2
- lsls r1, 5
- adds r1, r5, r1
- lsrs r2, 10
- ands r2, r6
- mov r0, r10
- bl sub_815C0D4
- mov r0, r8
- ldrh r2, [r0, 0xC]
- adds r1, r4, 0
- ands r1, r2
- lsls r1, 5
- adds r1, r5, r1
- lsrs r2, 10
- ands r2, r6
- mov r0, r10
- bl sub_815C0D4
- movs r0, 0x60
- add r9, r0
- mov r0, r8
- ldrh r2, [r0, 0x6]
- adds r1, r4, 0
- ands r1, r2
- lsls r1, 5
- adds r1, r5, r1
- lsrs r2, 10
- ands r2, r6
- mov r0, r9
- bl sub_815C0D4
- mov r0, r8
- ldrh r2, [r0, 0xE]
- ands r4, r2
- lsls r4, 5
- adds r5, r4
- lsrs r2, 10
- ands r2, r6
- mov r0, r9
- adds r1, r5, 0
- bl sub_815C0D4
- pop {r3-r5}
- mov r8, r3
- mov r9, r4
- mov r10, r5
- pop {r4-r6}
- pop {r0}
- bx r0
- .align 2, 0
-_0815C0D0: .4byte 0x000003ff
- thumb_func_end sub_815BFF0
-
- thumb_func_start sub_815C0D4
-sub_815C0D4: @ 815C0D4
- push {r4-r7,lr}
- mov r7, r10
- mov r6, r9
- mov r5, r8
- push {r5-r7}
- sub sp, 0x4
- mov r9, r0
- adds r4, r1, 0
- lsls r2, 24
- lsrs r2, 24
- mov r10, r2
- movs r0, 0x20
- bl AllocZeroed
- adds r6, r0, 0
- movs r0, 0x20
- bl AllocZeroed
- str r0, [sp]
- adds r0, r4, 0
- adds r1, r6, 0
- movs r2, 0x8
- bl CpuFastSet
- movs r0, 0x1
- mov r1, r10
- ands r0, r1
- cmp r0, 0
- beq _0815C15A
- movs r5, 0
- movs r7, 0xF
- mov r12, r7
- movs r0, 0xF0
- mov r8, r0
-_0815C118:
- movs r3, 0
- lsls r4, r5, 2
-_0815C11C:
- subs r0, r3, 0x3
- subs r0, r4, r0
- adds r0, r6, r0
- ldrb r1, [r0]
- adds r2, r4, r3
- ldr r7, [sp]
- adds r2, r7, r2
- adds r0, r1, 0
- mov r7, r12
- ands r0, r7
- lsls r0, 4
- mov r7, r8
- ands r1, r7
- lsrs r1, 4
- adds r0, r1
- strb r0, [r2]
- adds r0, r3, 0x1
- lsls r0, 24
- lsrs r3, r0, 24
- cmp r3, 0x3
- bls _0815C11C
- adds r0, r5, 0x1
- lsls r0, 24
- lsrs r5, r0, 24
- cmp r5, 0x7
- bls _0815C118
- ldr r0, [sp]
- adds r1, r6, 0
- movs r2, 0x8
- bl CpuFastSet
-_0815C15A:
- movs r0, 0x2
- mov r1, r10
- ands r0, r1
- cmp r0, 0
- beq _0815C18E
- movs r5, 0
-_0815C166:
- lsls r0, r5, 2
- ldr r7, [sp]
- adds r0, r7
- movs r1, 0x7
- subs r1, r5
- lsls r1, 2
- adds r1, r6
- movs r2, 0x4
- bl memcpy
- adds r0, r5, 0x1
- lsls r0, 24
- lsrs r5, r0, 24
- cmp r5, 0x7
- bls _0815C166
- ldr r0, [sp]
- adds r1, r6, 0
- movs r2, 0x8
- bl CpuFastSet
-_0815C18E:
- movs r5, 0
- movs r0, 0xF0
- mov r8, r0
- movs r1, 0xF
- mov r12, r1
-_0815C198:
- adds r4, r6, r5
- ldrb r0, [r4]
- mov r3, r8
- ands r3, r0
- cmp r3, 0
- beq _0815C1B2
- mov r7, r9
- adds r2, r7, r5
- ldrb r1, [r2]
- mov r0, r12
- ands r0, r1
- adds r0, r3
- strb r0, [r2]
-_0815C1B2:
- ldrb r0, [r4]
- mov r3, r12
- ands r3, r0
- cmp r3, 0
- beq _0815C1CA
- mov r0, r9
- adds r2, r0, r5
- ldrb r1, [r2]
- mov r0, r8
- ands r0, r1
- adds r0, r3
- strb r0, [r2]
-_0815C1CA:
- adds r0, r5, 0x1
- lsls r0, 24
- lsrs r5, r0, 24
- cmp r5, 0x1F
- bls _0815C198
- ldr r0, [sp]
- bl Free
- adds r0, r6, 0
- bl Free
- add sp, 0x4
- pop {r3-r5}
- mov r8, r3
- mov r9, r4
- mov r10, r5
- pop {r4-r7}
- pop {r0}
- bx r0
- thumb_func_end sub_815C0D4
-
- thumb_func_start sub_815C1F0
-sub_815C1F0: @ 815C1F0
- push {r4,lr}
- adds r4, r0, 0
- lsls r1, 16
- lsrs r1, 28
- movs r3, 0
- ldrb r0, [r4]
- cmp r0, r1
- beq _0815C220
- cmp r0, 0xFF
- bne _0815C208
- strb r1, [r4]
- b _0815C220
-_0815C208:
- adds r0, r3, 0x1
- lsls r0, 16
- lsrs r3, r0, 16
- cmp r3, 0xF
- bhi _0815C220
- adds r2, r4, r3
- ldrb r0, [r2]
- cmp r0, r1
- beq _0815C220
- cmp r0, 0xFF
- bne _0815C208
- strb r1, [r2]
-_0815C220:
- movs r0, 0xF
- subs r0, r3
- lsls r0, 16
- lsrs r0, 16
- pop {r4}
- pop {r1}
- bx r1
- thumb_func_end sub_815C1F0
-
- thumb_func_start sub_815C230
-sub_815C230: @ 815C230
- push {r4-r6,lr}
- adds r6, r0, 0
- adds r5, r1, 0
- movs r4, 0
- ldrb r0, [r5]
- cmp r0, 0xFF
- beq _0815C274
-_0815C23E:
- adds r1, r5, r4
- ldrb r0, [r1]
- cmp r0, 0x6
- bls _0815C24A
- ldr r0, [r6, 0x14]
- b _0815C24C
-_0815C24A:
- ldr r0, [r6, 0x10]
-_0815C24C:
- ldrb r1, [r1]
- lsls r1, 5
- ldr r0, [r0, 0x8]
- adds r0, r1
- movs r1, 0xF
- subs r1, r4
- lsls r1, 20
- lsrs r1, 16
- movs r2, 0x20
- bl LoadPalette
- adds r0, r4, 0x1
- lsls r0, 24
- lsrs r4, r0, 24
- cmp r4, 0xF
- bhi _0815C274
- adds r0, r5, r4
- ldrb r0, [r0]
- cmp r0, 0xFF
- bne _0815C23E
-_0815C274:
- pop {r4-r6}
- pop {r0}
- bx r0
- thumb_func_end sub_815C230
-
- .align 2, 0 @ Don't pad with nop.
diff --git a/data/data_83FECCC.s b/data/data_83FECCC.s
index edddda0ab..52af8de8a 100644
--- a/data/data_83FECCC.s
+++ b/data/data_83FECCC.s
@@ -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"
diff --git a/data/data_8471F00.s b/data/data_8471F00.s
index e8b51cf69..672a9178e 100644
--- a/data/data_8471F00.s
+++ b/data/data_8471F00.s
@@ -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
diff --git a/include/field_map_obj.h b/include/field_map_obj.h
index 459122d32..27a7f23d7 100644
--- a/include/field_map_obj.h
+++ b/include/field_map_obj.h
@@ -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
diff --git a/include/fieldmap.h b/include/fieldmap.h
index 537626edc..9903962a1 100644
--- a/include/fieldmap.h
+++ b/include/fieldmap.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);
diff --git a/include/global.fieldmap.h b/include/global.fieldmap.h
index a14905cc2..3623737ea 100644
--- a/include/global.fieldmap.h
+++ b/include/global.fieldmap.h
@@ -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
diff --git a/include/graphics.h b/include/graphics.h
index 04d05da2b..f48f7f8ca 100644
--- a/include/graphics.h
+++ b/include/graphics.h
@@ -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
diff --git a/include/help_system.h b/include/help_system.h
index 6398d306b..97acec45e 100644
--- a/include/help_system.h
+++ b/include/help_system.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);
diff --git a/include/item_menu.h b/include/item_menu.h
index efd0066ed..2801a5001 100644
--- a/include/item_menu.h
+++ b/include/item_menu.h
@@ -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
diff --git a/include/list_menu.h b/include/list_menu.h
index 8ff65da0b..79dc3ec3f 100644
--- a/include/list_menu.h
+++ b/include/list_menu.h
@@ -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);
diff --git a/include/main.h b/include/main.h
index 6e9d2a25d..a250475cb 100644
--- a/include/main.h
+++ b/include/main.h
@@ -3,8 +3,6 @@
#include "global.h"
-#include "global.h"
-
typedef void (*MainCallback)(void);
typedef void (*IntrCallback)(void);
typedef void (*IntrFunc)(void);
diff --git a/include/menu_helpers.h b/include/menu_helpers.h
index e27fb4e5d..f8b57034a 100644
--- a/include/menu_helpers.h
+++ b/include/menu_helpers.h
@@ -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);
diff --git a/include/menu_indicators.h b/include/menu_indicators.h
index 8c669aeef..76f25224c 100644
--- a/include/menu_indicators.h
+++ b/include/menu_indicators.h
@@ -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
diff --git a/include/overworld.h b/include/overworld.h
index 5c4235b8c..a3fe1161f 100644
--- a/include/overworld.h
+++ b/include/overworld.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
diff --git a/include/sprite.h b/include/sprite.h
index bc47f7100..fb0f710e8 100644
--- a/include/sprite.h
+++ b/include/sprite.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[];
diff --git a/include/strings.h b/include/strings.h
index 6af1b0d69..51aeb376a 100644
--- a/include/strings.h
+++ b/include/strings.h
@@ -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
diff --git a/include/teachy_tv.h b/include/teachy_tv.h
index 374780c04..f3b9eb565 100644
--- a/include/teachy_tv.h
+++ b/include/teachy_tv.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);
diff --git a/include/unk_8159F40.h b/include/unk_8159F40.h
index f0e85d416..7f6a98c3a 100644
--- a/include/unk_8159F40.h
+++ b/include/unk_8159F40.h
@@ -3,6 +3,7 @@
#include "global.h"
+void sub_8159F40(void);
void sub_815A008(struct QuestLog *);
void sub_815A1F8(struct QuestLog *, struct MapObjectTemplate *);
diff --git a/ld_script.txt b/ld_script.txt
index ecc924060..d264549b7 100644
--- a/ld_script.txt
+++ b/ld_script.txt
@@ -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);
diff --git a/src/coins.c b/src/coins.c
index 08646e2f9..e97928df7 100644
--- a/src/coins.c
+++ b/src/coins.c
@@ -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;
diff --git a/src/fame_checker.c b/src/fame_checker.c
index dea1b2874..b2ee17c93 100644
--- a/src/fame_checker.c
+++ b/src/fame_checker.c
@@ -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;
}
diff --git a/src/mevent_8145654.c b/src/mevent_8145654.c
index 3e484bd56..034a07679 100644
--- a/src/mevent_8145654.c
+++ b/src/mevent_8145654.c
@@ -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)
diff --git a/src/mystery_gift_menu.c b/src/mystery_gift_menu.c
index 16e01f362..9ff96eb23 100644
--- a/src/mystery_gift_menu.c
+++ b/src/mystery_gift_menu.c
@@ -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;
}
diff --git a/src/teachy_tv.c b/src/teachy_tv.c
new file mode 100644
index 000000000..ca2e509a7
--- /dev/null
+++ b/src/teachy_tv.c
@@ -0,0 +1,1688 @@
+#include "task.h"
+#include "menu.h"
+#include "palette.h"
+#include "sprite.h"
+#include "menu_helpers.h"
+#include "new_menu_helpers.h"
+#include "sound.h"
+#include "malloc.h"
+#include "scanline_effect.h"
+#include "bg.h"
+#include "gpu_regs.h"
+#include "decompress.h"
+#include "window.h"
+#include "list_menu.h"
+#include "item_menu.h"
+#include "item.h"
+#include "menu_indicators.h"
+#include "field_map_obj.h"
+#include "random.h"
+#include "text.h"
+#include "constants/songs.h"
+#include "constants/items.h"
+#include "event_data.h"
+#include "load_save.h"
+#include "battle_transition.h"
+#include "battle_2.h"
+#include "battle.h"
+#include "global.fieldmap.h"
+#include "teachy_tv.h"
+#include "help_system.h"
+#include "overworld.h"
+#include "unk_8159F40.h"
+#include "graphics.h"
+#include "fieldmap.h"
+#include "strings.h"
+
+struct TeachyTvCtrlBlk
+{
+ MainCallback callback;
+ u8 mode;
+ u8 optionChosen;
+ u16 scrollOffset;
+ u16 selectedRow;
+ u16 filler;
+};
+
+struct TeachyTvBuf
+{
+ MainCallback savedCallback;
+ u8 buffer1[0x1000];
+ u8 buffer2[0x1000];
+ u8 buffer3[0x1000];
+ u8 buffer4[0x1000];
+ u8 var_4004;
+ u8 var_4005;
+ u8 var_4006;
+ u8 var_4007;
+};
+
+EWRAM_DATA struct TeachyTvCtrlBlk gTeachyTV_StaticResources = {0};
+EWRAM_DATA struct TeachyTvBuf * gUnknown_203F450 = NULL;
+
+void TeachyTvClusFuncTransitionRenderBg2TeachyTvGraphicInitNpcPos(u8 taskId);
+void TeachyTvClusFuncClearBg2TeachyTvGraphic(u8 taskId);
+void TeachyTvClusFuncNpcMoveAndSetupTextPrinter(u8 taskId);
+void TeachyTvClusFuncIdleIfTextPrinterIsActive(u8 taskId);
+void TeachyTvClusFuncTextPrinterSwitchStringByOptionChosen(u8 taskId);
+void TeachyTvClusFuncTextPrinterSwitchStringByOptionChosen2(u8 taskId);
+void TeachyTvClusFuncIdleIfTextPrinterIsActive2(u8 taskId);
+void TeachyTvClusFuncEraseTextWindowIfKeyPressed(u8 taskId);
+void TeachyTvClusFuncStartAnimNpcWalkIntoGrass(u8 taskId);
+void TeachyTvClusFuncDudeMoveUp(u8 taskId);
+void TeachyTvClusFuncDudeMoveRight(u8 taskId);
+void TeachyTvClusFuncDudeTurnLeft(u8 taskId);
+void TeachyTvClusFuncDudeMoveLeft(u8 taskId);
+void TeachyTvClusFuncRenderAndRemoveBg1EndGraphic(u8 taskId);
+void TeachyTvClusFuncTaskBattleOrFadeByOptionChosen(u8 taskId);
+void TeachyTvCallback(void);
+void TeachyTvMainCallback(void);
+void TeachyTvVblankHandler(void);
+void TeachyTvCreateAndRenderRbox(void);
+void TeachyTvInitIo(void);
+u8 TeachyTvSetupObjEventAndOam(void);
+void TeachyTvSetupPostBattleWindowAndObj(u8);
+u8 TeachyTvSetupWindow(void);
+void TeachyTvSetupScrollIndicatorArrowPair(void);
+void TeachyTvSetWindowRegs(void);
+void TeachyTvSetupBg(void);
+void TeachyTvLoadGraphic(void);
+void TeachyTvPostBattleFadeControl(u8);
+void TeachyTvOptionListController(u8);
+void TeachyTvAudioByInput(s32, bool8, struct ListMenu *);
+void TeachyTvQuitFadeControlAndTaskDel(u8 taskId);
+void TeachyTvRenderMsgAndSwitchClusterFuncs(u8 taskId);
+void TeachyTvClearBg1EndGraphicText(void);
+void TeachyTvBackToOptionList(u8 taskId);
+void TeachyTvSetupBagItemsByOptionChosen(void);
+void TeachyTvPrepBattle(u8 taskId);
+void TeachyTvGrassAnimationMain(u8 taskId, s16 x, s16 y, u8 subpriority, bool8 mode);
+void TeachyTvLoadBg3Map(void *);
+u8 TeachyTvGrassAnimationCheckIfNeedsToGenerateGrassObj(s16 x, s16 y);
+void TeachyTvGrassAnimationObjCallback(struct Sprite *sprite);
+void TeachyTvRestorePlayerPartyCallback(void);
+void TeachyTvPreBattleAnimAndSetBattleCallback(u8 taskId);
+void TeachyTvLoadMapTilesetToBuffer(struct Tileset *ts, u8 *dstBuffer, u16 size);
+void TeachyTvPushBackNewMapPalIndexArrayEntry(struct MapData *mStruct, u16 *buf1, u8 *palIndexArray, u16 mapEntry, u16 offset);
+void TeachyTvComputeMapTilesFromTilesetAndMetaTiles(u16 *metaTilesArray, u8 *blockBuf, u8 *tileset);
+void TeachyTvComputeSingleMapTileBlockFromTilesetAndMetaTiles(u8 *blockBuf, u8 *tileset, u8 metaTile);
+u16 TeachyTvComputePalIndexArrayEntryByMetaTile(u8 *palIndexArrayBuf, u16 metaTile);
+void TeachyTvLoadMapPalette(const struct MapData * mStruct, const u8 *palIndexArray);
+
+const struct BgTemplate gTeachyTvBgTemplateArray[] =
+{
+ {
+ .bg = 0x0,
+ .charBaseIndex = 0x0,
+ .mapBaseIndex = 0x1F,
+ .screenSize = 0x0,
+ .paletteMode = 0x0,
+ .priority = 0x1,
+ .baseTile = 0x0,
+ },
+ {
+ .bg = 0x1,
+ .charBaseIndex = 0x0,
+ .mapBaseIndex = 0x1E,
+ .screenSize = 0x0,
+ .paletteMode = 0x0,
+ .priority = 0x0,
+ .baseTile = 0x0,
+ },
+ {
+ .bg = 0x2,
+ .charBaseIndex = 0x0,
+ .mapBaseIndex = 0x1D,
+ .screenSize = 0x0,
+ .paletteMode = 0x0,
+ .priority = 0x2,
+ .baseTile = 0x0,
+ },
+ {
+ .bg = 0x3,
+ .charBaseIndex = 0x2,
+ .mapBaseIndex = 0x1C,
+ .screenSize = 0x0,
+ .paletteMode = 0x0,
+ .priority = 0x3,
+ .baseTile = 0x0,
+ },
+};
+
+const struct WindowTemplate gTeachyTvWindowTemplateArray[] =
+{
+ {
+ .bg = 0x1,
+ .tilemapLeft = 0x2,
+ .tilemapTop = 0xF,
+ .width = 0x1A,
+ .height = 0x4,
+ .paletteNum = 0x3,
+ .baseBlock = 0xEA,
+ },
+ {
+ .bg = 0x0,
+ .tilemapLeft = 0x4,
+ .tilemapTop = 0x1,
+ .width = 0x16,
+ .height = 0xC,
+ .paletteNum = 0x3,
+ .baseBlock = 0x152,
+ },
+ DUMMY_WIN_TEMPLATE,
+};
+
+const struct ListMenuItem gTeachyTvListMenuItemArray[] =
+{
+ {
+ .label = gUnknown_841B7A4,
+ .index = 0,
+ },
+ {
+ .label = gUnknown_841B7BC,
+ .index = 1,
+ },
+ {
+ .label = gUnknown_841B7D6,
+ .index = 2,
+ },
+ {
+ .label = gUnknown_841B7EE,
+ .index = 3,
+ },
+ {
+ .label = gUnknown_841B807,
+ .index = 4,
+ },
+ {
+ .label = gUnknown_841B81B,
+ .index = 5,
+ },
+
+ {
+ .label = gUnknown_841B836,
+ .index = -2,
+ },
+};
+
+const struct ListMenuItem gTeachyTvListMenuItemArray2[] =
+{
+ {
+ .label = gUnknown_841B7A4,
+ .index = 0,
+ },
+ {
+ .label = gUnknown_841B7BC,
+ .index = 1,
+ },
+ {
+ .label = gUnknown_841B7D6,
+ .index = 2,
+ },
+ {
+ .label = gUnknown_841B7EE,
+ .index = 3,
+ },
+ {
+ .label = gUnknown_841B836,
+ .index = -2,
+ },
+};
+
+const struct ListMenuTemplate gTeachyTvListMenuTemplateArray =
+{
+ .items = gTeachyTvListMenuItemArray,
+ .moveCursorFunc = NULL,
+ .itemPrintFunc = NULL,
+ .totalItems = 0x7,
+ .maxShowed = 0x6,
+ .windowId = 0x0,
+ .header_X = 0x0,
+ .item_X = 0x8,
+ .cursor_X = 0x0,
+ .upText_Y = 0x6,
+ .cursorPal = 0x1,
+ .fillValue = 0x0,
+ .cursorShadowPal = 0x2,
+ .lettersSpacing = 0x0,
+ .itemVerticalPadding = 0x0,
+ .scrollMultiple = 0x1,
+ .fontId = 0x2,
+ .cursorKind = 0x0,
+};
+
+const struct ScrollArrowsTemplate gTeachyTvScrollIndicatorArrowPairTemplateArray =
+{
+ .firstArrowType = 0x2,
+ .firstX = 0x78,
+ .firstY = 0xC,
+ .secondArrowType = 0x3,
+ .secondX = 0x78,
+ .secondY = 0x64,
+ .fullyUpThreshold = 0x0,
+ .fullyDownThreshold = 0x1,
+ .tileTag = 0x800,
+ .palTag = 0x800,
+ .palNum = 0x0,
+};
+
+const u8 gTeachyTvSwitchFuncArray[] =
+{
+ 0xC, 0xC, 0xC, 0xC, 0x9, 0x9, 0x0, 0x0,
+};
+
+void (* const gTeachyTvFuncCluster0[])(u8) =
+{
+ TeachyTvClusFuncTransitionRenderBg2TeachyTvGraphicInitNpcPos,
+ TeachyTvClusFuncClearBg2TeachyTvGraphic,
+ TeachyTvClusFuncNpcMoveAndSetupTextPrinter,
+ TeachyTvClusFuncIdleIfTextPrinterIsActive,
+ TeachyTvClusFuncIdleIfTextPrinterIsActive2,
+ TeachyTvClusFuncTextPrinterSwitchStringByOptionChosen,
+ TeachyTvClusFuncIdleIfTextPrinterIsActive2,
+ TeachyTvClusFuncEraseTextWindowIfKeyPressed,
+ TeachyTvClusFuncStartAnimNpcWalkIntoGrass,
+ TeachyTvClusFuncDudeMoveUp,
+ TeachyTvClusFuncDudeMoveRight,
+ TeachyTvClusFuncTaskBattleOrFadeByOptionChosen,
+ TeachyTvClusFuncTextPrinterSwitchStringByOptionChosen2,
+ TeachyTvClusFuncIdleIfTextPrinterIsActive2,
+ TeachyTvClusFuncEraseTextWindowIfKeyPressed,
+ TeachyTvClusFuncDudeTurnLeft,
+ TeachyTvClusFuncDudeMoveLeft,
+ TeachyTvClusFuncRenderAndRemoveBg1EndGraphic,
+ TeachyTvBackToOptionList,
+};
+
+void (* const gTeachyTvFuncCluster1[])(u8) =
+{
+ TeachyTvClusFuncTransitionRenderBg2TeachyTvGraphicInitNpcPos,
+ TeachyTvClusFuncClearBg2TeachyTvGraphic,
+ TeachyTvClusFuncNpcMoveAndSetupTextPrinter,
+ TeachyTvClusFuncIdleIfTextPrinterIsActive,
+ TeachyTvClusFuncIdleIfTextPrinterIsActive2,
+ TeachyTvClusFuncTextPrinterSwitchStringByOptionChosen,
+ TeachyTvClusFuncIdleIfTextPrinterIsActive2,
+ TeachyTvClusFuncEraseTextWindowIfKeyPressed,
+ TeachyTvClusFuncStartAnimNpcWalkIntoGrass,
+ TeachyTvClusFuncDudeMoveUp,
+ TeachyTvClusFuncDudeMoveRight,
+ TeachyTvClusFuncTaskBattleOrFadeByOptionChosen,
+ TeachyTvClusFuncTextPrinterSwitchStringByOptionChosen2,
+ TeachyTvClusFuncIdleIfTextPrinterIsActive2,
+ TeachyTvClusFuncEraseTextWindowIfKeyPressed,
+ TeachyTvClusFuncDudeTurnLeft,
+ TeachyTvClusFuncDudeMoveLeft,
+ TeachyTvClusFuncRenderAndRemoveBg1EndGraphic,
+ TeachyTvBackToOptionList,
+};
+
+void (* const gTeachyTvFuncCluster2[])(u8) =
+{
+ TeachyTvClusFuncTransitionRenderBg2TeachyTvGraphicInitNpcPos,
+ TeachyTvClusFuncClearBg2TeachyTvGraphic,
+ TeachyTvClusFuncNpcMoveAndSetupTextPrinter,
+ TeachyTvClusFuncIdleIfTextPrinterIsActive,
+ TeachyTvClusFuncIdleIfTextPrinterIsActive2,
+ TeachyTvClusFuncTextPrinterSwitchStringByOptionChosen,
+ TeachyTvClusFuncIdleIfTextPrinterIsActive2,
+ TeachyTvClusFuncEraseTextWindowIfKeyPressed,
+ TeachyTvClusFuncStartAnimNpcWalkIntoGrass,
+ TeachyTvClusFuncDudeMoveUp,
+ TeachyTvClusFuncDudeMoveRight,
+ TeachyTvClusFuncTaskBattleOrFadeByOptionChosen,
+ TeachyTvClusFuncTextPrinterSwitchStringByOptionChosen2,
+ TeachyTvClusFuncIdleIfTextPrinterIsActive2,
+ TeachyTvClusFuncEraseTextWindowIfKeyPressed,
+ TeachyTvClusFuncDudeTurnLeft,
+ TeachyTvClusFuncDudeMoveLeft,
+ TeachyTvClusFuncRenderAndRemoveBg1EndGraphic,
+ TeachyTvBackToOptionList,
+};
+
+void (* const gTeachyTvFuncCluster3[])(u8) =
+{
+ TeachyTvClusFuncTransitionRenderBg2TeachyTvGraphicInitNpcPos,
+ TeachyTvClusFuncClearBg2TeachyTvGraphic,
+ TeachyTvClusFuncNpcMoveAndSetupTextPrinter,
+ TeachyTvClusFuncIdleIfTextPrinterIsActive,
+ TeachyTvClusFuncIdleIfTextPrinterIsActive2,
+ TeachyTvClusFuncTextPrinterSwitchStringByOptionChosen,
+ TeachyTvClusFuncIdleIfTextPrinterIsActive2,
+ TeachyTvClusFuncEraseTextWindowIfKeyPressed,
+ TeachyTvClusFuncStartAnimNpcWalkIntoGrass,
+ TeachyTvClusFuncDudeMoveUp,
+ TeachyTvClusFuncDudeMoveRight,
+ TeachyTvClusFuncTaskBattleOrFadeByOptionChosen,
+ TeachyTvClusFuncTextPrinterSwitchStringByOptionChosen2,
+ TeachyTvClusFuncIdleIfTextPrinterIsActive2,
+ TeachyTvClusFuncEraseTextWindowIfKeyPressed,
+ TeachyTvClusFuncDudeTurnLeft,
+ TeachyTvClusFuncDudeMoveLeft,
+ TeachyTvClusFuncRenderAndRemoveBg1EndGraphic,
+ TeachyTvBackToOptionList,
+};
+
+void (* const gTeachyTvFuncCluster4[])(u8) =
+{
+ TeachyTvClusFuncTransitionRenderBg2TeachyTvGraphicInitNpcPos,
+ TeachyTvClusFuncClearBg2TeachyTvGraphic,
+ TeachyTvClusFuncNpcMoveAndSetupTextPrinter,
+ TeachyTvClusFuncIdleIfTextPrinterIsActive,
+ TeachyTvClusFuncIdleIfTextPrinterIsActive2,
+ TeachyTvClusFuncTextPrinterSwitchStringByOptionChosen,
+ TeachyTvClusFuncIdleIfTextPrinterIsActive2,
+ TeachyTvClusFuncEraseTextWindowIfKeyPressed,
+ TeachyTvClusFuncTaskBattleOrFadeByOptionChosen,
+ TeachyTvClusFuncTextPrinterSwitchStringByOptionChosen2,
+ TeachyTvClusFuncIdleIfTextPrinterIsActive2,
+ TeachyTvClusFuncEraseTextWindowIfKeyPressed,
+ TeachyTvClusFuncDudeTurnLeft,
+ TeachyTvClusFuncDudeMoveLeft,
+ TeachyTvClusFuncRenderAndRemoveBg1EndGraphic,
+ TeachyTvBackToOptionList,
+};
+
+void (* const gTeachyTvFuncCluster5[])(u8) =
+{
+ TeachyTvClusFuncTransitionRenderBg2TeachyTvGraphicInitNpcPos,
+ TeachyTvClusFuncClearBg2TeachyTvGraphic,
+ TeachyTvClusFuncNpcMoveAndSetupTextPrinter,
+ TeachyTvClusFuncIdleIfTextPrinterIsActive,
+ TeachyTvClusFuncIdleIfTextPrinterIsActive2,
+ TeachyTvClusFuncTextPrinterSwitchStringByOptionChosen,
+ TeachyTvClusFuncIdleIfTextPrinterIsActive2,
+ TeachyTvClusFuncEraseTextWindowIfKeyPressed,
+ TeachyTvClusFuncTaskBattleOrFadeByOptionChosen,
+ TeachyTvClusFuncTextPrinterSwitchStringByOptionChosen2,
+ TeachyTvClusFuncIdleIfTextPrinterIsActive2,
+ TeachyTvClusFuncEraseTextWindowIfKeyPressed,
+ TeachyTvClusFuncDudeTurnLeft,
+ TeachyTvClusFuncDudeMoveLeft,
+ TeachyTvClusFuncRenderAndRemoveBg1EndGraphic,
+ TeachyTvBackToOptionList,
+};
+
+void (* const * const gTeachyTvFuncClusterArray[])(u8) =
+{
+ gTeachyTvFuncCluster0,
+ gTeachyTvFuncCluster1,
+ gTeachyTvFuncCluster2,
+ gTeachyTvFuncCluster3,
+ gTeachyTvFuncCluster4,
+ gTeachyTvFuncCluster5,
+};
+
+void TeachyTvCallback(void)
+{
+ RunTasks();
+ AnimateSprites();
+ BuildOamBuffer();
+ do_scheduled_bg_tilemap_copies_to_vram();
+ UpdatePaletteFade();
+}
+
+void TeachyTvVblankHandler(void)
+{
+ LoadOam();
+ ProcessSpriteCopyRequests();
+ TransferPlttBuffer();
+}
+
+void sub_815ABC4(u8 mode, void (*cb)())
+{
+ gTeachyTV_StaticResources.mode = mode;
+ gTeachyTV_StaticResources.callback = cb;
+ if (mode == 0)
+ {
+ gTeachyTV_StaticResources.scrollOffset = 0;
+ gTeachyTV_StaticResources.selectedRow = 0;
+ gTeachyTV_StaticResources.optionChosen = 0;
+ }
+ if (mode == 1)
+ {
+ gTeachyTV_StaticResources.mode = 0;
+ }
+ SetMainCallback2(TeachyTvMainCallback);
+}
+
+void CB2_ReturnToTeachyTV(void)
+{
+ if (gTeachyTV_StaticResources.mode == 1)
+ sub_815ABC4(1, gTeachyTV_StaticResources.callback);
+ else
+ sub_815ABC4(2, gTeachyTV_StaticResources.callback);
+}
+
+void sub_815AC20(void)
+{
+ gTeachyTV_StaticResources.mode = 1;
+}
+
+void TeachyTvMainCallback(void)
+{
+ u8 taskId;
+ struct Task *taskAddr;
+
+ switch (gMain.state)
+ {
+ case 0:
+ gUnknown_203F450 = AllocZeroed(sizeof(struct TeachyTvBuf));
+ gUnknown_203F450->savedCallback = NULL;
+ gUnknown_203F450->var_4006 = 0;
+ gUnknown_203F450->var_4007 = 0xFF;
+ VblankHblankHandlerSetZero();
+ clear_scheduled_bg_copies_to_vram();
+ ScanlineEffect_Stop();
+ FreeAllSpritePalettes();
+ ResetPaletteFade();
+ ResetSpriteData();
+ ResetTasks();
+ TeachyTvSetupBg();
+ TeachyTvLoadGraphic();
+ ++gMain.state;
+ break;
+ case 1:
+ if (free_temp_tile_data_buffers_if_possible() == TRUE)
+ return;
+ TeachyTvCreateAndRenderRbox();
+ TeachyTvInitIo();
+ if (gTeachyTV_StaticResources.mode == 2)
+ {
+ taskId = CreateTask(TeachyTvPostBattleFadeControl, 0);
+ gTasks[taskId].data[1] = TeachyTvSetupObjEventAndOam();
+ TeachyTvSetupPostBattleWindowAndObj(taskId);
+ }
+ else
+ {
+ taskId = CreateTask(TeachyTvOptionListController, 0);
+ gTasks[taskId].data[0] = TeachyTvSetupWindow();
+ gTasks[taskId].data[1] = TeachyTvSetupObjEventAndOam();
+ TeachyTvSetupScrollIndicatorArrowPair();
+ PlayNewMapMusic(BGM_FRLG_TEACHY_TV);
+ TeachyTvSetWindowRegs();
+ }
+ schedule_bg_copy_tilemap_to_vram(0);
+ schedule_bg_copy_tilemap_to_vram(1);
+ schedule_bg_copy_tilemap_to_vram(2);
+ schedule_bg_copy_tilemap_to_vram(3);
+ sub_812B1E0(9); // help system something
+ BlendPalettes(0xFFFFFFFF, 0x10, 0);
+ BeginNormalPaletteFade(0xFFFFFFFF, 0, 0x10, 0, 0);
+ SetVBlankCallback(TeachyTvVblankHandler);
+ SetMainCallback2(TeachyTvCallback);
+ break;
+ }
+}
+
+void TeachyTvSetupBg(void)
+{
+ InitBgReg();
+ ResetBgsAndClearDma3BusyFlags(0);
+ InitBgsFromTemplates(0, gTeachyTvBgTemplateArray, 4);
+ SetBgTilemapBuffer(1, gUnknown_203F450->buffer1);
+ SetBgTilemapBuffer(2, gUnknown_203F450->buffer2);
+ SetBgTilemapBuffer(3, gUnknown_203F450->buffer3);
+ SetGpuReg(REG_OFFSET_DISPCNT, 0x3040);
+ ShowBg(0);
+ ShowBg(1);
+ ShowBg(2);
+ ShowBg(3);
+ ChangeBgX(3, 0x1000, 2);
+ ChangeBgY(3, 0x2800, 1);
+ gUnknown_203F450->var_4004 = 0;
+ gUnknown_203F450->var_4005 = 3;
+ SetGpuReg(REG_OFFSET_BLDCNT, 0);
+}
+
+void TeachyTvLoadGraphic(void)
+{
+ u16 src = 0;
+ reset_temp_tile_data_buffers();
+ decompress_and_copy_tile_data_to_vram(1, gUnknown_8E86240, 0, 0, 0);
+ LZDecompressWram(gUnknown_8E86BE8, gUnknown_203F450->buffer1);
+ LZDecompressWram(gUnknown_8E86D6C, gUnknown_203F450->buffer4);
+ LoadCompressedPalette(gUnknown_8E86F98, 0, 0x80);
+ LoadPalette(&src, 0, 2);
+ LoadSpritePalette(&gUnknown_83A5348);
+ TeachyTvLoadBg3Map(gUnknown_203F450->buffer3);
+}
+
+void TeachyTvCreateAndRenderRbox(void)
+{
+ InitWindows(gTeachyTvWindowTemplateArray);
+ DeactivateAllTextPrinters();
+ FillWindowPixelBuffer(0, 0xCC);
+ PutWindowTilemap(0);
+ PutWindowTilemap(1);
+ CopyWindowToVram(0, 2);
+}
+
+u8 TeachyTvSetupWindow(void)
+{
+ gMultiuseListMenuTemplate = gTeachyTvListMenuTemplateArray;
+ gMultiuseListMenuTemplate.windowId = 1;
+ gMultiuseListMenuTemplate.moveCursorFunc = TeachyTvAudioByInput;
+ if (!CheckBagHasItem(ITEM_TM_CASE, 1))
+ {
+ gMultiuseListMenuTemplate.items = gTeachyTvListMenuItemArray2;
+ gMultiuseListMenuTemplate.totalItems = 5;
+ gMultiuseListMenuTemplate.maxShowed = 5;
+ gMultiuseListMenuTemplate.upText_Y = (gMultiuseListMenuTemplate.upText_Y + 8) & 0xF;
+ }
+ return ListMenuInit(
+ &gMultiuseListMenuTemplate,
+ gTeachyTV_StaticResources.scrollOffset,
+ gTeachyTV_StaticResources.selectedRow);
+}
+
+void TeachyTvSetupScrollIndicatorArrowPair(void)
+{
+ if (!CheckBagHasItem(ITEM_TM_CASE, 1))
+ {
+ struct TeachyTvBuf * temp = gUnknown_203F450;
+ temp->var_4007 = 0xFF;
+ }
+
+ else {
+ u8 res = AddScrollIndicatorArrowPair(&gTeachyTvScrollIndicatorArrowPairTemplateArray, &(gTeachyTV_StaticResources.scrollOffset));
+ gUnknown_203F450->var_4007 = res;
+ }
+}
+
+void TeachyTvRemoveScrollIndicatorArrowPair(void)
+{
+ if (gUnknown_203F450->var_4007 != 0xFF)
+ {
+ RemoveScrollIndicatorArrowPair(gUnknown_203F450->var_4007);
+ gUnknown_203F450->var_4007 = 0xFF;
+ }
+}
+
+void TeachyTvAudioByInput(s32 notUsed, bool8 play, struct ListMenu *notUsedAlt)
+{
+ if (play != TRUE)
+ PlaySE(SE_SELECT);
+}
+
+void TeachyTvInitIo(void)
+{
+ SetGpuReg(REG_OFFSET_WININ, 0x3F);
+ SetGpuReg(REG_OFFSET_WINOUT, 0x1F);
+ SetGpuReg(REG_OFFSET_BLDCNT, 0xCC);
+ SetGpuReg(REG_OFFSET_BLDY, 0x5);
+}
+
+u8 TeachyTvSetupObjEventAndOam(void)
+{
+ u8 objId = AddPseudoEventObject(90, SpriteCallbackDummy, 0, 0, 8);
+ gSprites[objId].oam.priority = 2;
+ gSprites[objId].invisible = 1;
+ return objId;
+}
+
+void TeachyTvSetSpriteCoordsAndSwitchFrame(u8 objId, u16 x, u16 y, u8 frame)
+{
+ gSprites[objId].pos2.x = x;
+ gSprites[objId].pos2.y = y;
+ gSprites[objId].invisible = 0;
+ StartSpriteAnim(&gSprites[objId], frame);
+}
+
+void TeachyTvSetWindowRegs(void)
+{
+ SetGpuReg(REG_OFFSET_WIN0V, 0xC64);
+ SetGpuReg(REG_OFFSET_WIN0H, 0x1CD4);
+}
+
+void TeachyTvClearWindowRegs(void)
+{
+ SetGpuReg(REG_OFFSET_WIN0V, 0x0);
+ SetGpuReg(REG_OFFSET_WIN0H, 0x0);
+}
+
+void TeachyTvBg2AnimController(void)
+{
+ u16 * tilemapBuffer = GetBgTilemapBuffer(2);
+ u8 i, j;
+ for (i = 1; i < 13; i++)
+ {
+ for (j = 2; j < 28; j++)
+ {
+ tilemapBuffer[32 * i + j] = ((Random() & 3) << 10) + 0x301F;
+ }
+ }
+ schedule_bg_copy_tilemap_to_vram(2);
+}
+
+void TeachyTvSetupPostBattleWindowAndObj(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ int v1 = data[1];
+ struct Sprite *objAddr = &gSprites[v1];
+ int op;
+
+ ClearWindowTilemap(1);
+ TeachyTvClearWindowRegs();
+ op = gTeachyTV_StaticResources.optionChosen;
+ if (op >= 0)
+ {
+ if (op <= 3)
+ {
+ TeachyTvSetSpriteCoordsAndSwitchFrame(((char*)data)[2], 0x78, 0x38, 0);
+ ChangeBgX(3, 0x3000, 1);
+ ChangeBgY(3, 0x3000, 2);
+ gUnknown_203F450->var_4004 += 3;
+ gUnknown_203F450->var_4005 -= 3;
+ }
+ else if (op <= 5)
+ TeachyTvSetSpriteCoordsAndSwitchFrame(((char*)data)[2], 0x78, 0x38, 0);
+ }
+
+ data[4] = 0;
+ data[5] = 0;
+ TeachyTvGrassAnimationMain(taskId, objAddr->pos2.x, objAddr->pos2.y, 0, 1);
+}
+
+void TeachyTvInitTextPrinter(const char *text)
+{
+ u8 spd;
+ gTextFlags.autoScroll = 0;
+ spd = GetTextSpeedSetting();
+ AddTextPrinterParameterized2(0, 4, (const char *)text, spd, 0, 1, 0xC, 3);
+}
+
+void TeachyTvFree(void)
+{
+ Free(gUnknown_203F450);
+ gUnknown_203F450 = NULL;
+ FreeAllWindowBuffers();
+}
+
+void TeachyTvQuitBeginFade(u8 taskId)
+{
+ BeginNormalPaletteFade(0xFFFFFFFF, 0, 0, 0x10, 0);
+ gTasks[taskId].func = TeachyTvQuitFadeControlAndTaskDel;
+}
+
+void TeachyTvQuitFadeControlAndTaskDel(u8 taskId)
+{
+ if (!(gPaletteFade.active))
+ {
+ if (gUnknown_203F450->savedCallback != NULL)
+ {
+ SetMainCallback2(gUnknown_203F450->savedCallback);
+ }
+ else
+ {
+ sub_8055DC4();
+ SetMainCallback2(gTeachyTV_StaticResources.callback);
+ }
+ TeachyTvFree();
+ DestroyTask(taskId);
+ }
+}
+
+void TeachyTvOptionListController(u8 taskId)
+{
+ s16 * data = gTasks[taskId].data;
+ s32 input;
+
+ TeachyTvBg2AnimController();
+ if (!gPaletteFade.active)
+ {
+ input = ListMenuHandleInput(data[0]);
+ ListMenuGetScrollAndRow(data[0], &gTeachyTV_StaticResources.scrollOffset, &gTeachyTV_StaticResources.selectedRow);
+ if ((JOY_NEW(SELECT_BUTTON) && gTeachyTV_StaticResources.callback != UseFameCheckerFromMenu))
+ {
+ PlaySE(SE_SELECT);
+ TeachyTvQuitBeginFade(taskId);
+ }
+ else
+ {
+ switch (input)
+ {
+ case -1:
+ break;
+ case -2:
+ PlaySE(SE_SELECT);
+ TeachyTvQuitBeginFade(taskId);
+ break;
+ default:
+ PlaySE(SE_SELECT);
+ gTeachyTV_StaticResources.optionChosen = input;
+ DestroyListMenu(data[0], &gTeachyTV_StaticResources.scrollOffset, &gTeachyTV_StaticResources.selectedRow);
+ TeachyTvClearWindowRegs();
+ ClearWindowTilemap(1);
+ schedule_bg_copy_tilemap_to_vram(0);
+ TeachyTvRemoveScrollIndicatorArrowPair();
+ data[3] = 0;
+ data[2] = 0;
+ gTasks[taskId].func = TeachyTvRenderMsgAndSwitchClusterFuncs;
+ break;
+ }
+ }
+ }
+}
+
+void TeachyTvClusFuncTransitionRenderBg2TeachyTvGraphicInitNpcPos(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ TeachyTvBg2AnimController();
+ if (++data[2] > 63)
+ {
+ CopyToBgTilemapBufferRect_ChangePalette(2, gUnknown_203F450->buffer4, 0, 0, 0x20, 0x20, 0x11);
+ TeachyTvSetSpriteCoordsAndSwitchFrame(((u8 *)data)[2], 8, 0x38, 7);
+ schedule_bg_copy_tilemap_to_vram(2);
+ data[2] = 0;
+ ++data[3];
+ PlayNewMapMusic(BGM_FRLG_FOLLOW_ME);
+ }
+}
+
+void TeachyTvClusFuncClearBg2TeachyTvGraphic(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ if (++data[2] == 134)
+ {
+ FillBgTilemapBufferRect_Palette0(2, 0, 2, 1, 0x1A, 0xC);
+ schedule_bg_copy_tilemap_to_vram(2);
+ data[2] = 0;
+ ++data[3];
+ }
+}
+
+void TeachyTvClusFuncNpcMoveAndSetupTextPrinter(u8 taskId)
+{
+ s16 * data = gTasks[taskId].data;
+ struct Sprite * spriteAddr = &gSprites[data[1]];
+ if (data[2] != 35)
+ ++data[2];
+ else {
+ if (spriteAddr->pos2.x == 0x78)
+ {
+ StartSpriteAnim(&gSprites[data[1]], 0);
+ TeachyTvInitTextPrinter(gUnknown_841B83D);
+ data[2] = 0;
+ ++data[3];
+ }
+ else
+ ++spriteAddr->pos2.x;
+ }
+}
+
+void TeachyTvClusFuncIdleIfTextPrinterIsActive(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ if (!sub_80BF518(0))
+ ++data[3];
+}
+
+void TeachyTvRenderMsgAndSwitchClusterFuncs(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ if (JOY_NEW(B_BUTTON))
+ {
+ u8 *offset = &(gUnknown_203F450->var_4006);
+ u32 zero = 0;
+ offset[0] = 1;
+ TeachyTvSetSpriteCoordsAndSwitchFrame(*((char *)data + 2), 0, 0, 0);
+ FillWindowPixelBuffer(0, 0xCC);
+ CopyWindowToVram(0, 2);
+ TeachyTvClearBg1EndGraphicText();
+ data[2] = zero;
+ data[3] = zero;
+ gTasks[taskId].func = TeachyTvBackToOptionList;
+ }
+ else
+ {
+ void (* const * const *array)(u8) = gTeachyTvFuncClusterArray;
+ void (* const * const cluster)(u8) = array[(u8)gTeachyTV_StaticResources.optionChosen];
+ cluster[data[3]](taskId);
+ }
+}
+
+void TeachyTvClusFuncTextPrinterSwitchStringByOptionChosen(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ const u8 * const *texts = (const u8 *const [])
+ {
+ gUnknown_841B8BF,
+ gUnknown_841BB40,
+ gUnknown_841BE76,
+ gUnknown_841C23B,
+ gUnknown_841C459,
+ gUnknown_841C82A,
+ };
+ TeachyTvInitTextPrinter(texts[gTeachyTV_StaticResources.optionChosen]);
+ ++data[3];
+}
+
+void TeachyTvClusFuncTextPrinterSwitchStringByOptionChosen2(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ const u8 * const *texts = (const u8 *const [])
+ {
+ gUnknown_841BA41,
+ gUnknown_841BD10,
+ gUnknown_841C0AF,
+ gUnknown_841C384,
+ gUnknown_841C7B4,
+ gUnknown_841C994,
+ };
+ TeachyTvInitTextPrinter(texts[gTeachyTV_StaticResources.optionChosen]);
+ ++data[3];
+}
+
+const u16 gUnknown_8479590[] =
+{
+ 0xD1, 0xD2, 0xD3, 0xD4, 0xD5, 0xD6, 0xD7, 0xD8,
+ 0xE1, 0xE2, 0xE3, 0xE4, 0xE5, 0xE6, 0xE7, 0xE8,
+};
+
+const struct Subsprite gTeachyTvSubspriteArray[] =
+{
+ {
+ .x = -0x8,
+ .y = -0x8,
+ .shape = 0x1,
+ .size = 0x0,
+ .tileOffset = 0x0,
+ .priority = 0x3,
+ },
+ {
+ .x = -0x8,
+ .y = 0x0,
+ .shape = 0x1,
+ .size = 0x0,
+ .tileOffset = 0x2,
+ .priority = 0x2,
+ },
+};
+
+const struct SubspriteTable gTeachyTvSubspriteTableArray[] =
+{
+ {
+ .subspriteCount = 0,
+ .subsprites = NULL,
+ },
+ {
+ .subspriteCount = 2,
+ .subsprites = gTeachyTvSubspriteArray,
+ },
+};
+
+const u8 gTeachyTvGrassAnimArray[] =
+{
+ 0, 0, 1, 1, 1, 1, 1, 1,
+ 1, 1, 1, 1, 1, 1, 0, 0,
+ 0, 0, 1, 1, 1, 1, 1, 1,
+ 1, 1, 1, 1, 1, 1, 0, 0,
+ 0, 0, 1, 1, 1, 1, 1, 1,
+ 1, 1, 1, 1, 1, 1, 0, 0,
+ 0, 0, 1, 1, 1, 1, 1, 1,
+ 1, 1, 1, 1, 1, 1, 0, 0,
+ 0, 0, 1, 1, 1, 1, 1, 1,
+ 1, 1, 1, 1, 1, 1, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0,
+ 1, 1, 1, 1, 1, 1, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0,
+ 1, 1, 1, 1, 1, 1, 0, 0,
+};
+
+void TeachyTvClusFuncIdleIfTextPrinterIsActive2(u8 taskId)
+{
+ s16 *data = (u16 *)gTasks[taskId].data;
+ if (!sub_80BF518(0))
+ ++data[3];
+}
+
+void TeachyTvClusFuncEraseTextWindowIfKeyPressed(u8 taskId)
+{
+ s16 *data = (u16 *)gTasks[taskId].data;
+ if (JOY_NEW(A_BUTTON | B_BUTTON))
+ {
+ FillWindowPixelBuffer(0, 0xCC);
+ CopyWindowToVram(0, 2);
+ ++data[3];
+ }
+}
+
+void TeachyTvClusFuncStartAnimNpcWalkIntoGrass(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ StartSpriteAnim(&gSprites[(s16)data[1]], 5);
+ data[2] = 0;
+ data[4] = 0;
+ data[5] = 1;
+ ++data[3];
+}
+
+void TeachyTvClusFuncDudeMoveUp(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ struct Sprite *obj = &gSprites[data[1]];
+ ChangeBgY(3, 0x100, 2);
+ if (!(++data[2] & 0xF))
+ {
+ --gUnknown_203F450->var_4005;
+ TeachyTvGrassAnimationMain(taskId, obj->pos2.x, obj->pos2.y, 0, 0);
+ }
+ if (data[2] == 48)
+ {
+ data[2] = 0;
+ data[4] = -1;
+ data[5] = 0;
+ StartSpriteAnim(obj, 7);
+ ++data[3];
+ }
+}
+
+void TeachyTvClusFuncDudeMoveRight(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ struct Sprite *obj = &gSprites[data[1]];
+ ChangeBgX(3, 0x100, 1);
+ if (!(++data[2] & 0xF))
+ ++gUnknown_203F450->var_4004;
+ if (!((data[2] + 8) & 0xF))
+ TeachyTvGrassAnimationMain(taskId, obj->pos2.x + 8, obj->pos2.y, 0, 0);
+ if (data[2] == 0x30)
+ {
+ data[2] = 0;
+ data[4] = 0;
+ data[5] = 0;
+ StartSpriteAnim(obj, 3);
+ ++data[3];
+ }
+}
+
+void TeachyTvClusFuncDudeTurnLeft(u8 taskId)
+{
+
+ s16 *data = gTasks[taskId].data;
+ struct Sprite *objAddr = &gSprites[data[1]];
+ StartSpriteAnim(objAddr, 6);
+ ++data[3];
+ data[4] = 0;
+ data[5] = 0;
+ TeachyTvGrassAnimationMain(taskId, objAddr->pos2.x, objAddr->pos2.y, 0, 0);
+}
+
+void TeachyTvClusFuncDudeMoveLeft(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ struct Sprite *objAddr = &gSprites[data[1]];
+
+ if (!(objAddr->pos2.x & 0xF))
+ TeachyTvGrassAnimationMain(taskId, objAddr->pos2.x - 8, objAddr->pos2.y, 0, 0);
+ if (objAddr->pos2.x == 8)
+ ++data[3];
+ else
+ --objAddr->pos2.x;
+}
+
+void TeachyTvClusFuncRenderAndRemoveBg1EndGraphic(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ if (!data[2])
+ {
+ CopyToBgTilemapBufferRect_ChangePalette(1, gUnknown_8479590, 0x14, 0xA, 8, 2, 0x11);
+ schedule_bg_copy_tilemap_to_vram(1);
+ }
+ if (++data[2] > 126)
+ {
+ TeachyTvClearBg1EndGraphicText();
+ data[2] = 0;
+ ++data[3];
+ }
+}
+
+void TeachyTvClearBg1EndGraphicText(void)
+{
+ FillBgTilemapBufferRect_Palette0(1, 0, 0x14, 0xA, 8, 2);
+ schedule_bg_copy_tilemap_to_vram(1);
+}
+
+void TeachyTvBackToOptionList(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ if (data[2] == 0)
+ PlayNewMapMusic(BGM_FRLG_TEACHY_TV);
+ TeachyTvBg2AnimController();
+ if (++data[2] > 63)
+ {
+ data[2] = 0;
+ data[3] = 0;
+ data[0] = TeachyTvSetupWindow();
+ gTasks[taskId].func = TeachyTvOptionListController;
+ PutWindowTilemap(0);
+ TeachyTvSetupScrollIndicatorArrowPair();
+ TeachyTvSetWindowRegs();
+ schedule_bg_copy_tilemap_to_vram(0);
+ ChangeBgX(3, 0x0, 0);
+ ChangeBgY(3, 0x0, 0);
+ ChangeBgX(3, 0x1000, 2);
+ ChangeBgY(3, 0x2800, 1);
+ gUnknown_203F450->var_4004 = 0;
+ gUnknown_203F450->var_4005 = 3;
+ gUnknown_203F450->var_4006 = 0;
+ }
+}
+
+void TeachyTvClusFuncTaskBattleOrFadeByOptionChosen(u8 taskId)
+{
+ int op = gTeachyTV_StaticResources.optionChosen;
+ if (op >= 0)
+ {
+ if (op <= 3)
+ {
+ TeachyTvPrepBattle(taskId);
+
+ }
+ else if (op <= 5)
+ {
+ gUnknown_203F450->savedCallback = TeachyTvSetupBagItemsByOptionChosen;
+ TeachyTvQuitBeginFade(taskId);
+ }
+ }
+}
+
+void TeachyTvSetupBagItemsByOptionChosen(void)
+{
+ if (gTeachyTV_StaticResources.optionChosen == 4)
+ sub_810B108(10);
+ else
+ sub_810B108(9);
+}
+
+void TeachyTvPostBattleFadeControl(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ if (!(gPaletteFade.active))
+ {
+ const u8 *funcIdx = gTeachyTvSwitchFuncArray;
+ int arg = funcIdx[gTeachyTV_StaticResources.optionChosen];
+ data[3] = arg;
+ gTasks[taskId].func = TeachyTvRenderMsgAndSwitchClusterFuncs;
+ }
+}
+
+void TeachyTvGrassAnimationMain(u8 taskId, s16 x, s16 y, u8 subpriority, bool8 mode)
+{
+ int res;
+ struct Sprite *obj;
+ int objId;
+ const struct SpriteTemplate *const *objTemAddr;
+
+ u8 subprio = subpriority;
+ if (gUnknown_203F450->var_4006 != 1)
+ {
+ res = TeachyTvGrassAnimationCheckIfNeedsToGenerateGrassObj(x - 0x10, y);
+ if (res)
+ {
+ objTemAddr = gUnknown_83A0010;
+ objId = CreateSprite(*(objTemAddr+4), 0, 0, subprio);
+ obj = gSprites + objId;
+ obj->pos2.x = x;
+ obj->pos2.y = y + 8;
+ obj->callback = TeachyTvGrassAnimationObjCallback;
+ obj->data[0] = taskId;
+ if (mode == 1)
+ {
+ SeekSpriteAnim(obj, 4);
+ obj->oam.priority = 2;
+ }
+ else
+ {
+ SetSubspriteTables(obj, gTeachyTvSubspriteTableArray);
+ obj->subspriteTableNum = 0;
+ obj->subspriteMode = 1;
+ }
+ }
+ }
+}
+
+void TeachyTvGrassAnimationObjCallback(struct Sprite *sprite)
+{
+ s16 diff1, diff2, *data = gTasks[sprite->data[0]].data;
+ struct Sprite *objAddr = &gSprites[data[1]];
+ if (gUnknown_203F450->var_4006 == 1)
+ DestroySprite(sprite);
+ else {
+ if (!sprite->animCmdIndex)
+ sprite->subspriteTableNum = 1;
+ else
+ sprite->subspriteTableNum = 0;
+ sprite->pos2.x += (u16)data[4];
+ sprite->pos2.y += (u16)data[5];
+ if (!sprite->animEnded)
+ return;
+ sprite->subpriority = 0;
+ diff1 = (u16)(sprite->pos2.x - objAddr->pos2.x);
+ diff2 = (u16)(sprite->pos2.y - objAddr->pos2.y);
+ diff1 += 0xF;
+ if ((u16)diff1 <= 0x1E)
+ {
+ if (diff2 > -0x10)
+ {
+ if (diff2 <= 0x17)
+ return;
+ }
+ }
+ DestroySprite(sprite);
+ }
+}
+
+u8 TeachyTvGrassAnimationCheckIfNeedsToGenerateGrassObj(s16 x, s16 y)
+{
+ const u8 * arr;
+ struct TeachyTvBuf *ptr;
+ int high, low;
+ if ((x < 0) || (y < 0))
+ return 0;
+ arr = gTeachyTvGrassAnimArray;
+ high = ((y >> 4) + gUnknown_203F450->var_4005) << 4;
+ low = ((x >> 4) + gUnknown_203F450->var_4004);
+ return arr[high+low];
+}
+
+void TeachyTvPrepBattle(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ TeachyTvFree();
+ gSpecialVar_0x8004 = gTeachyTV_StaticResources.optionChosen;
+ gMain.savedCallback = TeachyTvRestorePlayerPartyCallback;
+ SavePlayerParty();
+ sub_8159F40();
+ PlayMapChosenOrBattleBGM(MUS_DUMMY);
+ if (!gTeachyTV_StaticResources.optionChosen)
+ data[6] = 9;
+ else
+ data[6] = 8;
+ data[7] = 0;
+ gTasks[taskId].func = TeachyTvPreBattleAnimAndSetBattleCallback;
+}
+
+void TeachyTvPreBattleAnimAndSetBattleCallback(u8 taskId)
+{
+ s16 *data = gTasks[taskId].data;
+ switch (data[7])
+ {
+ case 0:
+ sub_80D08B8(data[6]);
+ ++data[7];
+ break;
+ case 1:
+ if (sub_80D08F8())
+ {
+ SetMainCallback2(sub_800FD9C);
+ DestroyTask(taskId);
+ }
+ break;
+ }
+}
+
+void TeachyTvRestorePlayerPartyCallback(void)
+{
+ LoadPlayerParty();
+ if (gUnknown_2023E8A == 3)
+ sub_815AC20();
+ else
+ PlayNewMapMusic(BGM_FRLG_FOLLOW_ME);
+ CB2_ReturnToTeachyTV();
+}
+
+#ifdef NONMATCHING
+void TeachyTvLoadBg3Map(void *buffer)
+{
+ u16 *mapArray;
+ int v2;
+ int v3;
+ int v4;
+ int v5;
+ int mapEntry;
+ int v7;
+ u16 v8;
+ int i;
+ char *MapTileBlockBuf;
+ void *FourMapTileBlocksTempBuf;
+ unsigned int j;
+ u16 *v13;
+ u8 *v14;
+ void *tileset;
+ u8 *palIndexArray;
+ unsigned int v17;
+ u32 v18;
+ int v19;
+ struct MapData * md;
+
+ md = &Route1_Layout;
+ v14 = (u8 *)buffer;
+ v17 = 0;
+ mapArray = (u16 *)AllocZeroed(0x800);
+ tileset = AllocZeroed(0x8000);
+ palIndexArray = Alloc(0x10);
+ memset(palIndexArray, 0xFF, 0x10);
+ TeachyTvLoadMapTilesetToBuffer(md->primaryTileset, (u8 *)tileset, 0x280);
+ TeachyTvLoadMapTilesetToBuffer(md->secondaryTileset, (u8 *)tileset + 0x5000, 0x180);
+ v2 = 0;
+ do
+ {
+ v3 = 0;
+ v19 = v2 + 6;
+ v4 = 16 * v2;
+ v5 = v2 << 6;
+ v18 = v2 + 1;
+ do
+ {
+ mapEntry = md->map[v3 + 24 * v19 + 8] & 0x3FF;
+ v7 = 0;
+ v8 = v3 + 1;
+ if (v4 + v3 <= 0)
+ {
+LABEL_9:
+ if (mapArray[v7])
+ goto LABEL_11;
+ }
+ else
+ {
+ for (i = *mapArray; i; i = mapArray[v7])
+ {
+ if (i == mapEntry)
+ goto LABEL_9;
+ v7 = (u16)(v7 + 1);
+ if (v7 >= v4 + v3)
+ goto LABEL_9;
+ }
+ }
+ mapArray[v7] = mapEntry;
+ v17 = (u16)(v17 + 1);
+LABEL_11:
+ TeachyTvPushBackNewMapPalIndexArrayEntry(
+ md,
+ (u16 *)&v14[2 * (v5 + 2 * v3)],
+ palIndexArray,
+ mapEntry,
+ v7);
+ v3 = v8;
+ }
+ while ((u16)v8 <= 0xF);
+ v2 = v18;
+ }
+ while ((u16)v18 <= 8);
+ MapTileBlockBuf = (char *)Alloc(v17 << 7);
+ FourMapTileBlocksTempBuf = Alloc(0x80);
+ for (j = 0; j < v17; j = (u16)j + 1)
+ {
+ memset(FourMapTileBlocksTempBuf, 0, 0x80);
+ v13 = &mapArray[j];
+ if (*v13 <= 0x27F)
+ TeachyTvComputeMapTilesFromTilesetAndMetaTiles(
+ (u16 *)(16 * *v13 + (u16*)(md->primaryTileset->metatiles)),
+ (u8 *)FourMapTileBlocksTempBuf,
+ (u8 *)tileset);
+ else
+ TeachyTvComputeMapTilesFromTilesetAndMetaTiles(
+ (u16 *)(16 * (*v13 - 0x280) + (u16*)(md->secondaryTileset->metatiles)),
+ (u8 *)FourMapTileBlocksTempBuf,
+ (u8 *)tileset);
+
+ CpuFastSet(FourMapTileBlocksTempBuf, &MapTileBlockBuf[0x80 * j], 0x20);
+ }
+ LoadBgTiles(3, MapTileBlockBuf, (u16)v17 << 7, 0);
+ TeachyTvLoadMapPalette(&Route1_Layout, palIndexArray);
+ Free(FourMapTileBlocksTempBuf);
+ Free(MapTileBlockBuf);
+ Free(palIndexArray);
+ Free(tileset);
+ Free(mapArray);
+}
+#else
+NAKED
+void TeachyTvLoadBg3Map(void *buffer)
+{
+ asm_unified("\n\
+ push {r4-r7,lr}\n\
+ mov r7, r10\n\
+ mov r6, r9\n\
+ mov r5, r8\n\
+ push {r5-r7}\n\
+ sub sp, 0x1C\n\
+ str r0, [sp, 0x4]\n\
+ movs r0, 0\n\
+ str r0, [sp, 0x10]\n\
+ ldr r1, _0815BE1C @ =Route1_Layout\n\
+ mov r8, r1\n\
+ movs r0, 0x80\n\
+ lsls r0, 4\n\
+ bl AllocZeroed\n\
+ adds r6, r0, 0\n\
+ movs r0, 0x80\n\
+ lsls r0, 8\n\
+ bl AllocZeroed\n\
+ str r0, [sp, 0x8]\n\
+ movs r0, 0x10\n\
+ bl Alloc\n\
+ str r0, [sp, 0xC]\n\
+ movs r1, 0xFF\n\
+ movs r2, 0x10\n\
+ bl memset\n\
+ mov r2, r8\n\
+ ldr r0, [r2, 0x10]\n\
+ movs r2, 0xA0\n\
+ lsls r2, 2\n\
+ ldr r1, [sp, 0x8]\n\
+ bl TeachyTvLoadMapTilesetToBuffer\n\
+ mov r3, r8\n\
+ ldr r0, [r3, 0x14]\n\
+ ldr r2, [sp, 0x8]\n\
+ movs r3, 0xA0\n\
+ lsls r3, 7\n\
+ adds r1, r2, r3\n\
+ movs r2, 0xC0\n\
+ lsls r2, 1\n\
+ bl TeachyTvLoadMapTilesetToBuffer\n\
+ movs r4, 0\n\
+ _0815BDDE:\n\
+ movs r2, 0\n\
+ adds r0, r4, 0x6\n\
+ str r0, [sp, 0x18]\n\
+ lsls r1, r4, 4\n\
+ mov r10, r1\n\
+ lsls r3, r4, 6\n\
+ mov r9, r3\n\
+ adds r4, 0x1\n\
+ str r4, [sp, 0x14]\n\
+ _0815BDF0:\n\
+ mov r1, r8\n\
+ ldr r0, [r1]\n\
+ ldr r3, [sp, 0x18]\n\
+ muls r0, r3\n\
+ ldr r1, [r1, 0xC]\n\
+ adds r0, r2, r0\n\
+ lsls r0, 1\n\
+ adds r0, r1\n\
+ ldrh r1, [r0, 0x10]\n\
+ ldr r3, _0815BE20 @ =0x000003ff\n\
+ adds r0, r3, 0\n\
+ adds r4, r0, 0\n\
+ ands r4, r1\n\
+ movs r3, 0\n\
+ mov r0, r10\n\
+ adds r1, r0, r2\n\
+ lsls r5, r2, 1\n\
+ adds r7, r2, 0x1\n\
+ cmp r3, r1\n\
+ bge _0815BE3C\n\
+ ldrh r0, [r6]\n\
+ b _0815BE34\n\
+ .align 2, 0\n\
+ _0815BE1C: .4byte Route1_Layout\n\
+ _0815BE20: .4byte 0x000003ff\n\
+ _0815BE24:\n\
+ adds r0, r3, 0x1\n\
+ lsls r0, 16\n\
+ lsrs r3, r0, 16\n\
+ cmp r3, r1\n\
+ bge _0815BE3C\n\
+ lsls r0, r3, 1\n\
+ adds r0, r6\n\
+ ldrh r0, [r0]\n\
+ _0815BE34:\n\
+ cmp r0, 0\n\
+ beq _0815BE46\n\
+ cmp r0, r4\n\
+ bne _0815BE24\n\
+ _0815BE3C:\n\
+ lsls r0, r3, 1\n\
+ adds r0, r6\n\
+ ldrh r0, [r0]\n\
+ cmp r0, 0\n\
+ bne _0815BE56\n\
+ _0815BE46:\n\
+ lsls r0, r3, 1\n\
+ adds r0, r6\n\
+ strh r4, [r0]\n\
+ ldr r0, [sp, 0x10]\n\
+ adds r0, 0x1\n\
+ lsls r0, 16\n\
+ lsrs r0, 16\n\
+ str r0, [sp, 0x10]\n\
+ _0815BE56:\n\
+ mov r2, r9\n\
+ adds r1, r2, r5\n\
+ lsls r1, 1\n\
+ ldr r0, [sp, 0x4]\n\
+ adds r1, r0, r1\n\
+ str r3, [sp]\n\
+ mov r0, r8\n\
+ ldr r2, [sp, 0xC]\n\
+ adds r3, r4, 0\n\
+ bl TeachyTvPushBackNewMapPalIndexArrayEntry\n\
+ lsls r0, r7, 16\n\
+ lsrs r2, r0, 16\n\
+ cmp r2, 0xF\n\
+ bls _0815BDF0\n\
+ ldr r1, [sp, 0x14]\n\
+ lsls r0, r1, 16\n\
+ lsrs r4, r0, 16\n\
+ cmp r4, 0x8\n\
+ bls _0815BDDE\n\
+ ldr r2, [sp, 0x10]\n\
+ lsls r0, r2, 7\n\
+ bl Alloc\n\
+ adds r7, r0, 0\n\
+ movs r0, 0x80\n\
+ bl Alloc\n\
+ adds r5, r0, 0\n\
+ movs r4, 0\n\
+ ldr r3, [sp, 0x10]\n\
+ lsls r3, 23\n\
+ mov r9, r3\n\
+ ldr r0, [sp, 0x10]\n\
+ cmp r4, r0\n\
+ bcs _0815BF00\n\
+ ldr r1, _0815BECC @ =0x0000027f\n\
+ mov r10, r1\n\
+ _0815BEA2:\n\
+ adds r0, r5, 0\n\
+ movs r1, 0\n\
+ movs r2, 0x80\n\
+ bl memset\n\
+ lsls r0, r4, 1\n\
+ adds r1, r0, r6\n\
+ ldrh r0, [r1]\n\
+ cmp r0, r10\n\
+ bhi _0815BED0\n\
+ mov r2, r8\n\
+ ldr r0, [r2, 0x10]\n\
+ ldrh r1, [r1]\n\
+ lsls r1, 4\n\
+ ldr r0, [r0, 0xC]\n\
+ adds r0, r1\n\
+ adds r1, r5, 0\n\
+ ldr r2, [sp, 0x8]\n\
+ bl TeachyTvComputeMapTilesFromTilesetAndMetaTiles\n\
+ b _0815BEE8\n\
+ .align 2, 0\n\
+ _0815BECC: .4byte 0x0000027f\n\
+ _0815BED0:\n\
+ mov r3, r8\n\
+ ldr r0, [r3, 0x14]\n\
+ ldrh r1, [r1]\n\
+ ldr r2, _0815BF44 @ =0xfffffd80\n\
+ adds r1, r2\n\
+ lsls r1, 4\n\
+ ldr r0, [r0, 0xC]\n\
+ adds r0, r1\n\
+ adds r1, r5, 0\n\
+ ldr r2, [sp, 0x8]\n\
+ bl TeachyTvComputeMapTilesFromTilesetAndMetaTiles\n\
+ _0815BEE8:\n\
+ lsls r1, r4, 7\n\
+ adds r1, r7, r1\n\
+ adds r0, r5, 0\n\
+ movs r2, 0x20\n\
+ bl CpuFastSet\n\
+ adds r0, r4, 0x1\n\
+ lsls r0, 16\n\
+ lsrs r4, r0, 16\n\
+ ldr r3, [sp, 0x10]\n\
+ cmp r4, r3\n\
+ bcc _0815BEA2\n\
+ _0815BF00:\n\
+ mov r0, r9\n\
+ lsrs r2, r0, 16\n\
+ movs r0, 0x3\n\
+ adds r1, r7, 0\n\
+ movs r3, 0\n\
+ bl LoadBgTiles\n\
+ mov r0, r8\n\
+ ldr r1, [sp, 0xC]\n\
+ bl TeachyTvLoadMapPalette\n\
+ adds r0, r5, 0\n\
+ bl Free\n\
+ adds r0, r7, 0\n\
+ bl Free\n\
+ ldr r0, [sp, 0xC]\n\
+ bl Free\n\
+ ldr r0, [sp, 0x8]\n\
+ bl Free\n\
+ adds r0, r6, 0\n\
+ bl Free\n\
+ add sp, 0x1C\n\
+ pop {r3-r5}\n\
+ mov r8, r3\n\
+ mov r9, r4\n\
+ mov r10, r5\n\
+ pop {r4-r7}\n\
+ pop {r0}\n\
+ bx r0\n\
+ .align 2, 0\n\
+ _0815BF44: .4byte 0xfffffd80\n\
+ ");
+}
+#endif
+
+void TeachyTvLoadMapTilesetToBuffer(struct Tileset *ts, u8 *dstBuffer, u16 size)
+{
+ if (ts)
+ {
+ if (!ts->isCompressed)
+ CpuFastSet(ts->tiles, dstBuffer, 8 * size);
+ else
+ LZDecompressWram(ts->tiles, dstBuffer);
+ }
+}
+
+void TeachyTvPushBackNewMapPalIndexArrayEntry(struct MapData *mStruct, u16 *buf1, u8 *palIndexArray, u16 mapEntry, u16 offset)
+{
+ u16 * metaTileEntryAddr = mapEntry <= 0x27F ? &((u16*)(mStruct->primaryTileset->metatiles))[8 * mapEntry] : &((u16*)(mStruct->secondaryTileset->metatiles))[8 * (mapEntry - 0x280)];
+ buf1[0] = (TeachyTvComputePalIndexArrayEntryByMetaTile(palIndexArray, metaTileEntryAddr[0]) << 12) + 4 * offset;
+ buf1[1] = (TeachyTvComputePalIndexArrayEntryByMetaTile(palIndexArray, metaTileEntryAddr[1]) << 12) + 4 * offset + 1;
+ buf1[32] = (TeachyTvComputePalIndexArrayEntryByMetaTile(palIndexArray, metaTileEntryAddr[2]) << 12) + 4 * offset + 2;
+ buf1[33] = (TeachyTvComputePalIndexArrayEntryByMetaTile(palIndexArray, metaTileEntryAddr[3]) << 12) + 4 * offset + 3;
+}
+
+void TeachyTvComputeMapTilesFromTilesetAndMetaTiles(u16 *metaTilesArray, u8 *blockBuf, u8 *tileset)
+{
+ TeachyTvComputeSingleMapTileBlockFromTilesetAndMetaTiles(blockBuf, &tileset[0x20 * (*metaTilesArray & 0x3FF)], (*metaTilesArray >> 10) & 3);
+ TeachyTvComputeSingleMapTileBlockFromTilesetAndMetaTiles(blockBuf, &tileset[0x20 * (metaTilesArray[4] & 0x3FF)], (metaTilesArray[4] >> 10) & 3);
+ TeachyTvComputeSingleMapTileBlockFromTilesetAndMetaTiles(blockBuf + 0x20, &tileset[0x20 * (metaTilesArray[1] & 0x3FF)], (metaTilesArray[1] >> 10) & 3);
+ TeachyTvComputeSingleMapTileBlockFromTilesetAndMetaTiles(blockBuf + 0x20, &tileset[0x20 * (metaTilesArray[5] & 0x3FF)], (metaTilesArray[5] >> 10) & 3);
+ TeachyTvComputeSingleMapTileBlockFromTilesetAndMetaTiles(blockBuf + 0x40, &tileset[0x20 * (metaTilesArray[2] & 0x3FF)], (metaTilesArray[2] >> 10) & 3);
+ TeachyTvComputeSingleMapTileBlockFromTilesetAndMetaTiles(blockBuf + 0x40, &tileset[0x20 * (metaTilesArray[6] & 0x3FF)], (metaTilesArray[6] >> 10) & 3);
+ blockBuf += 0x60;
+ TeachyTvComputeSingleMapTileBlockFromTilesetAndMetaTiles(blockBuf, &tileset[0x20 * (metaTilesArray[3] & 0x3FF)], (metaTilesArray[3] >> 10) & 3);
+ TeachyTvComputeSingleMapTileBlockFromTilesetAndMetaTiles(blockBuf, &tileset[0x20 * (metaTilesArray[7] & 0x3FF)], (metaTilesArray[7] >> 10) & 3);
+}
+
+void TeachyTvComputeSingleMapTileBlockFromTilesetAndMetaTiles(u8 *blockBuf, u8 *tileset, u8 metaTile)
+{
+ u8 i, j, * src, *buffer = (u8 *)AllocZeroed(0x20);
+ src = AllocZeroed(0x20);
+ CpuFastSet(tileset, buffer, 8);
+ if (metaTile & 1)
+ {
+ for (i = 0; i < 8; ++i)
+ {
+ for (j = 0; j < 4; ++j)
+ {
+ u32 offset = j - 3;
+ u8 value = buffer[(i << 2) - offset];
+ src[(i << 2) + j] = ((value & 0xF) << 4) + ((value & 0xF0) >> 4);
+ }
+ }
+ CpuFastSet(src, buffer, 8);
+ }
+ if (metaTile & 2)
+ {
+ for (i = 0; i < 8; ++i)
+ memcpy(&src[4 * i], &buffer[4 * (7 - i)], 4);
+ CpuFastSet(src, buffer, 8);
+ }
+ for (i = 0; i < 32; ++i)
+ {
+ if (buffer[i] & 0xF0)
+ blockBuf[i] = (blockBuf[i] & 0xF) + (buffer[i] & 0xF0);
+ if (buffer[i] & 0xF)
+ blockBuf[i] = (blockBuf[i] & 0xF0) + (buffer[i] & 0xF);
+ }
+ Free(src);
+ Free(buffer);
+}
+
+u16 TeachyTvComputePalIndexArrayEntryByMetaTile(u8 *palIndexArrayBuf, u16 metaTile)
+{
+ u16 i;
+ int firstEntry;
+ int temp;
+ u32 pal = metaTile >> 12;
+ i = 0;
+ firstEntry = *palIndexArrayBuf;
+ if (firstEntry != pal)
+ {
+ if (firstEntry == 0xFF)
+ {
+ *palIndexArrayBuf = pal;
+ }
+ else
+ {
+ while (++i < 16)
+ {
+ temp = palIndexArrayBuf[i];
+ if (temp == pal)
+ break;
+ if (temp == 0xFF)
+ {
+ palIndexArrayBuf[i] = pal;
+ break;
+ }
+ }
+ }
+ }
+ return (0xF - i);
+}
+
+void TeachyTvLoadMapPalette(const struct MapData * mStruct, const u8 * palIndexArray)
+{
+ u8 i;
+ const struct Tileset * ts;
+ u16 * dest;
+
+ for (i = 0; i < 16; i++)
+ {
+ if (palIndexArray[i] == 0xFF)
+ break;
+ if (palIndexArray[i] > 6)
+ dest = (u16 *)mStruct->secondaryTileset->palettes + 0x10 * palIndexArray[i];
+ else
+ dest = (u16 *)mStruct->primaryTileset->palettes + 0x10 * palIndexArray[i];
+ LoadPalette(dest, 0x10 * (15 - i), 0x20);
+ }
+}
diff --git a/src/tm_case.c b/src/tm_case.c
index 08b3c5004..026ba95a7 100644
--- a/src/tm_case.c
+++ b/src/tm_case.c
@@ -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);
diff --git a/sym_ewram.txt b/sym_ewram.txt
index d97599e8c..7d3054653 100644
--- a/sym_ewram.txt
+++ b/sym_ewram.txt
@@ -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