2020-10-03 15:22:44 +00:00
|
|
|
|
#include "global.h"
|
2022-11-01 23:17:11 +00:00
|
|
|
|
#include "terminal.h"
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
2022-10-15 17:24:13 +00:00
|
|
|
|
RomFile sNaviQuestHintFiles[];
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
|
s32 Object_Spawn(ObjectContext* objectCtx, s16 objectId) {
|
2020-03-17 04:31:30 +00:00
|
|
|
|
u32 size;
|
|
|
|
|
|
|
|
|
|
objectCtx->status[objectCtx->num].id = objectId;
|
|
|
|
|
size = gObjectTable[objectId].vromEnd - gObjectTable[objectId].vromStart;
|
|
|
|
|
|
2020-10-13 16:32:19 +00:00
|
|
|
|
osSyncPrintf("OBJECT[%d] SIZE %fK SEG=%x\n", objectId, size / 1024.0f, objectCtx->status[objectCtx->num].segment);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
|
osSyncPrintf("num=%d adrs=%x end=%x\n", objectCtx->num, (s32)objectCtx->status[objectCtx->num].segment + size,
|
|
|
|
|
objectCtx->spaceEnd);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
2021-04-29 18:39:46 +00:00
|
|
|
|
ASSERT(((objectCtx->num < OBJECT_EXCHANGE_BANK_MAX) &&
|
|
|
|
|
(((s32)objectCtx->status[objectCtx->num].segment + size) < (u32)objectCtx->spaceEnd)),
|
|
|
|
|
"this->num < OBJECT_EXCHANGE_BANK_MAX && (this->status[this->num].Segment + size) < this->endSegment",
|
|
|
|
|
"../z_scene.c", 142);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
|
DmaMgr_SendRequest1(objectCtx->status[objectCtx->num].segment, gObjectTable[objectId].vromStart, size,
|
|
|
|
|
"../z_scene.c", 145);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
|
if (objectCtx->num < OBJECT_EXCHANGE_BANK_MAX - 1) {
|
|
|
|
|
objectCtx->status[objectCtx->num + 1].segment =
|
|
|
|
|
(void*)ALIGN16((s32)objectCtx->status[objectCtx->num].segment + size);
|
|
|
|
|
}
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
|
|
|
|
objectCtx->num++;
|
|
|
|
|
objectCtx->unk_09 = objectCtx->num;
|
|
|
|
|
|
|
|
|
|
return objectCtx->num - 1;
|
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
void Object_InitBank(PlayState* play, ObjectContext* objectCtx) {
|
|
|
|
|
PlayState* play2 = play; // Needs to be a new variable to match (possibly a sub struct?)
|
2020-03-17 04:31:30 +00:00
|
|
|
|
u32 spaceSize;
|
|
|
|
|
s32 i;
|
|
|
|
|
|
2022-07-31 23:44:47 +00:00
|
|
|
|
if (play2->sceneId == SCENE_SPOT00) {
|
2020-03-17 04:31:30 +00:00
|
|
|
|
spaceSize = 1024000;
|
2022-07-31 23:44:47 +00:00
|
|
|
|
} else if (play2->sceneId == SCENE_GANON_DEMO) {
|
2022-07-30 21:28:50 +00:00
|
|
|
|
if (gSaveContext.sceneLayer != 4) {
|
2020-03-17 04:31:30 +00:00
|
|
|
|
spaceSize = 1177600;
|
2020-03-22 21:19:43 +00:00
|
|
|
|
} else {
|
2020-03-17 04:31:30 +00:00
|
|
|
|
spaceSize = 1024000;
|
2020-03-22 21:19:43 +00:00
|
|
|
|
}
|
2022-07-31 23:44:47 +00:00
|
|
|
|
} else if (play2->sceneId == SCENE_JYASINBOSS) {
|
2020-03-17 04:31:30 +00:00
|
|
|
|
spaceSize = 1075200;
|
2022-07-31 23:44:47 +00:00
|
|
|
|
} else if (play2->sceneId == SCENE_KENJYANOMA) {
|
2020-03-17 04:31:30 +00:00
|
|
|
|
spaceSize = 1075200;
|
2022-07-31 23:44:47 +00:00
|
|
|
|
} else if (play2->sceneId == SCENE_GANON_BOSS) {
|
2020-03-17 04:31:30 +00:00
|
|
|
|
spaceSize = 1075200;
|
2020-03-22 21:19:43 +00:00
|
|
|
|
} else {
|
2020-03-17 04:31:30 +00:00
|
|
|
|
spaceSize = 1024000;
|
2020-03-22 21:19:43 +00:00
|
|
|
|
}
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
|
|
|
|
objectCtx->num = objectCtx->unk_09 = 0;
|
|
|
|
|
objectCtx->mainKeepIndex = objectCtx->subKeepIndex = 0;
|
|
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
|
for (i = 0; i < OBJECT_EXCHANGE_BANK_MAX; i++) {
|
2021-08-30 01:24:32 +00:00
|
|
|
|
objectCtx->status[i].id = OBJECT_INVALID;
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
osSyncPrintf(VT_FGCOL(GREEN));
|
2021-09-04 13:33:19 +00:00
|
|
|
|
// "Object exchange bank data %8.3fKB"
|
2020-10-13 16:32:19 +00:00
|
|
|
|
osSyncPrintf("オブジェクト入れ替えバンク情報 %8.3fKB\n", spaceSize / 1024.0f);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
osSyncPrintf(VT_RST);
|
|
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
|
objectCtx->spaceStart = objectCtx->status[0].segment =
|
2022-05-21 18:23:43 +00:00
|
|
|
|
GameState_Alloc(&play->state, spaceSize, "../z_scene.c", 219);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
objectCtx->spaceEnd = (void*)((s32)objectCtx->spaceStart + spaceSize);
|
|
|
|
|
|
|
|
|
|
objectCtx->mainKeepIndex = Object_Spawn(objectCtx, OBJECT_GAMEPLAY_KEEP);
|
2020-09-01 01:06:44 +00:00
|
|
|
|
gSegments[4] = VIRTUAL_TO_PHYSICAL(objectCtx->status[objectCtx->mainKeepIndex].segment);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
|
void Object_UpdateBank(ObjectContext* objectCtx) {
|
2020-03-17 04:31:30 +00:00
|
|
|
|
s32 i;
|
2021-02-14 00:49:40 +00:00
|
|
|
|
ObjectStatus* status = &objectCtx->status[0];
|
2020-03-17 04:31:30 +00:00
|
|
|
|
RomFile* objectFile;
|
|
|
|
|
u32 size;
|
|
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
|
for (i = 0; i < objectCtx->num; i++) {
|
|
|
|
|
if (status->id < 0) {
|
|
|
|
|
if (status->dmaRequest.vromAddr == 0) {
|
2020-03-17 04:31:30 +00:00
|
|
|
|
osCreateMesgQueue(&status->loadQueue, &status->loadMsg, 1);
|
|
|
|
|
objectFile = &gObjectTable[-status->id];
|
|
|
|
|
size = objectFile->vromEnd - objectFile->vromStart;
|
2020-10-13 16:32:19 +00:00
|
|
|
|
osSyncPrintf("OBJECT EXCHANGE BANK-%2d SIZE %8.3fK SEG=%08x\n", i, size / 1024.0f, status->segment);
|
2020-03-22 21:19:43 +00:00
|
|
|
|
DmaMgr_SendRequest2(&status->dmaRequest, status->segment, objectFile->vromStart, size, 0,
|
|
|
|
|
&status->loadQueue, NULL, "../z_scene.c", 266);
|
2022-04-09 00:20:23 +00:00
|
|
|
|
} else if (osRecvMesg(&status->loadQueue, NULL, OS_MESG_NOBLOCK) == 0) {
|
2020-03-17 04:31:30 +00:00
|
|
|
|
status->id = -status->id;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
status++;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
|
s32 Object_GetIndex(ObjectContext* objectCtx, s16 objectId) {
|
2020-03-17 04:31:30 +00:00
|
|
|
|
s32 i;
|
|
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
|
for (i = 0; i < objectCtx->num; i++) {
|
|
|
|
|
if (ABS(objectCtx->status[i].id) == objectId) {
|
2020-03-17 04:31:30 +00:00
|
|
|
|
return i;
|
2020-03-22 21:19:43 +00:00
|
|
|
|
}
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
|
s32 Object_IsLoaded(ObjectContext* objectCtx, s32 bankIndex) {
|
|
|
|
|
if (objectCtx->status[bankIndex].id > 0) {
|
2022-01-12 20:48:04 +00:00
|
|
|
|
return true;
|
2020-03-22 21:19:43 +00:00
|
|
|
|
} else {
|
2022-01-12 20:48:04 +00:00
|
|
|
|
return false;
|
2020-03-22 21:19:43 +00:00
|
|
|
|
}
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
|
void func_800981B8(ObjectContext* objectCtx) {
|
2020-03-17 04:31:30 +00:00
|
|
|
|
s32 i;
|
|
|
|
|
s32 id;
|
|
|
|
|
u32 size;
|
|
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
|
for (i = 0; i < objectCtx->num; i++) {
|
2020-03-17 04:31:30 +00:00
|
|
|
|
id = objectCtx->status[i].id;
|
|
|
|
|
size = gObjectTable[id].vromEnd - gObjectTable[id].vromStart;
|
2020-10-13 16:32:19 +00:00
|
|
|
|
osSyncPrintf("OBJECT[%d] SIZE %fK SEG=%x\n", objectCtx->status[i].id, size / 1024.0f,
|
2020-03-22 21:19:43 +00:00
|
|
|
|
objectCtx->status[i].segment);
|
|
|
|
|
osSyncPrintf("num=%d adrs=%x end=%x\n", objectCtx->num, (s32)objectCtx->status[i].segment + size,
|
|
|
|
|
objectCtx->spaceEnd);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
DmaMgr_SendRequest1(objectCtx->status[i].segment, gObjectTable[id].vromStart, size, "../z_scene.c", 342);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
|
void* func_800982FC(ObjectContext* objectCtx, s32 bankIndex, s16 objectId) {
|
2020-03-17 04:31:30 +00:00
|
|
|
|
ObjectStatus* status = &objectCtx->status[bankIndex];
|
|
|
|
|
RomFile* objectFile = &gObjectTable[objectId];
|
|
|
|
|
u32 size;
|
|
|
|
|
void* nextPtr;
|
|
|
|
|
|
|
|
|
|
status->id = -objectId;
|
|
|
|
|
status->dmaRequest.vromAddr = 0;
|
|
|
|
|
|
|
|
|
|
size = objectFile->vromEnd - objectFile->vromStart;
|
2020-10-13 16:32:19 +00:00
|
|
|
|
osSyncPrintf("OBJECT EXCHANGE NO=%2d BANK=%3d SIZE=%8.3fK\n", bankIndex, objectId, size / 1024.0f);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
2021-02-14 00:49:40 +00:00
|
|
|
|
nextPtr = (void*)ALIGN16((s32)status->segment + size);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
2021-04-29 18:39:46 +00:00
|
|
|
|
ASSERT(nextPtr < objectCtx->spaceEnd, "nextptr < this->endSegment", "../z_scene.c", 381);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
2021-09-04 13:33:19 +00:00
|
|
|
|
// "Object exchange free size=%08x"
|
2020-03-17 04:31:30 +00:00
|
|
|
|
osSyncPrintf("オブジェクト入れ替え空きサイズ=%08x\n", (s32)objectCtx->spaceEnd - (s32)nextPtr);
|
|
|
|
|
|
|
|
|
|
return nextPtr;
|
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
s32 Scene_ExecuteCommands(PlayState* play, SceneCmd* sceneCmd) {
|
2020-03-17 04:31:30 +00:00
|
|
|
|
u32 cmdCode;
|
|
|
|
|
|
2021-02-14 00:49:40 +00:00
|
|
|
|
while (true) {
|
2020-03-17 04:31:30 +00:00
|
|
|
|
cmdCode = sceneCmd->base.code;
|
2020-03-22 21:19:43 +00:00
|
|
|
|
osSyncPrintf("*** Scene_Word = { code=%d, data1=%02x, data2=%04x } ***\n", cmdCode, sceneCmd->base.data1,
|
|
|
|
|
sceneCmd->base.data2);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
2022-03-16 21:14:56 +00:00
|
|
|
|
if (cmdCode == SCENE_CMD_ID_END) {
|
2020-03-17 04:31:30 +00:00
|
|
|
|
break;
|
2020-03-22 21:19:43 +00:00
|
|
|
|
}
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
2022-03-16 21:14:56 +00:00
|
|
|
|
if (cmdCode < ARRAY_COUNT(gSceneCmdHandlers)) {
|
2022-05-21 18:23:43 +00:00
|
|
|
|
gSceneCmdHandlers[cmdCode](play, sceneCmd);
|
2020-03-22 21:19:43 +00:00
|
|
|
|
} else {
|
2020-03-17 04:31:30 +00:00
|
|
|
|
osSyncPrintf(VT_FGCOL(RED));
|
2021-09-04 13:33:19 +00:00
|
|
|
|
osSyncPrintf("code の値が異常です\n"); // "code variable is abnormal"
|
2020-03-17 04:31:30 +00:00
|
|
|
|
osSyncPrintf(VT_RST);
|
|
|
|
|
}
|
|
|
|
|
sceneCmd++;
|
|
|
|
|
}
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
2022-10-16 22:00:18 +00:00
|
|
|
|
void Scene_CommandPlayerEntryList(PlayState* play, SceneCmd* cmd) {
|
|
|
|
|
ActorEntry* playerEntry = play->playerEntry =
|
|
|
|
|
(ActorEntry*)SEGMENTED_TO_VIRTUAL(cmd->playerEntryList.data) + play->spawnList[play->spawn].playerEntryIndex;
|
2020-03-17 04:31:30 +00:00
|
|
|
|
s16 linkObjectId;
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
play->linkAgeOnLoad = ((void)0, gSaveContext.linkAge);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
2020-08-23 21:50:30 +00:00
|
|
|
|
linkObjectId = gLinkObjectIds[((void)0, gSaveContext.linkAge)];
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
2022-10-16 22:00:18 +00:00
|
|
|
|
gActorOverlayTable[playerEntry->id].initInfo->objectId = linkObjectId;
|
2022-05-21 18:23:43 +00:00
|
|
|
|
Object_Spawn(&play->objectCtx, linkObjectId);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-10-16 22:00:18 +00:00
|
|
|
|
void Scene_CommandActorEntryList(PlayState* play, SceneCmd* cmd) {
|
|
|
|
|
play->numActorEntries = cmd->actorEntryList.length;
|
|
|
|
|
play->actorEntryList = SEGMENTED_TO_VIRTUAL(cmd->actorEntryList.data);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
void Scene_CommandUnused2(PlayState* play, SceneCmd* cmd) {
|
|
|
|
|
play->unk_11DFC = SEGMENTED_TO_VIRTUAL(cmd->unused02.segment);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
void Scene_CommandCollisionHeader(PlayState* play, SceneCmd* cmd) {
|
2022-06-09 19:02:18 +00:00
|
|
|
|
CollisionHeader* colHeader = SEGMENTED_TO_VIRTUAL(cmd->colHeader.data);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
z_bgcheck.c, 800430A0.c, 80043480.c (#256)
* beginning of migrating changes
* got matching
* changed order a bit
* clean up bgcheck
* fix conflict
* fix conflict again
* first stab at identifying types, some oks
* Clean up most bad structs/pointer math, move relevant structs to z64bgcheck.h, get some OKs
* more OKs, z_bgcheck.bss migration, update some sys_math3d.c args
* couple more OKs
* pushing some OKs
* fix compilation issues
* code_800430A0.c OK, more files decomp'd
* 8003A3E0 big OK :)
* Decomp most of func_8003C614, decomp helper funcs
* Decomp SurfaceType, CamData, and WaterBox property related functions
* more OKs, big OK in 8003C078
* more OKs, more progress, move a function definition in z_collision_check to functions.h
* more clean-ups, more OKs, dyn_vtx is now defined as u8*
* 8003A5B8, 8003A7D8, 8003C614, 8003DD6C OK, document function args better
* data migrated, more OKs
* 80041240 OK, func_8003B3C8 and func_8003BB18 disassembled
* func_80040284, 800409A8 non_matching, add IS_ZERO macro
* All asm files have C representations, some big OKs, lots of minor tweaks
* More OKs, non-matching code cleanup
* 8003FBF4 and 80040BE4 OK, improve codegen for most functions
* format z_bgcheck.c
* fix warnings, compile errors on NON_MATCHING
* func_8003EE80 is now NON_MATCHING
* begin documenting some functions
* formatting
* more documentation, func_8003A95C OK
* fix PHYSICAL_TO_VIRTUAL changes
* fix var rename
* More documentation, functions 80040E40, 80041648 OK, change types to not be compatible with ZAP
* func_8004239C ok, more NON_MATCHING improvements, more documentation
* Implement most suggested changes
* Convert comments to slower comments
* /**
* Implement ZAP2 changes
* my anti-virus ate my format.sh results
* Rename a couple hundred functions, fix minor stuff
* rename var so that clang formats correctly
* run format.sh
* implement Petrie's matches/suggestions
* format
* matches
* and the asm
* slight error
* Add SSList
* two more matches
* stuff
* implement code changes
* clean up Petrie's matchings
Co-authored-by: Arthur <arthurtilly413@gmail.com>
Co-authored-by: fig02 <fig02srl@gmail.com>
Co-authored-by: petrie911 <pmontag@DESKTOP-LG8A167.localdomain>
2021-01-08 11:12:58 +00:00
|
|
|
|
colHeader->vtxList = SEGMENTED_TO_VIRTUAL(colHeader->vtxList);
|
|
|
|
|
colHeader->polyList = SEGMENTED_TO_VIRTUAL(colHeader->polyList);
|
|
|
|
|
colHeader->surfaceTypeList = SEGMENTED_TO_VIRTUAL(colHeader->surfaceTypeList);
|
2022-06-17 18:25:42 +00:00
|
|
|
|
colHeader->bgCamList = SEGMENTED_TO_VIRTUAL(colHeader->bgCamList);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
colHeader->waterBoxes = SEGMENTED_TO_VIRTUAL(colHeader->waterBoxes);
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
BgCheck_Allocate(&play->colCtx, play, colHeader);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
void Scene_CommandRoomList(PlayState* play, SceneCmd* cmd) {
|
2022-06-09 19:02:18 +00:00
|
|
|
|
play->numRooms = cmd->roomList.length;
|
|
|
|
|
play->roomList = SEGMENTED_TO_VIRTUAL(cmd->roomList.data);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-10-16 22:00:18 +00:00
|
|
|
|
void Scene_CommandSpawnList(PlayState* play, SceneCmd* cmd) {
|
|
|
|
|
play->spawnList = SEGMENTED_TO_VIRTUAL(cmd->spawnList.data);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
void Scene_CommandSpecialFiles(PlayState* play, SceneCmd* cmd) {
|
2022-01-12 20:48:04 +00:00
|
|
|
|
if (cmd->specialFiles.keepObjectId != OBJECT_INVALID) {
|
2022-05-21 18:23:43 +00:00
|
|
|
|
play->objectCtx.subKeepIndex = Object_Spawn(&play->objectCtx, cmd->specialFiles.keepObjectId);
|
|
|
|
|
gSegments[5] = VIRTUAL_TO_PHYSICAL(play->objectCtx.status[play->objectCtx.subKeepIndex].segment);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-10-15 17:24:13 +00:00
|
|
|
|
if (cmd->specialFiles.naviQuestHintFileId != NAVI_QUEST_HINTS_NONE) {
|
|
|
|
|
play->naviQuestHints = Play_LoadFile(play, &sNaviQuestHintFiles[cmd->specialFiles.naviQuestHintFileId - 1]);
|
2020-03-22 21:19:43 +00:00
|
|
|
|
}
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
void Scene_CommandRoomBehavior(PlayState* play, SceneCmd* cmd) {
|
|
|
|
|
play->roomCtx.curRoom.behaviorType1 = cmd->roomBehavior.gpFlag1;
|
|
|
|
|
play->roomCtx.curRoom.behaviorType2 = cmd->roomBehavior.gpFlag2 & 0xFF;
|
|
|
|
|
play->roomCtx.curRoom.lensMode = (cmd->roomBehavior.gpFlag2 >> 8) & 1;
|
|
|
|
|
play->msgCtx.disableWarpSongs = (cmd->roomBehavior.gpFlag2 >> 0xA) & 1;
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-08-31 23:28:51 +00:00
|
|
|
|
void Scene_CommandRoomShape(PlayState* play, SceneCmd* cmd) {
|
|
|
|
|
play->roomCtx.curRoom.roomShape = SEGMENTED_TO_VIRTUAL(cmd->mesh.data);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
void Scene_CommandObjectList(PlayState* play, SceneCmd* cmd) {
|
2021-02-14 00:49:40 +00:00
|
|
|
|
s32 i;
|
|
|
|
|
s32 j;
|
|
|
|
|
s32 k;
|
2020-03-17 04:31:30 +00:00
|
|
|
|
ObjectStatus* status;
|
|
|
|
|
ObjectStatus* status2;
|
2020-05-27 14:10:03 +00:00
|
|
|
|
ObjectStatus* firstStatus;
|
2022-06-09 19:02:18 +00:00
|
|
|
|
s16* objectEntry = SEGMENTED_TO_VIRTUAL(cmd->objectList.data);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
void* nextPtr;
|
|
|
|
|
|
|
|
|
|
k = 0;
|
2022-05-21 18:23:43 +00:00
|
|
|
|
i = play->objectCtx.unk_09;
|
|
|
|
|
firstStatus = &play->objectCtx.status[0];
|
|
|
|
|
status = &play->objectCtx.status[i];
|
2020-05-27 16:46:59 +00:00
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
while (i < play->objectCtx.num) {
|
2020-03-22 21:19:43 +00:00
|
|
|
|
if (status->id != *objectEntry) {
|
2022-05-21 18:23:43 +00:00
|
|
|
|
status2 = &play->objectCtx.status[i];
|
|
|
|
|
for (j = i; j < play->objectCtx.num; j++) {
|
2021-08-30 01:24:32 +00:00
|
|
|
|
status2->id = OBJECT_INVALID;
|
2020-05-27 14:10:03 +00:00
|
|
|
|
status2++;
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
2022-05-21 18:23:43 +00:00
|
|
|
|
play->objectCtx.num = i;
|
|
|
|
|
func_80031A28(play, &play->actorCtx);
|
2020-05-27 16:46:59 +00:00
|
|
|
|
|
2020-05-27 14:10:03 +00:00
|
|
|
|
continue;
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
2020-05-27 16:46:59 +00:00
|
|
|
|
|
2020-05-27 14:10:03 +00:00
|
|
|
|
i++;
|
|
|
|
|
k++;
|
|
|
|
|
objectEntry++;
|
|
|
|
|
status++;
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
2020-05-27 16:46:59 +00:00
|
|
|
|
|
2022-06-09 19:02:18 +00:00
|
|
|
|
ASSERT(cmd->objectList.length <= OBJECT_EXCHANGE_BANK_MAX,
|
|
|
|
|
"scene_info->object_bank.num <= OBJECT_EXCHANGE_BANK_MAX", "../z_scene.c", 705);
|
2020-05-27 16:46:59 +00:00
|
|
|
|
|
2022-06-09 19:02:18 +00:00
|
|
|
|
while (k < cmd->objectList.length) {
|
2022-05-21 18:23:43 +00:00
|
|
|
|
nextPtr = func_800982FC(&play->objectCtx, i, *objectEntry);
|
2020-03-23 23:11:21 +00:00
|
|
|
|
if (i < OBJECT_EXCHANGE_BANK_MAX - 1) {
|
2020-05-27 14:10:03 +00:00
|
|
|
|
firstStatus[i + 1].segment = nextPtr;
|
2020-03-23 23:11:21 +00:00
|
|
|
|
}
|
2020-05-27 14:10:03 +00:00
|
|
|
|
i++;
|
2020-03-17 04:31:30 +00:00
|
|
|
|
k++;
|
|
|
|
|
objectEntry++;
|
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
play->objectCtx.num = i;
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
void Scene_CommandLightList(PlayState* play, SceneCmd* cmd) {
|
2020-03-17 04:31:30 +00:00
|
|
|
|
s32 i;
|
2022-06-09 19:02:18 +00:00
|
|
|
|
LightInfo* lightInfo = SEGMENTED_TO_VIRTUAL(cmd->lightList.data);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
2022-06-09 19:02:18 +00:00
|
|
|
|
for (i = 0; i < cmd->lightList.length; i++) {
|
2022-05-21 18:23:43 +00:00
|
|
|
|
LightContext_InsertLight(play, &play->lightCtx, lightInfo);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
lightInfo++;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
void Scene_CommandPathList(PlayState* play, SceneCmd* cmd) {
|
2022-10-16 22:00:18 +00:00
|
|
|
|
play->pathList = SEGMENTED_TO_VIRTUAL(cmd->pathList.data);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-10-16 22:00:18 +00:00
|
|
|
|
void Scene_CommandTransitionActorEntryList(PlayState* play, SceneCmd* cmd) {
|
2022-06-09 19:02:18 +00:00
|
|
|
|
play->transiActorCtx.numActors = cmd->transiActorList.length;
|
|
|
|
|
play->transiActorCtx.list = SEGMENTED_TO_VIRTUAL(cmd->transiActorList.data);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2021-08-15 23:15:58 +00:00
|
|
|
|
void TransitionActor_InitContext(GameState* state, TransitionActorContext* transiActorCtx) {
|
|
|
|
|
transiActorCtx->numActors = 0;
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
void Scene_CommandLightSettingsList(PlayState* play, SceneCmd* cmd) {
|
2022-06-09 19:02:18 +00:00
|
|
|
|
play->envCtx.numLightSettings = cmd->lightSettingList.length;
|
|
|
|
|
play->envCtx.lightSettingsList = SEGMENTED_TO_VIRTUAL(cmd->lightSettingList.data);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
void Scene_CommandSkyboxSettings(PlayState* play, SceneCmd* cmd) {
|
|
|
|
|
play->skyboxId = cmd->skyboxSettings.skyboxId;
|
2022-06-09 19:02:18 +00:00
|
|
|
|
play->envCtx.skyboxConfig = play->envCtx.changeSkyboxNextConfig = cmd->skyboxSettings.skyboxConfig;
|
|
|
|
|
play->envCtx.lightMode = cmd->skyboxSettings.envLightMode;
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
void Scene_CommandSkyboxDisables(PlayState* play, SceneCmd* cmd) {
|
2022-06-09 19:02:18 +00:00
|
|
|
|
play->envCtx.skyboxDisabled = cmd->skyboxDisables.skyboxDisabled;
|
|
|
|
|
play->envCtx.sunMoonDisabled = cmd->skyboxDisables.sunMoonDisabled;
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
void Scene_CommandTimeSettings(PlayState* play, SceneCmd* cmd) {
|
2020-03-22 21:19:43 +00:00
|
|
|
|
if ((cmd->timeSettings.hour != 0xFF) && (cmd->timeSettings.min != 0xFF)) {
|
2021-09-20 16:51:35 +00:00
|
|
|
|
gSaveContext.skyboxTime = gSaveContext.dayTime =
|
|
|
|
|
((cmd->timeSettings.hour + (cmd->timeSettings.min / 60.0f)) * 60.0f) / ((f32)(24 * 60) / 0x10000);
|
2020-03-22 21:19:43 +00:00
|
|
|
|
}
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
2022-06-09 19:02:18 +00:00
|
|
|
|
if (cmd->timeSettings.timeSpeed != 0xFF) {
|
|
|
|
|
play->envCtx.sceneTimeSpeed = cmd->timeSettings.timeSpeed;
|
2020-03-22 21:19:43 +00:00
|
|
|
|
} else {
|
2022-05-21 18:23:43 +00:00
|
|
|
|
play->envCtx.sceneTimeSpeed = 0;
|
2020-03-22 21:19:43 +00:00
|
|
|
|
}
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
2021-09-20 16:51:35 +00:00
|
|
|
|
if (gSaveContext.sunsSongState == SUNSSONG_INACTIVE) {
|
2022-05-21 18:23:43 +00:00
|
|
|
|
gTimeSpeed = play->envCtx.sceneTimeSpeed;
|
2020-03-22 21:19:43 +00:00
|
|
|
|
}
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
play->envCtx.sunPos.x = -(Math_SinS(((void)0, gSaveContext.dayTime) - CLOCK_TIME(12, 0)) * 120.0f) * 25.0f;
|
|
|
|
|
play->envCtx.sunPos.y = (Math_CosS(((void)0, gSaveContext.dayTime) - CLOCK_TIME(12, 0)) * 120.0f) * 25.0f;
|
|
|
|
|
play->envCtx.sunPos.z = (Math_CosS(((void)0, gSaveContext.dayTime) - CLOCK_TIME(12, 0)) * 20.0f) * 25.0f;
|
2020-04-16 21:36:12 +00:00
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
if (((play->envCtx.sceneTimeSpeed == 0) && (gSaveContext.cutsceneIndex < 0xFFF0)) ||
|
2022-05-09 17:45:53 +00:00
|
|
|
|
(gSaveContext.entranceIndex == ENTR_SPOT06_8)) {
|
2021-09-20 16:51:35 +00:00
|
|
|
|
gSaveContext.skyboxTime = ((void)0, gSaveContext.dayTime);
|
2022-05-21 18:23:43 +00:00
|
|
|
|
|
2022-05-20 18:40:13 +00:00
|
|
|
|
if ((gSaveContext.skyboxTime > CLOCK_TIME(4, 0)) && (gSaveContext.skyboxTime < CLOCK_TIME(6, 30))) {
|
|
|
|
|
gSaveContext.skyboxTime = CLOCK_TIME(5, 0) + 1;
|
|
|
|
|
} else if ((gSaveContext.skyboxTime >= CLOCK_TIME(6, 30)) && (gSaveContext.skyboxTime <= CLOCK_TIME(8, 0))) {
|
|
|
|
|
gSaveContext.skyboxTime = CLOCK_TIME(8, 0) + 1;
|
|
|
|
|
} else if ((gSaveContext.skyboxTime >= CLOCK_TIME(16, 0)) && (gSaveContext.skyboxTime <= CLOCK_TIME(17, 0))) {
|
|
|
|
|
gSaveContext.skyboxTime = CLOCK_TIME(17, 0) + 1;
|
|
|
|
|
} else if ((gSaveContext.skyboxTime >= CLOCK_TIME(18, 0) + 1) &&
|
|
|
|
|
(gSaveContext.skyboxTime <= CLOCK_TIME(19, 0))) {
|
|
|
|
|
gSaveContext.skyboxTime = CLOCK_TIME(19, 0) + 1;
|
2020-03-22 21:19:43 +00:00
|
|
|
|
}
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
void Scene_CommandWindSettings(PlayState* play, SceneCmd* cmd) {
|
2021-09-20 16:51:35 +00:00
|
|
|
|
s8 x = cmd->windSettings.x;
|
|
|
|
|
s8 y = cmd->windSettings.y;
|
|
|
|
|
s8 z = cmd->windSettings.z;
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
play->envCtx.windDirection.x = x;
|
|
|
|
|
play->envCtx.windDirection.y = y;
|
|
|
|
|
play->envCtx.windDirection.z = z;
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
play->envCtx.windSpeed = cmd->windSettings.unk_07;
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
void Scene_CommandExitList(PlayState* play, SceneCmd* cmd) {
|
2022-10-16 22:00:18 +00:00
|
|
|
|
play->exitList = SEGMENTED_TO_VIRTUAL(cmd->exitList.data);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
void Scene_CommandUndefined9(PlayState* play, SceneCmd* cmd) {
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
void Scene_CommandSoundSettings(PlayState* play, SceneCmd* cmd) {
|
|
|
|
|
play->sequenceCtx.seqId = cmd->soundSettings.seqId;
|
|
|
|
|
play->sequenceCtx.natureAmbienceId = cmd->soundSettings.natureAmbienceId;
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
2021-12-03 14:49:32 +00:00
|
|
|
|
if (gSaveContext.seqId == (u8)NA_BGM_DISABLED) {
|
2022-10-07 11:29:33 +00:00
|
|
|
|
SEQCMD_RESET_AUDIO_HEAP(0, cmd->soundSettings.specId);
|
2020-03-22 21:19:43 +00:00
|
|
|
|
}
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
void Scene_CommandEchoSettings(PlayState* play, SceneCmd* cmd) {
|
|
|
|
|
play->roomCtx.curRoom.echo = cmd->echoSettings.echo;
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
void Scene_CommandAlternateHeaderList(PlayState* play, SceneCmd* cmd) {
|
2020-08-23 21:50:30 +00:00
|
|
|
|
s32 pad;
|
2020-03-17 04:31:30 +00:00
|
|
|
|
SceneCmd* altHeader;
|
|
|
|
|
|
2020-08-23 21:50:30 +00:00
|
|
|
|
osSyncPrintf("\n[ZU]sceneset age =[%X]", ((void)0, gSaveContext.linkAge));
|
|
|
|
|
osSyncPrintf("\n[ZU]sceneset time =[%X]", ((void)0, gSaveContext.cutsceneIndex));
|
2022-07-30 21:28:50 +00:00
|
|
|
|
osSyncPrintf("\n[ZU]sceneset counter=[%X]", ((void)0, gSaveContext.sceneLayer));
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
2022-07-30 21:28:50 +00:00
|
|
|
|
if (gSaveContext.sceneLayer != 0) {
|
|
|
|
|
altHeader = ((SceneCmd**)SEGMENTED_TO_VIRTUAL(cmd->altHeaders.data))[gSaveContext.sceneLayer - 1];
|
2020-08-23 21:50:30 +00:00
|
|
|
|
|
|
|
|
|
if (1) {}
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
|
if (altHeader != NULL) {
|
2022-05-21 18:23:43 +00:00
|
|
|
|
Scene_ExecuteCommands(play, SEGMENTED_TO_VIRTUAL(altHeader));
|
2022-03-16 21:14:56 +00:00
|
|
|
|
(cmd + 1)->base.code = SCENE_CMD_ID_END;
|
2020-03-22 21:19:43 +00:00
|
|
|
|
} else {
|
2021-09-04 13:33:19 +00:00
|
|
|
|
// "Coughh! There is no specified dataaaaa!"
|
2020-03-17 04:31:30 +00:00
|
|
|
|
osSyncPrintf("\nげぼはっ! 指定されたデータがないでええっす!");
|
|
|
|
|
|
2022-07-30 21:28:50 +00:00
|
|
|
|
if (gSaveContext.sceneLayer == SCENE_LAYER_ADULT_NIGHT) {
|
|
|
|
|
// Due to the condition above, this is equivalent to accessing altHeaders[SCENE_LAYER_ADULT_DAY - 1]
|
|
|
|
|
altHeader = ((SceneCmd**)SEGMENTED_TO_VIRTUAL(
|
|
|
|
|
cmd->altHeaders
|
|
|
|
|
.data))[(gSaveContext.sceneLayer - SCENE_LAYER_ADULT_NIGHT) + SCENE_LAYER_ADULT_DAY - 1];
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
2021-09-04 13:33:19 +00:00
|
|
|
|
// "Using adult day data there!"
|
2020-03-17 04:31:30 +00:00
|
|
|
|
osSyncPrintf("\nそこで、大人の昼データを使用するでええっす!!");
|
|
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
|
if (altHeader != NULL) {
|
2022-05-21 18:23:43 +00:00
|
|
|
|
Scene_ExecuteCommands(play, SEGMENTED_TO_VIRTUAL(altHeader));
|
2022-03-16 21:14:56 +00:00
|
|
|
|
(cmd + 1)->base.code = SCENE_CMD_ID_END;
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
void Scene_CommandCutsceneData(PlayState* play, SceneCmd* cmd) {
|
|
|
|
|
osSyncPrintf("\ngame_play->demo_play.data=[%x]", play->csCtx.segment);
|
2022-06-09 19:02:18 +00:00
|
|
|
|
play->csCtx.segment = SEGMENTED_TO_VIRTUAL(cmd->cutsceneData.data);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 12:54:51 +00:00
|
|
|
|
// Camera & World Map Area
|
2022-05-21 18:23:43 +00:00
|
|
|
|
void Scene_CommandMiscSettings(PlayState* play, SceneCmd* cmd) {
|
2022-06-21 00:31:53 +00:00
|
|
|
|
R_SCENE_CAM_TYPE = cmd->miscSettings.sceneCamType;
|
2020-04-16 21:36:12 +00:00
|
|
|
|
gSaveContext.worldMapArea = cmd->miscSettings.area;
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
2022-07-31 23:44:47 +00:00
|
|
|
|
if ((play->sceneId == SCENE_SHOP1) || (play->sceneId == SCENE_SYATEKIJYOU)) {
|
2020-03-22 21:19:43 +00:00
|
|
|
|
if (LINK_AGE_IN_YEARS == YEARS_ADULT) {
|
2020-04-16 21:36:12 +00:00
|
|
|
|
gSaveContext.worldMapArea = 1;
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2022-07-31 23:44:47 +00:00
|
|
|
|
if (((play->sceneId >= SCENE_SPOT00) && (play->sceneId <= SCENE_GANON_TOU)) ||
|
|
|
|
|
((play->sceneId >= SCENE_ENTRA) && (play->sceneId <= SCENE_SHRINE_R))) {
|
2020-04-16 21:36:12 +00:00
|
|
|
|
if (gSaveContext.cutsceneIndex < 0xFFF0) {
|
|
|
|
|
gSaveContext.worldMapAreaData |= gBitFlags[gSaveContext.worldMapArea];
|
|
|
|
|
osSyncPrintf("000 area_arrival=%x (%d)\n", gSaveContext.worldMapAreaData,
|
|
|
|
|
gSaveContext.worldMapArea);
|
2020-03-17 04:31:30 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 18:23:43 +00:00
|
|
|
|
void (*gSceneCmdHandlers[SCENE_CMD_ID_MAX])(PlayState*, SceneCmd*) = {
|
2022-10-16 22:00:18 +00:00
|
|
|
|
Scene_CommandPlayerEntryList, // SCENE_CMD_ID_SPAWN_LIST
|
|
|
|
|
Scene_CommandActorEntryList, // SCENE_CMD_ID_ACTOR_LIST
|
|
|
|
|
Scene_CommandUnused2, // SCENE_CMD_ID_UNUSED_2
|
|
|
|
|
Scene_CommandCollisionHeader, // SCENE_CMD_ID_COLLISION_HEADER
|
|
|
|
|
Scene_CommandRoomList, // SCENE_CMD_ID_ROOM_LIST
|
|
|
|
|
Scene_CommandWindSettings, // SCENE_CMD_ID_WIND_SETTINGS
|
|
|
|
|
Scene_CommandSpawnList, // SCENE_CMD_ID_ENTRANCE_LIST
|
|
|
|
|
Scene_CommandSpecialFiles, // SCENE_CMD_ID_SPECIAL_FILES
|
|
|
|
|
Scene_CommandRoomBehavior, // SCENE_CMD_ID_ROOM_BEHAVIOR
|
|
|
|
|
Scene_CommandUndefined9, // SCENE_CMD_ID_UNDEFINED_9
|
|
|
|
|
Scene_CommandRoomShape, // SCENE_CMD_ID_ROOM_SHAPE
|
|
|
|
|
Scene_CommandObjectList, // SCENE_CMD_ID_OBJECT_LIST
|
|
|
|
|
Scene_CommandLightList, // SCENE_CMD_ID_LIGHT_LIST
|
|
|
|
|
Scene_CommandPathList, // SCENE_CMD_ID_PATH_LIST
|
|
|
|
|
Scene_CommandTransitionActorEntryList, // SCENE_CMD_ID_TRANSITION_ACTOR_LIST
|
|
|
|
|
Scene_CommandLightSettingsList, // SCENE_CMD_ID_LIGHT_SETTINGS_LIST
|
|
|
|
|
Scene_CommandTimeSettings, // SCENE_CMD_ID_TIME_SETTINGS
|
|
|
|
|
Scene_CommandSkyboxSettings, // SCENE_CMD_ID_SKYBOX_SETTINGS
|
|
|
|
|
Scene_CommandSkyboxDisables, // SCENE_CMD_ID_SKYBOX_DISABLES
|
|
|
|
|
Scene_CommandExitList, // SCENE_CMD_ID_EXIT_LIST
|
|
|
|
|
NULL, // SCENE_CMD_ID_END
|
|
|
|
|
Scene_CommandSoundSettings, // SCENE_CMD_ID_SOUND_SETTINGS
|
|
|
|
|
Scene_CommandEchoSettings, // SCENE_CMD_ID_ECHO_SETTINGS
|
|
|
|
|
Scene_CommandCutsceneData, // SCENE_CMD_ID_CUTSCENE_DATA
|
|
|
|
|
Scene_CommandAlternateHeaderList, // SCENE_CMD_ID_ALTERNATE_HEADER_LIST
|
|
|
|
|
Scene_CommandMiscSettings, // SCENE_CMD_ID_MISC_SETTINGS
|
2020-03-17 04:31:30 +00:00
|
|
|
|
};
|
|
|
|
|
|
2022-10-15 17:24:13 +00:00
|
|
|
|
RomFile sNaviQuestHintFiles[] = {
|
2020-03-17 04:31:30 +00:00
|
|
|
|
ROM_FILE(elf_message_field),
|
|
|
|
|
ROM_FILE(elf_message_ydan),
|
|
|
|
|
};
|