mirror of https://github.com/zeldaret/tmc.git
Merge pull request #585 from hatal175/sub_08079550
This commit is contained in:
commit
3dd736ef98
|
@ -1,218 +0,0 @@
|
||||||
.syntax unified
|
|
||||||
push {r4, r5, r6, r7, lr}
|
|
||||||
mov r7, sb
|
|
||||||
mov r6, r8
|
|
||||||
push {r6, r7}
|
|
||||||
ldr r0, _080795A8 @ =gDiggingCaveEntranceTransition
|
|
||||||
ldrb r0, [r0, #8]
|
|
||||||
cmp r0, #0
|
|
||||||
beq _08079562
|
|
||||||
b _080796FC
|
|
||||||
_08079562:
|
|
||||||
ldr r2, _080795AC @ =gPlayerState
|
|
||||||
ldrb r0, [r2, #0x1e]
|
|
||||||
cmp r0, #0
|
|
||||||
beq _08079576
|
|
||||||
ldr r0, [r2, #0x30]
|
|
||||||
movs r1, #0x80
|
|
||||||
lsls r1, r1, #3
|
|
||||||
ands r0, r1
|
|
||||||
cmp r0, #0
|
|
||||||
beq _080795B4
|
|
||||||
_08079576:
|
|
||||||
adds r0, r2, #0
|
|
||||||
adds r0, #0x26
|
|
||||||
ldrb r0, [r0]
|
|
||||||
ldr r1, _080795B0 @ =gPlayerEntity
|
|
||||||
mov r8, r1
|
|
||||||
cmp r0, #0
|
|
||||||
bne _080795A0
|
|
||||||
ldrb r1, [r2, #0x1b]
|
|
||||||
movs r0, #0x40
|
|
||||||
ands r0, r1
|
|
||||||
cmp r0, #0
|
|
||||||
bne _080795A0
|
|
||||||
mov r3, r8
|
|
||||||
ldrb r1, [r3, #0x15]
|
|
||||||
ldrb r2, [r2, #0xd]
|
|
||||||
cmp r1, r2
|
|
||||||
bne _080795A0
|
|
||||||
movs r0, #0x80
|
|
||||||
ands r0, r1
|
|
||||||
cmp r0, #0
|
|
||||||
beq _080795B4
|
|
||||||
_080795A0:
|
|
||||||
movs r0, #0
|
|
||||||
mov r5, r8
|
|
||||||
strb r0, [r5, #0xf]
|
|
||||||
b _080796FE
|
|
||||||
.align 2, 0
|
|
||||||
_080795A8: .4byte gDiggingCaveEntranceTransition
|
|
||||||
_080795AC: .4byte gPlayerState
|
|
||||||
_080795B0: .4byte gPlayerEntity
|
|
||||||
_080795B4:
|
|
||||||
bl sub_08079778
|
|
||||||
cmp r0, #0
|
|
||||||
bne _080795BE
|
|
||||||
b _080796FC
|
|
||||||
_080795BE:
|
|
||||||
ldr r3, _08079610 @ =gPlayerEntity
|
|
||||||
ldrb r2, [r3, #0x14]
|
|
||||||
movs r0, #6
|
|
||||||
ands r0, r2
|
|
||||||
ldr r1, _08079614 @ =gUnk_0811C100
|
|
||||||
adds r1, r0, r1
|
|
||||||
movs r0, #2
|
|
||||||
ands r0, r2
|
|
||||||
mov r8, r3
|
|
||||||
cmp r0, #0
|
|
||||||
beq _0807961C
|
|
||||||
movs r6, #0x2e
|
|
||||||
ldrsh r2, [r3, r6]
|
|
||||||
movs r0, #0
|
|
||||||
ldrsb r0, [r1, r0]
|
|
||||||
adds r2, r2, r0
|
|
||||||
ldr r4, _08079618 @ =gRoomControls
|
|
||||||
ldrh r0, [r4, #6]
|
|
||||||
subs r2, r2, r0
|
|
||||||
asrs r2, r2, #4
|
|
||||||
movs r3, #0x3f
|
|
||||||
ands r2, r3
|
|
||||||
mov r0, r8
|
|
||||||
movs r5, #0x32
|
|
||||||
ldrsh r1, [r0, r5]
|
|
||||||
ldr r0, [r0, #0x48]
|
|
||||||
ldrb r5, [r0, #3]
|
|
||||||
adds r0, r1, r5
|
|
||||||
ldrh r4, [r4, #8]
|
|
||||||
subs r0, r0, r4
|
|
||||||
asrs r0, r0, #4
|
|
||||||
ands r0, r3
|
|
||||||
lsls r7, r0, #6
|
|
||||||
orrs r7, r2
|
|
||||||
subs r1, r1, r5
|
|
||||||
subs r1, r1, r4
|
|
||||||
asrs r1, r1, #4
|
|
||||||
ands r1, r3
|
|
||||||
lsls r4, r1, #6
|
|
||||||
orrs r4, r2
|
|
||||||
b _0807965E
|
|
||||||
.align 2, 0
|
|
||||||
_08079610: .4byte gPlayerEntity
|
|
||||||
_08079614: .4byte gUnk_0811C100
|
|
||||||
_08079618: .4byte gRoomControls
|
|
||||||
_0807961C:
|
|
||||||
mov r6, r8
|
|
||||||
movs r0, #0x2e
|
|
||||||
ldrsh r2, [r6, r0]
|
|
||||||
ldr r0, [r6, #0x48]
|
|
||||||
ldrb r0, [r0, #4]
|
|
||||||
mov ip, r0
|
|
||||||
adds r0, r2, r0
|
|
||||||
ldr r4, _080796EC @ =gRoomControls
|
|
||||||
ldrh r3, [r4, #6]
|
|
||||||
mov sb, r3
|
|
||||||
subs r0, r0, r3
|
|
||||||
asrs r7, r0, #4
|
|
||||||
movs r3, #0x3f
|
|
||||||
ands r7, r3
|
|
||||||
movs r5, #0x32
|
|
||||||
ldrsh r0, [r6, r5]
|
|
||||||
ldrb r1, [r1, #1]
|
|
||||||
lsls r1, r1, #0x18
|
|
||||||
asrs r1, r1, #0x18
|
|
||||||
adds r0, r0, r1
|
|
||||||
ldrh r1, [r4, #8]
|
|
||||||
subs r0, r0, r1
|
|
||||||
asrs r0, r0, #4
|
|
||||||
ands r0, r3
|
|
||||||
lsls r0, r0, #6
|
|
||||||
orrs r7, r0
|
|
||||||
mov r6, ip
|
|
||||||
subs r2, r2, r6
|
|
||||||
mov r1, sb
|
|
||||||
subs r2, r2, r1
|
|
||||||
asrs r4, r2, #4
|
|
||||||
ands r4, r3
|
|
||||||
orrs r4, r0
|
|
||||||
_0807965E:
|
|
||||||
adds r0, r7, #0
|
|
||||||
mov r5, r8
|
|
||||||
adds r5, #0x38
|
|
||||||
ldrb r1, [r5]
|
|
||||||
bl sub_080B1AE0
|
|
||||||
adds r3, r0, #0
|
|
||||||
ldr r6, _080796F0 @ =gUnk_0811C1E8
|
|
||||||
mov r1, r8
|
|
||||||
ldrb r0, [r1, #0x14]
|
|
||||||
lsrs r0, r0, #1
|
|
||||||
lsls r0, r0, #2
|
|
||||||
adds r0, r0, r6
|
|
||||||
ldr r1, [r0]
|
|
||||||
adds r0, r3, #0
|
|
||||||
bl sub_08007DD6
|
|
||||||
adds r3, r0, #0
|
|
||||||
cmp r3, #0
|
|
||||||
beq _080796FC
|
|
||||||
adds r0, r4, #0
|
|
||||||
ldrb r1, [r5]
|
|
||||||
bl sub_080B1AE0
|
|
||||||
adds r3, r0, #0
|
|
||||||
mov r5, r8
|
|
||||||
ldrb r0, [r5, #0x14]
|
|
||||||
lsrs r0, r0, #1
|
|
||||||
lsls r0, r0, #2
|
|
||||||
adds r0, r0, r6
|
|
||||||
ldr r1, [r0]
|
|
||||||
adds r0, r3, #0
|
|
||||||
bl sub_08007DD6
|
|
||||||
adds r3, r0, #0
|
|
||||||
cmp r3, #0
|
|
||||||
beq _080796FC
|
|
||||||
ldr r1, _080796F4 @ =gPlayerState
|
|
||||||
ldrb r2, [r1, #6]
|
|
||||||
movs r0, #0x80
|
|
||||||
orrs r0, r2
|
|
||||||
strb r0, [r1, #6]
|
|
||||||
ldrb r0, [r1, #0x1e]
|
|
||||||
adds r4, r1, #0
|
|
||||||
cmp r0, #0
|
|
||||||
bne _080796C8
|
|
||||||
ldrb r0, [r5, #0xf]
|
|
||||||
adds r0, #1
|
|
||||||
strb r0, [r5, #0xf]
|
|
||||||
lsls r0, r0, #0x18
|
|
||||||
lsrs r0, r0, #0x18
|
|
||||||
cmp r0, #5
|
|
||||||
bls _080796FC
|
|
||||||
_080796C8:
|
|
||||||
ldr r0, _080796F8 @ =gPlayerEntity
|
|
||||||
subs r1, r3, #1
|
|
||||||
movs r2, #0
|
|
||||||
strb r1, [r0, #0x14]
|
|
||||||
movs r1, #4
|
|
||||||
strb r1, [r0, #0xc]
|
|
||||||
strb r2, [r0, #0xd]
|
|
||||||
ldrb r2, [r0, #0x10]
|
|
||||||
movs r1, #0x7f
|
|
||||||
ands r1, r2
|
|
||||||
strb r1, [r0, #0x10]
|
|
||||||
movs r1, #0x81
|
|
||||||
strb r1, [r4, #2]
|
|
||||||
bl DoPlayerAction
|
|
||||||
movs r0, #1
|
|
||||||
b _080796FE
|
|
||||||
.align 2, 0
|
|
||||||
_080796EC: .4byte gRoomControls
|
|
||||||
_080796F0: .4byte gUnk_0811C1E8
|
|
||||||
_080796F4: .4byte gPlayerState
|
|
||||||
_080796F8: .4byte gPlayerEntity
|
|
||||||
_080796FC:
|
|
||||||
movs r0, #0
|
|
||||||
_080796FE:
|
|
||||||
pop {r3, r4}
|
|
||||||
mov r8, r3
|
|
||||||
mov sb, r4
|
|
||||||
pop {r4, r5, r6, r7, pc}
|
|
||||||
.align 2, 0
|
|
||||||
.syntax divided
|
|
|
@ -1763,7 +1763,54 @@ u32 sub_0807953C(void) {
|
||||||
return gPlayerState.playerInput.newInput & tmp;
|
return gPlayerState.playerInput.newInput & tmp;
|
||||||
}
|
}
|
||||||
|
|
||||||
ASM_FUNC("asm/non_matching/playerUtils/sub_08079550.inc", u32 sub_08079550(void))
|
bool32 sub_08079550(void) {
|
||||||
|
const s8* ptr;
|
||||||
|
u32 uVar3;
|
||||||
|
u32 tilePos2;
|
||||||
|
u32 tilePos1;
|
||||||
|
|
||||||
|
if (gDiggingCaveEntranceTransition.isDiggingCave == 0) {
|
||||||
|
if ((gPlayerState.dash_state == 0 || (gPlayerState.flags & PL_BURNING)) &&
|
||||||
|
(gPlayerState.swim_state != 0 || (gPlayerState.sword_state & 0x40) ||
|
||||||
|
gPlayerEntity.direction != gPlayerState.direction || (gPlayerEntity.direction & 0x80))) {
|
||||||
|
gPlayerEntity.subtimer = 0;
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
if (sub_08079778()) {
|
||||||
|
ptr = &gUnk_0811C100[gPlayerEntity.animationState & 6];
|
||||||
|
if ((gPlayerEntity.animationState & 2) != 0) {
|
||||||
|
tilePos1 = COORD_TO_TILE_OFFSET(&gPlayerEntity, -ptr[0], -(gPlayerEntity.hitbox)->unk2[1]);
|
||||||
|
tilePos2 = COORD_TO_TILE_OFFSET(&gPlayerEntity, -ptr[0], +(gPlayerEntity.hitbox)->unk2[1]);
|
||||||
|
} else {
|
||||||
|
|
||||||
|
tilePos1 = COORD_TO_TILE_OFFSET(&gPlayerEntity, -(gPlayerEntity.hitbox)->unk2[2], -ptr[1]);
|
||||||
|
tilePos2 = COORD_TO_TILE_OFFSET(&gPlayerEntity, (gPlayerEntity.hitbox)->unk2[2], -ptr[1]);
|
||||||
|
}
|
||||||
|
|
||||||
|
uVar3 = sub_080B1AE0(tilePos1, gPlayerEntity.collisionLayer);
|
||||||
|
uVar3 = sub_08007DD6(uVar3, gUnk_0811C1E8[gPlayerEntity.animationState >> 1]);
|
||||||
|
if (uVar3 != 0) {
|
||||||
|
uVar3 = sub_080B1AE0(tilePos2, gPlayerEntity.collisionLayer);
|
||||||
|
uVar3 = sub_08007DD6(uVar3, gUnk_0811C1E8[gPlayerEntity.animationState >> 1]);
|
||||||
|
if (uVar3 != 0) {
|
||||||
|
gPlayerState.pushedObject |= 0x80;
|
||||||
|
if (gPlayerState.dash_state == 0 && (++gPlayerEntity.subtimer <= 5)) {
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
gPlayerEntity.animationState = uVar3 - 1;
|
||||||
|
gPlayerEntity.action = 4;
|
||||||
|
gPlayerEntity.subAction = 0;
|
||||||
|
COLLISION_OFF(&gPlayerEntity);
|
||||||
|
gPlayerState.jump_status = 0x81;
|
||||||
|
DoPlayerAction(&gPlayerEntity);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
void sub_08079708(Entity* this) {
|
void sub_08079708(Entity* this) {
|
||||||
gPlayerState.framestate = PL_STATE_DIE;
|
gPlayerState.framestate = PL_STATE_DIE;
|
||||||
|
|
Loading…
Reference in New Issue