Skip to content

Commit

Permalink
Merge pull request #25 from Trueffeloot/d_a_tag_kb_item
Browse files Browse the repository at this point in the history
d_a_tag_kb_item OK
  • Loading branch information
magcius authored Sep 13, 2023
2 parents 6431f41 + 3347d15 commit 8f4ec8a
Show file tree
Hide file tree
Showing 2 changed files with 98 additions and 25 deletions.
2 changes: 1 addition & 1 deletion configure.py
Original file line number Diff line number Diff line change
Expand Up @@ -451,7 +451,7 @@ def ActorRel(status, rel_name):
ActorRel(NonMatching, "d_a_tag_evsw"),
ActorRel(NonMatching, "d_a_tag_ghostship"),
ActorRel(NonMatching, "d_a_tag_hint"),
ActorRel(NonMatching, "d_a_tag_kb_item"),
ActorRel(Matching, "d_a_tag_kb_item"),
ActorRel(NonMatching, "d_a_tag_kk1"),
ActorRel(NonMatching, "d_a_tag_light"),
ActorRel(NonMatching, "d_a_tag_msg"),
Expand Down
121 changes: 97 additions & 24 deletions src/d/actor/d_a_tag_kb_item.cpp
Original file line number Diff line number Diff line change
@@ -1,58 +1,131 @@
//
// Generated by dtk
// Translation Unit: d_a_tag_kb_item.cpp
//
/**
* d_a_tag_kb_item.cpp
*
*/

#include "d_a_tag_kb_item.h"
// #include "d_a_tag_kb_item.h"
#include "JSystem/JKernel/JKRHeap.h"
#include "d/d_com_inf_game.h"
#include "d/d_procname.h"
#include "dolphin/types.h"
#include "f_op/f_op_actor_mng.h"

class daTagKbItem_c : public fopAc_ac_c {
public:
void kb_dig(fopAc_ac_c*);
void dig_main();
bool _delete();
void CreateInit();
int _create();
bool _execute();
bool _draw();

/* 0x290 */ u8 field_0x290[0x298 - 0x290];
/* 0x298 */ u8 field_0x298;
/* 0x299 */ u8 field_0x299;
/* 0x29C */ s32 field_0x29c;
/* 0x2A0 */ u8 field_0x2a0;
/* 0x2A1 */ u8 field_0x2a1;
/* 0x2A4 */ s32 field_0x2a4;
/* 0x2A8 */ fopAc_ac_c* mpActor;
}; // Size: 0x2AC

/* 00000078-000000C8 .text _delete__13daTagKbItem_cFv */
void daTagKbItem_c::_delete() {
/* Nonmatching */
bool daTagKbItem_c::_delete() {
#if VERSION != VERSION_JP
if (field_0x2a0 != 0xff && field_0x2a4 != 0xff) {
dComIfGs_offSwitch(field_0x2a4, orig.roomNo);
}
#endif
return 1;
}

/* 000000C8-0000010C .text CreateInit__13daTagKbItem_cFv */
void daTagKbItem_c::CreateInit() {
/* Nonmatching */
field_0x2a0 = fopAcM_GetParam(this);
s8 paramBit = fopAcM_GetParamBit(this, 8, 8);
field_0x29c = paramBit;
field_0x2a1 = fopAcM_GetParamBit(this, 0x10, 8);
field_0x2a4 = fopAcM_GetParamBit(this, 0x18, 8);
field_0x298 = 0;
field_0x299 = 0;
mpActor = NULL;
}

/* 0000010C-000001BC .text _create__13daTagKbItem_cFv */
void daTagKbItem_c::_create() {
/* Nonmatching */
int daTagKbItem_c::_create() {
fopAcM_SetupActor(this, daTagKbItem_c);

CreateInit();
if (field_0x29c != 0x1f && dComIfGs_isItem(field_0x29c, orig.roomNo) ||
field_0x2a4 != 0xff && dComIfGs_isSwitch(field_0x2a4, orig.roomNo))
{
return cPhs_ERROR_e;
}
return cPhs_COMPLEATE_e;
}

/* 000001BC-000001C4 .text _execute__13daTagKbItem_cFv */
void daTagKbItem_c::_execute() {
/* Nonmatching */
bool daTagKbItem_c::_execute() {
#if VERSION == VERSION_JP
if (field_0x29c != 0x1f && dComIfGs_isItem(field_0x29c, orig.roomNo) ||
field_0x2a4 != 0xff && dComIfGs_isSwitch(field_0x2a4, orig.roomNo))
{
fopAcM_delete(this);
}
#endif
return 1;
}

/* 000001C4-000001CC .text _draw__13daTagKbItem_cFv */
void daTagKbItem_c::_draw() {
/* Nonmatching */
bool daTagKbItem_c::_draw() {
return 1;
}

/* 000001CC-000001EC .text daTagKbItem_Create__FPv */
void daTagKbItem_Create(void*) {
/* Nonmatching */
static int daTagKbItem_Create(void* i_this) {
return static_cast<daTagKbItem_c*>(i_this)->_create();
}

/* 000001EC-00000210 .text daTagKbItem_Delete__FPv */
void daTagKbItem_Delete(void*) {
/* Nonmatching */
static int daTagKbItem_Delete(void* i_this) {
return static_cast<daTagKbItem_c*>(i_this)->_delete();
}

/* 00000210-00000234 .text daTagKbItem_Draw__FPv */
void daTagKbItem_Draw(void*) {
/* Nonmatching */
static int daTagKbItem_Draw(void* i_this) {
return static_cast<daTagKbItem_c*>(i_this)->_draw();
}

/* 00000234-00000258 .text daTagKbItem_Execute__FPv */
void daTagKbItem_Execute(void*) {
/* Nonmatching */
static int daTagKbItem_Execute(void* i_this) {
return static_cast<daTagKbItem_c*>(i_this)->_execute();
}

/* 00000258-00000260 .text daTagKbItem_IsDelete__FPv */
void daTagKbItem_IsDelete(void*) {
/* Nonmatching */
static int daTagKbItem_IsDelete(void* i_this) {
return 1;
}

static actor_method_class daTagKbItemMethodTable = {
(process_method_func)daTagKbItem_Create, (process_method_func)daTagKbItem_Delete,
(process_method_func)daTagKbItem_Execute, (process_method_func)daTagKbItem_IsDelete,
(process_method_func)daTagKbItem_Draw,
};

extern actor_process_profile_definition g_profile_TAG_KB_ITEM = {
fpcLy_CURRENT_e,
7,
fpcLy_CURRENT_e,
PROC_TAG_KB_ITEM,
&g_fpcLf_Method.mBase,
sizeof(daTagKbItem_c),
0,
0,
&g_fopAc_Method.base,
0x0127,
&daTagKbItemMethodTable,
0x00040000,
fopAc_ACTOR_e,
fopAc_CULLBOX_0_e,
};

0 comments on commit 8f4ec8a

Please sign in to comment.