Skip to content

Commit 34c5d82

Browse files
authored
daObjCBlk_c equivalent (#2326)
1 parent 15a807b commit 34c5d82

File tree

6 files changed

+277
-960
lines changed

6 files changed

+277
-960
lines changed

configure.py

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1851,7 +1851,7 @@ def MatchingFor(*versions):
18511851
ActorRel(MatchingFor("GZ2E01"), "d_a_obj_bubblePilar"),
18521852
ActorRel(MatchingFor("GZ2E01"), "d_a_obj_catdoor"),
18531853
ActorRel(MatchingFor("GZ2E01"), "d_a_obj_cb"),
1854-
ActorRel(NonMatching, "d_a_obj_cblock"),
1854+
ActorRel(Equivalent, "d_a_obj_cblock"),
18551855
ActorRel(MatchingFor("GZ2E01"), "d_a_obj_cdoor"),
18561856
ActorRel(MatchingFor("GZ2E01"), "d_a_obj_chandelier"),
18571857
ActorRel(MatchingFor("GZ2E01"), "d_a_obj_chest"),

include/d/actor/d_a_obj_cblock.h

Lines changed: 42 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -1,8 +1,12 @@
11
#ifndef D_A_OBJ_CBLOCK_H
22
#define D_A_OBJ_CBLOCK_H
33

4+
#include "d/d_bg_s_movebg_actor.h"
5+
#include "d/d_cc_d.h"
46
#include "f_op/f_op_actor_mng.h"
57

8+
class dPath;
9+
610
/**
711
* @ingroup actors-objects
812
* @class daObjCBlk_c
@@ -11,32 +15,61 @@
1115
* @details
1216
*
1317
*/
14-
class daObjCBlk_c : public fopAc_ac_c {
18+
class daObjCBlk_c : public dBgS_MoveBgActor {
1519
public:
20+
typedef void (daObjCBlk_c::*modeFunc)();
21+
1622
struct chain_s {
1723
public:
1824
/* 80BC5E58 */ ~chain_s();
1925
/* 80BC5E94 */ chain_s();
26+
27+
J3DModel* model;
28+
cXyz position;
2029
};
2130

2231
/* 80BC5A0C */ void initBaseMtx();
2332
/* 80BC5A48 */ void setBaseMtx();
24-
/* 80BC5ABC */ void Create();
25-
/* 80BC5CF8 */ void CreateHeap();
26-
/* 80BC5E98 */ void create();
27-
/* 80BC6260 */ void Execute(f32 (**)[3][4]);
33+
/* 80BC5ABC */ int Create();
34+
/* 80BC5CF8 */ int CreateHeap();
35+
/* 80BC5E98 */ int create();
36+
/* 80BC6260 */ int Execute(f32 (**)[3][4]);
2837
/* 80BC6270 */ void initWait();
2938
/* 80BC627C */ void modeWait();
3039
/* 80BC6414 */ void initWalk();
3140
/* 80BC6430 */ void modeWalk();
3241
/* 80BC65CC */ void getChainBasePos(cXyz*);
3342
/* 80BC6648 */ void setPower(f32);
34-
/* 80BC66DC */ void checkWall();
35-
/* 80BC6868 */ bool Draw();
36-
/* 80BC6870 */ void Delete();
43+
/* 80BC66DC */ BOOL checkWall();
44+
/* 80BC6868 */ int Draw();
45+
/* 80BC6870 */ int Delete();
46+
47+
u8 getArg0() { return fopAcM_GetParamBit(this, 0, 4); }
48+
u8 getSwNo() { return fopAcM_GetParamBit(this, 16, 8); }
49+
u8 getPathID() { return fopAcM_GetParamBit(this, 24, 8); }
3750

3851
private:
39-
/* 0x568 */ u8 field_0x568[0xca8 - 0x568];
52+
/* 0x5A0 */ request_of_phase_process_class phase;
53+
/* 0x5A8 */ J3DModel* model1;
54+
/* 0x5AC */ J3DModel* model2;
55+
/* 0x5B0 */ dCcD_Stts stts;
56+
/* 0x5EC */ dCcD_Cyl cyl;
57+
/* 0x728 */ dCcD_Cyl cyls[4];
58+
/* 0xC18 */ chain_s* chains;
59+
/* 0xC1C */ u8 field_0xc1c;
60+
/* 0xC1D */ u8 field_0xc1d;
61+
/* 0xC1E */ u8 field_0xc1e;
62+
/* 0xC1F */ u8 field_0xc1f;
63+
/* 0xC20 */ f32 power;
64+
/* 0xC24 */ cXyz field_0xc24[7];
65+
/* 0xC78 */ u8 field_0xc78[0xc9c - 0xc78];
66+
/* 0xC9C */ dPath* roomPath;
67+
/* 0xCA0 */ u8 swNo;
68+
/* 0xCA1 */ u8 arg0;
69+
/* 0xCA2 */ u8 field_0xca2;
70+
/* 0xCA3 */ u8 field_0xca3;
71+
/* 0xCA4 */ s16 walkTimer;
72+
/* 0xCA6 */ s16 field_0xca6;
4073
};
4174

4275
STATIC_ASSERT(sizeof(daObjCBlk_c) == 0xca8);

src/d/actor/d_a_e_kg.cpp

Lines changed: 1 addition & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -8,10 +8,7 @@
88
UNK_REL_DATA;
99
#include "f_op/f_op_actor_enemy.h"
1010

11-
12-
//
13-
// Declarations:
14-
//
11+
// NONMATCHING - weak function order
1512

1613
/* 806F7EEC-806F7F24 0000EC 0038+00 1/1 0/0 0/0 .text __ct__12daE_KG_HIO_cFv */
1714
daE_KG_HIO_c::daE_KG_HIO_c() {

0 commit comments

Comments
 (0)