d_a_npc_bans almost matching (#2762)

* initial work

* almost matching

* enum work

* tiny work

* nonmatching fixes - thanks Yunata!

* PR cleanup
This commit is contained in:
Carco_21 2025-11-01 00:11:28 -04:00 committed by GitHub
parent c9838e29fa
commit 68514b59f7
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
6 changed files with 1981 additions and 1692 deletions

View File

@ -1842,7 +1842,7 @@ config.libs = [
ActorRel(MatchingFor("GZ2E01", "GZ2P01", "GZ2J01"), "d_a_npc_aru"),
ActorRel(NonMatching, "d_a_npc_ash", extra_cflags=[DANPCF_C_HACK]), # weak func order
ActorRel(NonMatching, "d_a_npc_ashB", extra_cflags=[DANPCF_C_HACK]),
ActorRel(NonMatching, "d_a_npc_bans"),
ActorRel(MatchingFor("GZ2E01", "GZ2P01", "GZ2J01"), "d_a_npc_bans"),
ActorRel(NonMatching, "d_a_npc_blue_ns", extra_cflags=[DANPCF_C_HACK]),
ActorRel(MatchingFor("GZ2E01", "GZ2P01", "GZ2J01"), "d_a_npc_bou"),
ActorRel(NonMatching, "d_a_npc_bouS"),

View File

@ -2,6 +2,7 @@
#define D_A_NPC_BANS_H
#include "d/actor/d_a_npc.h"
#include "d/d_shop_system.h"
/**
* @ingroup actors-npcs
@ -10,72 +11,137 @@
*
* @details
*
*/
class daNpc_Bans_c : public fopAc_ac_c {
*/
struct daNpc_Bans_HIOParam {
/* 0x00 */ daNpcT_HIOParam common;
/* 0x8C */ f32 run_spd;
};
class daNpc_Bans_Param_c {
public:
/* 80967C24 */ virtual ~daNpc_Bans_Param_c() {}
static daNpc_Bans_HIOParam const m;
};
#if DEBUG
class daNpc_Bans_HIO_c : public mDoHIO_entry_c {
public:
daNpc_Bans_HIO_c();
void listenPropertyEvent(const JORPropertyEvent*);
void genMessage(JORMContext*);
/* 0x8 */ daNpc_Bans_HIOParam m;
};
#define NPC_BANS_HIO_CLASS daNpc_Bans_HIO_c
#else
#define NPC_BANS_HIO_CLASS daNpc_Bans_Param_c
#endif
class daNpc_Bans_c : public dShopSystem_c {
public:
typedef int (daNpc_Bans_c::*actionFunc)(void*);
typedef int (daNpc_Bans_c::*cutFunc)(int);
/* 809628CC */ ~daNpc_Bans_c();
/* 80962AA0 */ void create();
/* 80962D6C */ void CreateHeap();
/* 80963338 */ void Delete();
/* 8096336C */ void Execute();
/* 80963444 */ void Draw();
/* 809634E0 */ void createHeapCallBack(fopAc_ac_c*);
/* 80963500 */ void ctrlJointCallBack(J3DJoint*, int);
/* 80963558 */ void getType();
/* 809635BC */ void isDelete();
/* 80962AA0 */ cPhs__Step create();
/* 80962D6C */ int CreateHeap();
/* 80963338 */ int Delete();
/* 8096336C */ int Execute();
/* 80963444 */ int Draw();
/* 809634E0 */ static int createHeapCallBack(fopAc_ac_c*);
/* 80963500 */ static int ctrlJointCallBack(J3DJoint*, int);
/* 80963558 */ u8 getType();
/* 809635BC */ BOOL isDelete();
/* 809636C0 */ void reset();
/* 80963840 */ void afterJntAnm(int);
/* 809638CC */ void setParam();
/* 80963A7C */ void checkChangeEvt();
/* 80963A7C */ BOOL checkChangeEvt();
/* 80963B30 */ void setAfterTalkMotion();
/* 80963BA8 */ void srchActors();
/* 80963DB0 */ void evtTalk();
/* 80963EDC */ void evtCutProc();
/* 80963DB0 */ BOOL evtTalk();
/* 80963EDC */ BOOL evtCutProc();
/* 80963FA4 */ void action();
/* 80964148 */ void beforeMove();
/* 80964228 */ void setAttnPos();
/* 809646E0 */ void setCollision();
/* 80964994 */ bool drawDbgInfo();
/* 80964994 */ int drawDbgInfo();
/* 8096499C */ void drawOtherMdl();
/* 80964AD8 */ void setScoopAnm(int, int, f32);
/* 80964B9C */ void afterSetMotionAnm(int, int, f32, int);
/* 80964BD0 */ void selectAction();
/* 80964C4C */ void chkAction(int (daNpc_Bans_c::*)(void*));
/* 80964C78 */ void setAction(int (daNpc_Bans_c::*)(void*));
/* 80964D20 */ void checkPlayerIn2ndFloorOfBombShop();
/* 80964AD8 */ bool setScoopAnm(int, int, f32);
/* 80964B9C */ bool afterSetMotionAnm(int, int, f32, int);
/* 80964BD0 */ BOOL selectAction();
/* 80964C4C */ BOOL chkAction(actionFunc);
/* 80964C78 */ BOOL setAction(actionFunc);
/* 80964D20 */ BOOL checkPlayerIn2ndFloorOfBombShop();
/* 80964DD0 */ void orderAngerEvt();
/* 80964EB0 */ void getKMsgTagP();
/* 80964EB0 */ fopAc_ac_c* getKMsgTagP();
/* 80964F48 */ void setPrtcls();
/* 80964FEC */ void cutAnger(int);
/* 809658F8 */ void cutPurchase(int);
/* 80965CCC */ void wait(void*);
/* 809661F0 */ void tend(void*);
/* 80966888 */ void talk(void*);
/* 80966B24 */ void shop(void*);
/* 80967AC4 */ daNpc_Bans_c(daNpcT_faceMotionAnmData_c const*, daNpcT_motionAnmData_c const*,
daNpcT_MotionSeqMngr_c::sequenceStepData_c const*, int,
daNpcT_MotionSeqMngr_c::sequenceStepData_c const*, int,
daNpcT_evtData_c const*, char**);
/* 80967BE4 */ u16 getEyeballMaterialNo();
/* 80967BEC */ s32 getHeadJointNo();
/* 80967BF4 */ s32 getNeckJointNo();
/* 80967BFC */ bool getBackboneJointNo();
/* 80967C04 */ void checkChangeJoint(int);
/* 80967C14 */ void checkRemoveJoint(int);
/* 80964FEC */ int cutAnger(int);
/* 809658F8 */ int cutPurchase(int);
/* 80965CCC */ int wait(void*);
/* 809661F0 */ int tend(void*);
/* 80966888 */ int talk(void*);
/* 80966B24 */ int shop(void*);
/* 80DA60D0 */ int test(void*);
/* 80967AC4 */ daNpc_Bans_c(
daNpcT_faceMotionAnmData_c const* i_faceMotionAnmData,
daNpcT_motionAnmData_c const* i_motionAnmData,
daNpcT_MotionSeqMngr_c::sequenceStepData_c const* i_faceMotionSequenceData,
int i_faceMotionStepNum,
daNpcT_MotionSeqMngr_c::sequenceStepData_c const* i_motionSequenceData, int i_motionStepNum,
daNpcT_evtData_c const* i_evtData, char** i_arcNames)
: dShopSystem_c(i_faceMotionAnmData, i_motionAnmData, i_faceMotionSequenceData,
i_faceMotionStepNum, i_motionSequenceData, i_motionStepNum, i_evtData,
i_arcNames) {
OS_REPORT("|%06d:%x|daNpc_Bans_c -> コンストラクト\n", g_Counter.mCounter0, this);
}
/* 80967BE4 */ u16 getEyeballMaterialNo() { return 2; }
/* 80967BEC */ s32 getHeadJointNo() { return 6; }
/* 80967BF4 */ s32 getNeckJointNo() { return 5; }
/* 80967BFC */ s32 getBackboneJointNo() { return 1; }
/* 80967C04 */ BOOL checkChangeJoint(int i_joint) { return i_joint == 6; }
/* 80967C14 */ BOOL checkRemoveJoint(int i_joint) { return i_joint == 0xB; }
u8 getGroupId() { return (fopAcM_GetParam(this) & ~0xFFFFFFF) >> 28; }
u8 getMaxNumItem() { return (fopAcM_GetParam(this) & 0xF000000) >> 24; }
u8 getPathID() { return (fopAcM_GetParam(this) & 0xFF00) >> 8; }
u32 getFlowNodeNo() {
u16 nodeNo = home.angle.x;
u32 rv;
if (nodeNo == 0xffff) {
rv = -1;
} else {
rv = nodeNo;
}
return rv;
}
static char* mCutNameList[4];
static u8 mCutList[48];
private:
/* 0x568 */ u8 field_0x568[0x1270 - 0x568];
static cutFunc mCutList[4];
/* 0x0F7C */ mDoExt_McaMorfSO* mpScoopMorf;
/* 0x0F80 */ NPC_BANS_HIO_CLASS* mHIO;
/* 0x0F84 */ J3DModel* mTubModel[1];
/* 0x0F88 */ dCcD_Cyl mCyl1;
/* 0x10C4 */ dCcD_Cyl mCyl2;
/* 0x1200 */ u8 mType;
/* 0x1204 */ daNpcT_ActorMngr_c mActorMngrs[8];
/* 0x1244 */ actionFunc mNextAction;
/* 0x1250 */ actionFunc mAction;
/* 0x125C */ int mShopProcess;
/* 0x1260 */ int mTimer;
/* 0x1264 */ u8 mSetParamFlag;
/* 0x1265 */ u8 mShopFlag;
/* 0x1266 */ u8 field_0x1266;
/* 0x1267 */ u8 mDemo13Flag;
/* 0x1268 */ u8 mDropWaterTimer;
/* 0x1269 */ u8 field_0x1269;
/* 0x126A */ u8 field_0x126a;
/* 0x126B */ u8 field_0x126b;
/* 0x126C */ u8 field_0x126c;
};
STATIC_ASSERT(sizeof(daNpc_Bans_c) == 0x1270);
class daNpc_Bans_Param_c {
public:
/* 80967C24 */ ~daNpc_Bans_Param_c();
static u8 const m[144];
};
#endif /* D_A_NPC_BANS_H */

View File

@ -1250,7 +1250,10 @@ public:
BOOL checkInsectRelease() { return checkResetFlg1(RFLG1_UNK_100); }
void onChainForcePull() { onEndResetFlg1(ERFLG1_UNK_1000000); }
void onChainPullEnd() { onEndResetFlg1(ERFLG1_UNK_2000000); }
void onChainPullEnd() { onEndResetFlg1(ERFLG1_UNK_2000000); }
void onWaterDrop() { onEndResetFlg1(ERFLG1_UNK_20000); }
void forceKandelaarLightOff() { onNoResetFlg2(FLG2_UNK_10000000); }
};
int daPy_addCalcShort(s16* param_0, s16 param_1, s16 param_2, s16 param_3, s16 param_4);

View File

@ -4,9 +4,29 @@
#include "f_op/f_op_actor.h"
struct ShopCam_action_c {
class ShopCam_action_c {
public:
typedef int (ShopCam_action_c::*ShopCamFunc)();
ShopCam_action_c() {
setCameraSpeed(0.25f, 20.0f, 0.25f, 5.0f);
field_0xda = true;
field_0xd0 = 0;
field_0xd2 = 0;
field_0xd4 = -1;
setCamDataIdx(0);
field_0x7c.set(0.0f, 0.0f, 0.0f);
field_0x88.set(0.0f, 0.0f, 100.0f);
field_0x94 = 60.0f;
field_0xb0.set(0.0f, 0.0f, 0.0f);
field_0xd8 = 0;
field_0x18 = NULL;
field_0x1c = field_0x20 = field_0x24 = NULL;
field_0x28 = field_0x2c = field_0x30 = NULL;
field_0x34 = NULL;
setCamAction(NULL);
}
/* 80195C9C */ int shop_cam_action_init();
/* 80195E18 */ int shop_cam_action();
/* 8019630C */ void Save();

View File

@ -32,38 +32,8 @@ public:
daNpcT_MotionSeqMngr_c::sequenceStepData_c const* param_3, int param_4,
daNpcT_MotionSeqMngr_c::sequenceStepData_c const* param_5, int param_6, daNpcT_evtData_c const* param_7,
char** param_8) : daNpcT_c(param_1,param_2,param_3,param_4,param_5,param_6,param_7,param_8) {
mShopCamAction.field_0xc0 = 0.25f;
mShopCamAction.field_0xc4 = 20.0f;
mShopCamAction.field_0xc8 = 0.25f;
mShopCamAction.field_0xcc = 5.0f;
mShopCamAction.field_0xda = true;
mShopCamAction.field_0xd0 = 0;
mShopCamAction.field_0xd2 = 0;
mShopCamAction.field_0xd4 = -1;
mShopCamAction.mCamDataIdx = 0;
mShopCamAction.field_0x7c.x = 0.0f;
mShopCamAction.field_0x7c.y = 0.0f;
mShopCamAction.field_0x7c.z = 0.0f;
mShopCamAction.field_0x88.x = 0.0f;
mShopCamAction.field_0x88.y = 0.0f;
mShopCamAction.field_0x88.z = 100.0f;
mShopCamAction.field_0x94 = 60.0f;
mShopCamAction.field_0xb0.x = 0.0f;
mShopCamAction.field_0xb0.y = 0.0f;
mShopCamAction.field_0xb0.z = 0.0f;
mShopCamAction.field_0xd8 = 0;
mShopCamAction.field_0x18 = NULL;
mShopCamAction.field_0x24 = NULL;
mShopCamAction.field_0x20 = NULL;
mShopCamAction.field_0x1c = NULL;
mShopCamAction.field_0x30 = NULL;
mShopCamAction.field_0x2c = NULL;
mShopCamAction.field_0x28 = NULL;
mShopCamAction.field_0x34 = NULL;
mShopCamAction.mCamAction = NULL;
OS_REPORT("|%06d:%x|dShopSystem_c -> コンストラクト\n", g_Counter.mCounter0, this);
initShopSystem();
}
/* 80197338 */ void initShopSystem();

File diff suppressed because it is too large Load Diff