mirror of https://github.com/zeldaret/tmc.git
Put const data into ghostBrothers
This commit is contained in:
parent
dff1e3299a
commit
09d2e2c80c
|
@ -36853,26 +36853,6 @@
|
||||||
"size": 9,
|
"size": 9,
|
||||||
"type": "animation"
|
"type": "animation"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"path": "ghostBrothers/gUnk_0811015C.bin",
|
|
||||||
"start": 1114460,
|
|
||||||
"size": 8
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"path": "ghostBrothers/gUnk_08110188.bin",
|
|
||||||
"start": 1114504,
|
|
||||||
"size": 166
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"path": "ghostBrothers/gUnk_0811022E.bin",
|
|
||||||
"start": 1114670,
|
|
||||||
"size": 70
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"path": "ghostBrothers/gUnk_08110280.bin",
|
|
||||||
"start": 1114752,
|
|
||||||
"size": 128
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"path": "animations/gSpriteAnimations_Smith_0.bin",
|
"path": "animations/gSpriteAnimations_Smith_0.bin",
|
||||||
"start": 1115108,
|
"start": 1115108,
|
||||||
|
|
|
@ -1,35 +0,0 @@
|
||||||
.include "asm/macros.inc"
|
|
||||||
.include "constants/constants.inc"
|
|
||||||
|
|
||||||
.section .rodata
|
|
||||||
.align 2
|
|
||||||
|
|
||||||
gUnk_0811015C:: @ 0811015C
|
|
||||||
.incbin "ghostBrothers/gUnk_0811015C.bin"
|
|
||||||
|
|
||||||
gUnk_08110164:: @ 08110164
|
|
||||||
.4byte sub_08065BF4
|
|
||||||
.4byte sub_08065BF4
|
|
||||||
.4byte sub_08065BF4
|
|
||||||
.4byte sub_08065BF4
|
|
||||||
.4byte sub_08065EBC
|
|
||||||
.4byte sub_08065EBC
|
|
||||||
|
|
||||||
gUnk_0811017C:: @ 0811017C
|
|
||||||
.4byte sub_08065D18
|
|
||||||
.4byte sub_08065D74
|
|
||||||
.4byte sub_08065DB8
|
|
||||||
|
|
||||||
gUnk_08110188:: @ 08110188
|
|
||||||
.incbin "ghostBrothers/gUnk_08110188.bin"
|
|
||||||
|
|
||||||
gUnk_0811022E:: @ 0811022E
|
|
||||||
.incbin "ghostBrothers/gUnk_0811022E.bin"
|
|
||||||
|
|
||||||
gUnk_08110274:: @ 08110274
|
|
||||||
.4byte sub_08065D18
|
|
||||||
.4byte sub_08065EDC
|
|
||||||
.4byte sub_08065F20
|
|
||||||
|
|
||||||
gUnk_08110280:: @ 08110280
|
|
||||||
.incbin "ghostBrothers/gUnk_08110280.bin"
|
|
|
@ -1207,7 +1207,7 @@ SECTIONS {
|
||||||
data/animations/npc/epona.o(.rodata);
|
data/animations/npc/epona.o(.rodata);
|
||||||
src/npc/milkCart.o(.rodata);
|
src/npc/milkCart.o(.rodata);
|
||||||
data/animations/npc/milkCart.o(.rodata);
|
data/animations/npc/milkCart.o(.rodata);
|
||||||
data/const/npc/ghostBrothers.o(.rodata);
|
src/npc/ghostBrothers.o(.rodata);
|
||||||
data/animations/npc/ghostBrothers.o(.rodata);
|
data/animations/npc/ghostBrothers.o(.rodata);
|
||||||
data/const/npc/smith.o(.rodata);
|
data/const/npc/smith.o(.rodata);
|
||||||
data/animations/npc/smith.o(.rodata);
|
data/animations/npc/smith.o(.rodata);
|
||||||
|
|
|
@ -5,30 +5,30 @@
|
||||||
#include "message.h"
|
#include "message.h"
|
||||||
#include "npc.h"
|
#include "npc.h"
|
||||||
|
|
||||||
extern void (*const gUnk_0811017C[])(Entity*);
|
|
||||||
|
|
||||||
extern void (*const gUnk_08110274[])(Entity*);
|
|
||||||
|
|
||||||
extern Dialog gUnk_08110280[];
|
|
||||||
|
|
||||||
extern u32 gSpriteAnimations_GhostBrothers[];
|
extern u32 gSpriteAnimations_GhostBrothers[];
|
||||||
|
|
||||||
extern u32 gUnk_08110188;
|
|
||||||
extern s8 gUnk_0811015C[8];
|
|
||||||
|
|
||||||
extern u8 gUnk_0811022E[];
|
|
||||||
|
|
||||||
void sub_08065C0C(Entity* this);
|
void sub_08065C0C(Entity* this);
|
||||||
static EntityAction* const gUnk_08110164[];
|
void sub_08065BF4(Entity* this);
|
||||||
|
void sub_08065EBC(Entity* this);
|
||||||
|
void sub_08065D18(Entity* this);
|
||||||
|
void sub_08065D74(Entity* this);
|
||||||
|
void sub_08065DB8(Entity* this);
|
||||||
|
void sub_08065D18(Entity* this);
|
||||||
|
void sub_08065EDC(Entity* this);
|
||||||
|
void sub_08065F20(Entity* this);
|
||||||
|
|
||||||
void GhostBrothers(Entity* this) {
|
void GhostBrothers(Entity* this) {
|
||||||
|
static const s8 gUnk_0811015C[8] = { -14, -16, -18, -20, -22, -20, -18, -16 };
|
||||||
|
static EntityAction* const actionFuncs[] = {
|
||||||
|
sub_08065BF4, sub_08065BF4, sub_08065BF4, sub_08065BF4, sub_08065EBC, sub_08065EBC,
|
||||||
|
};
|
||||||
if (this->flags & ENT_SCRIPTED) {
|
if (this->flags & ENT_SCRIPTED) {
|
||||||
sub_08065C0C(this);
|
sub_08065C0C(this);
|
||||||
} else {
|
} else {
|
||||||
gUnk_08110164[this->type](this);
|
actionFuncs[this->type](this);
|
||||||
|
|
||||||
if (this->type < 3) {
|
if (this->type < 3) {
|
||||||
s8* ptr = gUnk_0811015C;
|
const s8* ptr = gUnk_0811015C;
|
||||||
u32 subtimer = this->subtimer++;
|
u32 subtimer = this->subtimer++;
|
||||||
this->z.HALF_U.HI = *(ptr + (((subtimer << 0x18) >> 0x1b) & 0x7));
|
this->z.HALF_U.HI = *(ptr + (((subtimer << 0x18) >> 0x1b) & 0x7));
|
||||||
}
|
}
|
||||||
|
@ -36,9 +36,25 @@ void GhostBrothers(Entity* this) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void sub_08065BF4(Entity* this) {
|
void sub_08065BF4(Entity* this) {
|
||||||
gUnk_0811017C[this->action](this);
|
static void (*const actionFuncs[])(Entity*) = {
|
||||||
|
sub_08065D18,
|
||||||
|
sub_08065D74,
|
||||||
|
sub_08065DB8,
|
||||||
|
};
|
||||||
|
actionFuncs[this->action](this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const u16 gUnk_08110188[] = { 0x1000, 0x4, 0xf01, 0x4, 0xe02, 0x4, 0xd03, 0x4, 0xc04, 0x8, 0xd03, 0x4,
|
||||||
|
0xe02, 0x4, 0xf01, 0x4, 0x1000, 0x14, 0xf01, 0x4, 0xe02, 0x4, 0xd03, 0x4,
|
||||||
|
0xc04, 0x4, 0xb05, 0x4, 0xa06, 0x4, 0x907, 0x4, 0x808, 0x8, 0x907, 0x4,
|
||||||
|
0xa06, 0x4, 0xb05, 0x4, 0xc04, 0x4, 0xd03, 0x4, 0xe02, 0x4, 0xf01, 0x4,
|
||||||
|
0x1000, 0x14, 0xf01, 0x4, 0xe02, 0x4, 0xd03, 0x4, 0xc04, 0x4, 0xb05, 0x4,
|
||||||
|
0xa06, 0x4, 0x907, 0x4, 0x808, 0x4, 0x709, 0x4, 0x60a, 0x4, 0x50b, 0x4,
|
||||||
|
0x40c, 0x4, 0x30d, 0x4, 0x20e, 0x4, 0x10f, 0x4, 0x10, 0x1e, 0xffff };
|
||||||
|
static const u16 gUnk_0811022E[] = { 0x10, 0x2, 0x10f, 0x2, 0x20e, 0x2, 0x30d, 0x2, 0x40c, 0x2, 0x50b, 0x2,
|
||||||
|
0x60a, 0x2, 0x709, 0x2, 0x808, 0x2, 0x907, 0x2, 0xa06, 0x2, 0xb05, 0x2,
|
||||||
|
0xc04, 0x2, 0xd03, 0x2, 0xe02, 0x2, 0xf01, 0x2, 0x1000, 0x2, 0xffff };
|
||||||
|
|
||||||
void sub_08065C0C(Entity* this) {
|
void sub_08065C0C(Entity* this) {
|
||||||
u16* puVar3;
|
u16* puVar3;
|
||||||
|
|
||||||
|
@ -89,7 +105,7 @@ void sub_08065CCC(Entity* this) {
|
||||||
this->action = 3;
|
this->action = 3;
|
||||||
this->timer = 0x1e;
|
this->timer = 0x1e;
|
||||||
this->spriteRendering.alphaBlend = 1;
|
this->spriteRendering.alphaBlend = 1;
|
||||||
*(u32**)&this->field_0x6c = (u32*)gUnk_0811022E;
|
*(const u16**)&this->field_0x6c = gUnk_0811022E;
|
||||||
gScreen.controls.layerFXControl = 0x3f40;
|
gScreen.controls.layerFXControl = 0x3f40;
|
||||||
gScreen.controls.alphaBlend = 0x10;
|
gScreen.controls.alphaBlend = 0x10;
|
||||||
}
|
}
|
||||||
|
@ -105,7 +121,7 @@ void sub_08065D18(Entity* this) {
|
||||||
this->subtimer = 0;
|
this->subtimer = 0;
|
||||||
this->spriteSettings.draw = 1;
|
this->spriteSettings.draw = 1;
|
||||||
this->spriteRendering.alphaBlend = 1;
|
this->spriteRendering.alphaBlend = 1;
|
||||||
*(u32**)&this->field_0x6c = &gUnk_08110188;
|
*(const u16**)&this->field_0x6c = gUnk_08110188;
|
||||||
SetDefaultPriority(this, PRIO_MESSAGE);
|
SetDefaultPriority(this, PRIO_MESSAGE);
|
||||||
InitAnimationForceUpdate(this, 2);
|
InitAnimationForceUpdate(this, 2);
|
||||||
gScreen.controls.layerFXControl = 0x3f40;
|
gScreen.controls.layerFXControl = 0x3f40;
|
||||||
|
@ -161,7 +177,7 @@ void sub_08065DB8(Entity* this) {
|
||||||
if ((gMessage.doTextBox & 0x7f) == 0) {
|
if ((gMessage.doTextBox & 0x7f) == 0) {
|
||||||
this->subAction++;
|
this->subAction++;
|
||||||
this->timer = 0x1e;
|
this->timer = 0x1e;
|
||||||
*(u8**)&this->field_0x6c = gUnk_0811022E;
|
*(const u16**)&this->field_0x6c = gUnk_0811022E;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -185,7 +201,12 @@ void sub_08065DB8(Entity* this) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void sub_08065EBC(Entity* this) {
|
void sub_08065EBC(Entity* this) {
|
||||||
gUnk_08110274[this->action](this);
|
static void (*const actionFuncs[])(Entity*) = {
|
||||||
|
sub_08065D18,
|
||||||
|
sub_08065EDC,
|
||||||
|
sub_08065F20,
|
||||||
|
};
|
||||||
|
actionFuncs[this->action](this);
|
||||||
sub_0806ED78(this);
|
sub_0806ED78(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -217,11 +238,29 @@ void sub_08065F20(Entity* this) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void sub_08065F64(Entity* this) {
|
void sub_08065F64(Entity* this) {
|
||||||
|
static const Dialog dialogs[][8] = {
|
||||||
|
{ { 0, 0, 1, 1, { 0, 0x3f31 } },
|
||||||
|
{ 0, 0, 1, 1, { 0, 0x3f31 } },
|
||||||
|
{ 0, 0, 1, 1, { 0, 0x3f31 } },
|
||||||
|
{ 0, 0, 1, 1, { 0, 0x3f31 } },
|
||||||
|
{ 0, 0, 1, 1, { 0, 0x3f31 } },
|
||||||
|
{ 0, 0, 1, 1, { 0, 0x3f31 } },
|
||||||
|
{ 0, 0, 1, 1, { 0, 0x3f31 } },
|
||||||
|
{ 0, 0, 1, 1, { 0, 0x3f31 } } },
|
||||||
|
{ { 4, 0, 3, 1, { 0x3417, 0x3416 } },
|
||||||
|
{ 4, 0, 3, 1, { 0x3417, 0x3416 } },
|
||||||
|
{ 4, 0, 3, 1, { 0x3513, 0x3512 } },
|
||||||
|
{ 4, 0, 3, 1, { 0x3613, 0x3612 } },
|
||||||
|
{ 4, 0, 3, 1, { 0x3713, 0x3712 } },
|
||||||
|
{ 4, 0, 3, 1, { 0x3813, 0x3812 } },
|
||||||
|
{ 4, 0, 3, 1, { 0x3912, 0x3911 } },
|
||||||
|
{ 0, 0, 1, 1, { 0, 0x3A03 } } },
|
||||||
|
};
|
||||||
s32 tmp = gSave.global_progress - 2;
|
s32 tmp = gSave.global_progress - 2;
|
||||||
if (tmp < 0) {
|
if (tmp < 0) {
|
||||||
tmp = 0;
|
tmp = 0;
|
||||||
}
|
}
|
||||||
ShowNPCDialogue(this, gUnk_08110280 + this->type * 8 + tmp);
|
ShowNPCDialogue(this, &dialogs[this->type][tmp]);
|
||||||
}
|
}
|
||||||
|
|
||||||
void GhostBrothers_Fusion(Entity* this) {
|
void GhostBrothers_Fusion(Entity* this) {
|
||||||
|
|
Loading…
Reference in New Issue