Files
tww/src/SSystem/SComponent/c_bg_s.cpp
T
2025-03-06 20:41:37 -05:00

274 lines
8.2 KiB
C++

//
// Generated by dtk
// Translation Unit: c_bg_s.cpp
//
#include "SSystem/SComponent/c_bg_s.h"
#include "SSystem/SComponent/c_bg_s_gnd_chk.h"
#include "SSystem/SComponent/c_bg_s_lin_chk.h"
#include "SSystem/SComponent/c_bg_w.h"
#include "JSystem/JUtility/JUTAssert.h"
#include "dolphin/types.h"
s32 l_SetCounter = 0;
/* 80246440-8024645C .text Init__11cBgS_ChkElmFv */
void cBgS_ChkElm::Init() {
m_bgw_base_ptr = NULL;
m_flags = 0;
m_actor_ptr = NULL;
m_actor_id = fpcM_ERROR_PROCESS_ID_e;
}
/* 8024645C-80246478 .text Regist2__11cBgS_ChkElmFP4cBgWUiPv */
void cBgS_ChkElm::Regist2(cBgW* bgw, fpc_ProcID pid, void* actor) {
m_flags |= 1;
m_bgw_base_ptr = bgw;
m_actor_id = pid;
m_actor_ptr = (fopAc_ac_c*)actor;
}
/* 80246478-8024649C .text Release__11cBgS_ChkElmFv */
void cBgS_ChkElm::Release() {
m_flags &= ~1;
m_bgw_base_ptr = NULL;
m_actor_id = fpcM_ERROR_PROCESS_ID_e;
m_actor_ptr = NULL;
}
/* 8024649C-80246600 .text Regist__4cBgSFP4cBgWUiPv */
bool cBgS::Regist(cBgW* bgw, fpc_ProcID pid, void* actor) {
if (bgw == NULL)
return true;
if (bgw->ChkUsed())
return true;
if (bgw->ChkMemoryError())
return true;
s32 i = l_SetCounter;
JUT_ASSERT(0x97, 0 <= i && i < 256);
while (true) {
if (!m_chk_element[i].ChkUsed()) {
m_chk_element[i].Regist2(bgw, pid, actor);
bgw->SetId(i);
l_SetCounter = i + 1;
if (l_SetCounter >= 256)
l_SetCounter = 0;
return false;
}
i++;
if (i >= 256)
i = 0;
if (l_SetCounter == i)
break;
}
bgw->SetId(256);
return true;
}
static void dummy() {
OSReport("c_bg_s_poly_info.h");
}
/* 80246600-8024669C .text Release__4cBgSFP4cBgW */
bool cBgS::Release(cBgW* bgw) {
if (bgw == NULL)
return true;
if (bgw->ChkUsed() && bgw->GetId() >= 0 && bgw->GetId() < 0x100 && m_chk_element[bgw->GetId()].ChkUsed()) {
m_chk_element[bgw->GetId()].Release();
bgw->SetId(256);
} else {
return true;
}
return false;
}
/* 8024669C-802466F0 .text Ct__4cBgSFv */
void cBgS::Ct() {
l_SetCounter = 0;
for (s32 i = 0; i < (s32)ARRAY_SIZE(m_chk_element); i++)
m_chk_element[i].Init();
}
/* 802466F0-8024676C .text Dt__4cBgSFv */
void cBgS::Dt() {
for (s32 i = 0; i < (s32)ARRAY_SIZE(m_chk_element); i++)
if (m_chk_element[i].ChkUsed())
m_chk_element[i].Release();
for (s32 i = 0; i < (s32)ARRAY_SIZE(m_chk_element); i++)
m_chk_element[i].Init();
}
/* 8024676C-802468E4 .text LineCross__4cBgSFP11cBgS_LinChk */
bool cBgS::LineCross(cBgS_LinChk* chk) {
bool ret = false;
chk->ClearPi();
chk->ClrHit();
for (s32 bg_index = 0; bg_index < (s32)ARRAY_SIZE(m_chk_element); bg_index++) {
cBgS_ChkElm* elm = &m_chk_element[bg_index];
if (elm->ChkUsed() && elm->m_bgw_base_ptr->GetVtxTbl() != NULL && !chk->ChkSameActorPid(elm->m_actor_id)) {
chk->PreCalc();
if (elm->m_bgw_base_ptr->LineCheck(chk)) {
chk->SetActorInfo(bg_index, elm->m_bgw_base_ptr, elm->m_actor_id);
ret = true;
}
}
}
if (ret)
chk->SetHit();
return ret;
}
/* 802468E4-80246A14 .text GroundCross__4cBgSFP11cBgS_GndChk */
f32 cBgS::GroundCross(cBgS_GndChk* chk) {
chk->SetNowY(C_BG_MIN_HEIGHT);
chk->ClearPi();
chk->mWallPrecheck = (chk->mFlag & 0x02);
chk->mGndPrecheck = (chk->mFlag & 0x01);
cBgS_ChkElm* elm = m_chk_element;
for (s32 bg_index = 0; bg_index < (s32)ARRAY_SIZE(m_chk_element); bg_index++, elm++) {
if (elm->ChkUsed() && elm->m_bgw_base_ptr->GetVtxTbl() != NULL && !chk->ChkSameActorPid(elm->m_actor_id)) {
if (elm->m_bgw_base_ptr->GroundCross(chk)) {
chk->SetActorInfo(bg_index, elm->m_bgw_base_ptr, elm->m_actor_id);
}
}
}
return chk->GetNowY();
}
/* 80246A14-80246C98 .text ConvDzb__4cBgSFPv */
void* cBgS::ConvDzb(void* work) {
cBgD_t * pbgd = (cBgD_t *)work;
if (((pbgd->flag & 0x80000000) == 0)) {
pbgd->flag |= 0x80000000;
} else {
return pbgd;
}
JUT_ASSERT(0x214, ((int)pbgd->m_v_tbl % 4) == 0);
JUT_ASSERT(0x215, ((int)pbgd->m_t_tbl % 2) == 0);
JUT_ASSERT(0x216, ((int)pbgd->m_b_tbl % 2) == 0);
JUT_ASSERT(0x217, ((int)pbgd->m_tree_tbl % 2) == 0);
JUT_ASSERT(0x218, ((int)pbgd->m_g_tbl % 4) == 0);
JUT_ASSERT(0x219, ((int)pbgd->m_ti_tbl % 4) == 0);
if (pbgd->m_v_tbl != NULL)
pbgd->m_v_tbl = (cBgD_Vtx_t*)((u32)pbgd->m_v_tbl + (u32)pbgd);
pbgd->m_t_tbl = (cBgD_Tri_t*)((u32)pbgd->m_t_tbl + (u32)pbgd);
pbgd->m_b_tbl = (cBgD_Blk_t*)((u32)pbgd->m_b_tbl + (u32)pbgd);
pbgd->m_tree_tbl = (cBgD_Tree_t*)((u32)pbgd->m_tree_tbl + (u32)pbgd);
pbgd->m_g_tbl = (cBgD_Grp_t*)((u32)pbgd->m_g_tbl + (u32)pbgd);
pbgd->m_ti_tbl = (cBgD_Ti_t*)((u32)pbgd->m_ti_tbl + (u32)pbgd);
for (s32 i = 0; i < pbgd->m_g_num; i++) {
pbgd->m_g_tbl[i].m_name = (char*)((u32)pbgd + (u32)pbgd->m_g_tbl[i].m_name);
}
return pbgd;
}
/* 80246C98-80246D24 .text GetActorPointer__4cBgSCFi */
fopAc_ac_c* cBgS::GetActorPointer(int actor_index) const {
JUT_ASSERT(0x237, 0 <= actor_index && actor_index < 256);
return m_chk_element[actor_index].m_actor_ptr;
}
/* 80246D24-80246D5C .text GetBgWPointer__4cBgSCFR13cBgS_PolyInfo */
cBgW* cBgS::GetBgWPointer(cBgS_PolyInfo& poly) const {
s32 id = poly.GetBgIndex();
if (!(0 <= id && id < 256) || !m_chk_element[id].ChkUsed())
return NULL;
return m_chk_element[id].m_bgw_base_ptr;
}
/* 80246D5C-80246DF8 .text ChkPolySafe__4cBgSFR13cBgS_PolyInfo */
bool cBgS::ChkPolySafe(cBgS_PolyInfo& poly) {
if (!poly.ChkSetInfo())
return false;
int id = poly.GetBgIndex();
if (!(0 <= id && id < 256))
return false;
if (!m_chk_element[id].ChkUsed())
return false;
return poly.ChkSafe(m_chk_element[id].m_bgw_base_ptr, m_chk_element[id].m_actor_id);
}
/* 80246DF8-80246F10 .text GetTriGrp__4cBgSCFii */
s32 cBgS::GetTriGrp(int bg_index, int poly_index) const {
JUT_ASSERT(0x278, 0 <= bg_index && bg_index < 256);
if (!m_chk_element[bg_index].ChkUsed())
return -1;
return m_chk_element[bg_index].m_bgw_base_ptr->GetTriGrp(poly_index);
}
/* 80246F10-80246FE4 .text GetGrpToRoomId__4cBgSCFii */
s32 cBgS::GetGrpToRoomId(int bg_index, int grp_id) const {
JUT_ASSERT(0x289, 0 <= bg_index && bg_index < 256);
if (!m_chk_element[bg_index].ChkUsed())
return 0xFFFF;
if (grp_id == 0xFFFF)
return 0xFFFF;
return m_chk_element[bg_index].m_bgw_base_ptr->GetGrpToRoomIndex(grp_id);
}
/* 80246FE4-802470B8 .text GetTriPla__4cBgSCFii */
cM3dGPla* cBgS::GetTriPla(int bg_index, int poly_index) const {
if (!(0 <= bg_index && bg_index < 256))
return NULL;
if (!m_chk_element[bg_index].ChkUsed())
return NULL;
return m_chk_element[bg_index].m_bgw_base_ptr->GetTriPla(poly_index);
}
static void dummy2() {
// from c_bg_s_poly_info.h
OSReport("0 <= grp_index && grp_index < pm_bgd->m_g_num");
}
/* 802470B8-80247178 .text GetTriPnt__4cBgSCFR13cBgS_PolyInfoP4cXyzP4cXyzP4cXyz */
void cBgS::GetTriPnt(cBgS_PolyInfo& poly, cXyz* p0, cXyz* p1, cXyz* p2) const {
s32 id = poly.GetBgIndex();
JUT_ASSERT(0x2f6, 0 <= id && id < 256);
if (m_chk_element[id].ChkUsed())
m_chk_element[id].m_bgw_base_ptr->GetTriPnt(poly.GetPolyIndex(), p0, p1, p2);
}
/* 80247178-8024717C .text Move__4cBgSFv */
void cBgS::Move() {
}
/* 8024717C-802471E8 .text ShdwDraw__4cBgSFP13cBgS_ShdwDraw */
void cBgS::ShdwDraw(cBgS_ShdwDraw* shdw) {
for (s32 i = 0; i < (s32)ARRAY_SIZE(m_chk_element); i++)
if (m_chk_element[i].ChkUsed())
m_chk_element[i].m_bgw_base_ptr->ShdwDraw(shdw);
}
/* 802471E8-80247304 .text GetGrpInf__4cBgSCFR13cBgS_PolyInfoi */
s32 cBgS::GetGrpInf(cBgS_PolyInfo& poly, int grp_id) const {
s32 bg_index = poly.GetBgIndex();
JUT_ASSERT(0x37d, 0 <= bg_index && bg_index < 256);
if (!m_chk_element[bg_index].ChkUsed())
return -1;
return m_chk_element[bg_index].m_bgw_base_ptr->GetGrpInf(grp_id);
}