mirror of https://github.com/zeldaret/tmc.git
Merge pull request #361 from hatal175/rocscape
This commit is contained in:
commit
e1fc6d628c
|
@ -1,146 +0,0 @@
|
|||
.syntax unified
|
||||
push {r4, r5, lr}
|
||||
adds r3, r0, #0
|
||||
adds r4, r1, #0
|
||||
ldrb r0, [r3, #4]
|
||||
cmp r0, #0
|
||||
beq _08076654
|
||||
adds r0, r3, #0
|
||||
bl sub_08076758
|
||||
b _08076754
|
||||
_08076654:
|
||||
ldr r0, _080766BC @ =gPlayerState
|
||||
ldr r1, [r0, #0x2c]
|
||||
adds r2, r0, #0
|
||||
cmp r1, #0
|
||||
bne _0807674C
|
||||
ldrb r0, [r2, #1]
|
||||
cmp r0, #0
|
||||
beq _080766C4
|
||||
ldrb r1, [r2, #4]
|
||||
ldrb r0, [r2, #5]
|
||||
orrs r0, r1
|
||||
cmp r0, #0
|
||||
bne _0807674C
|
||||
ldrb r0, [r2, #0x12]
|
||||
cmp r0, #0x12
|
||||
beq _08076678
|
||||
cmp r0, #1
|
||||
bne _08076686
|
||||
_08076678:
|
||||
ldr r0, _080766C0 @ =gPlayerEntity
|
||||
ldr r0, [r0, #0x34]
|
||||
cmp r0, #0
|
||||
bne _08076686
|
||||
ldrb r0, [r2, #0x14]
|
||||
cmp r0, #0
|
||||
beq _0807674C
|
||||
_08076686:
|
||||
ldrb r1, [r2, #2]
|
||||
cmp r1, #0
|
||||
beq _08076694
|
||||
movs r0, #7
|
||||
ands r0, r1
|
||||
cmp r0, #3
|
||||
bne _08076710
|
||||
_08076694:
|
||||
ldr r5, _080766C0 @ =gPlayerEntity
|
||||
ldr r0, [r5, #0x34]
|
||||
cmp r0, #0
|
||||
blt _0807674C
|
||||
movs r1, #0
|
||||
strb r1, [r2, #1]
|
||||
ldrb r0, [r3, #4]
|
||||
adds r0, #1
|
||||
strb r0, [r3, #4]
|
||||
strb r1, [r2, #0xb]
|
||||
movs r0, #1
|
||||
strb r0, [r2, #2]
|
||||
movs r0, #0xff
|
||||
strb r0, [r2, #0xe]
|
||||
str r1, [r2, #0x2c]
|
||||
movs r0, #0x80
|
||||
lsls r0, r0, #0xa
|
||||
str r0, [r5, #0x20]
|
||||
b _0807673C
|
||||
.align 2, 0
|
||||
_080766BC: .4byte gPlayerState
|
||||
_080766C0: .4byte gPlayerEntity
|
||||
_080766C4:
|
||||
ldrb r0, [r2, #0x1b]
|
||||
ldrb r1, [r2, #0xa]
|
||||
orrs r0, r1
|
||||
ldrb r1, [r2, #4]
|
||||
orrs r0, r1
|
||||
ldrb r1, [r2, #5]
|
||||
orrs r0, r1
|
||||
ldrb r1, [r2, #0x1c]
|
||||
orrs r0, r1
|
||||
adds r1, r2, #0
|
||||
adds r1, #0x3d
|
||||
ldrb r1, [r1]
|
||||
orrs r0, r1
|
||||
cmp r0, #0
|
||||
bne _0807674C
|
||||
ldrb r1, [r2, #0x12]
|
||||
adds r0, r1, #0
|
||||
subs r0, #0x12
|
||||
lsls r0, r0, #0x18
|
||||
lsrs r0, r0, #0x18
|
||||
cmp r0, #1
|
||||
bls _080766F4
|
||||
cmp r1, #1
|
||||
bne _08076702
|
||||
_080766F4:
|
||||
ldr r0, _0807671C @ =gPlayerEntity
|
||||
ldr r0, [r0, #0x34]
|
||||
cmp r0, #0
|
||||
bne _08076702
|
||||
ldrb r0, [r2, #0x14]
|
||||
cmp r0, #0
|
||||
beq _0807674C
|
||||
_08076702:
|
||||
ldrb r1, [r2, #2]
|
||||
cmp r1, #0
|
||||
beq _08076720
|
||||
movs r0, #7
|
||||
ands r0, r1
|
||||
cmp r0, #3
|
||||
beq _08076720
|
||||
_08076710:
|
||||
adds r0, r3, #0
|
||||
adds r1, r4, #0
|
||||
bl sub_08076758
|
||||
b _08076754
|
||||
.align 2, 0
|
||||
_0807671C: .4byte gPlayerEntity
|
||||
_08076720:
|
||||
ldr r1, _08076748 @ =gPlayerEntity
|
||||
ldr r0, [r1, #0x34]
|
||||
cmp r0, #0
|
||||
blt _0807674C
|
||||
movs r0, #0x80
|
||||
lsls r0, r0, #0xa
|
||||
str r0, [r1, #0x20]
|
||||
movs r1, #0
|
||||
movs r0, #1
|
||||
strb r0, [r2, #2]
|
||||
str r1, [r2, #0x2c]
|
||||
ldrb r0, [r3, #4]
|
||||
adds r0, #1
|
||||
strb r0, [r3, #4]
|
||||
_0807673C:
|
||||
bl sub_08077F84
|
||||
movs r0, #0x78
|
||||
bl SoundReq
|
||||
b _08076754
|
||||
.align 2, 0
|
||||
_08076748: .4byte gPlayerEntity
|
||||
_0807674C:
|
||||
adds r0, r3, #0
|
||||
adds r1, r4, #0
|
||||
bl sub_08077E78
|
||||
_08076754:
|
||||
pop {r4, r5, pc}
|
||||
.align 2, 0
|
||||
.syntax divided
|
|
@ -5,46 +5,49 @@
|
|||
void sub_08076758(ItemBehavior*, u32);
|
||||
extern void sub_08077F84(void);
|
||||
|
||||
/*void ItemRocsCape(ItemBehavior* this, u32 arg1) {
|
||||
void ItemRocsCape(ItemBehavior* this, u32 arg1) {
|
||||
if (this->stateID != 0) {
|
||||
sub_08076758(this, arg1);
|
||||
return;
|
||||
}
|
||||
if (gPlayerState.item == NULL) {
|
||||
if (gPlayerState.field_0x0[1] == 0) {
|
||||
if (((u8)(gPlayerState.sword_state | gPlayerState.field_0xa | gPlayerState.field_0x3[1] |
|
||||
gPlayerState.heldObject | gPlayerState.field_0x1c | gPlayerState.field_0x3c[1]) == 0) &&
|
||||
((((1 < (u8)(gPlayerState.field_0x10[2] - 0x12) && (gPlayerState.field_0x10[2] != 1)) ||
|
||||
(gPlayerEntity.z.WORD != 0)) ||
|
||||
(gPlayerState.field_0x14 != 0)))) {
|
||||
if ((gPlayerState.jump_status != 0) && ((gPlayerState.jump_status & 7) != 3))
|
||||
goto _08076710;
|
||||
if (-1 < gPlayerEntity.z.WORD) {
|
||||
gPlayerEntity.zVelocity = 0x20000;
|
||||
gPlayerState.jump_status = 1;
|
||||
gPlayerState.item = NULL;
|
||||
this->stateID += 1;
|
||||
goto _0807673C;
|
||||
}
|
||||
}
|
||||
} else {
|
||||
if (((gPlayerState.heldObject | gPlayerState.field_0x3[1]) == 0) &&
|
||||
(((gPlayerState.field_0x10[2] != 0x12 && (gPlayerState.field_0x10[2] != 1)) ||
|
||||
if (gPlayerState.field_0x0[1]) {
|
||||
if (((gPlayerState.field_0x3[1] | gPlayerState.heldObject) == 0) &&
|
||||
(((gPlayerState.floor_type != SURFACE_DOOR && (gPlayerState.floor_type != SURFACE_PIT)) ||
|
||||
((gPlayerEntity.z.WORD != 0 || (gPlayerState.field_0x14 != 0)))))) {
|
||||
if ((gPlayerState.jump_status != 0) && ((gPlayerState.jump_status & 7) != 3)) {
|
||||
_08076710:
|
||||
if ((gPlayerState.jump_status == 0) || ((gPlayerState.jump_status & 7) == 3)) {
|
||||
if (-1 < gPlayerEntity.z.WORD) {
|
||||
gPlayerState.field_0x0[1] = 0;
|
||||
this->stateID += 1;
|
||||
gPlayerState.keepFacing = 0;
|
||||
gPlayerState.jump_status = 1;
|
||||
gPlayerState.field_0xe = -1;
|
||||
gPlayerState.item = NULL;
|
||||
gPlayerEntity.zVelocity = 0x20000;
|
||||
sub_08077F84();
|
||||
SoundReq(SFX_PLY_VO4);
|
||||
return;
|
||||
}
|
||||
} else {
|
||||
sub_08076758(this, arg1);
|
||||
return;
|
||||
}
|
||||
if (-1 < gPlayerEntity.z.WORD) {
|
||||
gPlayerState.field_0x0[1] = 0;
|
||||
this->stateID += 1;
|
||||
gPlayerState.keepFacing = 0;
|
||||
gPlayerState.jump_status = 1;
|
||||
gPlayerState.field_0xe = -1;
|
||||
gPlayerState.item = NULL;
|
||||
}
|
||||
} else {
|
||||
if (((u8)(gPlayerState.sword_state | gPlayerState.field_0xa | gPlayerState.field_0x3[1] |
|
||||
gPlayerState.heldObject | gPlayerState.field_0x1c | gPlayerState.field_0x3c[1]) == 0) &&
|
||||
((((gPlayerState.floor_type != SURFACE_DOOR && gPlayerState.floor_type != SURFACE_DOOR_13 &&
|
||||
gPlayerState.floor_type != SURFACE_PIT) ||
|
||||
(gPlayerEntity.z.WORD != 0)) ||
|
||||
(gPlayerState.field_0x14 != 0)))) {
|
||||
if ((gPlayerState.jump_status != 0) && ((gPlayerState.jump_status & 7) != 3)) {
|
||||
sub_08076758(this, arg1);
|
||||
return;
|
||||
} else if (-1 < gPlayerEntity.z.WORD) {
|
||||
gPlayerEntity.zVelocity = 0x20000;
|
||||
_0807673C:
|
||||
gPlayerState.jump_status = 1;
|
||||
gPlayerState.item = NULL;
|
||||
this->stateID += 1;
|
||||
sub_08077F84();
|
||||
SoundReq(SFX_PLY_VO4);
|
||||
return;
|
||||
|
@ -54,8 +57,6 @@ extern void sub_08077F84(void);
|
|||
}
|
||||
sub_08077E78(this, arg1);
|
||||
}
|
||||
*/
|
||||
ASM_FUNC("asm/non_matching/itemRocsCape/ItemRocsCape.inc", void ItemRocsCape(ItemBehavior* this, u32 arg1))
|
||||
|
||||
void sub_08076758(ItemBehavior* this, u32 arg1) {
|
||||
s32 iVar1;
|
||||
|
|
Loading…
Reference in New Issue