Skip to content

Commit 0e8d06c

Browse files
d_a_npc_doorboy equivalent (#2581)
* initial work * doorboy equivalent * Update d_a_npc_doorboy.h --------- Co-authored-by: hatal175 <hatal175@users.noreply.github.com>
1 parent 41c72dc commit 0e8d06c

File tree

3 files changed

+867
-993
lines changed

3 files changed

+867
-993
lines changed

configure.py

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1776,7 +1776,7 @@ def MatchingFor(*versions) -> bool:
17761776
ActorRel(NonMatching, "d_a_npc_coach"),
17771777
ActorRel(NonMatching, "d_a_npc_df"),
17781778
ActorRel(NonMatching, "d_a_npc_doc"),
1779-
ActorRel(NonMatching, "d_a_npc_doorboy"),
1779+
ActorRel(Equivalent, "d_a_npc_doorboy", extra_cflags=[DANPCF_C_HACK]),
17801780
ActorRel(NonMatching, "d_a_npc_drainSol"),
17811781
ActorRel(NonMatching, "d_a_npc_du"),
17821782
ActorRel(NonMatching, "d_a_npc_fairy"),

include/d/actor/d_a_npc_doorboy.h

Lines changed: 57 additions & 24 deletions
Original file line numberDiff line numberDiff line change
@@ -2,6 +2,7 @@
22
#define D_A_NPC_DOORBOY_H
33

44
#include "d/actor/d_a_npc.h"
5+
#include "d/d_msg_object.h"
56

67
/**
78
* @ingroup actors-npcs
@@ -10,48 +11,80 @@
1011
*
1112
* @details
1213
*
13-
*/
14-
class daNpcDoorBoy_c : public fopAc_ac_c {
14+
*/
15+
16+
struct daNpcDoorBoy_HIOParam {
17+
/* 0x0 */ daNpcF_HIOParam common;
18+
};
19+
20+
class daNpcDoorBoy_c : public daNpcF_c {
1521
public:
22+
typedef bool (daNpcDoorBoy_c::*actionFunc)(void*);
23+
typedef BOOL (daNpcDoorBoy_c::*EventFn)(int);
24+
1625
/* 809AAC8C */ daNpcDoorBoy_c();
1726
/* 809AAEA0 */ ~daNpcDoorBoy_c();
18-
/* 809AB088 */ void Create();
19-
/* 809AB320 */ void CreateHeap();
20-
/* 809AB4A4 */ void Delete();
21-
/* 809AB4D8 */ void Execute();
22-
/* 809AB4FC */ void Draw();
23-
/* 809AB578 */ void ctrlJoint(J3DJoint*, J3DModel*);
24-
/* 809AB704 */ void createHeapCallBack(fopAc_ac_c*);
25-
/* 809AB724 */ void ctrlJointCallBack(J3DJoint*, int);
27+
/* 809AB088 */ cPhs__Step Create();
28+
/* 809AB320 */ int CreateHeap();
29+
/* 809AB4A4 */ int Delete();
30+
/* 809AB4D8 */ int Execute();
31+
/* 809AB4FC */ int Draw();
32+
/* 809AB578 */ int ctrlJoint(J3DJoint*, J3DModel*);
33+
/* 809AB704 */ static int createHeapCallBack(fopAc_ac_c*);
34+
/* 809AB724 */ static int ctrlJointCallBack(J3DJoint*, int);
2635
/* 809AB770 */ void setMotion(int, f32, int);
2736
/* 809AB7B8 */ void reset();
28-
/* 809AB984 */ void setAction(bool (daNpcDoorBoy_c::*)(void*));
29-
/* 809ABA2C */ void wait(void*);
30-
/* 809AC064 */ void fear(void*);
31-
/* 809AC114 */ void talk(void*);
32-
/* 809AC528 */ void demo(void*);
33-
/* 809AC6F4 */ void dummyTalk(void*);
37+
/* 809AB984 */ inline BOOL setAction(bool (daNpcDoorBoy_c::*)(void*));
38+
/* 809ABA2C */ bool wait(void*);
39+
/* 809AC064 */ bool fear(void*);
40+
/* 809AC114 */ bool talk(void*);
41+
/* 809AC528 */ bool demo(void*);
42+
/* 809AC6F4 */ bool dummyTalk(void*);
3443
/* 809AC994 */ void setParam();
35-
/* 809ACA58 */ void main();
44+
/* 809ACA58 */ BOOL main();
3645
/* 809ACC5C */ void setAttnPos();
37-
/* 809ACE18 */ void lookat();
38-
/* 809ACFF8 */ bool setMotionAnm(int, f32);
39-
/* 809AD0C8 */ bool drawDbgInfo();
46+
/* 809ACE18 */ inline void lookat();
47+
/* 809ACFF8 */ void setMotionAnm(int, f32);
48+
/* 809AD0C8 */ BOOL drawDbgInfo();
4049
/* 809AD938 */ void adjustShapeAngle();
4150

42-
static u8 mEvtSeqList[12];
51+
inline u16 getMessageNo() { return fopAcM_GetParam(this) >> 8; }
52+
inline void playMotion();
53+
inline bool chkFindPlayer();
54+
inline void setLookMode(int);
55+
inline BOOL step(s16, int);
56+
inline s16 dMsgObject_getNowTalkFlowNo() { return dMsgObject_getMsgObjectClass()->getNowTalkFlowNo(); }
57+
inline int getTimeHour();
58+
inline bool isDummyTalk();
59+
60+
static EventFn mEvtSeqList[1];
4361

4462
private:
45-
/* 0x568 */ u8 field_0x568[0xe08 - 0x568];
63+
/* 0xB48 */ Z2CreatureCitizen mSound;
64+
/* 0xBEC */ u8 field_0xbec[0xbf0 - 0xbec];
65+
/* 0xBF0 */ daNpcF_Lookat_c mLookat;
66+
/* 0xC8C */ daNpcF_ActorMngr_c mActorMngr[1];
67+
/* 0xC95 */ u8 field_0xc94[0xc98 - 0xc94];
68+
/* 0xC98 */ dCcD_Cyl field_0xc98;
69+
/* 0xDD4 */ actionFunc mAction;
70+
/* 0xDE0 */ request_of_phase_process_class mPhases[2];
71+
/* 0xDF0 */ fpc_ProcID field_0xdf0;
72+
/* 0xDF4 */ int field_0xdf4;
73+
/* 0xDF8 */ int field_0xdf8;
74+
/* 0xDFC */ int mMessageNo;
75+
/* 0xE00 */ s16 mLookMode;
76+
/* 0xE02 */ s16 field_0xe02;
77+
/* 0xE04 */ u16 mMode;
78+
/* 0xE06 */ u8 field_0xe06;
4679
};
4780

4881
STATIC_ASSERT(sizeof(daNpcDoorBoy_c) == 0xe08);
4982

5083
class daNpcDoorBoy_Param_c {
5184
public:
52-
/* 809AD93C */ ~daNpcDoorBoy_Param_c();
85+
/* 809AD93C */ virtual ~daNpcDoorBoy_Param_c() {}
5386

54-
static u8 const m[108];
87+
static daNpcDoorBoy_HIOParam const m;
5588
};
5689

5790

0 commit comments

Comments
 (0)