diff options
-rw-r--r-- | asm/field_effect_helpers.s | 6 | ||||
-rw-r--r-- | asm/field_tasks.s | 697 | ||||
-rw-r--r-- | asm/overworld.s | 6 | ||||
-rw-r--r-- | data/field_tasks.s | 22 | ||||
-rw-r--r-- | data/maps/FourIsland_IcefallCave_1F/scripts.inc | 2 | ||||
-rw-r--r-- | data/specials.inc | 2 | ||||
-rw-r--r-- | include/bike.h | 1 | ||||
-rw-r--r-- | include/field_effect_helpers.h | 1 | ||||
-rw-r--r-- | include/overworld.h | 2 | ||||
-rw-r--r-- | ld_script.txt | 4 | ||||
-rw-r--r-- | src/field_tasks.c | 293 |
11 files changed, 307 insertions, 729 deletions
diff --git a/asm/field_effect_helpers.s b/asm/field_effect_helpers.s index 3f2cf04d1..2797accf4 100644 --- a/asm/field_effect_helpers.s +++ b/asm/field_effect_helpers.s @@ -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 diff --git a/asm/field_tasks.s b/asm/field_tasks.s deleted file mode 100644 index b4106c021..000000000 --- a/asm/field_tasks.s +++ /dev/null @@ -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. diff --git a/asm/overworld.s b/asm/overworld.s index 47c5d26af..3fab3a71d 100644 --- a/asm/overworld.s +++ b/asm/overworld.s @@ -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: diff --git a/data/field_tasks.s b/data/field_tasks.s deleted file mode 100644 index 2ff9ad215..000000000 --- a/data/field_tasks.s +++ /dev/null @@ -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 diff --git a/data/maps/FourIsland_IcefallCave_1F/scripts.inc b/data/maps/FourIsland_IcefallCave_1F/scripts.inc index 451541b8c..1c3d8da1f 100644 --- a/data/maps/FourIsland_IcefallCave_1F/scripts.inc +++ b/data/maps/FourIsland_IcefallCave_1F/scripts.inc @@ -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 diff --git a/data/specials.inc b/data/specials.inc index 74ba0c849..f7ca055ef 100644 --- a/data/specials.inc +++ b/data/specials.inc @@ -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 diff --git a/include/bike.h b/include/bike.h index 68cc5f5c9..30049ee8c 100644 --- a/include/bike.h +++ b/include/bike.h @@ -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 diff --git a/include/field_effect_helpers.h b/include/field_effect_helpers.h index f2a4f83a7..e1a56a26c 100644 --- a/include/field_effect_helpers.h +++ b/include/field_effect_helpers.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 diff --git a/include/overworld.h b/include/overworld.h index 845550a17..97cf245e5 100644 --- a/include/overworld.h +++ b/include/overworld.h @@ -148,4 +148,6 @@ void sub_8055778(int); void sub_8055738(u8 loc); +void sub_8056078(void *, void *); + #endif //GUARD_OVERWORLD_H diff --git a/ld_script.txt b/ld_script.txt index f3e5177a8..6ba2ccd27 100644 --- a/ld_script.txt +++ b/ld_script.txt @@ -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); diff --git a/src/field_tasks.c b/src/field_tasks.c new file mode 100644 index 000000000..7ca6d0e7b --- /dev/null +++ b/src/field_tasks.c @@ -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); +} |