pokeemerald/src/pokenav.c

649 lines
14 KiB
C
Raw Normal View History

2019-02-11 14:59:44 -05:00
#include "global.h"
#include "alloc.h"
#include "task.h"
#include "main.h"
#include "overworld.h"
2019-02-12 01:39:27 -05:00
#include "field_weather.h"
2019-02-12 02:23:08 -05:00
#include "palette.h"
2019-02-12 03:48:32 -05:00
#include "pokemon_storage_system.h"
#include "pokenav.h"
2019-02-12 02:23:08 -05:00
2019-02-23 13:34:01 +01:00
enum
{
MODE_NORMAL, // Chosen from Start menu.
MODE_FORCE_CALL_1, // Used for the script's special. Has to choose Match Call and make a call.
MODE_FORCE_CALL_2, // Set after making a call, has to exit Pokenav.
};
enum
{
NAVMENU_CB_UNK_0,
NAVMENU_CB_UNK_1,
NAVMENU_CB_UNK_2,
NAVMENU_CB_UNK_3,
NAVMENU_CB_UNK_4,
NAVMENU_CB_UNK_5,
NAVMENU_CB_UNK_6
};
2019-04-06 16:15:52 -04:00
#define LOOPED_TASK_DECODE_STATE(action) (action - 5)
#define LOOPED_TASK_ID(primary, secondary) (((secondary) << 16) |(primary))
#define LOOPED_TASK_PRIMARY_ID(taskId) (taskId & 0xFFFF)
#define LOOPED_TASK_SECONDARY_ID(taskId) (taskId >> 16)
#define UNKNOWN_OFFSET 100000
2019-02-23 13:34:01 +01:00
#define SUBSTRUCT_COUNT 19
2019-04-06 16:15:52 -04:00
struct PokenavResources
2019-02-15 00:07:57 -05:00
{
u32 (*currentMenuCb1)(void);
u32 currentMenuIndex;
2019-02-23 13:34:01 +01:00
u16 mode;
2019-02-15 00:29:32 -05:00
u16 fieldA;
2019-02-23 13:34:01 +01:00
bool32 hasAnyRibbons;
2019-02-23 23:17:26 -05:00
void *field10[SUBSTRUCT_COUNT];
2019-02-12 22:35:07 -05:00
};
extern u32 sub_81C9430(void);
extern u32 sub_81C941C(void);
extern u32 sub_81C9924(void);
extern u32 sub_81C99C0(void);
extern u32 sub_81C9990(void);
extern u32 sub_81C9940(void);
extern u32 sub_81C9338(void);
extern u32 sub_81C9368(void);
extern u32 sub_81C92CC(void);
extern u32 sub_81C9304(void);
extern u32 sub_81CC4D4(void);
extern u32 sub_81CC554(void);
extern u32 sub_81CC5F4(void);
extern u32 sub_81CC62C(void);
extern u32 sub_81CC65C(void);
extern u32 sub_81CC524(void);
extern u32 sub_81CC670(void);
extern u32 sub_81CCFD8(void);
extern u32 sub_81CD070(void);
extern u32 sub_81CDDD4(void);
extern u32 sub_81CDE2C(void);
extern u32 sub_81CDE64(void);
extern u32 sub_81CD1C0(void);
extern u32 sub_81CECA0(void);
extern u32 sub_81CEF3C(void);
extern u32 sub_81CEFDC(void);
extern u32 sub_81CF330(void);
extern u32 sub_81CF3A0(void);
extern u32 sub_81CF3D0(void);
extern u32 sub_81CEFF0(void);
extern u32 sub_81CF3F8(void);
extern u32 sub_81CD024(void);
extern u32 sub_81CEF98(void);
extern u32 sub_81CF368(void);
extern u32 sub_81CAAE8(void);
extern u32 sub_81CAB24(void);
extern u32 sub_81CB260(void);
extern u32 sub_81CB29C(void);
extern u32 sub_81CB2CC(void);
extern u32 sub_81CAB38(void);
extern u32 sub_81CB2E0(void);
extern u32 sub_81CF9BC(void);
extern u32 sub_81CFA34(void);
extern u32 sub_81CFDD0(void);
extern u32 sub_81CFE40(void);
extern u32 sub_81CFE70(void);
extern u32 sub_81CFA48(void);
extern u32 sub_81CFE98(void);
extern u32 sub_81D0450(void);
extern u32 sub_81D04A0(void);
extern u32 sub_81D0978(void);
extern u32 sub_81D09B0(void);
extern u32 sub_81D09E0(void);
extern u32 sub_81D04B8(void);
extern u32 sub_81D09F4(void);
extern u32 sub_81CFA04(void);
extern u32 sub_81CFE08(void);
bool32 SetActivePokenavMenu(u32 a0);
bool32 InitPokenavMainMenu(void);
2019-02-23 13:34:01 +01:00
static bool32 AnyMonHasRibbon(void);
2019-02-12 21:33:15 -05:00
u32 sub_81C75E0(void);
u32 sub_81C75D4(void);
u32 PokenavMainMenuLoopedTaskIsActive(void);
u32 sub_81C786C(void);
bool32 WaitForPokenavShutdownFade(void);
2019-02-23 13:34:01 +01:00
void sub_81C7834(void *func1, void *func2);
static void InitPokenavResources(struct PokenavResources *a0);
void sub_81C7850(u32 a0);
2019-04-06 16:15:52 -04:00
void Task_RunLoopedTask_LinkMode(u8 a0);
void Task_RunLoopedTask(u8 taskId);
2019-02-12 22:18:12 -05:00
void sub_81C742C(u8 taskId);
void ShutdownPokenav(void);
2019-02-23 13:34:01 +01:00
static void InitKeys_(void);
static void FreePokenavResources(void);
2019-04-06 16:15:52 -04:00
static void VBlankCB_Pokenav(void);
2019-03-02 03:18:08 -05:00
static void CB2_Pokenav(void);
2019-02-12 02:23:08 -05:00
void sub_81C72BC(void);
2019-02-23 13:34:01 +01:00
// Const rom data.
u32 (*const PokenavMenuCallbacks[15][7])(void) =
{
2019-02-15 00:29:32 -05:00
{
sub_81C9298,
2019-02-15 00:29:32 -05:00
sub_81C941C,
sub_81C9924,
sub_81C9990,
sub_81C99C0,
sub_81C9430,
sub_81C99D4,
},
{
sub_81C9298,
sub_81C941C,
sub_81C9940,
sub_81C9990,
sub_81C99C0,
sub_81C9430,
sub_81C99D4,
},
{
sub_81C9338,
sub_81C941C,
sub_81C9940,
sub_81C9990,
sub_81C99C0,
sub_81C9430,
sub_81C99D4,
},
{
sub_81C9368,
sub_81C941C,
sub_81C9940,
sub_81C9990,
sub_81C99C0,
sub_81C9430,
sub_81C99D4,
},
{
sub_81C92CC,
sub_81C941C,
sub_81C9940,
sub_81C9990,
sub_81C99C0,
sub_81C9430,
sub_81C99D4,
},
{
sub_81C9304,
sub_81C941C,
sub_81C9940,
sub_81C9990,
sub_81C99C0,
sub_81C9430,
sub_81C99D4,
},
{
sub_81CC4D4,
sub_81CC554,
sub_81CC5F4,
sub_81CC62C,
sub_81CC65C,
sub_81CC524,
sub_81CC670,
},
{
sub_81CCFD8,
sub_81CD070,
sub_81CDDD4,
sub_81CDE2C,
sub_81CDE64,
sub_81CD1C0,
sub_81CECA0,
},
{
sub_81CEF3C,
sub_81CEFDC,
sub_81CF330,
sub_81CF3A0,
sub_81CF3D0,
sub_81CEFF0,
sub_81CF3F8,
},
{
sub_81CD024,
sub_81CD070,
sub_81CDDD4,
sub_81CDE2C,
sub_81CDE64,
sub_81CD1C0,
sub_81CECA0,
},
{
sub_81CEF98,
sub_81CEFDC,
sub_81CF368,
sub_81CF3A0,
sub_81CF3D0,
sub_81CEFF0,
sub_81CF3F8,
},
{
sub_81CAAE8,
sub_81CAB24,
sub_81CB260,
sub_81CB29C,
sub_81CB2CC,
sub_81CAB38,
sub_81CB2E0,
},
{
sub_81CF9BC,
sub_81CFA34,
sub_81CFDD0,
sub_81CFE40,
sub_81CFE70,
sub_81CFA48,
sub_81CFE98,
},
{
sub_81D0450,
sub_81D04A0,
sub_81D0978,
sub_81D09B0,
sub_81D09E0,
sub_81D04B8,
sub_81D09F4,
},
{
sub_81CFA04,
sub_81CFA34,
sub_81CFE08,
sub_81CFE40,
sub_81CFE70,
sub_81CFA48,
sub_81CFE98,
},
};
2019-04-06 16:15:52 -04:00
EWRAM_DATA u8 gNextLoopedTaskId = 0;
EWRAM_DATA struct PokenavResources *gPokenavResources = NULL;
2019-03-15 19:33:30 -04:00
2019-02-23 13:34:01 +01:00
// code
2019-04-06 16:15:52 -04:00
u32 CreateLoopedTask(LoopedTask loopedTask, u32 priority)
2019-02-11 14:59:44 -05:00
{
u16 taskId;
if (!IsUpdateLinkStateCBActive())
2019-04-06 16:15:52 -04:00
taskId = CreateTask(Task_RunLoopedTask, priority);
2019-02-15 00:29:32 -05:00
else
2019-04-06 16:15:52 -04:00
taskId = CreateTask(Task_RunLoopedTask_LinkMode, priority);
2019-02-11 14:59:44 -05:00
2019-04-06 16:15:52 -04:00
SetWordTaskArg(taskId, 1, (u32)loopedTask);
2019-02-11 14:59:44 -05:00
2019-04-06 16:15:52 -04:00
gTasks[taskId].data[3] = gNextLoopedTaskId;
return LOOPED_TASK_ID(taskId, gNextLoopedTaskId++);
2019-02-11 14:59:44 -05:00
}
2019-04-06 16:15:52 -04:00
bool32 IsLoopedTaskActive(u32 taskId)
2019-02-11 16:35:02 -05:00
{
2019-04-06 16:15:52 -04:00
u32 primaryId = LOOPED_TASK_PRIMARY_ID(taskId);
u32 secondaryId = LOOPED_TASK_SECONDARY_ID(taskId);
2019-02-23 13:34:01 +01:00
2019-04-06 16:15:52 -04:00
if (gTasks[primaryId].isActive
&& (gTasks[primaryId].func == Task_RunLoopedTask || gTasks[primaryId].func == Task_RunLoopedTask_LinkMode)
&& gTasks[primaryId].data[3] == secondaryId)
2019-02-15 00:29:32 -05:00
return TRUE;
else
return FALSE;
2019-02-11 16:06:46 -05:00
}
2019-04-06 16:15:52 -04:00
bool32 FuncIsActiveLoopedTask(LoopedTask func)
2019-02-11 16:35:02 -05:00
{
2019-02-15 00:29:32 -05:00
s32 i;
2019-02-23 13:34:01 +01:00
for (i = 0; i < NUM_TASKS; i++)
2019-02-15 00:29:32 -05:00
{
if (gTasks[i].isActive
2019-04-06 16:15:52 -04:00
&& (gTasks[i].func == Task_RunLoopedTask || gTasks[i].func == Task_RunLoopedTask_LinkMode)
&& (LoopedTask)GetWordTaskArg(i, 1) == func)
2019-02-23 13:34:01 +01:00
return TRUE;
2019-02-15 00:29:32 -05:00
}
return FALSE;
2019-02-12 00:51:54 -05:00
}
2019-04-06 16:15:52 -04:00
void Task_RunLoopedTask(u8 taskId)
2019-02-12 00:51:54 -05:00
{
2019-04-06 16:15:52 -04:00
LoopedTask loopedTask = (LoopedTask)GetWordTaskArg(taskId, 1);
s16 *state = &gTasks[taskId].data[0];
2019-02-23 13:34:01 +01:00
bool32 exitLoop = FALSE;
2019-02-15 00:29:32 -05:00
while (!exitLoop)
{
2019-04-06 16:15:52 -04:00
u32 action = loopedTask(*state);
switch (action)
2019-02-16 12:09:27 -05:00
{
2019-04-06 16:15:52 -04:00
case LT_INC_AND_CONTINUE:
(*state)++;
2019-02-15 00:29:32 -05:00
break;
case LT_INC_AND_PAUSE:
2019-04-06 16:15:52 -04:00
(*state)++;
2019-02-15 00:29:32 -05:00
return;
2019-04-06 16:15:52 -04:00
case LT_FINISH:
2019-02-15 00:29:32 -05:00
DestroyTask(taskId);
return;
2019-04-06 16:15:52 -04:00
// case LT_SET_STATE:
2019-02-15 00:29:32 -05:00
default:
2019-04-06 16:15:52 -04:00
*state = LOOPED_TASK_DECODE_STATE(action);
2019-02-15 00:29:32 -05:00
break;
2019-04-06 16:15:52 -04:00
case LT_CONTINUE:
2019-02-15 00:29:32 -05:00
break;
case LT_PAUSE:
2019-02-15 00:29:32 -05:00
return;
}
}
2019-02-12 01:30:39 -05:00
}
// Every "Continue" action pauses instead.
2019-04-06 16:15:52 -04:00
void Task_RunLoopedTask_LinkMode(u8 taskId)
2019-02-15 00:07:57 -05:00
{
2019-04-06 16:15:52 -04:00
LoopedTask task;
s16 *state;
u32 action;
2019-02-15 00:29:32 -05:00
if (sub_8087598())
return;
2019-04-06 16:15:52 -04:00
task = (LoopedTask)GetWordTaskArg(taskId, 1);
state = &gTasks[taskId].data[0];
action = task(*state);
switch (action)
{
case LT_INC_AND_PAUSE:
2019-04-06 16:15:52 -04:00
case LT_INC_AND_CONTINUE:
(*state)++;
2019-02-16 12:09:27 -05:00
break;
2019-04-06 16:15:52 -04:00
case LT_FINISH:
2019-02-16 12:09:27 -05:00
DestroyTask(taskId);
break;
2019-04-06 16:15:52 -04:00
// case: LT_SET_STATE:
2019-02-16 12:09:27 -05:00
default:
2019-04-06 16:15:52 -04:00
*state = LOOPED_TASK_DECODE_STATE(action);
2019-02-16 12:09:27 -05:00
break;
case LT_PAUSE:
2019-04-06 16:15:52 -04:00
case LT_CONTINUE:
break;
2019-02-15 00:29:32 -05:00
}
2019-02-12 01:34:43 -05:00
}
2019-03-02 03:18:08 -05:00
void CB2_InitPokeNav(void)
2019-02-12 01:34:43 -05:00
{
2019-04-06 16:15:52 -04:00
gPokenavResources = Alloc(sizeof(*gPokenavResources));
if (gPokenavResources == NULL)
{
2019-02-12 01:34:43 -05:00
SetMainCallback2(CB2_ReturnToFieldWithOpenMenu);
}
2019-02-16 12:09:27 -05:00
else
{
InitPokenavResources(gPokenavResources);
2019-02-12 01:34:43 -05:00
ResetTasks();
SetVBlankCallback(NULL);
CreateTask(sub_81C742C, 0);
2019-03-02 03:18:08 -05:00
SetMainCallback2(CB2_Pokenav);
2019-04-06 16:15:52 -04:00
SetVBlankCallback(VBlankCB_Pokenav);
2019-02-12 01:34:43 -05:00
}
2019-02-12 01:39:27 -05:00
}
2019-02-23 13:34:01 +01:00
void sub_81C72A4(void)
2019-02-15 00:07:57 -05:00
{
2019-02-15 00:29:32 -05:00
SetMainCallback2(sub_81C72BC);
FadeScreen(1, 0);
2019-02-12 02:23:08 -05:00
}
2019-02-23 13:34:01 +01:00
void sub_81C72BC(void)
2019-02-15 00:07:57 -05:00
{
2019-02-15 00:29:32 -05:00
UpdatePaletteFade();
2019-02-23 13:34:01 +01:00
if (gPaletteFade.active)
return;
2019-04-06 16:15:52 -04:00
gPokenavResources = Alloc(sizeof(*gPokenavResources));
if (gPokenavResources == NULL)
2019-02-15 00:29:32 -05:00
{
2019-02-23 13:34:01 +01:00
SetMainCallback2(CB2_ReturnToFieldContinueScriptPlayMapMusic);
}
else
{
InitPokenavResources(gPokenavResources);
2019-04-06 16:15:52 -04:00
gPokenavResources->mode = MODE_FORCE_CALL_1;
2019-02-23 13:34:01 +01:00
ResetTasks();
ResetSpriteData();
FreeAllSpritePalettes();
SetVBlankCallback(NULL);
CreateTask(sub_81C742C, 0);
2019-03-02 03:18:08 -05:00
SetMainCallback2(CB2_Pokenav);
2019-04-06 16:15:52 -04:00
SetVBlankCallback(VBlankCB_Pokenav);
2019-02-15 00:29:32 -05:00
}
2019-02-12 02:28:46 -05:00
}
static void FreePokenavResources(void)
2019-02-15 00:07:57 -05:00
{
2019-02-15 00:29:32 -05:00
s32 i;
2019-02-12 02:28:46 -05:00
2019-02-23 13:34:01 +01:00
for (i = 0; i < SUBSTRUCT_COUNT; i++)
FreePokenavSubstruct(i);
2019-02-23 13:34:01 +01:00
2019-04-06 16:15:52 -04:00
FREE_AND_SET_NULL(gPokenavResources);
2019-02-15 00:29:32 -05:00
InitKeys();
2019-02-12 02:59:17 -05:00
}
static void InitPokenavResources(struct PokenavResources *a0)
2019-02-15 00:07:57 -05:00
{
2019-02-15 00:29:32 -05:00
s32 i;
2019-02-23 13:34:01 +01:00
for (i = 0; i < SUBSTRUCT_COUNT; i++)
a0->field10[i] = NULL;
a0->mode = MODE_NORMAL;
a0->currentMenuIndex = 0;
2019-02-23 13:34:01 +01:00
a0->hasAnyRibbons = AnyMonHasRibbon();
a0->currentMenuCb1 = NULL;
2019-02-12 03:48:32 -05:00
}
2019-02-23 13:34:01 +01:00
static bool32 AnyMonHasRibbon(void)
2019-02-15 00:07:57 -05:00
{
2019-02-23 13:34:01 +01:00
s32 i, j;
2019-02-15 00:29:32 -05:00
for (i = 0; i < PARTY_SIZE; i++)
2019-02-15 00:29:32 -05:00
{
if (GetMonData(&gPlayerParty[i], MON_DATA_SANITY_HAS_SPECIES)
&& !GetMonData(&gPlayerParty[i], MON_DATA_SANITY_IS_EGG)
&& GetMonData(&gPlayerParty[i], MON_DATA_RIBBON_COUNT) != 0)
{
return TRUE;
}
}
for (j = 0; j < TOTAL_BOXES_COUNT; j++)
2019-02-15 00:29:32 -05:00
{
2019-02-23 13:34:01 +01:00
for (i = 0; i < IN_BOX_COUNT; i++)
2019-02-15 00:29:32 -05:00
{
if (CheckBoxMonSanityAt(j, i)
&& GetBoxMonDataAt(j, i, MON_DATA_RIBBON_COUNT) != 0)
{
return TRUE;
}
}
}
return FALSE;
2019-02-12 03:51:48 -05:00
}
2019-03-02 03:18:08 -05:00
static void CB2_Pokenav(void)
2019-02-15 00:07:57 -05:00
{
2019-02-15 00:29:32 -05:00
RunTasks();
AnimateSprites();
BuildOamBuffer();
UpdatePaletteFade();
2019-02-12 03:54:35 -05:00
}
2019-04-06 16:15:52 -04:00
static void VBlankCB_Pokenav(void)
2019-02-15 00:07:57 -05:00
{
2019-02-15 00:29:32 -05:00
TransferPlttBuffer();
LoadOam();
ProcessSpriteCopyRequests();
2019-02-12 20:20:15 -05:00
}
2019-02-15 00:07:57 -05:00
void sub_81C742C(u8 taskId)
{
2019-02-15 00:29:32 -05:00
u32 v1;
2019-02-23 13:34:01 +01:00
s16 *data = gTasks[taskId].data;
2019-02-15 00:29:32 -05:00
2019-02-23 13:34:01 +01:00
switch (data[0])
2019-02-15 00:29:32 -05:00
{
case 0:
InitPokenavMainMenu();
2019-02-23 13:34:01 +01:00
data[0] = 1;
2019-02-15 00:29:32 -05:00
break;
case 1:
// Wait for LoopedTask_InitPokenavMenu to finish
if (PokenavMainMenuLoopedTaskIsActive())
2019-02-15 00:29:32 -05:00
break;
SetActivePokenavMenu(0 + UNKNOWN_OFFSET);
2019-02-23 13:34:01 +01:00
data[0] = 4;
2019-02-15 00:29:32 -05:00
break;
case 2:
if (sub_81C786C())
break;
2019-02-23 13:34:01 +01:00
data[0] = 3;
2019-02-15 00:29:32 -05:00
case 3:
v1 = sub_81C75E0();
if (v1 == -1)
{
ShutdownPokenav();
2019-02-23 13:34:01 +01:00
data[0] = 5;
2019-02-15 00:29:32 -05:00
}
else if (v1 >= UNKNOWN_OFFSET)
{
PokenavMenuCallbacks[gPokenavResources->currentMenuIndex][NAVMENU_CB_UNK_6]();
PokenavMenuCallbacks[gPokenavResources->currentMenuIndex][NAVMENU_CB_UNK_5]();
if (SetActivePokenavMenu(v1))
{
2019-02-23 13:34:01 +01:00
data[0] = 4;
}
2019-02-15 00:29:32 -05:00
else
{
ShutdownPokenav();
2019-02-23 13:34:01 +01:00
data[0] = 5;
2019-02-15 00:29:32 -05:00
}
}
else if (v1 != 0)
{
sub_81C7850(v1);
if (sub_81C786C())
2019-02-23 13:34:01 +01:00
data[0] = 2;
2019-02-15 00:29:32 -05:00
}
break;
case 4:
if (!sub_81C75D4())
2019-02-23 13:34:01 +01:00
data[0] = 3;
2019-02-15 00:29:32 -05:00
break;
case 5:
if (!WaitForPokenavShutdownFade())
2019-02-15 00:29:32 -05:00
{
2019-04-06 16:15:52 -04:00
bool32 calledFromScript = (gPokenavResources->mode != MODE_NORMAL);
2019-02-23 13:34:01 +01:00
2019-02-15 00:29:32 -05:00
sub_81C9430();
FreePokenavResources();
2019-02-23 13:34:01 +01:00
if (calledFromScript)
2019-02-15 00:29:32 -05:00
SetMainCallback2(CB2_ReturnToFieldContinueScriptPlayMapMusic);
else
SetMainCallback2(CB2_ReturnToFieldWithOpenMenu);
}
break;
2019-02-15 00:29:32 -05:00
}
}
bool32 SetActivePokenavMenu(u32 indexWithOffset)
2019-02-15 00:07:57 -05:00
{
u32 index = indexWithOffset - UNKNOWN_OFFSET;
2019-02-15 00:29:32 -05:00
2019-02-23 13:34:01 +01:00
InitKeys_();
if (!PokenavMenuCallbacks[index][NAVMENU_CB_UNK_0]())
2019-02-15 00:29:32 -05:00
return FALSE;
if (!PokenavMenuCallbacks[index][NAVMENU_CB_UNK_2]())
2019-02-15 00:29:32 -05:00
return FALSE;
2019-02-23 13:34:01 +01:00
sub_81C7834(PokenavMenuCallbacks[index][NAVMENU_CB_UNK_3], PokenavMenuCallbacks[index][NAVMENU_CB_UNK_4]);
gPokenavResources->currentMenuCb1 = PokenavMenuCallbacks[index][NAVMENU_CB_UNK_1];
gPokenavResources->currentMenuIndex = index;
2019-02-15 00:29:32 -05:00
return TRUE;
2019-02-12 21:33:15 -05:00
}
2019-02-15 00:07:57 -05:00
u32 sub_81C75D4(void)
{
2019-02-15 00:29:32 -05:00
return sub_81C786C();
2019-02-12 21:33:15 -05:00
}
2019-02-15 00:07:57 -05:00
u32 sub_81C75E0(void)
{
return gPokenavResources->currentMenuCb1();
2019-02-12 21:33:15 -05:00
}
2019-02-23 13:34:01 +01:00
static void InitKeys_(void)
2019-02-15 00:07:57 -05:00
{
2019-02-15 00:29:32 -05:00
InitKeys();
2019-02-12 21:33:15 -05:00
}
2019-02-23 13:34:01 +01:00
void SetVBlankCallback_(IntrCallback callback)
2019-02-15 00:07:57 -05:00
{
2019-02-15 00:29:32 -05:00
SetVBlankCallback(callback);
2019-02-12 21:33:15 -05:00
}
2019-02-23 13:34:01 +01:00
void SetPokenavVBlankCallback(void)
2019-02-15 00:07:57 -05:00
{
2019-04-06 16:15:52 -04:00
SetVBlankCallback(VBlankCB_Pokenav);
2019-02-12 21:33:15 -05:00
}
2019-02-23 13:34:01 +01:00
void *AllocSubstruct(u32 index, u32 size)
2019-02-15 00:07:57 -05:00
{
2019-04-06 16:15:52 -04:00
return gPokenavResources->field10[index] = Alloc(size);
2019-02-12 22:18:12 -05:00
}
void *GetSubstructPtr(u32 index)
2019-02-15 00:07:57 -05:00
{
2019-04-06 16:15:52 -04:00
return gPokenavResources->field10[index];
2019-02-12 22:18:12 -05:00
}
void FreePokenavSubstruct(u32 index)
2019-02-15 00:07:57 -05:00
{
2019-04-06 16:15:52 -04:00
if (gPokenavResources->field10[index] != NULL)
FREE_AND_SET_NULL(gPokenavResources->field10[index]);
2019-02-12 22:18:12 -05:00
}
2019-02-23 13:34:01 +01:00
u16 GetPokenavMode(void)
2019-02-15 00:07:57 -05:00
{
2019-04-06 16:15:52 -04:00
return gPokenavResources->mode;
2019-02-12 22:18:12 -05:00
}
2019-02-23 13:34:01 +01:00
void SetPokenavMode(u16 mode)
2019-02-15 00:07:57 -05:00
{
2019-04-06 16:15:52 -04:00
gPokenavResources->mode = mode;
2019-02-12 22:18:12 -05:00
}
2019-02-15 00:07:57 -05:00
void sub_81C7694(u32 a0)
{
2019-02-23 13:34:01 +01:00
u32 value = a0;
if (value > 4)
2019-02-15 00:29:32 -05:00
value = 0;
2019-04-06 16:15:52 -04:00
gPokenavResources->fieldA = value;
2019-02-12 22:18:12 -05:00
}
2019-02-15 00:07:57 -05:00
u16 sub_81C76AC(void)
{
2019-04-06 16:15:52 -04:00
return gPokenavResources->fieldA;
2019-02-12 22:18:12 -05:00
}
2019-02-23 13:34:01 +01:00
bool32 CanViewRibbonsMenu(void)
2019-02-15 00:07:57 -05:00
{
2019-04-06 16:15:52 -04:00
return gPokenavResources->hasAnyRibbons;
2019-02-12 22:18:12 -05:00
}