mirror of
https://github.com/zeldaret/tww.git
synced 2026-06-10 12:55:02 -04:00
274 lines
8.2 KiB
C++
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);
|
|
}
|