decomp unk_810C3A4 as part of vs_seeker
This commit is contained in:
@@ -1,389 +0,0 @@
|
||||
.include "asm/macros.inc"
|
||||
.include "constants/constants.inc"
|
||||
|
||||
.syntax unified
|
||||
|
||||
.text
|
||||
|
||||
thumb_func_start sub_810C3A4
|
||||
sub_810C3A4: @ 810C3A4
|
||||
push {lr}
|
||||
ldr r0, _0810C3B4 @ =sub_810C3B8
|
||||
movs r1, 0x50
|
||||
bl CreateTask
|
||||
pop {r0}
|
||||
bx r0
|
||||
.align 2, 0
|
||||
_0810C3B4: .4byte sub_810C3B8
|
||||
thumb_func_end sub_810C3A4
|
||||
|
||||
thumb_func_start sub_810C3B8
|
||||
sub_810C3B8: @ 810C3B8
|
||||
push {r4-r7,lr}
|
||||
lsls r0, 24
|
||||
lsrs r6, r0, 24
|
||||
lsls r0, r6, 2
|
||||
adds r0, r6
|
||||
lsls r0, 3
|
||||
ldr r1, _0810C43C @ =gTasks
|
||||
adds r5, r0, r1
|
||||
movs r1, 0x8
|
||||
ldrsh r0, [r5, r1]
|
||||
cmp r0, 0
|
||||
bne _0810C3E2
|
||||
bl walkrun_is_standing_still
|
||||
lsls r0, 24
|
||||
lsrs r4, r0, 24
|
||||
cmp r4, 0x1
|
||||
bne _0810C3E2
|
||||
bl sub_805C270
|
||||
strh r4, [r5, 0x8]
|
||||
_0810C3E2:
|
||||
movs r1, 0xA
|
||||
ldrsh r0, [r5, r1]
|
||||
cmp r0, 0
|
||||
bne _0810C41C
|
||||
movs r4, 0
|
||||
ldr r7, _0810C440 @ =gMapObjects
|
||||
_0810C3EE:
|
||||
adds r0, r4, 0
|
||||
bl sub_810CF04
|
||||
lsls r0, 24
|
||||
lsrs r0, 24
|
||||
cmp r0, 0x1
|
||||
bne _0810C412
|
||||
lsls r0, r4, 3
|
||||
adds r0, r4
|
||||
lsls r0, 2
|
||||
adds r1, r0, r7
|
||||
ldrb r0, [r1]
|
||||
lsls r0, 30
|
||||
cmp r0, 0
|
||||
blt _0810C436
|
||||
adds r0, r1, 0
|
||||
bl FreezeMapObject
|
||||
_0810C412:
|
||||
adds r0, r4, 0x1
|
||||
lsls r0, 24
|
||||
lsrs r4, r0, 24
|
||||
cmp r4, 0xF
|
||||
bls _0810C3EE
|
||||
_0810C41C:
|
||||
movs r0, 0x1
|
||||
strh r0, [r5, 0xA]
|
||||
movs r1, 0x8
|
||||
ldrsh r0, [r5, r1]
|
||||
cmp r0, 0
|
||||
beq _0810C436
|
||||
adds r0, r6, 0
|
||||
bl DestroyTask
|
||||
bl sub_805C780
|
||||
bl EnableBothScriptContexts
|
||||
_0810C436:
|
||||
pop {r4-r7}
|
||||
pop {r0}
|
||||
bx r0
|
||||
.align 2, 0
|
||||
_0810C43C: .4byte gTasks
|
||||
_0810C440: .4byte gMapObjects
|
||||
thumb_func_end sub_810C3B8
|
||||
|
||||
thumb_func_start sub_810C444
|
||||
sub_810C444: @ 810C444
|
||||
push {r4-r7,lr}
|
||||
mov r7, r8
|
||||
push {r7}
|
||||
sub sp, 0x4
|
||||
ldr r0, _0810C4E0 @ =gSaveBlock1Ptr
|
||||
ldr r0, [r0]
|
||||
movs r1, 0x8E
|
||||
lsls r1, 4
|
||||
adds r1, r0
|
||||
mov r8, r1
|
||||
movs r7, 0
|
||||
ldr r0, _0810C4E4 @ =gMapHeader
|
||||
ldr r1, [r0, 0x4]
|
||||
adds r2, r0, 0
|
||||
ldrb r1, [r1]
|
||||
cmp r7, r1
|
||||
bcs _0810C4D2
|
||||
_0810C466:
|
||||
lsls r0, r7, 1
|
||||
adds r0, r7
|
||||
lsls r0, 3
|
||||
mov r1, r8
|
||||
adds r5, r0, r1
|
||||
ldrh r0, [r5, 0xC]
|
||||
cmp r0, 0x1
|
||||
beq _0810C47A
|
||||
cmp r0, 0x3
|
||||
bne _0810C4C4
|
||||
_0810C47A:
|
||||
ldrb r0, [r5, 0x9]
|
||||
subs r0, 0x4D
|
||||
lsls r0, 24
|
||||
lsrs r0, 24
|
||||
cmp r0, 0x2
|
||||
bhi _0810C4C4
|
||||
bl sub_810CF54
|
||||
lsls r0, 24
|
||||
lsrs r6, r0, 24
|
||||
ldrb r0, [r5]
|
||||
ldr r1, _0810C4E0 @ =gSaveBlock1Ptr
|
||||
ldr r2, [r1]
|
||||
ldrb r1, [r2, 0x5]
|
||||
ldrb r2, [r2, 0x4]
|
||||
mov r3, sp
|
||||
bl TryGetFieldObjectIdByLocalIdAndMap
|
||||
mov r0, sp
|
||||
ldrb r0, [r0]
|
||||
lsls r1, r0, 3
|
||||
adds r1, r0
|
||||
lsls r1, 2
|
||||
ldr r2, _0810C4E8 @ =gMapObjects
|
||||
adds r4, r1, r2
|
||||
bl sub_810CF04
|
||||
lsls r0, 24
|
||||
lsrs r0, 24
|
||||
cmp r0, 0x1
|
||||
bne _0810C4C0
|
||||
adds r0, r4, 0
|
||||
adds r1, r6, 0
|
||||
bl npc_set_running_behaviour_etc
|
||||
_0810C4C0:
|
||||
strb r6, [r5, 0x9]
|
||||
ldr r2, _0810C4E4 @ =gMapHeader
|
||||
_0810C4C4:
|
||||
adds r0, r7, 0x1
|
||||
lsls r0, 24
|
||||
lsrs r7, r0, 24
|
||||
ldr r0, [r2, 0x4]
|
||||
ldrb r0, [r0]
|
||||
cmp r7, r0
|
||||
bcc _0810C466
|
||||
_0810C4D2:
|
||||
add sp, 0x4
|
||||
pop {r3}
|
||||
mov r8, r3
|
||||
pop {r4-r7}
|
||||
pop {r0}
|
||||
bx r0
|
||||
.align 2, 0
|
||||
_0810C4E0: .4byte gSaveBlock1Ptr
|
||||
_0810C4E4: .4byte gMapHeader
|
||||
_0810C4E8: .4byte gMapObjects
|
||||
thumb_func_end sub_810C444
|
||||
|
||||
thumb_func_start sub_810C4EC
|
||||
sub_810C4EC: @ 810C4EC
|
||||
push {r4-r7,lr}
|
||||
movs r0, 0xB5
|
||||
lsls r0, 1
|
||||
movs r1, 0x1
|
||||
bl CheckBagHasItem
|
||||
lsls r0, 24
|
||||
lsrs r0, 24
|
||||
cmp r0, 0x1
|
||||
bne _0810C516
|
||||
ldr r0, _0810C568 @ =gSaveBlock1Ptr
|
||||
ldr r0, [r0]
|
||||
movs r2, 0xC7
|
||||
lsls r2, 3
|
||||
adds r1, r0, r2
|
||||
ldrh r2, [r1]
|
||||
ldrb r0, [r1]
|
||||
cmp r0, 0x63
|
||||
bhi _0810C516
|
||||
adds r0, r2, 0x1
|
||||
strh r0, [r1]
|
||||
_0810C516:
|
||||
ldr r7, _0810C56C @ =0x00000801
|
||||
adds r0, r7, 0
|
||||
bl FlagGet
|
||||
lsls r0, 24
|
||||
lsrs r0, 24
|
||||
cmp r0, 0x1
|
||||
bne _0810C570
|
||||
ldr r6, _0810C568 @ =gSaveBlock1Ptr
|
||||
ldr r0, [r6]
|
||||
movs r5, 0xC7
|
||||
lsls r5, 3
|
||||
adds r3, r0, r5
|
||||
ldrh r2, [r3]
|
||||
lsrs r1, r2, 8
|
||||
movs r4, 0xFF
|
||||
cmp r1, 0x63
|
||||
bhi _0810C548
|
||||
adds r1, 0x1
|
||||
lsls r1, 24
|
||||
movs r0, 0xFF
|
||||
ands r0, r2
|
||||
lsrs r1, 16
|
||||
orrs r0, r1
|
||||
strh r0, [r3]
|
||||
_0810C548:
|
||||
ldr r0, [r6]
|
||||
adds r0, r5
|
||||
ldrh r0, [r0]
|
||||
lsrs r0, 8
|
||||
ands r0, r4
|
||||
cmp r0, 0x64
|
||||
bne _0810C570
|
||||
adds r0, r7, 0
|
||||
bl FlagClear
|
||||
bl sub_810C640
|
||||
bl sub_810D0D0
|
||||
movs r0, 0x1
|
||||
b _0810C572
|
||||
.align 2, 0
|
||||
_0810C568: .4byte gSaveBlock1Ptr
|
||||
_0810C56C: .4byte 0x00000801
|
||||
_0810C570:
|
||||
movs r0, 0
|
||||
_0810C572:
|
||||
pop {r4-r7}
|
||||
pop {r1}
|
||||
bx r1
|
||||
thumb_func_end sub_810C4EC
|
||||
|
||||
thumb_func_start sub_810C578
|
||||
sub_810C578: @ 810C578
|
||||
push {lr}
|
||||
ldr r0, _0810C590 @ =0x00000801
|
||||
bl FlagClear
|
||||
bl sub_810C640
|
||||
bl sub_810D0D0
|
||||
bl sub_810C594
|
||||
pop {r0}
|
||||
bx r0
|
||||
.align 2, 0
|
||||
_0810C590: .4byte 0x00000801
|
||||
thumb_func_end sub_810C578
|
||||
|
||||
thumb_func_start sub_810C594
|
||||
sub_810C594: @ 810C594
|
||||
push {r4-r7,lr}
|
||||
movs r5, 0
|
||||
movs r6, 0
|
||||
_0810C59A:
|
||||
lsls r0, r5, 3
|
||||
adds r0, r5
|
||||
lsls r0, 2
|
||||
ldr r1, _0810C5FC @ =gMapObjects
|
||||
adds r4, r0, r1
|
||||
ldrb r0, [r4, 0x6]
|
||||
subs r0, 0x4D
|
||||
lsls r0, 24
|
||||
lsrs r0, 24
|
||||
cmp r0, 0x2
|
||||
bhi _0810C5EA
|
||||
bl sub_810CF54
|
||||
lsls r0, 24
|
||||
lsrs r3, r0, 24
|
||||
ldrb r0, [r4]
|
||||
lsls r0, 31
|
||||
cmp r0, 0
|
||||
beq _0810C5EA
|
||||
ldr r2, _0810C600 @ =gSprites
|
||||
ldrb r0, [r4, 0x4]
|
||||
lsls r1, r0, 4
|
||||
adds r1, r0
|
||||
lsls r1, 2
|
||||
adds r1, r2
|
||||
movs r7, 0x2E
|
||||
ldrsh r0, [r1, r7]
|
||||
cmp r0, r5
|
||||
bne _0810C5EA
|
||||
strh r6, [r1, 0x24]
|
||||
ldrb r1, [r4, 0x4]
|
||||
lsls r0, r1, 4
|
||||
adds r0, r1
|
||||
lsls r0, 2
|
||||
adds r0, r2
|
||||
strh r6, [r0, 0x26]
|
||||
adds r0, r4, 0
|
||||
adds r1, r3, 0
|
||||
bl npc_set_running_behaviour_etc
|
||||
_0810C5EA:
|
||||
adds r0, r5, 0x1
|
||||
lsls r0, 24
|
||||
lsrs r5, r0, 24
|
||||
cmp r5, 0xF
|
||||
bls _0810C59A
|
||||
pop {r4-r7}
|
||||
pop {r0}
|
||||
bx r0
|
||||
.align 2, 0
|
||||
_0810C5FC: .4byte gMapObjects
|
||||
_0810C600: .4byte gSprites
|
||||
thumb_func_end sub_810C594
|
||||
|
||||
thumb_func_start sub_810C604
|
||||
sub_810C604: @ 810C604
|
||||
ldr r0, _0810C61C @ =gSaveBlock1Ptr
|
||||
ldr r1, [r0]
|
||||
movs r0, 0xC7
|
||||
lsls r0, 3
|
||||
adds r1, r0
|
||||
ldrh r2, [r1]
|
||||
movs r0, 0xFF
|
||||
lsls r0, 8
|
||||
ands r0, r2
|
||||
strh r0, [r1]
|
||||
bx lr
|
||||
.align 2, 0
|
||||
_0810C61C: .4byte gSaveBlock1Ptr
|
||||
thumb_func_end sub_810C604
|
||||
|
||||
thumb_func_start sub_810C620
|
||||
sub_810C620: @ 810C620
|
||||
ldr r0, _0810C63C @ =gSaveBlock1Ptr
|
||||
ldr r2, [r0]
|
||||
movs r0, 0xC7
|
||||
lsls r0, 3
|
||||
adds r2, r0
|
||||
ldrh r1, [r2]
|
||||
movs r0, 0xFF
|
||||
lsls r0, 8
|
||||
ands r0, r1
|
||||
movs r1, 0x64
|
||||
orrs r0, r1
|
||||
strh r0, [r2]
|
||||
bx lr
|
||||
.align 2, 0
|
||||
_0810C63C: .4byte gSaveBlock1Ptr
|
||||
thumb_func_end sub_810C620
|
||||
|
||||
thumb_func_start sub_810C640
|
||||
sub_810C640: @ 810C640
|
||||
ldr r0, _0810C650 @ =gSaveBlock1Ptr
|
||||
ldr r0, [r0]
|
||||
movs r1, 0xC7
|
||||
lsls r1, 3
|
||||
adds r0, r1
|
||||
ldrb r1, [r0]
|
||||
strh r1, [r0]
|
||||
bx lr
|
||||
.align 2, 0
|
||||
_0810C650: .4byte gSaveBlock1Ptr
|
||||
thumb_func_end sub_810C640
|
||||
|
||||
thumb_func_start sub_810C654
|
||||
sub_810C654: @ 810C654
|
||||
ldr r0, _0810C66C @ =gSaveBlock1Ptr
|
||||
ldr r1, [r0]
|
||||
movs r0, 0xC7
|
||||
lsls r0, 3
|
||||
adds r1, r0
|
||||
ldrb r0, [r1]
|
||||
movs r3, 0xC8
|
||||
lsls r3, 7
|
||||
adds r2, r3, 0
|
||||
orrs r0, r2
|
||||
strh r0, [r1]
|
||||
bx lr
|
||||
.align 2, 0
|
||||
_0810C66C: .4byte gSaveBlock1Ptr
|
||||
thumb_func_end sub_810C654
|
||||
|
||||
.align 2, 0 @ Don't pad with nop.
|
||||
+7
-1
@@ -692,6 +692,12 @@ struct TrainerTowerLog
|
||||
u8 unkA_6:2;
|
||||
};
|
||||
|
||||
struct TrainerRematchState
|
||||
{
|
||||
u16 stepCounter;
|
||||
u8 rematches[100];
|
||||
};
|
||||
|
||||
struct SaveBlock1
|
||||
{
|
||||
/*0x0000*/ struct Coords16 pos;
|
||||
@@ -719,7 +725,7 @@ struct SaveBlock1
|
||||
/*0x05F8*/ u8 seen1[DEX_FLAGS_NO];
|
||||
/*0x062C*/ u16 berryBlenderRecords[3]; // unused
|
||||
/*0x0632*/ u8 field_632[6]; // unused?
|
||||
/*0x0638*/ u8 trainerRematchStepCounter;
|
||||
/*0x0638*/ u16 trainerRematchStepCounter;
|
||||
/*0x063A*/ u8 ALIGNED(2) trainerRematches[100];
|
||||
/*0x06A0*/ struct MapObject mapObjects[MAP_OBJECTS_COUNT];
|
||||
/*0x08E0*/ struct MapObjectTemplate mapObjectTemplates[64];
|
||||
|
||||
@@ -4,5 +4,6 @@
|
||||
#include "global.h"
|
||||
|
||||
void player_bitmagic(void);
|
||||
void FreezeMapObject(struct MapObject *);
|
||||
|
||||
#endif //GUARD_MAP_OBJ_80688E4_H
|
||||
|
||||
@@ -10,5 +10,6 @@ void LockSelectedMapObject(void);
|
||||
void sub_8098630(void);
|
||||
bool8 sub_8098734(void);
|
||||
void sub_80696C0(void);
|
||||
bool8 walkrun_is_standing_still(void);
|
||||
|
||||
#endif // GUARD_MAP_OBJ_LOCK_H
|
||||
|
||||
@@ -1,6 +1,25 @@
|
||||
#ifndef GUARD_UNK_810C3A4_H
|
||||
#define GUARD_UNK_810C3A4_H
|
||||
|
||||
#define GET_VS_SEEKER_COUNTER_0() (gSaveBlock1Ptr->trainerRematch.stepCounter & 0xFF)
|
||||
#define GET_VS_SEEKER_COUNTER_1() (gSaveBlock1Ptr->trainerRematch.stepCounter >> 8)
|
||||
#define SET_VS_SEEKER_COUNTER_0(x) ({\
|
||||
gSaveBlock1Ptr->trainerRematch.stepCounter &= 0xFF00;\
|
||||
gSaveBlock1Ptr->trainerRematch.stepCounter |= (x);\
|
||||
})
|
||||
#define SET_VS_SEEKER_COUNTER_1(x) ({\
|
||||
gSaveBlock1Ptr->trainerRematch.stepCounter &= 0x00FF;\
|
||||
gSaveBlock1Ptr->trainerRematch.stepCounter |= ((x) << 8);\
|
||||
})
|
||||
#define INC_VS_SEEKER_COUNTER_0() ({\
|
||||
u8 x = GET_VS_SEEKER_COUNTER_0();\
|
||||
if (x < 100) gSaveBlock1Ptr->trainerRematch.stepCounter++;\
|
||||
})
|
||||
#define INC_VS_SEEKER_COUNTER_1() ({\
|
||||
u8 x = GET_VS_SEEKER_COUNTER_1();\
|
||||
if (x < 100) {x++; SET_VS_SEEKER_COUNTER_1(x);}\
|
||||
})
|
||||
|
||||
void sub_810C604(void);
|
||||
void sub_810C640(void);
|
||||
|
||||
|
||||
@@ -213,7 +213,6 @@ SECTIONS {
|
||||
asm/save_location.o(.text);
|
||||
src/bag.o(.text);
|
||||
src/trainer_pokemon_sprites.o(.text);
|
||||
asm/unk_810C3A4.o(.text);
|
||||
src/vs_seeker.o(.text);
|
||||
asm/item_pc.o(.text);
|
||||
asm/mailbox_pc.o(.text);
|
||||
|
||||
+228
-2
@@ -19,6 +19,7 @@
|
||||
#include "random.h"
|
||||
#include "field_map_obj.h"
|
||||
#include "field_player_avatar.h"
|
||||
#include "map_obj_80688E4.h"
|
||||
#include "map_obj_8097404.h"
|
||||
#include "unk_810c3a4.h"
|
||||
#include "constants/movement_commands.h"
|
||||
@@ -70,6 +71,8 @@ extern u8 gSelectedEventObject;
|
||||
// static declarations
|
||||
static EWRAM_DATA struct VsSeekerStruct *sVsSeeker = NULL;
|
||||
|
||||
static void sub_810C3B8(u8 taskId);
|
||||
static void sub_810C594(void);
|
||||
static void Task_VsSeeker_1(u8 taskId);
|
||||
static void Task_VsSeeker_2(u8 taskId);
|
||||
static void GatherNearbyTrainerInfo(void);
|
||||
@@ -565,6 +568,229 @@ static const u8 gUnknown_8453F67[] = { 0x08, 0x08, 0x07, 0x09, 0x0a };
|
||||
|
||||
|
||||
// text
|
||||
|
||||
|
||||
void sub_810C3A4(void)
|
||||
{
|
||||
CreateTask(sub_810C3B8, 80);
|
||||
}
|
||||
|
||||
static void sub_810C3B8(u8 taskId)
|
||||
{
|
||||
struct Task * task = &gTasks[taskId];
|
||||
u8 i;
|
||||
|
||||
if (task->data[0] == 0 && walkrun_is_standing_still() == TRUE)
|
||||
{
|
||||
sub_805C270();
|
||||
task->data[0] = 1;
|
||||
}
|
||||
|
||||
if (task->data[1] == 0)
|
||||
{
|
||||
for (i = 0; i < MAP_OBJECTS_COUNT; i++)
|
||||
{
|
||||
if (sub_810CF04(i) == TRUE)
|
||||
{
|
||||
if (gMapObjects[i].mapobj_bit_1)
|
||||
return;
|
||||
FreezeMapObject(&gMapObjects[i]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
task->data[1] = 1;
|
||||
if (task->data[0] != 0)
|
||||
{
|
||||
DestroyTask(taskId);
|
||||
sub_805C780();
|
||||
EnableBothScriptContexts();
|
||||
}
|
||||
}
|
||||
|
||||
void sub_810C444(void)
|
||||
{
|
||||
struct MapObjectTemplate * templates = gSaveBlock1Ptr->mapObjectTemplates;
|
||||
u8 i;
|
||||
u8 r6;
|
||||
u8 sp0;
|
||||
struct MapObject * mapObject;
|
||||
|
||||
for (i = 0; i < gMapHeader.events->mapObjectCount; i++)
|
||||
{
|
||||
if ((templates[i].unkC == 1 || templates[i].unkC == 3) && (templates[i].movementType == 0x4D || templates[i].movementType == 0x4E || templates[i].movementType == 0x4F))
|
||||
{
|
||||
r6 = sub_810CF54();
|
||||
TryGetFieldObjectIdByLocalIdAndMap(templates[i].localId, gSaveBlock1Ptr->location.mapNum, gSaveBlock1Ptr->location.mapGroup, &sp0);
|
||||
mapObject = &gMapObjects[sp0];
|
||||
if (sub_810CF04(sp0) == TRUE)
|
||||
{
|
||||
npc_set_running_behaviour_etc(mapObject, r6);
|
||||
}
|
||||
templates[i].movementType = r6;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#ifdef NONMATCHING
|
||||
bool8 sub_810C4EC(void)
|
||||
{
|
||||
if (CheckBagHasItem(ITEM_VS_SEEKER, 1) == TRUE)
|
||||
{
|
||||
if ((gSaveBlock1Ptr->trainerRematchStepCounter & 0xFF) < 100)
|
||||
gSaveBlock1Ptr->trainerRematchStepCounter++;
|
||||
}
|
||||
|
||||
if (FlagGet(0x801) == TRUE)
|
||||
{
|
||||
u16 x;
|
||||
do {
|
||||
x = (gSaveBlock1Ptr->trainerRematchStepCounter >> 8) & 0xFF;
|
||||
} while (0);
|
||||
if (x < 100)
|
||||
{
|
||||
x++;
|
||||
gSaveBlock1Ptr->trainerRematchStepCounter = ((u16)(x << 8)) | (gSaveBlock1Ptr->trainerRematchStepCounter & 0xFF);
|
||||
}
|
||||
do {
|
||||
x = (gSaveBlock1Ptr->trainerRematchStepCounter >> 8) & 0xFF;
|
||||
} while (0);
|
||||
if (x == 100)
|
||||
{
|
||||
FlagClear(0x801);
|
||||
sub_810C640();
|
||||
sub_810D0D0();
|
||||
return TRUE;
|
||||
}
|
||||
}
|
||||
|
||||
return FALSE;
|
||||
}
|
||||
#else
|
||||
NAKED
|
||||
bool8 sub_810C4EC(void)
|
||||
{
|
||||
asm_unified("\tpush {r4-r7,lr}\n"
|
||||
"\tmovs r0, 0xB5\n"
|
||||
"\tlsls r0, 1\n"
|
||||
"\tmovs r1, 0x1\n"
|
||||
"\tbl CheckBagHasItem\n"
|
||||
"\tlsls r0, 24\n"
|
||||
"\tlsrs r0, 24\n"
|
||||
"\tcmp r0, 0x1\n"
|
||||
"\tbne _0810C516\n"
|
||||
"\tldr r0, _0810C568 @ =gSaveBlock1Ptr\n"
|
||||
"\tldr r0, [r0]\n"
|
||||
"\tmovs r2, 0xC7\n"
|
||||
"\tlsls r2, 3\n"
|
||||
"\tadds r1, r0, r2\n"
|
||||
"\tldrh r2, [r1]\n"
|
||||
"\tldrb r0, [r1]\n"
|
||||
"\tcmp r0, 0x63\n"
|
||||
"\tbhi _0810C516\n"
|
||||
"\tadds r0, r2, 0x1\n"
|
||||
"\tstrh r0, [r1]\n"
|
||||
"_0810C516:\n"
|
||||
"\tldr r7, _0810C56C @ =0x00000801\n"
|
||||
"\tadds r0, r7, 0\n"
|
||||
"\tbl FlagGet\n"
|
||||
"\tlsls r0, 24\n"
|
||||
"\tlsrs r0, 24\n"
|
||||
"\tcmp r0, 0x1\n"
|
||||
"\tbne _0810C570\n"
|
||||
"\tldr r6, _0810C568 @ =gSaveBlock1Ptr\n"
|
||||
"\tldr r0, [r6]\n"
|
||||
"\tmovs r5, 0xC7\n"
|
||||
"\tlsls r5, 3\n"
|
||||
"\tadds r3, r0, r5\n"
|
||||
"\tldrh r2, [r3]\n"
|
||||
"\tlsrs r1, r2, 8\n"
|
||||
"\tmovs r4, 0xFF\n"
|
||||
"\tcmp r1, 0x63\n"
|
||||
"\tbhi _0810C548\n"
|
||||
"\tadds r1, 0x1\n"
|
||||
"\tlsls r1, 24\n"
|
||||
"\tmovs r0, 0xFF\n"
|
||||
"\tands r0, r2\n"
|
||||
"\tlsrs r1, 16\n"
|
||||
"\torrs r0, r1\n"
|
||||
"\tstrh r0, [r3]\n"
|
||||
"_0810C548:\n"
|
||||
"\tldr r0, [r6]\n"
|
||||
"\tadds r0, r5\n"
|
||||
"\tldrh r0, [r0]\n"
|
||||
"\tlsrs r0, 8\n"
|
||||
"\tands r0, r4\n"
|
||||
"\tcmp r0, 0x64\n"
|
||||
"\tbne _0810C570\n"
|
||||
"\tadds r0, r7, 0\n"
|
||||
"\tbl FlagClear\n"
|
||||
"\tbl sub_810C640\n"
|
||||
"\tbl sub_810D0D0\n"
|
||||
"\tmovs r0, 0x1\n"
|
||||
"\tb _0810C572\n"
|
||||
"\t.align 2, 0\n"
|
||||
"_0810C568: .4byte gSaveBlock1Ptr\n"
|
||||
"_0810C56C: .4byte 0x00000801\n"
|
||||
"_0810C570:\n"
|
||||
"\tmovs r0, 0\n"
|
||||
"_0810C572:\n"
|
||||
"\tpop {r4-r7}\n"
|
||||
"\tpop {r1}\n"
|
||||
"\tbx r1");
|
||||
}
|
||||
#endif
|
||||
|
||||
void sub_810C578(void)
|
||||
{
|
||||
FlagClear(0x801);
|
||||
sub_810C640();
|
||||
sub_810D0D0();
|
||||
sub_810C594();
|
||||
}
|
||||
|
||||
static void sub_810C594(void)
|
||||
{
|
||||
u8 i;
|
||||
|
||||
for (i = 0; i < MAP_OBJECTS_COUNT; i++)
|
||||
{
|
||||
struct MapObject * mapObject = &gMapObjects[i];
|
||||
if (mapObject->animPattern == 0x4D || mapObject->animPattern == 0x4E || mapObject->animPattern == 0x4F)
|
||||
{
|
||||
u8 r3 = sub_810CF54();
|
||||
if (mapObject->active && gSprites[mapObject->spriteId].data[0] == i)
|
||||
{
|
||||
gSprites[mapObject->spriteId].pos2.x = 0;
|
||||
gSprites[mapObject->spriteId].pos2.y = 0;
|
||||
npc_set_running_behaviour_etc(mapObject, r3);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void sub_810C604(void)
|
||||
{
|
||||
gSaveBlock1Ptr->trainerRematchStepCounter &= 0xFF00;
|
||||
}
|
||||
|
||||
void sub_810C620(void)
|
||||
{
|
||||
gSaveBlock1Ptr->trainerRematchStepCounter &= 0xFF00;
|
||||
gSaveBlock1Ptr->trainerRematchStepCounter |= 100;
|
||||
}
|
||||
|
||||
void sub_810C640(void)
|
||||
{
|
||||
gSaveBlock1Ptr->trainerRematchStepCounter &= 0x00FF;
|
||||
}
|
||||
|
||||
void sub_810C654(void)
|
||||
{
|
||||
gSaveBlock1Ptr->trainerRematchStepCounter &= 0x00FF;
|
||||
gSaveBlock1Ptr->trainerRematchStepCounter |= (100 << 8);
|
||||
}
|
||||
|
||||
void Task_VsSeeker_0(u8 taskId)
|
||||
{
|
||||
u8 i;
|
||||
@@ -1225,7 +1451,7 @@ static u16 GetTrainerFlagFromScript(const u8 *script)
|
||||
* because the ARM processor requires shorts to be 16-bit
|
||||
* aligned, this function needs to perform explicit bitwise
|
||||
* operations to get the correct flag.
|
||||
*
|
||||
*
|
||||
* 5c XX YY ZZ ...
|
||||
* -- --
|
||||
*/
|
||||
@@ -1360,7 +1586,7 @@ static void StartAllRespondantIdleMovements(void)
|
||||
u8 dummy = 0;
|
||||
s32 i;
|
||||
s32 j;
|
||||
|
||||
|
||||
for (i = 0; i < sVsSeeker->numRematchableTrainers; i++)
|
||||
{
|
||||
for (j = 0; sVsSeeker->trainerInfo[j].localId != 0xFF; j++)
|
||||
|
||||
Reference in New Issue
Block a user