mirror of https://github.com/zeldaret/tmc.git
Merge pull request #416 from hatal175/giantrock
Decompile GiantRock and GiantRock2
This commit is contained in:
commit
00c79925f4
|
|
@ -1,42 +0,0 @@
|
||||||
.include "asm/macros.inc"
|
|
||||||
|
|
||||||
.include "constants/constants.inc"
|
|
||||||
|
|
||||||
.syntax unified
|
|
||||||
|
|
||||||
.text
|
|
||||||
|
|
||||||
|
|
||||||
thumb_func_start GiantRock
|
|
||||||
GiantRock: @ 0x08090FB8
|
|
||||||
push {r4, lr}
|
|
||||||
adds r4, r0, #0
|
|
||||||
ldrb r0, [r4, #0xc]
|
|
||||||
cmp r0, #0
|
|
||||||
bne _08090FF6
|
|
||||||
movs r2, #1
|
|
||||||
movs r0, #1
|
|
||||||
strb r0, [r4, #0xc]
|
|
||||||
ldrb r1, [r4, #0x18]
|
|
||||||
subs r0, #5
|
|
||||||
ands r0, r1
|
|
||||||
orrs r0, r2
|
|
||||||
strb r0, [r4, #0x18]
|
|
||||||
adds r1, r4, #0
|
|
||||||
adds r1, #0x38
|
|
||||||
movs r0, #2
|
|
||||||
strb r0, [r1]
|
|
||||||
adds r0, r4, #0
|
|
||||||
bl UpdateSpriteForCollisionLayer
|
|
||||||
adds r2, r4, #0
|
|
||||||
adds r2, #0x29
|
|
||||||
ldrb r1, [r2]
|
|
||||||
movs r0, #8
|
|
||||||
rsbs r0, r0, #0
|
|
||||||
ands r0, r1
|
|
||||||
strb r0, [r2]
|
|
||||||
ldrb r1, [r4, #0xa]
|
|
||||||
adds r0, r4, #0
|
|
||||||
bl InitializeAnimation
|
|
||||||
_08090FF6:
|
|
||||||
pop {r4, pc}
|
|
||||||
|
|
@ -1,95 +0,0 @@
|
||||||
.include "asm/macros.inc"
|
|
||||||
|
|
||||||
.include "constants/constants.inc"
|
|
||||||
|
|
||||||
.syntax unified
|
|
||||||
|
|
||||||
.text
|
|
||||||
|
|
||||||
|
|
||||||
thumb_func_start GiantRock2
|
|
||||||
GiantRock2: @ 0x08090FF8
|
|
||||||
push {lr}
|
|
||||||
ldr r2, _0809100C @ =gUnk_08122278
|
|
||||||
ldrb r1, [r0, #0xc]
|
|
||||||
lsls r1, r1, #2
|
|
||||||
adds r1, r1, r2
|
|
||||||
ldr r1, [r1]
|
|
||||||
bl _call_via_r1
|
|
||||||
pop {pc}
|
|
||||||
.align 2, 0
|
|
||||||
_0809100C: .4byte gUnk_08122278
|
|
||||||
|
|
||||||
thumb_func_start sub_08091010
|
|
||||||
sub_08091010: @ 0x08091010
|
|
||||||
push {r4, r5, r6, r7, lr}
|
|
||||||
adds r4, r0, #0
|
|
||||||
movs r0, #1
|
|
||||||
strb r0, [r4, #0xc]
|
|
||||||
movs r0, #0x2e
|
|
||||||
ldrsh r1, [r4, r0]
|
|
||||||
ldr r2, _08091094 @ =gRoomControls
|
|
||||||
ldrh r0, [r2, #6]
|
|
||||||
subs r1, r1, r0
|
|
||||||
asrs r1, r1, #4
|
|
||||||
movs r3, #0x3f
|
|
||||||
ands r1, r3
|
|
||||||
movs r5, #0x32
|
|
||||||
ldrsh r0, [r4, r5]
|
|
||||||
ldrh r2, [r2, #8]
|
|
||||||
subs r0, r0, r2
|
|
||||||
asrs r0, r0, #4
|
|
||||||
ands r0, r3
|
|
||||||
lsls r0, r0, #6
|
|
||||||
orrs r1, r0
|
|
||||||
adds r3, r4, #0
|
|
||||||
adds r3, #0x74
|
|
||||||
strh r1, [r3]
|
|
||||||
adds r0, r4, #0
|
|
||||||
adds r0, #0x38
|
|
||||||
ldrb r5, [r0]
|
|
||||||
adds r2, r4, #0
|
|
||||||
adds r2, #0x29
|
|
||||||
ldrb r0, [r2]
|
|
||||||
movs r1, #7
|
|
||||||
orrs r0, r1
|
|
||||||
strb r0, [r2]
|
|
||||||
ldrh r0, [r3]
|
|
||||||
subs r0, #0x80
|
|
||||||
lsls r0, r0, #0x10
|
|
||||||
lsrs r4, r0, #0x10
|
|
||||||
ldr r6, _08091098 @ =0x00004022
|
|
||||||
movs r7, #4
|
|
||||||
_0809105C:
|
|
||||||
subs r1, r4, #2
|
|
||||||
adds r0, r6, #0
|
|
||||||
adds r2, r5, #0
|
|
||||||
bl SetTile
|
|
||||||
subs r1, r4, #1
|
|
||||||
adds r0, r6, #0
|
|
||||||
adds r2, r5, #0
|
|
||||||
bl SetTile
|
|
||||||
adds r0, r6, #0
|
|
||||||
adds r1, r4, #0
|
|
||||||
adds r2, r5, #0
|
|
||||||
bl SetTile
|
|
||||||
adds r1, r4, #1
|
|
||||||
adds r0, r6, #0
|
|
||||||
adds r2, r5, #0
|
|
||||||
bl SetTile
|
|
||||||
adds r0, r4, #0
|
|
||||||
adds r0, #0x40
|
|
||||||
lsls r0, r0, #0x10
|
|
||||||
lsrs r4, r0, #0x10
|
|
||||||
subs r7, #1
|
|
||||||
cmp r7, #0
|
|
||||||
bge _0809105C
|
|
||||||
pop {r4, r5, r6, r7, pc}
|
|
||||||
.align 2, 0
|
|
||||||
_08091094: .4byte gRoomControls
|
|
||||||
_08091098: .4byte 0x00004022
|
|
||||||
|
|
||||||
thumb_func_start nullsub_523
|
|
||||||
nullsub_523: @ 0x0809109C
|
|
||||||
bx lr
|
|
||||||
.align 2, 0
|
|
||||||
|
|
@ -1,9 +0,0 @@
|
||||||
.include "asm/macros.inc"
|
|
||||||
.include "constants/constants.inc"
|
|
||||||
|
|
||||||
.section .rodata
|
|
||||||
.align 2
|
|
||||||
|
|
||||||
gUnk_08122278:: @ 08122278
|
|
||||||
.4byte sub_08091010
|
|
||||||
.4byte nullsub_523
|
|
||||||
|
|
@ -725,8 +725,8 @@ SECTIONS {
|
||||||
src/object/furniture.o(.text);
|
src/object/furniture.o(.text);
|
||||||
src/object/minishSizedEntrance.o(.text);
|
src/object/minishSizedEntrance.o(.text);
|
||||||
src/object/archway.o(.text);
|
src/object/archway.o(.text);
|
||||||
asm/object/giantRock.o(.text);
|
src/object/giantRock.o(.text);
|
||||||
asm/object/giantRock2.o(.text);
|
src/object/giantRock2.o(.text);
|
||||||
asm/object/object52.o(.text);
|
asm/object/object52.o(.text);
|
||||||
asm/object/object53.o(.text);
|
asm/object/object53.o(.text);
|
||||||
src/object/pullableLever.o(.text);
|
src/object/pullableLever.o(.text);
|
||||||
|
|
@ -1466,7 +1466,7 @@ SECTIONS {
|
||||||
src/object/furniture.o(.rodata);
|
src/object/furniture.o(.rodata);
|
||||||
data/const/object/minishSizedEntrance.o(.rodata);
|
data/const/object/minishSizedEntrance.o(.rodata);
|
||||||
data/animations/object/minishSizedEntrance.o(.rodata);
|
data/animations/object/minishSizedEntrance.o(.rodata);
|
||||||
data/const/object/giantRock2.o(.rodata);
|
src/object/giantRock2.o(.rodata);
|
||||||
data/const/object/object53.o(.rodata);
|
data/const/object/object53.o(.rodata);
|
||||||
src/object/pullableLever.o(.rodata);
|
src/object/pullableLever.o(.rodata);
|
||||||
data/animations/object/pullableLever.o(.rodata);
|
data/animations/object/pullableLever.o(.rodata);
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,12 @@
|
||||||
|
#include "entity.h"
|
||||||
|
|
||||||
|
void GiantRock(Entity* this) {
|
||||||
|
if (this->action == 0) {
|
||||||
|
this->action = 1;
|
||||||
|
this->spriteSettings.draw = 1;
|
||||||
|
this->collisionLayer = 2;
|
||||||
|
UpdateSpriteForCollisionLayer(this);
|
||||||
|
this->spritePriority.b0 = 0;
|
||||||
|
InitializeAnimation(this, this->type);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,45 @@
|
||||||
|
#define NENT_DEPRECATED
|
||||||
|
#include "entity.h"
|
||||||
|
#include "room.h"
|
||||||
|
#include "asm.h"
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
Entity base;
|
||||||
|
u8 filler[0xC];
|
||||||
|
u16 tile;
|
||||||
|
} GiantRock2Entity;
|
||||||
|
|
||||||
|
void GiantRock2_Init(GiantRock2Entity*);
|
||||||
|
void GiantRock2_Idle(GiantRock2Entity*);
|
||||||
|
|
||||||
|
void GiantRock2(Entity* this) {
|
||||||
|
static void (*const actionFuncs[])(GiantRock2Entity*) = {
|
||||||
|
GiantRock2_Init,
|
||||||
|
GiantRock2_Idle,
|
||||||
|
};
|
||||||
|
actionFuncs[this->action]((GiantRock2Entity*)this);
|
||||||
|
}
|
||||||
|
|
||||||
|
void GiantRock2_Init(GiantRock2Entity* this) {
|
||||||
|
u32 collisionLayer;
|
||||||
|
u16 position;
|
||||||
|
int index;
|
||||||
|
u32 tileIndex;
|
||||||
|
|
||||||
|
super->action = 1;
|
||||||
|
this->tile = COORD_TO_TILE(super);
|
||||||
|
collisionLayer = super->collisionLayer;
|
||||||
|
super->spritePriority.b0 = 7;
|
||||||
|
position = (this->tile - 0x80);
|
||||||
|
tileIndex = 0x4022;
|
||||||
|
for (index = 4; index > -1; index--) {
|
||||||
|
SetTile(tileIndex, position - 2, collisionLayer);
|
||||||
|
SetTile(tileIndex, position - 1, collisionLayer);
|
||||||
|
SetTile(tileIndex, position, collisionLayer);
|
||||||
|
SetTile(tileIndex, position + 1, collisionLayer);
|
||||||
|
position += 0x40;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void GiantRock2_Idle(GiantRock2Entity* this) {
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue