mirror of https://github.com/zeldaret/tmc.git
Decompile manager1B
This commit is contained in:
parent
d632913122
commit
fe1e97f8ef
|
@ -1,72 +0,0 @@
|
||||||
.syntax unified
|
|
||||||
push {r4, r5, lr}
|
|
||||||
adds r4, r0, #0
|
|
||||||
bl EntityHasDuplicateID
|
|
||||||
cmp r0, #0
|
|
||||||
beq _0805B3C4
|
|
||||||
bl DeleteThisEntity
|
|
||||||
_0805B3C4:
|
|
||||||
ldrb r0, [r4, #0xa]
|
|
||||||
lsls r0, r0, #2
|
|
||||||
ldr r1, _0805B438 @ =gUnk_08108C28
|
|
||||||
adds r5, r0, r1
|
|
||||||
ldrb r0, [r4, #0xc]
|
|
||||||
cmp r0, #0
|
|
||||||
bne _0805B41E
|
|
||||||
movs r0, #1
|
|
||||||
strb r0, [r4, #0xc]
|
|
||||||
ldrb r1, [r4, #0x10]
|
|
||||||
movs r0, #0x20
|
|
||||||
orrs r0, r1
|
|
||||||
strb r0, [r4, #0x10]
|
|
||||||
adds r0, r4, #0
|
|
||||||
movs r1, #6
|
|
||||||
bl sub_0805E3A0
|
|
||||||
ldrb r0, [r4, #0xa]
|
|
||||||
cmp r0, #0
|
|
||||||
beq _0805B3F6
|
|
||||||
ldr r1, _0805B43C @ =sub_0805B4B4
|
|
||||||
adds r0, r4, #0
|
|
||||||
movs r2, #0
|
|
||||||
bl sub_08052D74
|
|
||||||
_0805B3F6:
|
|
||||||
ldr r0, _0805B440 @ =gRoomControls
|
|
||||||
ldrh r1, [r0, #0x20]
|
|
||||||
movs r0, #0x80
|
|
||||||
lsls r0, r0, #1
|
|
||||||
subs r1, r0, r1
|
|
||||||
cmp r1, #0
|
|
||||||
bge _0805B406
|
|
||||||
movs r1, #0
|
|
||||||
_0805B406:
|
|
||||||
movs r0, #2
|
|
||||||
ldrsb r0, [r5, r0]
|
|
||||||
adds r0, r1, r0
|
|
||||||
str r0, [r4, #0x20]
|
|
||||||
ldr r1, _0805B444 @ =gUnk_08108C54
|
|
||||||
ldrb r0, [r5, #1]
|
|
||||||
lsls r0, r0, #2
|
|
||||||
adds r0, r0, r1
|
|
||||||
ldr r1, [r0]
|
|
||||||
adds r0, r4, #0
|
|
||||||
bl _call_via_r1
|
|
||||||
_0805B41E:
|
|
||||||
ldr r0, _0805B440 @ =gRoomControls
|
|
||||||
ldrh r0, [r0]
|
|
||||||
cmp r0, #0
|
|
||||||
bne _0805B436
|
|
||||||
ldr r0, _0805B444 @ =gUnk_08108C54
|
|
||||||
ldrb r1, [r5, #1]
|
|
||||||
lsls r1, r1, #2
|
|
||||||
adds r1, r1, r0
|
|
||||||
ldr r1, [r1]
|
|
||||||
adds r0, r4, #0
|
|
||||||
bl _call_via_r1
|
|
||||||
_0805B436:
|
|
||||||
pop {r4, r5, pc}
|
|
||||||
.align 2, 0
|
|
||||||
_0805B438: .4byte gUnk_08108C28
|
|
||||||
_0805B43C: .4byte sub_0805B4B4
|
|
||||||
_0805B440: .4byte gRoomControls
|
|
||||||
_0805B444: .4byte gUnk_08108C54
|
|
||||||
.syntax divided
|
|
|
@ -1,23 +0,0 @@
|
||||||
.syntax unified
|
|
||||||
push {r4, lr}
|
|
||||||
ldr r4, _0805B46C @ =gScreen
|
|
||||||
ldr r3, _0805B470 @ =gRoomControls
|
|
||||||
movs r2, #0xa
|
|
||||||
ldrsh r1, [r3, r2]
|
|
||||||
ldrh r2, [r3, #6]
|
|
||||||
subs r1, r1, r2
|
|
||||||
asrs r1, r1, #2
|
|
||||||
strh r1, [r4, #0x2e]
|
|
||||||
movs r2, #0xc
|
|
||||||
ldrsh r1, [r3, r2]
|
|
||||||
ldrh r2, [r3, #8]
|
|
||||||
subs r1, r1, r2
|
|
||||||
asrs r1, r1, #1
|
|
||||||
ldr r0, [r0, #0x20]
|
|
||||||
adds r0, r0, r1
|
|
||||||
strh r0, [r4, #0x30]
|
|
||||||
pop {r4, pc}
|
|
||||||
.align 2, 0
|
|
||||||
_0805B46C: .4byte gScreen
|
|
||||||
_0805B470: .4byte gRoomControls
|
|
||||||
.syntax divided
|
|
|
@ -1,31 +0,0 @@
|
||||||
.syntax unified
|
|
||||||
push {r4, r5, lr}
|
|
||||||
ldr r5, _0805B4A8 @ =gRoomControls
|
|
||||||
movs r0, #0xc
|
|
||||||
ldrsh r1, [r5, r0]
|
|
||||||
ldrh r4, [r5, #8]
|
|
||||||
subs r1, r1, r4
|
|
||||||
lsls r0, r1, #1
|
|
||||||
adds r0, r0, r1
|
|
||||||
lsls r0, r0, #5
|
|
||||||
ldrh r1, [r5, #0x20]
|
|
||||||
subs r1, #0xa0
|
|
||||||
bl __divsi3
|
|
||||||
ldr r2, _0805B4AC @ =gScreen
|
|
||||||
adds r4, r4, r0
|
|
||||||
strh r4, [r2, #0x30]
|
|
||||||
ldrh r0, [r5, #0x1e]
|
|
||||||
ldr r1, _0805B4B0 @ =0xFFFFFF00
|
|
||||||
adds r0, r0, r1
|
|
||||||
lsrs r1, r0, #0x1f
|
|
||||||
adds r0, r0, r1
|
|
||||||
asrs r0, r0, #1
|
|
||||||
ldrh r1, [r5, #0xa]
|
|
||||||
subs r1, r1, r0
|
|
||||||
strh r1, [r2, #0x2e]
|
|
||||||
pop {r4, r5, pc}
|
|
||||||
.align 2, 0
|
|
||||||
_0805B4A8: .4byte gRoomControls
|
|
||||||
_0805B4AC: .4byte gScreen
|
|
||||||
_0805B4B0: .4byte 0xFFFFFF00
|
|
||||||
.syntax divided
|
|
|
@ -1,14 +0,0 @@
|
||||||
.syntax unified
|
|
||||||
push {r4, lr}
|
|
||||||
adds r4, r0, #0
|
|
||||||
ldrb r0, [r4, #0xa]
|
|
||||||
bl sub_0805B4D0
|
|
||||||
ldrb r0, [r4, #0xa]
|
|
||||||
cmp r0, #2
|
|
||||||
bne _0805B4C8
|
|
||||||
bl sub_0806D0F8
|
|
||||||
_0805B4C8:
|
|
||||||
adds r0, r4, #0
|
|
||||||
bl Manager1B_Main
|
|
||||||
pop {r4, pc}
|
|
||||||
.syntax divided
|
|
|
@ -1,51 +0,0 @@
|
||||||
.syntax unified
|
|
||||||
push {r4, r5, lr}
|
|
||||||
adds r5, r0, #0
|
|
||||||
ldr r0, _0805B528 @ =gUnk_08108C5C
|
|
||||||
adds r0, r5, r0
|
|
||||||
ldrb r0, [r0]
|
|
||||||
bl LoadGfxGroup
|
|
||||||
ldr r4, _0805B52C @ =gScreen
|
|
||||||
ldr r0, _0805B530 @ =0x00001E07
|
|
||||||
strh r0, [r4, #0x2c]
|
|
||||||
ldrh r1, [r4]
|
|
||||||
movs r2, #0x80
|
|
||||||
lsls r2, r2, #4
|
|
||||||
adds r0, r2, #0
|
|
||||||
orrs r0, r1
|
|
||||||
strh r0, [r4]
|
|
||||||
ldr r2, _0805B534 @ =gRoomControls
|
|
||||||
movs r1, #0xa
|
|
||||||
ldrsh r0, [r2, r1]
|
|
||||||
ldrh r1, [r2, #6]
|
|
||||||
subs r0, r0, r1
|
|
||||||
asrs r0, r0, #2
|
|
||||||
strh r0, [r4, #0x2e]
|
|
||||||
movs r1, #0xc
|
|
||||||
ldrsh r0, [r2, r1]
|
|
||||||
ldrh r1, [r2, #8]
|
|
||||||
subs r0, r0, r1
|
|
||||||
asrs r3, r0, #1
|
|
||||||
ldrh r1, [r2, #0x20]
|
|
||||||
movs r0, #0x80
|
|
||||||
lsls r0, r0, #1
|
|
||||||
subs r2, r0, r1
|
|
||||||
cmp r2, #0
|
|
||||||
bge _0805B516
|
|
||||||
movs r2, #0
|
|
||||||
_0805B516:
|
|
||||||
ldr r0, _0805B538 @ =gUnk_08108C44
|
|
||||||
lsls r1, r5, #1
|
|
||||||
adds r1, r1, r0
|
|
||||||
adds r0, r3, r2
|
|
||||||
ldrh r1, [r1]
|
|
||||||
adds r0, r0, r1
|
|
||||||
strh r0, [r4, #0x30]
|
|
||||||
pop {r4, r5, pc}
|
|
||||||
.align 2, 0
|
|
||||||
_0805B528: .4byte gUnk_08108C5C
|
|
||||||
_0805B52C: .4byte gScreen
|
|
||||||
_0805B530: .4byte 0x00001E07
|
|
||||||
_0805B534: .4byte gRoomControls
|
|
||||||
_0805B538: .4byte gUnk_08108C44
|
|
||||||
.syntax divided
|
|
|
@ -1,12 +1,83 @@
|
||||||
|
|
||||||
#include "manager.h"
|
#include "manager.h"
|
||||||
|
#include "functions.h"
|
||||||
|
#include "screen.h"
|
||||||
|
|
||||||
ASM_FUNC("asm/non_matching/manager1B/Manager1B_Main.inc", void Manager1B_Main())
|
typedef struct {
|
||||||
|
Manager manager;
|
||||||
|
u32 field_0x20;
|
||||||
|
} Manager1B;
|
||||||
|
|
||||||
ASM_FUNC("asm/non_matching/manager1B/sub_0805B448.inc", void sub_0805B448())
|
extern u8 gUnk_08108C28[];
|
||||||
|
extern void (*const gUnk_08108C54[])(Manager1B*);
|
||||||
|
|
||||||
ASM_FUNC("asm/non_matching/manager1B/sub_0805B474.inc", void sub_0805B474())
|
void sub_0805B4B4(Manager1B*);
|
||||||
|
|
||||||
ASM_FUNC("asm/non_matching/manager1B/sub_0805B4B4.inc", void sub_0805B4B4())
|
void sub_0806D0F8(void); // in bigGoron?
|
||||||
|
|
||||||
ASM_FUNC("asm/non_matching/manager1B/sub_0805B4D0.inc", void sub_0805B4D0())
|
extern u8 gUnk_08108C5C[];
|
||||||
|
extern u16 gUnk_08108C44[];
|
||||||
|
|
||||||
|
void Manager1B_Main(Manager1B* this) {
|
||||||
|
s32 iVar3;
|
||||||
|
u8* tmp;
|
||||||
|
|
||||||
|
if (EntityHasDuplicateID((Entity*)this) != 0) {
|
||||||
|
DeleteThisEntity();
|
||||||
|
}
|
||||||
|
tmp = gUnk_08108C28 + this->manager.unk_0a * 4;
|
||||||
|
if (this->manager.action == 0) {
|
||||||
|
this->manager.action = 1;
|
||||||
|
this->manager.unk_10 |= 0x20;
|
||||||
|
sub_0805E3A0(this, 6);
|
||||||
|
if (this->manager.unk_0a != 0) {
|
||||||
|
sub_08052D74(this, sub_0805B4B4, NULL);
|
||||||
|
}
|
||||||
|
iVar3 = 0x100 - (u32)gRoomControls.height;
|
||||||
|
if (iVar3 < 0) {
|
||||||
|
iVar3 = 0;
|
||||||
|
}
|
||||||
|
this->field_0x20 = iVar3 + (s8)tmp[2];
|
||||||
|
gUnk_08108C54[tmp[1]](this);
|
||||||
|
}
|
||||||
|
if (gRoomControls.unk2 == 0) {
|
||||||
|
gUnk_08108C54[tmp[1]](this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void sub_0805B448(Manager1B* this) {
|
||||||
|
gScreen.affine.bg3xOffset = (gRoomControls.roomScrollX - gRoomControls.roomOriginX) >> 2;
|
||||||
|
gScreen.affine.bg3yOffset = ((gRoomControls.roomScrollY - gRoomControls.roomOriginY) >> 1) + this->field_0x20;
|
||||||
|
}
|
||||||
|
|
||||||
|
void sub_0805B474(Manager1B* this) {
|
||||||
|
s32 tmp = ((gRoomControls.roomScrollY - gRoomControls.roomOriginY) * 0x60) /
|
||||||
|
(gRoomControls.height - 0xa0);
|
||||||
|
gScreen.affine.bg3yOffset = gRoomControls.roomOriginY + tmp;
|
||||||
|
gScreen.affine.bg3xOffset = gRoomControls.roomScrollX - ((gRoomControls.width - 0x100) / 2);
|
||||||
|
}
|
||||||
|
|
||||||
|
void sub_0805B4B4(Manager1B* this) {
|
||||||
|
sub_0805B4D0(this->manager.unk_0a);
|
||||||
|
if (this->manager.unk_0a == 2) {
|
||||||
|
sub_0806D0F8();
|
||||||
|
}
|
||||||
|
Manager1B_Main(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
void sub_0805B4D0(u32 param_1) {
|
||||||
|
s32 iVar1;
|
||||||
|
u32 uVar2;
|
||||||
|
|
||||||
|
LoadGfxGroup(gUnk_08108C5C[param_1]);
|
||||||
|
gScreen.affine.bg3Control = 0x1e07;
|
||||||
|
gScreen.lcd.displayControl |= 0x800;
|
||||||
|
gScreen.affine.bg3xOffset = (gRoomControls.roomScrollX - gRoomControls.roomOriginX) >> 2;
|
||||||
|
|
||||||
|
uVar2 = (gRoomControls.roomScrollY - gRoomControls.roomOriginY) >> 1;
|
||||||
|
iVar1 = 0x100 - gRoomControls.height;
|
||||||
|
if (iVar1 < 0) {
|
||||||
|
iVar1 = 0;
|
||||||
|
}
|
||||||
|
gScreen.affine.bg3yOffset = uVar2 + iVar1+gUnk_08108C44[param_1];
|
||||||
|
}
|
||||||
|
|
|
@ -37,7 +37,7 @@ typedef struct {
|
||||||
u16 field_0x3e;
|
u16 field_0x3e;
|
||||||
} Manager2B;
|
} Manager2B;
|
||||||
|
|
||||||
extern void (*const gUnk_08108D30[])(Entity*);
|
extern void (*const gUnk_08108D30[])(Manager2B*);
|
||||||
|
|
||||||
extern u8 gEntCount;
|
extern u8 gEntCount;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue