mirror of
https://github.com/TwilitRealm/dusklight
synced 2026-05-25 07:02:47 -04:00
29c96f5c65
* Fix 6-byte multichar literals * Add `struct` to `e_ga_class::ga_s` * Fix remaining wrong forward declares (struct/class) * Replace `#include <string>` with `#include <cstring>` * Guard FLT_EPSILON define to prevent redefinition * Add missing `#include <cstring>` for direct cstring function usage
599 lines
14 KiB
C++
599 lines
14 KiB
C++
#include "d/d_com_static.h"
|
|
#include "d/d_debug_viewer.h"
|
|
#include "d/d_demo.h"
|
|
#include "d/d_s_play.h"
|
|
#include "d/actor/d_a_arrow.h"
|
|
#include "d/actor/d_a_dshutter.h"
|
|
#include "d/actor/d_a_grass.h"
|
|
#include "d/actor/d_a_mirror.h"
|
|
#include "d/actor/d_a_movie_player.h"
|
|
#include "d/actor/d_a_set_bgobj.h"
|
|
#include "d/actor/d_a_ykgr.h"
|
|
#include "d/actor/d_a_obj_carry.h"
|
|
#include "d/actor/d_a_obj_movebox.h"
|
|
#include "d/actor/d_a_tag_magne.h"
|
|
#include "d/actor/d_a_tag_mist.h"
|
|
#include "d/actor/d_a_tag_stream.h"
|
|
#include "d/actor/d_grass.h"
|
|
#include "d/actor/d_flower.h"
|
|
#include <cstdio>
|
|
#include <cstring>
|
|
|
|
s16 const daObjMovebox::Act_c::M_dir_base[4] = {
|
|
0x0000,
|
|
0x4000,
|
|
-0x8000,
|
|
-0x4000,
|
|
};
|
|
|
|
void daSus_c::data_c::set(s8 i_roomNo, cXyz const& param_1, cXyz const& param_2, u8 param_3,
|
|
u8 param_4, u8 i_type) {
|
|
mRoomNo = i_roomNo;
|
|
field_0x8.set(param_1.x - param_2.x, param_1.y, param_1.z - param_2.z);
|
|
field_0x14.set(param_1.x + param_2.x, param_1.y + param_2.y, param_1.z + param_2.z);
|
|
field_0x2 = param_3;
|
|
field_0x1 = param_4 != 0 ? true : false;
|
|
field_0x3 = isSwitch() == false;
|
|
mType = i_type;
|
|
}
|
|
|
|
daSus_c::data_c* daSus_c::data_c::reset() {
|
|
mRoomNo = -1;
|
|
return mpNext;
|
|
}
|
|
|
|
u8 daSus_c::data_c::isSwitch() {
|
|
if (field_0x1 & 1) {
|
|
return dComIfGs_isSwitch(field_0x2, mRoomNo);
|
|
} else {
|
|
return dComIfGs_isSwitch(field_0x2, mRoomNo) == false;
|
|
}
|
|
}
|
|
|
|
bool daSus_c::data_c::check(cXyz const& i_pos) {
|
|
if (field_0x3 != 0) {
|
|
return false;
|
|
}
|
|
|
|
if ((field_0x8.x <= i_pos.x && i_pos.x <= field_0x14.x) &&
|
|
(field_0x8.y <= i_pos.y && i_pos.y <= field_0x14.y) &&
|
|
(field_0x8.z <= i_pos.z && i_pos.z <= field_0x14.z))
|
|
{
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
u8 daSus_c::data_c::check(fopAc_ac_c* i_actor) {
|
|
if (field_0x3) {
|
|
return 0x80;
|
|
}
|
|
|
|
u8 tmp = 0x80;
|
|
|
|
if (check(i_actor->home.pos)) {
|
|
tmp |= 1;
|
|
}
|
|
|
|
if (check(i_actor->current.pos)) {
|
|
return tmp | 2;
|
|
}
|
|
|
|
return tmp;
|
|
}
|
|
|
|
void daSus_c::data_c::execute() {
|
|
u8 sw = isSwitch();
|
|
if (sw != field_0x3) {
|
|
field_0x3 = sw;
|
|
}
|
|
}
|
|
|
|
void daSus_c::data_c::draw() {
|
|
if (!isSwitch()) {
|
|
cXyz local_20 = field_0x14 - field_0x8;
|
|
local_20 *= 0.5f;
|
|
cXyz local_2c = field_0x8 + local_20;
|
|
csXyz local_34(0, 0, 0);
|
|
GXColor local_38 = {0, 0, 255, 160};
|
|
GXColor* r29 = &local_38;
|
|
dDbVw_drawCubeXlu(local_2c, local_20, local_34, *r29);
|
|
}
|
|
}
|
|
|
|
void daSus_c::room_c::add(daSus_c::data_c* i_data) {
|
|
if (mpData == NULL) {
|
|
mpData = i_data;
|
|
i_data->setNext(NULL);
|
|
return;
|
|
}
|
|
|
|
if (i_data->getType() == 0) {
|
|
i_data->setNext(mpData);
|
|
mpData = i_data;
|
|
return;
|
|
}
|
|
|
|
daSus_c::data_c* data1 = mpData;
|
|
for (daSus_c::data_c* data2 = data1->getNext(); data2 != NULL; data2 = data1->getNext()) {
|
|
if (data1->getType() != 0)
|
|
break;
|
|
data1 = data2;
|
|
}
|
|
|
|
i_data->setNext(data1->getNext());
|
|
data1->setNext(i_data);
|
|
}
|
|
|
|
void daSus_c::room_c::reset() {
|
|
while (mpData != NULL && mpData->getType() == 0) {
|
|
mpData = mpData->reset();
|
|
}
|
|
}
|
|
|
|
daSus_c::data_c daSus_c::mData[0x20];
|
|
|
|
daSus_c::room_c daSus_c::mRoom[0x40];
|
|
|
|
#if DEBUG
|
|
daCanBall_c::Hio_c daCanBall_c::mHIO;
|
|
#endif
|
|
|
|
s16 daArrow_c::m_count;
|
|
|
|
s16 daSus_c::mSetTop;
|
|
|
|
int daSus_c::newData(s8 i_roomNo, cXyz const& param_1, cXyz const& param_2, u8 param_3, u8 param_4,
|
|
u8 i_type) {
|
|
daSus_c::data_c* pData = mData + mSetTop;
|
|
for (s16 i = mSetTop; i < 32; i++) {
|
|
if (!pData->isUsed()) {
|
|
pData->set(i_roomNo, param_1, param_2, param_3, param_4, i_type);
|
|
mRoom[i_roomNo].add(pData);
|
|
mSetTop = (i + 1) % 32;
|
|
return 1;
|
|
}
|
|
pData++;
|
|
}
|
|
|
|
pData = mData;
|
|
for (s16 i = 0; i < mSetTop; i++) {
|
|
if (!pData->isUsed()) {
|
|
pData->set(i_roomNo, param_1, param_2, param_3, param_4, i_type);
|
|
mRoom[i_roomNo].add(pData);
|
|
mSetTop = (i + 1) % 32;
|
|
return 1;
|
|
}
|
|
pData++;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
void daSus_c::reset() {
|
|
daSus_c::data_c* pData = mData;
|
|
for (int i = 0; i < 0x20; i++) {
|
|
pData->reset();
|
|
pData++;
|
|
}
|
|
|
|
daSus_c::room_c* pRoom = mRoom;
|
|
for (int i = 0; i < 0x40; i++) {
|
|
pRoom->init();
|
|
pRoom++;
|
|
}
|
|
}
|
|
|
|
bool daSus_c::check(s8 i_roomNo, cXyz const& i_pos) {
|
|
daSus_c::data_c* pData = mData;
|
|
for (s16 i = 0; i < 0x20; i++) {
|
|
if (pData->isUsed() && i_roomNo == pData->getRoomNo() && pData->getType()) {
|
|
if (pData->check(i_pos)) {
|
|
return true;
|
|
}
|
|
}
|
|
pData++;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
void daSus_c::check(fopAc_ac_c* i_actor) {
|
|
if (fopAcM_GetGroup(i_actor) != 1 && fopAcM_GetGroup(i_actor) != 5) {
|
|
daSus_c::data_c* pData = mData;
|
|
u8 res = 0;
|
|
for (s16 i = 0; i < 0x20; i++) {
|
|
if (pData->isUsed() && pData->getType() == 0) {
|
|
res |= pData->check(i_actor);
|
|
}
|
|
pData++;
|
|
}
|
|
|
|
if ((res & 0x80) != 0) {
|
|
if ((res & 3) == 3) {
|
|
fopAcM_OnStatus(i_actor, 0x20000000);
|
|
} else {
|
|
fopAcM_OffStatus(i_actor, 0x20000000);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
void daSus_c::execute() {
|
|
daSus_c::data_c* pData = mData;
|
|
for (s16 i = 0; i < 0x20; i++) {
|
|
if (pData->isUsed()) {
|
|
pData->execute();
|
|
}
|
|
pData++;
|
|
}
|
|
}
|
|
|
|
void daSus_c::draw() {
|
|
if (!g_envHIO.mOther.mDisplayTransparentCyl) {
|
|
return;
|
|
}
|
|
daSus_c::data_c* pData = mData;
|
|
for (s16 i = 0; i < 0x20; i++) {
|
|
if (pData->isUsed()) {
|
|
pData->draw();
|
|
}
|
|
pData++;
|
|
}
|
|
}
|
|
|
|
#if DEBUG
|
|
daCanBall_c::Hio_c::Hio_c() {
|
|
field_0x8 = -2.0f;
|
|
field_0xc = -20.0f;
|
|
field_0x10 = 0.5f;
|
|
field_0x14 = 0.3f;
|
|
field_0x18 = 0.2f;
|
|
field_0x1c = 0.3f;
|
|
field_0x20 = 3.0f;
|
|
field_0x24 = 0.0f;
|
|
field_0x28 = 0.1f;
|
|
field_0x2c = 30.0f;
|
|
field_0x30 = 1.8f;
|
|
field_0x38 = 250;
|
|
field_0x34 = 200.0f;
|
|
field_0x3c = 1.0f;
|
|
}
|
|
|
|
void daCanBall_c::Hio_c::genMessage(JORMContext* mctx) {
|
|
mctx->genLabel("§ 鉄球のパラメータ設定 §\n", 0x80000001);
|
|
mctx->genSlider("鉄球の寿命", &field_0x38, 0, 500);
|
|
mctx->genSlider("重力加速度", &field_0x8, -20.0, 0.0);
|
|
mctx->genSlider("落下最高速度", &field_0xc, -50.0, 0.0);
|
|
mctx->genSlider("床の跳ね返り係数", &field_0x10, 0.0, 1.0);
|
|
mctx->genSlider("床の跳ね返り最小値", &field_0x14, 0.0, 10.0);
|
|
mctx->genSlider("壁の跳ね返り係数", &field_0x18, 0.0, 1.0);
|
|
mctx->genSlider("壁の跳ね返り最小値", &field_0x1c, 0.0, 10.0);
|
|
mctx->genSlider("画面を揺らす最小値", &field_0x20, 0.0, 10.0);
|
|
mctx->genSlider("初速度", &field_0x24, 0.0, 200.0);
|
|
mctx->genSlider("加速度", &field_0x28, 0.0, 200.0);
|
|
mctx->genSlider("最高速度", &field_0x2c, 0.0, 200.0);
|
|
mctx->genSlider("着地煙のサイズ", &field_0x30, 0.0, 20.0);
|
|
mctx->genSlider("バレルの長さ", &field_0x34, 200.0, 400.0);
|
|
mctx->genSlider("消滅する時の時間", &field_0x3c, -100.0, 100.0);
|
|
}
|
|
#endif
|
|
|
|
static void dummy(int aLayerNum) {
|
|
JUT_ASSERT(0, 0 <= aLayerNum && aLayerNum < 256);
|
|
}
|
|
|
|
namespace daNpc_Msg_c {
|
|
const int EVTEND_e = 43;
|
|
}
|
|
|
|
int daNpcMsg_setEvtNum(u8 iEvtNum) {
|
|
JUT_ASSERT(437, 0 <= iEvtNum && iEvtNum <= daNpc_Msg_c::EVTEND_e);
|
|
dComIfGs_setTmpReg(0xFDFF, iEvtNum);
|
|
return 1;
|
|
}
|
|
|
|
bool daNpcKakashi_chkSwdTutorialStage() {
|
|
return bool(strcmp(dComIfGp_getStartStageName(), "F_SP103") == 0 && dComIfG_play_c::getLayerNo(0) == 8);
|
|
}
|
|
|
|
void daNpcKakashi_setSwdTutorialStep(u8 iEvtNum) {
|
|
dComIfGs_setTmpReg(0xFF0F, iEvtNum);
|
|
}
|
|
|
|
u8 daNpcKakashi_getSwdTutorialStep() {
|
|
return dComIfGs_getTmpReg(0xFF0F) & 0xff;
|
|
}
|
|
|
|
bool daNpcKakashi_getSwdTutorialResult() {
|
|
/* dSv_event_tmp_flag_c::T_0004 - Ordon Village - sword tutorial - outcome */
|
|
return dComIfGs_isTmpBit(0x40);
|
|
}
|
|
|
|
void daNpcKakashi_setSwdTutorialResult(bool param_0) {
|
|
if (param_0) {
|
|
/* dSv_event_tmp_flag_c::T_0004 - Ordon Village - sword tutorial - outcome */
|
|
dComIfGs_onTmpBit(0x40);
|
|
} else {
|
|
/* dSv_event_tmp_flag_c::T_0004 - Ordon Village - sword tutorial - outcome */
|
|
dComIfGs_offTmpBit(0x40);
|
|
}
|
|
}
|
|
|
|
u8 daNpcKakashi_getSuccessCount() {
|
|
return dComIfGs_getTmpReg(0xFEFF) & 0xFF;
|
|
}
|
|
|
|
void daNpcKakashi_incSuccessCount() {
|
|
int tmpReg = dComIfGs_getTmpReg(0xFEFF);
|
|
tmpReg++;
|
|
dComIfGs_setTmpReg(0xFEFF, tmpReg);
|
|
}
|
|
|
|
void daNpcKakashi_clrSuccessCount() {
|
|
dComIfGs_setTmpReg(0xFEFF, 0);
|
|
}
|
|
|
|
bool daYkgr_c::m_flag;
|
|
|
|
bool daYkgr_c::m_alpha_flag;
|
|
|
|
u8 daYkgr_c::m_alpha;
|
|
|
|
f32 daYkgr_c::m_aim_rate;
|
|
|
|
dPath* daYkgr_c::m_path;
|
|
|
|
JPABaseEmitter* daYkgr_c::m_emitter;
|
|
|
|
const char* daSetBgObj_c::getArcName(fopAc_ac_c* i_this) {
|
|
static char arcName[8];
|
|
|
|
u32 r30 = fopAcM_GetParam(i_this);
|
|
u16 r29 = fopAcM_GetParam(i_this);
|
|
sprintf(arcName, "@bg%04x", r29);
|
|
|
|
if (DEBUG && r30 & 0x80000000) {
|
|
OS_REPORT("\e[43;30m旧仕様の地形ユニットMoveBGが残っています!!!\n\e[m");
|
|
u16 r28 = r30 >> 12 & 0x1FF;
|
|
u16 r27 = r30 & 0xFFF;
|
|
sprintf(arcName, "@%03x%03x", r28, (u16)r27);
|
|
}
|
|
return arcName;
|
|
}
|
|
|
|
f32 const daDsh_c::OPEN_SIZE = 270.1f;
|
|
|
|
f32 const daDsh_c::OPEN_ACCEL = 10.0f;
|
|
|
|
f32 const daDsh_c::OPEN_SPEED = -40.0f;
|
|
|
|
f32 const daDsh_c::OPEN_BOUND_SPEED = -30.0f;
|
|
|
|
f32 const daDsh_c::OPEN_BOUND_RATIO = -0.4f;
|
|
|
|
f32 const daDsh_c::CLOSE_ACCEL = 10.0f;
|
|
|
|
f32 const daDsh_c::CLOSE_SPEED = 40.0f;
|
|
|
|
f32 const daDsh_c::CLOSE_BOUND_SPEED = 30.0f;
|
|
|
|
f32 const daDsh_c::CLOSE_BOUND_RATIO = -0.4f;
|
|
|
|
int daTagStream_c::checkArea(cXyz const* param_0) {
|
|
cXyz relativePos;
|
|
fpoAcM_relativePos(this, param_0, &relativePos);
|
|
if (relativePos.y >= 0.0f && relativePos.y <= scale.y && fabsf(relativePos.x) <= scale.x &&
|
|
fabsf(relativePos.z) <= scale.z)
|
|
{
|
|
return 1;
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
daMirror_c::entryModelFunc daMirror_c::m_entryModel = NULL;
|
|
|
|
daTagStream_c* daTagStream_c::m_top;
|
|
|
|
daMirror_c* daMirror_c::m_myObj;
|
|
|
|
int daMirror_c::entry(J3DModel* param_0) {
|
|
if (m_myObj == NULL) {
|
|
return 0;
|
|
}
|
|
return (m_myObj->*(daMirror_c::m_entryModel))(param_0);
|
|
}
|
|
|
|
bool daMirror_c::remove() {
|
|
if (m_myObj == NULL) {
|
|
return false;
|
|
}
|
|
|
|
fopAcM_delete(m_myObj);
|
|
return true;
|
|
}
|
|
|
|
dGrass_packet_c::deleteFunc dGrass_packet_c::m_deleteRoom = NULL;
|
|
|
|
daGrass_c* daGrass_c::m_myObj;
|
|
|
|
dGrass_packet_c* daGrass_c::m_grass;
|
|
|
|
void daGrass_c::deleteRoomGrass(int param_0) {
|
|
if (m_grass) {
|
|
(m_grass->*dGrass_packet_c::getDeleteRoom())(param_0);;
|
|
}
|
|
}
|
|
|
|
dFlower_packet_c::deleteFunc dFlower_packet_c::m_deleteRoom = NULL;
|
|
|
|
dFlower_packet_c* daGrass_c::m_flower;
|
|
|
|
void daGrass_c::deleteRoomFlower(int param_0) {
|
|
if (m_flower != NULL) {
|
|
(m_flower->*dFlower_packet_c::getDeleteRoom())(param_0);
|
|
}
|
|
}
|
|
|
|
daMP_c* daMP_c::m_myObj;
|
|
|
|
u32 daMP_c::daMP_c_Get_MovieRestFrame() {
|
|
JUT_ASSERT(668, m_myObj != NULL);
|
|
return m_myObj->mpGetMovieRestFrame();
|
|
}
|
|
|
|
void daMP_c::daMP_c_Set_PercentMovieVolume(f32 i_volume) {
|
|
JUT_ASSERT(673, m_myObj != NULL);
|
|
m_myObj->mpSetPercentMovieVol(i_volume);
|
|
}
|
|
|
|
int daMP_c::daMP_c_THPPlayerPlay() {
|
|
if (m_myObj == NULL) {
|
|
dDemo_c::onStatus(1);
|
|
return 0;
|
|
} else {
|
|
dDemo_c::offStatus(1);
|
|
return m_myObj->mpTHPPlay();
|
|
}
|
|
}
|
|
|
|
void daMP_c::daMP_c_THPPlayerPause() {
|
|
JUT_ASSERT(697, m_myObj != NULL);
|
|
m_myObj->mpTHPPause();
|
|
}
|
|
|
|
daTagMagne_c* daTagMagne_c::mTagMagne;
|
|
|
|
int daTagMagne_c::checkMagnetCode(cBgS_PolyInfo& poly) {
|
|
#if DEBUG
|
|
if (g_regHIO.mChildReg[4].mShortReg[6]) {
|
|
return true;
|
|
}
|
|
#endif
|
|
if (mTagMagne == NULL) {
|
|
return 0;
|
|
}
|
|
|
|
int magCode = dComIfG_Bgsp().GetMagnetCode(poly);
|
|
if ((magCode == 1 && mTagMagne->checkMagneA()) || (magCode == 2 && mTagMagne->checkMagneB()) ||
|
|
(magCode == 3 && mTagMagne->checkMagneC()))
|
|
{
|
|
return 1;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
int daTagMagne_c::checkMagneA() {
|
|
if (mSwNo1 == 0xFF || fopAcM_isSwitch(this, mSwNo1)) {
|
|
return 1;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
int daTagMagne_c::checkMagneB() {
|
|
if (mSwNo2 == 0xFF || fopAcM_isSwitch(this, mSwNo2)) {
|
|
return 1;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
int daTagMagne_c::checkMagneC() {
|
|
if (mSwNo3 == 0xFF || fopAcM_isSwitch(this, mSwNo3)) {
|
|
return 1;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
u8 daTagMist_c::mPlayerNo;
|
|
|
|
bool daObjCarry_c::mSaveFlag;
|
|
|
|
u8 daTagMist_c::getPlayerNo() {
|
|
return mPlayerNo;
|
|
}
|
|
|
|
void daObjCarry_c::clrSaveFlag() {
|
|
mSaveFlag = false;
|
|
}
|
|
|
|
void daObjCarry_c::setSaveFlag() {
|
|
mSaveFlag = true;
|
|
}
|
|
|
|
bool daObjCarry_c::chkSaveFlag() {
|
|
return mSaveFlag == true;
|
|
}
|
|
|
|
cXyz daObjCarry_c::mPos[5];
|
|
|
|
const cXyz& daObjCarry_c::getPos(int param_0) {
|
|
#if DEBUG
|
|
if (param_0 < 0 || param_0 > 4) {
|
|
param_0 = 0;
|
|
}
|
|
#endif
|
|
return mPos[param_0];
|
|
}
|
|
|
|
void daObjCarry_c::savePos(int param_0, cXyz param_1) {
|
|
#if DEBUG
|
|
if (param_0 < 0 || param_0 > 4) {
|
|
param_0 = 0;
|
|
}
|
|
#endif
|
|
mPos[param_0] = param_1;
|
|
}
|
|
|
|
u8 daObjCarry_c::mSttsFlag[5];
|
|
|
|
void daObjCarry_c::onSttsFlag(int idx, u8 flag) {
|
|
#if DEBUG
|
|
if (idx < 0 || idx > 4) {
|
|
idx = 0;
|
|
}
|
|
#endif
|
|
cLib_onBit(mSttsFlag[idx], flag);
|
|
}
|
|
|
|
void daObjCarry_c::offSttsFlag(int idx, u8 flag) {
|
|
#if DEBUG
|
|
if (idx < 0 || idx > 4) {
|
|
idx = 0;
|
|
}
|
|
#endif
|
|
cLib_offBit(mSttsFlag[idx], flag);
|
|
}
|
|
|
|
u8 daObjCarry_c::chkSttsFlag(int idx, u8 flag) {
|
|
#if DEBUG
|
|
if (idx < 0 || idx > 4) {
|
|
idx = 0;
|
|
}
|
|
#endif
|
|
return cLib_checkBit(mSttsFlag[idx], flag) > 0;
|
|
}
|
|
|
|
s8 daObjCarry_c::mRoomNo[5];
|
|
|
|
void daObjCarry_c::setRoomNo(int idx, s8 roomNo) {
|
|
#if DEBUG
|
|
if (idx < 0 || idx > 4) {
|
|
idx = 0;
|
|
}
|
|
#endif
|
|
mRoomNo[idx] = roomNo;
|
|
}
|
|
|
|
s8 daObjCarry_c::getRoomNo(int idx) {
|
|
#if DEBUG
|
|
if (idx < 0 || idx > 4) {
|
|
idx = 0;
|
|
}
|
|
#endif
|
|
return mRoomNo[idx];
|
|
}
|