Merge pull request #203 from mrgriffin/field-tasks
Decompile field_tasks
This commit is contained in:
@@ -2691,8 +2691,8 @@ _080DC234: .4byte gFieldEffectObjectTemplatePointers
|
||||
_080DC238: .4byte gSprites
|
||||
thumb_func_end FldEff_Unknown22
|
||||
|
||||
thumb_func_start ash
|
||||
ash: @ 80DC23C
|
||||
thumb_func_start StartAshFieldEffect
|
||||
StartAshFieldEffect: @ 80DC23C
|
||||
push {r4,lr}
|
||||
lsls r2, 16
|
||||
lsrs r2, 16
|
||||
@@ -2718,7 +2718,7 @@ ash: @ 80DC23C
|
||||
bx r0
|
||||
.align 2, 0
|
||||
_080DC26C: .4byte gFieldEffectArguments
|
||||
thumb_func_end ash
|
||||
thumb_func_end StartAshFieldEffect
|
||||
|
||||
thumb_func_start oei_ash
|
||||
oei_ash: @ 80DC270
|
||||
|
||||
@@ -1,697 +0,0 @@
|
||||
.include "asm/macros.inc"
|
||||
.include "constants/constants.inc"
|
||||
|
||||
.syntax unified
|
||||
|
||||
.text
|
||||
|
||||
thumb_func_start task_per_step_callback_manager
|
||||
task_per_step_callback_manager: @ 806E810
|
||||
push {lr}
|
||||
lsls r0, 24
|
||||
lsrs r0, 24
|
||||
ldr r2, _0806E834 @ =gTasks
|
||||
lsls r1, r0, 2
|
||||
adds r1, r0
|
||||
lsls r1, 3
|
||||
adds r1, r2
|
||||
movs r2, 0x8
|
||||
ldrsh r1, [r1, r2]
|
||||
ldr r2, _0806E838 @ =gUnknown_83A7310
|
||||
lsls r1, 2
|
||||
adds r1, r2
|
||||
ldr r1, [r1]
|
||||
bl _call_via_r1
|
||||
pop {r0}
|
||||
bx r0
|
||||
.align 2, 0
|
||||
_0806E834: .4byte gTasks
|
||||
_0806E838: .4byte gUnknown_83A7310
|
||||
thumb_func_end task_per_step_callback_manager
|
||||
|
||||
thumb_func_start sub_806E83C
|
||||
sub_806E83C: @ 806E83C
|
||||
push {r4,lr}
|
||||
lsls r0, 24
|
||||
lsrs r0, 24
|
||||
lsls r1, r0, 2
|
||||
adds r1, r0
|
||||
lsls r1, 3
|
||||
ldr r0, _0806E874 @ =gTasks+0x8
|
||||
adds r4, r1, r0
|
||||
bl ScriptContext2_IsEnabled
|
||||
lsls r0, 24
|
||||
cmp r0, 0
|
||||
bne _0806E86C
|
||||
ldr r0, _0806E878 @ =gUnknown_203ADFA
|
||||
ldrb r0, [r0]
|
||||
subs r0, 0x2
|
||||
lsls r0, 24
|
||||
lsrs r0, 24
|
||||
cmp r0, 0x1
|
||||
bls _0806E86C
|
||||
adds r0, r4, 0x2
|
||||
adds r1, r4, 0x4
|
||||
bl sub_8056078
|
||||
_0806E86C:
|
||||
pop {r4}
|
||||
pop {r0}
|
||||
bx r0
|
||||
.align 2, 0
|
||||
_0806E874: .4byte gTasks+0x8
|
||||
_0806E878: .4byte gUnknown_203ADFA
|
||||
thumb_func_end sub_806E83C
|
||||
|
||||
thumb_func_start sub_806E87C
|
||||
sub_806E87C: @ 806E87C
|
||||
push {r4,r5,lr}
|
||||
ldr r5, _0806E8C4 @ =task_per_step_callback_manager
|
||||
adds r0, r5, 0
|
||||
bl FuncIsActiveTask
|
||||
lsls r0, 24
|
||||
lsrs r4, r0, 24
|
||||
cmp r4, 0
|
||||
bne _0806E8A6
|
||||
adds r0, r5, 0
|
||||
movs r1, 0x50
|
||||
bl CreateTask
|
||||
lsls r0, 24
|
||||
lsrs r0, 24
|
||||
ldr r2, _0806E8C8 @ =gTasks
|
||||
lsls r1, r0, 2
|
||||
adds r1, r0
|
||||
lsls r1, 3
|
||||
adds r1, r2
|
||||
strh r4, [r1, 0x8]
|
||||
_0806E8A6:
|
||||
ldr r4, _0806E8CC @ =sub_806E83C
|
||||
adds r0, r4, 0
|
||||
bl FuncIsActiveTask
|
||||
lsls r0, 24
|
||||
cmp r0, 0
|
||||
bne _0806E8BC
|
||||
adds r0, r4, 0
|
||||
movs r1, 0x50
|
||||
bl CreateTask
|
||||
_0806E8BC:
|
||||
pop {r4,r5}
|
||||
pop {r0}
|
||||
bx r0
|
||||
.align 2, 0
|
||||
_0806E8C4: .4byte task_per_step_callback_manager
|
||||
_0806E8C8: .4byte gTasks
|
||||
_0806E8CC: .4byte sub_806E83C
|
||||
thumb_func_end sub_806E87C
|
||||
|
||||
thumb_func_start ActivatePerStepCallback
|
||||
ActivatePerStepCallback: @ 806E8D0
|
||||
push {r4,lr}
|
||||
lsls r0, 24
|
||||
lsrs r4, r0, 24
|
||||
ldr r0, _0806E908 @ =task_per_step_callback_manager
|
||||
bl FindTaskIdByFunc
|
||||
lsls r0, 24
|
||||
lsrs r1, r0, 24
|
||||
cmp r1, 0xFF
|
||||
beq _0806E912
|
||||
lsls r0, r1, 2
|
||||
adds r0, r1
|
||||
lsls r0, 3
|
||||
ldr r1, _0806E90C @ =gTasks+0x8
|
||||
adds r1, r0, r1
|
||||
movs r2, 0
|
||||
adds r0, r1, 0
|
||||
adds r0, 0x1E
|
||||
_0806E8F4:
|
||||
strh r2, [r0]
|
||||
subs r0, 0x2
|
||||
cmp r0, r1
|
||||
bge _0806E8F4
|
||||
cmp r4, 0x7
|
||||
bls _0806E910
|
||||
movs r0, 0
|
||||
strh r0, [r1]
|
||||
b _0806E912
|
||||
.align 2, 0
|
||||
_0806E908: .4byte task_per_step_callback_manager
|
||||
_0806E90C: .4byte gTasks+0x8
|
||||
_0806E910:
|
||||
strh r4, [r1]
|
||||
_0806E912:
|
||||
pop {r4}
|
||||
pop {r0}
|
||||
bx r0
|
||||
thumb_func_end ActivatePerStepCallback
|
||||
|
||||
thumb_func_start wild_encounter_reset_coro_args
|
||||
wild_encounter_reset_coro_args: @ 806E918
|
||||
push {lr}
|
||||
ldr r0, _0806E948 @ =task_per_step_callback_manager
|
||||
bl FindTaskIdByFunc
|
||||
lsls r0, 24
|
||||
lsrs r1, r0, 24
|
||||
ldr r0, _0806E94C @ =sub_806E83C
|
||||
bl FindTaskIdByFunc
|
||||
lsls r0, 24
|
||||
lsrs r1, r0, 24
|
||||
cmp r1, 0xFF
|
||||
beq _0806E942
|
||||
lsls r0, r1, 2
|
||||
adds r0, r1
|
||||
lsls r0, 3
|
||||
ldr r1, _0806E950 @ =gTasks+0x8
|
||||
adds r0, r1
|
||||
movs r1, 0
|
||||
strh r1, [r0, 0x2]
|
||||
strh r1, [r0, 0x4]
|
||||
_0806E942:
|
||||
pop {r0}
|
||||
bx r0
|
||||
.align 2, 0
|
||||
_0806E948: .4byte task_per_step_callback_manager
|
||||
_0806E94C: .4byte sub_806E83C
|
||||
_0806E950: .4byte gTasks+0x8
|
||||
thumb_func_end wild_encounter_reset_coro_args
|
||||
|
||||
thumb_func_start nullsub_40
|
||||
nullsub_40: @ 806E954
|
||||
bx lr
|
||||
thumb_func_end nullsub_40
|
||||
|
||||
thumb_func_start sub_806E958
|
||||
sub_806E958: @ 806E958
|
||||
push {r4,r5,lr}
|
||||
movs r3, 0
|
||||
ldr r4, _0806E988 @ =gUnknown_83A7330
|
||||
lsls r0, 16
|
||||
asrs r5, r0, 16
|
||||
lsls r1, 16
|
||||
asrs r1, 16
|
||||
_0806E966:
|
||||
lsls r2, r3, 1
|
||||
adds r0, r2, r4
|
||||
ldrb r0, [r0]
|
||||
adds r0, 0x7
|
||||
cmp r0, r5
|
||||
bne _0806E98C
|
||||
adds r0, r4, 0x1
|
||||
adds r0, r2, r0
|
||||
ldrb r0, [r0]
|
||||
adds r0, 0x7
|
||||
cmp r0, r1
|
||||
bne _0806E98C
|
||||
adds r0, r3, 0x1
|
||||
bl FlagSet
|
||||
b _0806E996
|
||||
.align 2, 0
|
||||
_0806E988: .4byte gUnknown_83A7330
|
||||
_0806E98C:
|
||||
adds r0, r3, 0x1
|
||||
lsls r0, 24
|
||||
lsrs r3, r0, 24
|
||||
cmp r3, 0x8
|
||||
bls _0806E966
|
||||
_0806E996:
|
||||
pop {r4,r5}
|
||||
pop {r0}
|
||||
bx r0
|
||||
thumb_func_end sub_806E958
|
||||
|
||||
thumb_func_start sub_806E99C
|
||||
sub_806E99C: @ 806E99C
|
||||
push {r4-r7,lr}
|
||||
movs r4, 0
|
||||
ldr r6, _0806E9D8 @ =gUnknown_83A7330
|
||||
adds r7, r6, 0x1
|
||||
_0806E9A4:
|
||||
adds r5, r4, 0x1
|
||||
adds r0, r5, 0
|
||||
bl FlagGet
|
||||
lsls r0, 24
|
||||
lsrs r0, 24
|
||||
cmp r0, 0x1
|
||||
bne _0806E9C8
|
||||
lsls r1, r4, 1
|
||||
adds r0, r1, r6
|
||||
ldrb r0, [r0]
|
||||
adds r0, 0x7
|
||||
adds r1, r7
|
||||
ldrb r1, [r1]
|
||||
adds r1, 0x7
|
||||
ldr r2, _0806E9DC @ =0x0000035a
|
||||
bl MapGridSetMetatileIdAt
|
||||
_0806E9C8:
|
||||
lsls r0, r5, 24
|
||||
lsrs r4, r0, 24
|
||||
cmp r4, 0x8
|
||||
bls _0806E9A4
|
||||
pop {r4-r7}
|
||||
pop {r0}
|
||||
bx r0
|
||||
.align 2, 0
|
||||
_0806E9D8: .4byte gUnknown_83A7330
|
||||
_0806E9DC: .4byte 0x0000035a
|
||||
thumb_func_end sub_806E99C
|
||||
|
||||
thumb_func_start sub_806E9E0
|
||||
sub_806E9E0: @ 806E9E0
|
||||
push {r4-r6,lr}
|
||||
sub sp, 0x4
|
||||
lsls r0, 24
|
||||
lsrs r0, 24
|
||||
lsls r1, r0, 2
|
||||
adds r1, r0
|
||||
lsls r1, 3
|
||||
ldr r0, _0806EA04 @ =gTasks+0x8
|
||||
adds r5, r1, r0
|
||||
movs r1, 0x2
|
||||
ldrsh r0, [r5, r1]
|
||||
cmp r0, 0x1
|
||||
beq _0806EA2A
|
||||
cmp r0, 0x1
|
||||
bgt _0806EA08
|
||||
cmp r0, 0
|
||||
beq _0806EA12
|
||||
b _0806EB42
|
||||
.align 2, 0
|
||||
_0806EA04: .4byte gTasks+0x8
|
||||
_0806EA08:
|
||||
cmp r0, 0x2
|
||||
beq _0806EAB0
|
||||
cmp r0, 0x3
|
||||
beq _0806EAF4
|
||||
b _0806EB42
|
||||
_0806EA12:
|
||||
mov r4, sp
|
||||
adds r4, 0x2
|
||||
mov r0, sp
|
||||
adds r1, r4, 0
|
||||
bl PlayerGetDestCoords
|
||||
mov r0, sp
|
||||
ldrh r0, [r0]
|
||||
strh r0, [r5, 0x4]
|
||||
ldrh r0, [r4]
|
||||
strh r0, [r5, 0x6]
|
||||
b _0806EB3E
|
||||
_0806EA2A:
|
||||
mov r4, sp
|
||||
adds r4, 0x2
|
||||
mov r0, sp
|
||||
adds r1, r4, 0
|
||||
bl PlayerGetDestCoords
|
||||
mov r0, sp
|
||||
ldrh r2, [r0]
|
||||
movs r3, 0
|
||||
ldrsh r1, [r0, r3]
|
||||
movs r3, 0x4
|
||||
ldrsh r0, [r5, r3]
|
||||
cmp r1, r0
|
||||
bne _0806EA52
|
||||
movs r0, 0
|
||||
ldrsh r1, [r4, r0]
|
||||
movs r3, 0x6
|
||||
ldrsh r0, [r5, r3]
|
||||
cmp r1, r0
|
||||
beq _0806EB42
|
||||
_0806EA52:
|
||||
strh r2, [r5, 0x4]
|
||||
ldrh r0, [r4]
|
||||
strh r0, [r5, 0x6]
|
||||
mov r0, sp
|
||||
movs r1, 0
|
||||
ldrsh r0, [r0, r1]
|
||||
movs r2, 0
|
||||
ldrsh r1, [r4, r2]
|
||||
bl MapGridGetMetatileBehaviorAt
|
||||
lsls r0, 24
|
||||
lsrs r6, r0, 24
|
||||
adds r0, r6, 0
|
||||
bl MetatileBehavior_IsThinIce
|
||||
lsls r0, 24
|
||||
lsrs r0, 24
|
||||
cmp r0, 0x1
|
||||
bne _0806EA8E
|
||||
mov r0, sp
|
||||
movs r3, 0
|
||||
ldrsh r0, [r0, r3]
|
||||
movs r2, 0
|
||||
ldrsh r1, [r4, r2]
|
||||
bl sub_806E958
|
||||
movs r0, 0x4
|
||||
strh r0, [r5, 0xC]
|
||||
movs r0, 0x2
|
||||
b _0806EAA2
|
||||
_0806EA8E:
|
||||
adds r0, r6, 0
|
||||
bl MetatileBehavior_IsCrackedIce
|
||||
lsls r0, 24
|
||||
lsrs r0, 24
|
||||
cmp r0, 0x1
|
||||
bne _0806EB42
|
||||
movs r0, 0x4
|
||||
strh r0, [r5, 0xC]
|
||||
movs r0, 0x3
|
||||
_0806EAA2:
|
||||
strh r0, [r5, 0x2]
|
||||
mov r0, sp
|
||||
ldrh r0, [r0]
|
||||
strh r0, [r5, 0x8]
|
||||
ldrh r0, [r4]
|
||||
strh r0, [r5, 0xA]
|
||||
b _0806EB42
|
||||
_0806EAB0:
|
||||
ldrh r1, [r5, 0xC]
|
||||
movs r3, 0xC
|
||||
ldrsh r0, [r5, r3]
|
||||
cmp r0, 0
|
||||
bne _0806EAFE
|
||||
mov r1, sp
|
||||
ldrh r0, [r5, 0x8]
|
||||
strh r0, [r1]
|
||||
mov r4, sp
|
||||
adds r4, 0x2
|
||||
ldrh r0, [r5, 0xA]
|
||||
strh r0, [r4]
|
||||
movs r0, 0x24
|
||||
bl PlaySE
|
||||
mov r0, sp
|
||||
movs r1, 0
|
||||
ldrsh r0, [r0, r1]
|
||||
movs r2, 0
|
||||
ldrsh r1, [r4, r2]
|
||||
ldr r2, _0806EAF0 @ =0x0000035a
|
||||
bl MapGridSetMetatileIdAt
|
||||
mov r0, sp
|
||||
movs r3, 0
|
||||
ldrsh r0, [r0, r3]
|
||||
movs r2, 0
|
||||
ldrsh r1, [r4, r2]
|
||||
bl CurrentMapDrawMetatileAt
|
||||
b _0806EB3E
|
||||
.align 2, 0
|
||||
_0806EAF0: .4byte 0x0000035a
|
||||
_0806EAF4:
|
||||
ldrh r1, [r5, 0xC]
|
||||
movs r3, 0xC
|
||||
ldrsh r0, [r5, r3]
|
||||
cmp r0, 0
|
||||
beq _0806EB04
|
||||
_0806EAFE:
|
||||
subs r0, r1, 0x1
|
||||
strh r0, [r5, 0xC]
|
||||
b _0806EB42
|
||||
_0806EB04:
|
||||
mov r1, sp
|
||||
ldrh r0, [r5, 0x8]
|
||||
strh r0, [r1]
|
||||
mov r4, sp
|
||||
adds r4, 0x2
|
||||
ldrh r0, [r5, 0xA]
|
||||
strh r0, [r4]
|
||||
movs r0, 0x23
|
||||
bl PlaySE
|
||||
mov r0, sp
|
||||
movs r1, 0
|
||||
ldrsh r0, [r0, r1]
|
||||
movs r2, 0
|
||||
ldrsh r1, [r4, r2]
|
||||
ldr r2, _0806EB4C @ =0x0000035b
|
||||
bl MapGridSetMetatileIdAt
|
||||
mov r0, sp
|
||||
movs r3, 0
|
||||
ldrsh r0, [r0, r3]
|
||||
movs r2, 0
|
||||
ldrsh r1, [r4, r2]
|
||||
bl CurrentMapDrawMetatileAt
|
||||
ldr r0, _0806EB50 @ =0x00004001
|
||||
movs r1, 0x1
|
||||
bl VarSet
|
||||
_0806EB3E:
|
||||
movs r0, 0x1
|
||||
strh r0, [r5, 0x2]
|
||||
_0806EB42:
|
||||
add sp, 0x4
|
||||
pop {r4-r6}
|
||||
pop {r0}
|
||||
bx r0
|
||||
.align 2, 0
|
||||
_0806EB4C: .4byte 0x0000035b
|
||||
_0806EB50: .4byte 0x00004001
|
||||
thumb_func_end sub_806E9E0
|
||||
|
||||
thumb_func_start sub_806EB54
|
||||
sub_806EB54: @ 806EB54
|
||||
push {r4,r5,lr}
|
||||
sub sp, 0x4
|
||||
lsls r0, 24
|
||||
lsrs r0, 24
|
||||
lsls r1, r0, 2
|
||||
adds r1, r0
|
||||
lsls r1, 3
|
||||
ldr r0, _0806EBD8 @ =gTasks+0x8
|
||||
adds r5, r1, r0
|
||||
mov r4, sp
|
||||
adds r4, 0x2
|
||||
mov r0, sp
|
||||
adds r1, r4, 0
|
||||
bl PlayerGetDestCoords
|
||||
mov r0, sp
|
||||
ldrh r2, [r0]
|
||||
movs r3, 0
|
||||
ldrsh r1, [r0, r3]
|
||||
movs r3, 0x2
|
||||
ldrsh r0, [r5, r3]
|
||||
cmp r1, r0
|
||||
bne _0806EB8E
|
||||
movs r0, 0
|
||||
ldrsh r1, [r4, r0]
|
||||
movs r3, 0x4
|
||||
ldrsh r0, [r5, r3]
|
||||
cmp r1, r0
|
||||
beq _0806EBF6
|
||||
_0806EB8E:
|
||||
strh r2, [r5, 0x2]
|
||||
ldrh r0, [r4]
|
||||
strh r0, [r5, 0x4]
|
||||
mov r0, sp
|
||||
movs r1, 0
|
||||
ldrsh r0, [r0, r1]
|
||||
movs r2, 0
|
||||
ldrsh r1, [r4, r2]
|
||||
bl MapGridGetMetatileBehaviorAt
|
||||
lsls r0, 24
|
||||
lsrs r0, 24
|
||||
bl MetatileBehavior_ReturnFalse_4
|
||||
lsls r0, 24
|
||||
cmp r0, 0
|
||||
beq _0806EBF6
|
||||
mov r0, sp
|
||||
movs r3, 0
|
||||
ldrsh r0, [r0, r3]
|
||||
movs r2, 0
|
||||
ldrsh r1, [r4, r2]
|
||||
bl MapGridGetMetatileIdAt
|
||||
ldr r1, _0806EBDC @ =0x0000020a
|
||||
cmp r0, r1
|
||||
bne _0806EBE4
|
||||
mov r0, sp
|
||||
movs r3, 0
|
||||
ldrsh r0, [r0, r3]
|
||||
movs r2, 0
|
||||
ldrsh r1, [r4, r2]
|
||||
ldr r2, _0806EBE0 @ =0x00000212
|
||||
movs r3, 0x4
|
||||
bl ash
|
||||
b _0806EBF6
|
||||
.align 2, 0
|
||||
_0806EBD8: .4byte gTasks+0x8
|
||||
_0806EBDC: .4byte 0x0000020a
|
||||
_0806EBE0: .4byte 0x00000212
|
||||
_0806EBE4:
|
||||
mov r0, sp
|
||||
movs r3, 0
|
||||
ldrsh r0, [r0, r3]
|
||||
movs r2, 0
|
||||
ldrsh r1, [r4, r2]
|
||||
ldr r2, _0806EC00 @ =0x00000206
|
||||
movs r3, 0x4
|
||||
bl ash
|
||||
_0806EBF6:
|
||||
add sp, 0x4
|
||||
pop {r4,r5}
|
||||
pop {r0}
|
||||
bx r0
|
||||
.align 2, 0
|
||||
_0806EC00: .4byte 0x00000206
|
||||
thumb_func_end sub_806EB54
|
||||
|
||||
thumb_func_start sub_806EC04
|
||||
sub_806EC04: @ 806EC04
|
||||
push {r4,r5,lr}
|
||||
lsls r0, 16
|
||||
asrs r5, r0, 16
|
||||
lsls r1, 16
|
||||
asrs r4, r1, 16
|
||||
adds r0, r5, 0
|
||||
adds r1, r4, 0
|
||||
bl MapGridGetMetatileIdAt
|
||||
ldr r1, _0806EC38 @ =0x0000022f
|
||||
ldr r2, _0806EC3C @ =0x00000237
|
||||
cmp r0, r1
|
||||
bne _0806EC20
|
||||
subs r2, 0x31
|
||||
_0806EC20:
|
||||
adds r0, r5, 0
|
||||
adds r1, r4, 0
|
||||
bl MapGridSetMetatileIdAt
|
||||
adds r0, r5, 0
|
||||
adds r1, r4, 0
|
||||
bl CurrentMapDrawMetatileAt
|
||||
pop {r4,r5}
|
||||
pop {r0}
|
||||
bx r0
|
||||
.align 2, 0
|
||||
_0806EC38: .4byte 0x0000022f
|
||||
_0806EC3C: .4byte 0x00000237
|
||||
thumb_func_end sub_806EC04
|
||||
|
||||
thumb_func_start sub_806EC40
|
||||
sub_806EC40: @ 806EC40
|
||||
push {r4-r7,lr}
|
||||
sub sp, 0x4
|
||||
lsls r0, 24
|
||||
lsrs r0, 24
|
||||
lsls r1, r0, 2
|
||||
adds r1, r0
|
||||
lsls r1, 3
|
||||
ldr r0, _0806ED10 @ =gTasks+0x8
|
||||
adds r5, r1, r0
|
||||
mov r4, sp
|
||||
adds r4, 0x2
|
||||
mov r0, sp
|
||||
adds r1, r4, 0
|
||||
bl PlayerGetDestCoords
|
||||
mov r0, sp
|
||||
movs r1, 0
|
||||
ldrsh r0, [r0, r1]
|
||||
movs r2, 0
|
||||
ldrsh r1, [r4, r2]
|
||||
bl MapGridGetMetatileBehaviorAt
|
||||
lsls r0, 16
|
||||
lsrs r7, r0, 16
|
||||
ldrh r1, [r5, 0x8]
|
||||
movs r3, 0x8
|
||||
ldrsh r0, [r5, r3]
|
||||
adds r6, r4, 0
|
||||
cmp r0, 0
|
||||
beq _0806EC92
|
||||
subs r0, r1, 0x1
|
||||
strh r0, [r5, 0x8]
|
||||
lsls r0, 16
|
||||
cmp r0, 0
|
||||
bne _0806EC92
|
||||
movs r1, 0xA
|
||||
ldrsh r0, [r5, r1]
|
||||
movs r2, 0xC
|
||||
ldrsh r1, [r5, r2]
|
||||
bl sub_806EC04
|
||||
_0806EC92:
|
||||
ldrh r1, [r5, 0xE]
|
||||
movs r3, 0xE
|
||||
ldrsh r0, [r5, r3]
|
||||
cmp r0, 0
|
||||
beq _0806ECB2
|
||||
subs r0, r1, 0x1
|
||||
strh r0, [r5, 0xE]
|
||||
lsls r0, 16
|
||||
cmp r0, 0
|
||||
bne _0806ECB2
|
||||
movs r1, 0x10
|
||||
ldrsh r0, [r5, r1]
|
||||
movs r2, 0x12
|
||||
ldrsh r1, [r5, r2]
|
||||
bl sub_806EC04
|
||||
_0806ECB2:
|
||||
mov r0, sp
|
||||
ldrh r2, [r0]
|
||||
movs r3, 0
|
||||
ldrsh r1, [r0, r3]
|
||||
movs r3, 0x4
|
||||
ldrsh r0, [r5, r3]
|
||||
cmp r1, r0
|
||||
bne _0806ECCE
|
||||
movs r0, 0
|
||||
ldrsh r1, [r6, r0]
|
||||
movs r3, 0x6
|
||||
ldrsh r0, [r5, r3]
|
||||
cmp r1, r0
|
||||
beq _0806ED2E
|
||||
_0806ECCE:
|
||||
strh r2, [r5, 0x4]
|
||||
adds r4, r6, 0
|
||||
ldrh r0, [r4]
|
||||
strh r0, [r5, 0x6]
|
||||
lsls r0, r7, 24
|
||||
lsrs r0, 24
|
||||
bl MetatileBehavior_ReturnFalse_13
|
||||
lsls r0, 24
|
||||
cmp r0, 0
|
||||
beq _0806ED2E
|
||||
bl GetPlayerSpeed
|
||||
lsls r0, 16
|
||||
asrs r0, 16
|
||||
cmp r0, 0x4
|
||||
beq _0806ECF8
|
||||
ldr r0, _0806ED14 @ =0x00004030
|
||||
movs r1, 0
|
||||
bl VarSet
|
||||
_0806ECF8:
|
||||
movs r1, 0x8
|
||||
ldrsh r0, [r5, r1]
|
||||
cmp r0, 0
|
||||
bne _0806ED18
|
||||
movs r0, 0x3
|
||||
strh r0, [r5, 0x8]
|
||||
mov r0, sp
|
||||
ldrh r0, [r0]
|
||||
strh r0, [r5, 0xA]
|
||||
ldrh r0, [r4]
|
||||
strh r0, [r5, 0xC]
|
||||
b _0806ED2E
|
||||
.align 2, 0
|
||||
_0806ED10: .4byte gTasks+0x8
|
||||
_0806ED14: .4byte 0x00004030
|
||||
_0806ED18:
|
||||
movs r2, 0xE
|
||||
ldrsh r0, [r5, r2]
|
||||
cmp r0, 0
|
||||
bne _0806ED2E
|
||||
movs r0, 0x3
|
||||
strh r0, [r5, 0xE]
|
||||
mov r0, sp
|
||||
ldrh r0, [r0]
|
||||
strh r0, [r5, 0x10]
|
||||
ldrh r0, [r6]
|
||||
strh r0, [r5, 0x12]
|
||||
_0806ED2E:
|
||||
add sp, 0x4
|
||||
pop {r4-r7}
|
||||
pop {r0}
|
||||
bx r0
|
||||
thumb_func_end sub_806EC40
|
||||
|
||||
thumb_func_start sub_806ED38
|
||||
sub_806ED38: @ 806ED38
|
||||
push {lr}
|
||||
ldr r0, _0806ED4C @ =0x00000829
|
||||
bl FlagSet
|
||||
ldr r0, _0806ED50 @ =0x00000828
|
||||
bl FlagSet
|
||||
pop {r0}
|
||||
bx r0
|
||||
.align 2, 0
|
||||
_0806ED4C: .4byte 0x00000829
|
||||
_0806ED50: .4byte 0x00000828
|
||||
thumb_func_end sub_806ED38
|
||||
|
||||
.align 2, 0 @ Don't pad with nop.
|
||||
+3
-3
@@ -1737,7 +1737,7 @@ _080558D4:
|
||||
bl RoamerMove
|
||||
bl sub_8110920
|
||||
bl DoCurrentWeather
|
||||
bl wild_encounter_reset_coro_args
|
||||
bl ResetFieldTasksArgs
|
||||
bl mapheader_run_script_with_tag_x5
|
||||
bl sub_80561B4
|
||||
ldr r1, _0805591C @ =gMapHeader
|
||||
@@ -4648,7 +4648,7 @@ _08057056:
|
||||
bl sub_807B1B8
|
||||
cmp r4, 0
|
||||
bne _0805706A
|
||||
bl sub_806E87C
|
||||
bl SetUpFieldTasks
|
||||
_0805706A:
|
||||
bl mapheader_run_script_with_tag_x5
|
||||
pop {r4}
|
||||
@@ -5402,7 +5402,7 @@ _0805769C:
|
||||
bl FieldEffectActiveListClear
|
||||
bl sub_8079C08
|
||||
bl sub_807B1B8
|
||||
bl sub_806E87C
|
||||
bl SetUpFieldTasks
|
||||
bl mapheader_run_script_with_tag_x5
|
||||
b _0805772A
|
||||
_080576C2:
|
||||
|
||||
@@ -1,22 +0,0 @@
|
||||
.section .rodata
|
||||
.align 2
|
||||
gUnknown_83A7310:: @ 83A7310
|
||||
.4byte nullsub_40
|
||||
.4byte sub_806EB54
|
||||
.4byte nullsub_40
|
||||
.4byte nullsub_40
|
||||
.4byte sub_806E9E0
|
||||
.4byte nullsub_40
|
||||
.4byte nullsub_40
|
||||
.4byte sub_806EC40
|
||||
|
||||
gUnknown_83A7330:: @ 83A7330
|
||||
.byte 0x08, 0x03
|
||||
.byte 0x0a, 0x05
|
||||
.byte 0x0f, 0x05
|
||||
.byte 0x08, 0x09
|
||||
.byte 0x09, 0x09
|
||||
.byte 0x10, 0x09
|
||||
.byte 0x08, 0x0a
|
||||
.byte 0x09, 0x0a
|
||||
.byte 0x08, 0x0e
|
||||
@@ -9,7 +9,7 @@ FourIsland_IcefallCave_1F_MapScript1_163D54:: @ 8163D54
|
||||
end
|
||||
|
||||
FourIsland_IcefallCave_1F_MapScript2_163D57:: @ 8163D57
|
||||
special sub_806E99C
|
||||
special Special_SetIcefallCaveCrackedIceMetatiles
|
||||
end
|
||||
|
||||
FourIsland_IcefallCave_1F_MapScript3_163D5B:: @ 8163D5B
|
||||
|
||||
+1
-1
@@ -317,7 +317,7 @@ gSpecials:: @ 815FD60
|
||||
def_special Special_DrawElevatorCurrentFloorWindow
|
||||
def_special nullsub_75
|
||||
def_special Special_CheckPartyPokerus
|
||||
def_special sub_806E99C
|
||||
def_special Special_SetIcefallCaveCrackedIceMetatiles
|
||||
def_special Special_ShakeScreen
|
||||
def_special Special_StartGroudonKyogreBattle
|
||||
def_special Special_StartLegendaryBattle
|
||||
|
||||
@@ -4,5 +4,6 @@
|
||||
void sub_80BD620(u32 unkC, u32 unk10);
|
||||
bool8 sub_80BD540(void);
|
||||
void StartTransitionToFlipBikeState(u8 flags);
|
||||
s16 GetPlayerSpeed(void);
|
||||
|
||||
#endif //GUARD_BIKE_H
|
||||
|
||||
@@ -15,5 +15,6 @@
|
||||
u8 sub_8154228(void);
|
||||
bool8 sub_8155DA0(struct ObjectEvent *);
|
||||
void sub_80DC44C(u8, u8);
|
||||
void StartAshFieldEffect(s16, s16, u16, s16);
|
||||
|
||||
#endif //GUARD_FIELD_EFFECT_HELPERS_H
|
||||
|
||||
@@ -148,4 +148,6 @@ void sub_8055778(int);
|
||||
|
||||
void sub_8055738(u8 loc);
|
||||
|
||||
void sub_8056078(void *, void *);
|
||||
|
||||
#endif //GUARD_OVERWORLD_H
|
||||
|
||||
+2
-2
@@ -106,7 +106,7 @@ SECTIONS {
|
||||
asm/field_control_avatar.o(.text);
|
||||
src/event_data.o(.text);
|
||||
src/coord_event_weather.o(.text);
|
||||
asm/field_tasks.o(.text);
|
||||
src/field_tasks.o(.text);
|
||||
src/start_menu.o(.text);
|
||||
src/tileset_anims.o(.text);
|
||||
src/palette.o(.text);
|
||||
@@ -421,7 +421,7 @@ SECTIONS {
|
||||
data/event_object_80688E4.o(.rodata);
|
||||
src/scrcmd.o(.rodata);
|
||||
src/coord_event_weather.o(.rodata);
|
||||
data/field_tasks.o(.rodata);
|
||||
src/field_tasks.o(.rodata);
|
||||
src/start_menu.o(.rodata);
|
||||
src/tileset_anims.o(.rodata);
|
||||
src/palette.o(.rodata);
|
||||
|
||||
@@ -0,0 +1,293 @@
|
||||
#include "global.h"
|
||||
#include "bike.h"
|
||||
#include "event_data.h"
|
||||
#include "field_camera.h"
|
||||
#include "field_effect_helpers.h"
|
||||
#include "field_player_avatar.h"
|
||||
#include "fieldmap.h"
|
||||
#include "metatile_behavior.h"
|
||||
#include "overworld.h"
|
||||
#include "quest_log.h"
|
||||
#include "script.h"
|
||||
#include "sound.h"
|
||||
#include "task.h"
|
||||
#include "constants/flags.h"
|
||||
#include "constants/songs.h"
|
||||
#include "constants/vars.h"
|
||||
|
||||
static void DummyPerStepCallback(u8 taskId);
|
||||
static void AshGrassPerStepCallback(u8 taskId);
|
||||
static void IcefallCaveIcePerStepCallback(u8 taskId);
|
||||
static void CrackedFloorPerStepCallback(u8 taskId);
|
||||
|
||||
static const TaskFunc sPerStepCallbacks[] =
|
||||
{
|
||||
DummyPerStepCallback,
|
||||
AshGrassPerStepCallback,
|
||||
DummyPerStepCallback,
|
||||
DummyPerStepCallback,
|
||||
IcefallCaveIcePerStepCallback,
|
||||
DummyPerStepCallback,
|
||||
DummyPerStepCallback,
|
||||
CrackedFloorPerStepCallback
|
||||
};
|
||||
|
||||
static const u8 sIcefallCaveIceTileCoords[][2] =
|
||||
{
|
||||
{ 0x08, 0x03 },
|
||||
{ 0x0a, 0x05 },
|
||||
{ 0x0f, 0x05 },
|
||||
{ 0x08, 0x09 },
|
||||
{ 0x09, 0x09 },
|
||||
{ 0x10, 0x09 },
|
||||
{ 0x08, 0x0a },
|
||||
{ 0x09, 0x0a },
|
||||
{ 0x08, 0x0e }
|
||||
};
|
||||
|
||||
static void Task_RunPerStepCallback(u8 taskId)
|
||||
{
|
||||
int idx = gTasks[taskId].data[0];
|
||||
sPerStepCallbacks[idx](taskId);
|
||||
}
|
||||
|
||||
static void Task_RunTimeBasedEvents(u8 taskId)
|
||||
{
|
||||
s16 *data = gTasks[taskId].data;
|
||||
|
||||
if (!ScriptContext2_IsEnabled())
|
||||
{
|
||||
if (gUnknown_203ADFA != 2 && gUnknown_203ADFA != 3)
|
||||
{
|
||||
sub_8056078(&data[1], &data[2]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void SetUpFieldTasks(void)
|
||||
{
|
||||
if (!FuncIsActiveTask(Task_RunPerStepCallback))
|
||||
{
|
||||
u8 taskId = CreateTask(Task_RunPerStepCallback, 0x50);
|
||||
gTasks[taskId].data[0] = 0;
|
||||
}
|
||||
|
||||
if (!FuncIsActiveTask(Task_RunTimeBasedEvents))
|
||||
CreateTask(Task_RunTimeBasedEvents, 0x50);
|
||||
}
|
||||
|
||||
void ActivatePerStepCallback(u8 callbackId)
|
||||
{
|
||||
u8 taskId = FindTaskIdByFunc(Task_RunPerStepCallback);
|
||||
if (taskId != 0xff)
|
||||
{
|
||||
s32 i;
|
||||
s16 *data = gTasks[taskId].data;
|
||||
|
||||
for (i = 0; i < 16; i++)
|
||||
data[i] = 0;
|
||||
|
||||
if (callbackId >= NELEMS(sPerStepCallbacks))
|
||||
{
|
||||
data[0] = 0;
|
||||
}
|
||||
else
|
||||
{
|
||||
data[0] = callbackId;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void ResetFieldTasksArgs(void)
|
||||
{
|
||||
u8 taskId;
|
||||
s16 *data;
|
||||
|
||||
taskId = FindTaskIdByFunc(Task_RunPerStepCallback);
|
||||
if (taskId != 0xff)
|
||||
{
|
||||
data = gTasks[taskId].data;
|
||||
}
|
||||
taskId = FindTaskIdByFunc(Task_RunTimeBasedEvents);
|
||||
if (taskId != 0xff)
|
||||
{
|
||||
data = gTasks[taskId].data;
|
||||
data[1] = 0;
|
||||
data[2] = 0;
|
||||
}
|
||||
}
|
||||
|
||||
static void DummyPerStepCallback(u8 taskId)
|
||||
{
|
||||
}
|
||||
|
||||
static void MarkIcefallCaveCoordVisited(s16 x, s16 y)
|
||||
{
|
||||
u8 i = 0;
|
||||
for (; i < NELEMS(sIcefallCaveIceTileCoords); ++i)
|
||||
{
|
||||
if (sIcefallCaveIceTileCoords[i][0] + 7 == x && sIcefallCaveIceTileCoords[i][1] + 7 == y)
|
||||
{
|
||||
FlagSet(i + 1);
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void Special_SetIcefallCaveCrackedIceMetatiles(void)
|
||||
{
|
||||
u8 i = 0;
|
||||
for (; i < NELEMS(sIcefallCaveIceTileCoords); ++i)
|
||||
{
|
||||
if (FlagGet(i + 1) == TRUE)
|
||||
{
|
||||
int x = sIcefallCaveIceTileCoords[i][0] + 7;
|
||||
int y = sIcefallCaveIceTileCoords[i][1] + 7;
|
||||
MapGridSetMetatileIdAt(x, y, 0x35a);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static void IcefallCaveIcePerStepCallback(u8 taskId)
|
||||
{
|
||||
s16 x, y;
|
||||
u8 tileBehavior;
|
||||
u16 *iceStepCount;
|
||||
s16 *data = gTasks[taskId].data;
|
||||
switch (data[1])
|
||||
{
|
||||
case 0:
|
||||
PlayerGetDestCoords(&x, &y);
|
||||
data[2] = x;
|
||||
data[3] = y;
|
||||
data[1] = 1;
|
||||
break;
|
||||
case 1:
|
||||
PlayerGetDestCoords(&x, &y);
|
||||
if (x != data[2] || y != data[3])
|
||||
{
|
||||
data[2] = x;
|
||||
data[3] = y;
|
||||
tileBehavior = MapGridGetMetatileBehaviorAt(x, y);
|
||||
if (MetatileBehavior_IsThinIce(tileBehavior) == TRUE)
|
||||
{
|
||||
MarkIcefallCaveCoordVisited(x, y);
|
||||
data[6] = 4;
|
||||
data[1] = 2;
|
||||
data[4] = x;
|
||||
data[5] = y;
|
||||
}
|
||||
else if (MetatileBehavior_IsCrackedIce(tileBehavior) == TRUE)
|
||||
{
|
||||
data[6] = 4;
|
||||
data[1] = 3;
|
||||
data[4] = x;
|
||||
data[5] = y;
|
||||
}
|
||||
}
|
||||
break;
|
||||
case 2:
|
||||
if (data[6] != 0)
|
||||
{
|
||||
data[6]--;
|
||||
}
|
||||
else
|
||||
{
|
||||
x = data[4];
|
||||
y = data[5];
|
||||
PlaySE(SE_RU_BARI);
|
||||
MapGridSetMetatileIdAt(x, y, 0x35a);
|
||||
CurrentMapDrawMetatileAt(x, y);
|
||||
data[1] = 1;
|
||||
}
|
||||
break;
|
||||
case 3:
|
||||
if (data[6] != 0)
|
||||
{
|
||||
data[6]--;
|
||||
}
|
||||
else
|
||||
{
|
||||
x = data[4];
|
||||
y = data[5];
|
||||
PlaySE(SE_RU_GASYAN);
|
||||
MapGridSetMetatileIdAt(x, y, 0x35b);
|
||||
CurrentMapDrawMetatileAt(x, y);
|
||||
VarSet(VAR_0x4001, 1);
|
||||
data[1] = 1;
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// This is leftover from pokeruby and effectively a no-op.
|
||||
static void AshGrassPerStepCallback(u8 taskId)
|
||||
{
|
||||
s16 x, y;
|
||||
u16 *ashGatherCount;
|
||||
s16 *data = gTasks[taskId].data;
|
||||
PlayerGetDestCoords(&x, &y);
|
||||
if (x != data[1] || y != data[2])
|
||||
{
|
||||
data[1] = x;
|
||||
data[2] = y;
|
||||
if (MetatileBehavior_ReturnFalse_4((u8)MapGridGetMetatileBehaviorAt(x, y)))
|
||||
{
|
||||
if (MapGridGetMetatileIdAt(x, y) == 0x20a)
|
||||
StartAshFieldEffect(x, y, 0x212, 4);
|
||||
else
|
||||
StartAshFieldEffect(x, y, 0x206, 4);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static void SetCrackedFloorHoleMetatile(s16 x, s16 y)
|
||||
{
|
||||
MapGridSetMetatileIdAt(x, y, MapGridGetMetatileIdAt(x, y) == 0x22f ? 0x206 : 0x237);
|
||||
CurrentMapDrawMetatileAt(x, y);
|
||||
}
|
||||
|
||||
// This is leftover from pokeruby and effectively a no-op.
|
||||
static void CrackedFloorPerStepCallback(u8 taskId)
|
||||
{
|
||||
s16 x, y;
|
||||
u16 behavior;
|
||||
s16 *data = gTasks[taskId].data;
|
||||
PlayerGetDestCoords(&x, &y);
|
||||
behavior = MapGridGetMetatileBehaviorAt(x, y);
|
||||
if (data[4] != 0 && (--data[4]) == 0)
|
||||
SetCrackedFloorHoleMetatile(data[5], data[6]);
|
||||
|
||||
if (data[7] != 0 && (--data[7]) == 0)
|
||||
SetCrackedFloorHoleMetatile(data[8], data[9]);
|
||||
|
||||
if ((x != data[2] || y != data[3]))
|
||||
{
|
||||
data[2] = x;
|
||||
data[3] = y;
|
||||
if (MetatileBehavior_ReturnFalse_13(behavior))
|
||||
{
|
||||
if (GetPlayerSpeed() != 4)
|
||||
VarSet(VAR_0x4030, 0);
|
||||
|
||||
if (data[4] == 0)
|
||||
{
|
||||
data[4] = 3;
|
||||
data[5] = x;
|
||||
data[6] = y;
|
||||
}
|
||||
else if (data[7] == 0)
|
||||
{
|
||||
data[7] = 3;
|
||||
data[8] = x;
|
||||
data[9] = y;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static void sub_806ED38(void)
|
||||
{
|
||||
FlagSet(FLAG_SYS_POKEDEX_GET);
|
||||
FlagSet(FLAG_SYS_POKEMON_GET);
|
||||
}
|
||||
Reference in New Issue
Block a user