Files
tp/src/f_op/f_op_overlap_req.cpp
T
TakaRikka a6e76c0841 project cleanup (#2895)
* some wii OS fixes

* remove old dol2asm comments

* remove dol2asm.h

* remove function address comments

* normalize ATTRIBUTE_ALIGN usage

* DECL_WEAK macro

* fix gcc attribute weak macro

* wrap more mwcc specific things in ifdefs

* fixes

* fix revo sdk version flags

* fixes
2025-11-30 15:23:42 -07:00

161 lines
4.6 KiB
C++

/**
* f_op_overlap_req.cpp
* Overlap Process Request
*/
#include "SSystem/SComponent/c_request.h"
#include "f_op/f_op_overlap_req.h"
#include "f_pc/f_pc_manager.h"
void fopOvlpReq_SetPeektime(overlap_request_class*, u16);
static int fopOvlpReq_phase_Done(overlap_request_class* i_overlapReq) {
if (fpcM_Delete(i_overlapReq->overlap_task) == 1) {
i_overlapReq->overlap_task = NULL;
i_overlapReq->field_0x4 = 0;
i_overlapReq->peektime = 0;
i_overlapReq->field_0x8 = 0;
i_overlapReq->field_0xc = 0;
return cPhs_NEXT_e;
}
return cPhs_INIT_e;
}
static s32 fopOvlpReq_phase_IsDone(overlap_request_class* i_overlapReq) {
cReq_Done(&i_overlapReq->base);
if (i_overlapReq->field_0x2-- <= 0) {
return cPhs_NEXT_e;
}
return cPhs_INIT_e;
}
static int fopOvlpReq_phase_IsWaitOfFadeout(overlap_request_class* i_overlapReq) {
if (cReq_Is_Done(&i_overlapReq->overlap_task->request)) {
i_overlapReq->field_0x8 = 0;
return cPhs_NEXT_e;
}
return cPhs_INIT_e;
}
static int fopOvlpReq_phase_WaitOfFadeout(overlap_request_class* i_overlapReq) {
if (i_overlapReq->peektime) {
i_overlapReq->peektime--;
}
if (i_overlapReq->base.flag2 == 2 && !i_overlapReq->peektime) {
cReq_Command(&i_overlapReq->overlap_task->request, 2);
return cPhs_NEXT_e;
}
i_overlapReq->field_0x8 = 1;
return cPhs_INIT_e;
}
static int fopOvlpReq_phase_IsComplete(overlap_request_class* i_overlapReq) {
if (cReq_Is_Done(&i_overlapReq->overlap_task->request)) {
cReq_Done(&i_overlapReq->base);
return cPhs_NEXT_e;
}
return cPhs_INIT_e;
}
static int fopOvlpReq_phase_IsCreated(overlap_request_class* i_overlapReq) {
if (fpcM_IsCreating(i_overlapReq->request_id) == 0) {
overlap_task_class* process = (overlap_task_class*)fpcM_SearchByID(i_overlapReq->request_id);
if (process == NULL) {
return cPhs_ERROR_e;
}
i_overlapReq->overlap_task = process;
return cPhs_NEXT_e;
}
return cPhs_INIT_e;
}
static int fopOvlpReq_phase_Create(overlap_request_class* i_overlapReq) {
fpcLy_SetCurrentLayer(i_overlapReq->layer);
i_overlapReq->request_id =
fpcSCtRq_Request(fpcLy_CurrentLayer(), i_overlapReq->procname, NULL, NULL, NULL);
return cPhs_NEXT_e;
}
overlap_request_class* fopOvlpReq_Request(overlap_request_class* i_overlapReq, s16 i_procname,
u16 i_peektime) {
static cPhs__Handler phaseMethod[8] = {
(cPhs__Handler)fopOvlpReq_phase_Create,
(cPhs__Handler)fopOvlpReq_phase_IsCreated,
(cPhs__Handler)fopOvlpReq_phase_IsComplete,
(cPhs__Handler)fopOvlpReq_phase_WaitOfFadeout,
(cPhs__Handler)fopOvlpReq_phase_IsWaitOfFadeout,
(cPhs__Handler)fopOvlpReq_phase_IsDone,
(cPhs__Handler)fopOvlpReq_phase_Done,
(cPhs__Handler)NULL,
};
if (i_overlapReq->field_0x4 == 1) {
i_overlapReq = NULL;
return i_overlapReq;
}
cReq_Command(&i_overlapReq->base, 1);
i_overlapReq->procname = i_procname;
cPhs_Set(&i_overlapReq->phase_req, phaseMethod);
fopOvlpReq_SetPeektime(i_overlapReq, i_peektime);
i_overlapReq->field_0x4 = 1;
i_overlapReq->field_0x2 = 1;
i_overlapReq->overlap_task = NULL;
i_overlapReq->field_0x8 = 0;
i_overlapReq->field_0xc = 0;
i_overlapReq->layer = fpcLy_RootLayer();
return i_overlapReq;
}
int fopOvlpReq_Handler(overlap_request_class* i_overlapReq) {
int phase_state = cPhs_Do(&i_overlapReq->phase_req, i_overlapReq);
switch (phase_state) {
case cPhs_NEXT_e:
return fopOvlpReq_Handler(i_overlapReq);
case cPhs_INIT_e:
return cPhs_INIT_e;
case cPhs_LOADING_e:
return cPhs_INIT_e;
case cPhs_COMPLEATE_e:
return cPhs_COMPLEATE_e;
case cPhs_UNK3_e:
case cPhs_ERROR_e:
return cPhs_ERROR_e;
default:
return cPhs_ERROR_e;
}
}
int fopOvlpReq_Cancel(overlap_request_class* i_overlapReq) {
return fopOvlpReq_phase_Done(i_overlapReq) == cPhs_NEXT_e ? TRUE : FALSE;
}
int fopOvlpReq_Is_PeektimeLimit(overlap_request_class* i_overlapReq) {
return i_overlapReq->peektime == 0 ? TRUE : FALSE;
}
void fopOvlpReq_SetPeektime(overlap_request_class* i_overlapReq, u16 i_peektime) {
if (i_peektime <= 0x7FFF) {
i_overlapReq->peektime = i_peektime;
}
}
int fopOvlpReq_OverlapClr(overlap_request_class* i_overlapReq) {
if (i_overlapReq->base.flag0 == 1 || !fopOvlpReq_Is_PeektimeLimit(i_overlapReq))
{
return 0;
}
cReq_Create(&i_overlapReq->base, 2);
return 1;
}