// // Generated By: dol2asm // Translation Unit: d/d_jnt_col // #include "d/d_jnt_col.h" #include "dol2asm.h" #include "f_op/f_op_actor_mng.h" #include "m_Do/m_Do_mtx.h" // // Types: // struct cM3dGSph { /* 80036AA4 */ ~cM3dGSph(); /* 8026F664 */ void Set(cXyz const&, f32); }; struct cM3dGCyl { /* 8026F180 */ void Set(cXyz const&, f32, f32); }; // // Forward References: // extern "C" void __ct__9dJntCol_cFv(); extern "C" void init__9dJntCol_cFP10fopAc_ac_cPC13dJntColData_cP8J3DModeli(); extern "C" void setNowLine__9dJntCol_cFP8cM3dGLinPC4cXyzPC5csXyzP4cXyz(); extern "C" void searchNearPos__9dJntCol_cCFPC8cM3dGLinPC4cXyzP4cXyzi(); extern "C" void __dt__8cM3dGLinFv(); extern "C" void __dt__8cM3dGSphFv(); extern "C" void getArrowOffsetPosAndAngle__9dJntCol_cCFPC4cXyzPC5csXyzP4cXyzP4cXyz(); extern "C" void getHitmarkPosAndAngle__9dJntCol_cCFPC4cXyzPC5csXyzP4cXyzP5csXyzi(); extern "C" void setArrowPosAndAngle__9dJntCol_cFPC4cXyzPC4cXyziP4cXyzP5csXyz(); // // External References: // extern "C" void mDoMtx_XrotM__FPA4_fs(); extern "C" void mDoMtx_YrotM__FPA4_fs(); extern "C" void transS__14mDoMtx_stack_cFRC4cXyz(); extern "C" void transM__14mDoMtx_stack_cFfff(); extern "C" void ZXYrotS__14mDoMtx_stack_cFRC5csXyz(); extern "C" void __pl__4cXyzCFRC3Vec(); extern "C" void __mi__4cXyzCFRC3Vec(); extern "C" void __ml__4cXyzCFf(); extern "C" void __dv__4cXyzCFf(); extern "C" void normalizeZP__4cXyzFv(); extern "C" void atan2sX_Z__4cXyzCFv(); extern "C" void atan2sY_XZ__4cXyzCFv(); extern "C" void cM_atan2s__Fff(); extern "C" void cM3d_SignedLenPlaAndPos__FPC8cM3dGPlaPC3Vec(); extern "C" void cM3d_Cross_LinPla__FPC8cM3dGLinPC8cM3dGPlaP3Vecbb(); extern "C" void cM3d_Cross_LinSph_CrossPos__FRC8cM3dGSphRC8cM3dGLinP3VecP3Vec(); extern "C" void cM3d_Cross_CylLin__FPC8cM3dGCylPC8cM3dGLinP3VecP3Vec(); extern "C" void cM3d_lineVsPosSuisenCross__FPC8cM3dGLinPC3VecP3Vec(); extern "C" void cM3d_lineVsPosSuisenCross__FRC3VecRC3VecRC3VecP3Vec(); extern "C" void Set__8cM3dGCylFRC4cXyzff(); extern "C" void SetStartEnd__8cM3dGLinFRC4cXyzRC4cXyz(); extern "C" void crossInfLin__8cM3dGPlaCFRC4cXyzRC4cXyzR4cXyz(); extern "C" void SetupNP0__8cM3dGPlaFRC3VecRC3Vec(); extern "C" void Set__8cM3dGSphFRC4cXyzf(); extern "C" void __dl__FPv(); extern "C" void _savegpr_19(); extern "C" void _savegpr_27(); extern "C" void _savegpr_28(); extern "C" void _savegpr_29(); extern "C" void _restgpr_19(); extern "C" void _restgpr_27(); extern "C" void _restgpr_28(); extern "C" void _restgpr_29(); extern "C" extern void* __vt__8cM3dGPla[3]; extern "C" extern void* __vt__8cM3dGCyl[3]; extern "C" u8 now__14mDoMtx_stack_c[48]; extern "C" u8 BaseZ__4cXyz[12]; // // Declarations: // /* 80035C8C-80035CA0 0305CC 0014+00 0/0 1/1 8/8 .text __ct__9dJntCol_cFv */ dJntCol_c::dJntCol_c() { mModel = 0; mData = 0; field_0x8 = 0; } /* 80035CA0-80035CC8 0305E0 0028+00 0/0 2/2 8/8 .text * init__9dJntCol_cFP10fopAc_ac_cPC13dJntColData_cP8J3DModeli */ int dJntCol_c::init(fopAc_ac_c* i_actorP, dJntColData_c const* i_jntColP, J3DModel* i_modelP, int param_3) { mData = i_jntColP; mModel = i_modelP; field_0x8 = param_3; field_0xc = 0; if (i_actorP) { fopAcM_SetJntCol(i_actorP, this); } return 1; } /* 80035CC8-80035DC8 030608 0100+00 2/2 0/0 0/0 .text * setNowLine__9dJntCol_cFP8cM3dGLinPC4cXyzPC5csXyzP4cXyz */ void dJntCol_c::setNowLine(cM3dGLin* i_line, cXyz const* param_1, csXyz const* param_2, cXyz* param_3) { if (param_2 != NULL) { mDoMtx_stack_c::ZXYrotS(*param_2); mDoMtx_stack_c::multVec(&cXyz::BaseZ, param_3); } else { *param_3 = cXyz::BaseZ; } cXyz start_pos = *param_1 - *param_3 * 500.0f; cXyz end_pos = *param_1 + *param_3 * 500.0f; i_line->SetStartEnd(start_pos, end_pos); } /* ############################################################################################## */ /* 803A78F8-803A7904 004A18 000C+00 4/4 21/21 0/0 .data __vt__8cM3dGLin */ SECTION_DATA extern void* __vt__8cM3dGLin[3] = { (void*)NULL /* RTTI */, (void*)NULL, (void*)__dt__8cM3dGLinFv, }; /* 803A7904-803A7910 004A24 000C+00 2/2 10/10 0/0 .data __vt__8cM3dGSph */ SECTION_DATA extern void* __vt__8cM3dGSph[3] = { (void*)NULL /* RTTI */, (void*)NULL, (void*)__dt__8cM3dGSphFv, }; /* 80451D64-80451D68 000364 0004+00 1/1 0/0 0/0 .sdata2 @4141 */ SECTION_SDATA2 static f32 lit_4141 = -10000000.0f; /* 80451D68-80451D70 000368 0004+04 2/2 0/0 0/0 .sdata2 @4142 */ SECTION_SDATA2 static f32 lit_4142[1 + 1 /* padding */] = { 0.0f, /* padding */ 0.0f, }; /* 80451D70-80451D78 000370 0008+00 2/2 0/0 0/0 .sdata2 @4143 */ SECTION_SDATA2 static f64 lit_4143 = 0.5; /* 80451D78-80451D80 000378 0008+00 2/2 0/0 0/0 .sdata2 @4144 */ SECTION_SDATA2 static f64 lit_4144 = 3.0; /* 80451D80-80451D88 000380 0008+00 2/2 0/0 0/0 .sdata2 @4145 */ SECTION_SDATA2 static u8 lit_4145[8] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, }; /* 80451D88-80451D8C 000388 0004+00 1/1 0/0 0/0 .sdata2 @4146 */ SECTION_SDATA2 static f32 lit_4146 = 1.0f / 100.0f; /* 80451D8C-80451D90 00038C 0004+00 2/2 0/0 0/0 .sdata2 @4147 */ SECTION_SDATA2 static f32 lit_4147 = 9.999999747378752e-05f; /* 80451D90-80451D94 000390 0004+00 1/1 0/0 0/0 .sdata2 @4148 */ SECTION_SDATA2 static f32 lit_4148 = 0.5f; /* 80451D94-80451D98 000394 0004+00 1/1 0/0 0/0 .sdata2 @4149 */ SECTION_SDATA2 static f32 lit_4149 = 1.0f; /* 80035DC8-80036A5C 030708 0C94+00 2/2 0/0 0/0 .text * searchNearPos__9dJntCol_cCFPC8cM3dGLinPC4cXyzP4cXyzi */ #pragma push #pragma optimization_level 0 #pragma optimizewithasm off asm void dJntCol_c::searchNearPos(cM3dGLin const* param_0, cXyz const* param_1, cXyz* param_2, int param_3) const { nofralloc #include "asm/d/d_jnt_col/searchNearPos__9dJntCol_cCFPC8cM3dGLinPC4cXyzP4cXyzi.s" } #pragma pop /* 80036A5C-80036AA4 03139C 0048+00 1/0 3/3 0/0 .text __dt__8cM3dGLinFv */ #pragma push #pragma optimization_level 0 #pragma optimizewithasm off extern "C" asm void __dt__8cM3dGLinFv() { nofralloc #include "asm/d/d_jnt_col/__dt__8cM3dGLinFv.s" } #pragma pop /* 80036AA4-80036AEC 0313E4 0048+00 1/0 0/0 0/0 .text __dt__8cM3dGSphFv */ #pragma push #pragma optimization_level 0 #pragma optimizewithasm off asm cM3dGSph::~cM3dGSph() { nofralloc #include "asm/d/d_jnt_col/__dt__8cM3dGSphFv.s" } #pragma pop /* 80036AEC-80036C44 03142C 0158+00 0/0 0/0 1/1 .text * getArrowOffsetPosAndAngle__9dJntCol_cCFPC4cXyzPC5csXyzP4cXyzP4cXyz */ #pragma push #pragma optimization_level 0 #pragma optimizewithasm off asm void dJntCol_c::getArrowOffsetPosAndAngle(cXyz const* param_0, csXyz const* param_1, cXyz* param_2, cXyz* param_3) const { nofralloc #include "asm/d/d_jnt_col/getArrowOffsetPosAndAngle__9dJntCol_cCFPC4cXyzPC5csXyzP4cXyzP4cXyz.s" } #pragma pop /* 80036C44-80036FA8 031584 0364+00 0/0 3/3 0/0 .text * getHitmarkPosAndAngle__9dJntCol_cCFPC4cXyzPC5csXyzP4cXyzP5csXyzi */ #pragma push #pragma optimization_level 0 #pragma optimizewithasm off asm int dJntCol_c::getHitmarkPosAndAngle(cXyz const* param_0, csXyz const* param_1, cXyz* param_2, csXyz* param_3, int param_4) const { nofralloc #include "asm/d/d_jnt_col/getHitmarkPosAndAngle__9dJntCol_cCFPC4cXyzPC5csXyzP4cXyzP5csXyzi.s" } #pragma pop /* 80036FA8-80037038 0318E8 0090+00 0/0 0/0 1/1 .text * setArrowPosAndAngle__9dJntCol_cFPC4cXyzPC4cXyziP4cXyzP5csXyz */ void dJntCol_c::setArrowPosAndAngle(cXyz const* param_0, cXyz const* i_srcPos, int i_anmMtxIdx, cXyz* param_3, csXyz* i_arrowPosP) { cXyz dst_pos; mDoMtx_multVecSR(mModel->i_getAnmMtx(i_anmMtxIdx), i_srcPos, &dst_pos); i_arrowPosP->x = dst_pos.atan2sY_XZ(); i_arrowPosP->y = dst_pos.atan2sX_Z(); mDoMtx_multVec(mModel->i_getAnmMtx(i_anmMtxIdx), param_0, param_3); }