Found a debug system for pokemon contests

This commit is contained in:
Phlosioneer 2019-04-02 21:51:21 -04:00
parent f79a2fda68
commit 8f13e991d2
6 changed files with 92 additions and 79 deletions

View File

@ -3,6 +3,14 @@
#define CONTESTANT_COUNT 4 #define CONTESTANT_COUNT 4
#define CONTEST_DEBUG_MODE_OFF 0
// Prints the totalPoints value for each contestant.
#define CONTEST_DEBUG_MODE_PRINT_POINT_TOTAL 1
// Prints the ContestResourcesField1C::unk_C value as a bitstring for each contestant.
#define CONTEST_DEBUG_MODE_PRINT_UNK_C 2
// Prints the ContestResourcesField1C::unk_D value as a bitstring for each contestant.
#define CONTEST_DEBUG_MODE_PRINT_UNK_D 3
enum enum
{ {
CONTEST_CATEGORY_COOL, CONTEST_CATEGORY_COOL,
@ -281,7 +289,7 @@ struct Contest
/*0x11*/ u8 unk19215; /*0x11*/ u8 unk19215;
/*0x12*/ u8 unk19216; // sprite ID /*0x12*/ u8 unk19216; // sprite ID
/*0x13*/ s8 applauseLevel; /*0x13*/ s8 applauseLevel;
/*0x19218*/ u8 unk19218[CONTESTANT_COUNT]; /*0x19218*/ u8 prevTurnOrder[CONTESTANT_COUNT];
/*0x1921C*/ u32 unk1921C; // saved RNG value? /*0x1921C*/ u32 unk1921C; // saved RNG value?
u16 unk19220[5][4]; // move history? u16 unk19220[5][4]; // move history?
u8 unk19248[5][4]; // excitement history u8 unk19248[5][4]; // excitement history
@ -417,7 +425,7 @@ struct ContestResources
struct ContestStruct_field_18 *field_18; struct ContestStruct_field_18 *field_18;
struct ContestResourcesField1C * field_1c; struct ContestResourcesField1C * field_1c;
struct ContestResourcesField20 * field_20; struct ContestResourcesField20 * field_20;
u8 * field_24[4]; u8 * ContestantInfoTilemaps[CONTESTANT_COUNT];
void * field_34; void * field_34;
void * field_38; void * field_38;
void * field_3c; void * field_3c;
@ -431,7 +439,7 @@ struct ContestResources
#define eContestResources14 (*gContestResources->field_14) #define eContestResources14 (*gContestResources->field_14)
#define eUnknownHeap18000 (gHeap + 0x18000) #define eUnknownHeap18000 (gHeap + 0x18000)
#define eUnknownHeap19000 (gHeap + 0x19000) #define eUnknownHeap19000 (gHeap + 0x19000)
#define eUnknownHeap1A000 (gHeap[0x1a000]) #define eContestDebugMode (gHeap[0x1a000])
#define eUnknownHeap1A004 (*(struct Shared1A004 *)(gHeap + 0x1a004)) #define eUnknownHeap1A004 (*(struct Shared1A004 *)(gHeap + 0x1a004))
extern struct ContestPokemon gContestMons[4]; extern struct ContestPokemon gContestMons[4];
@ -460,7 +468,7 @@ extern u32 gContestRngValue;
// contest.c // contest.c
void ResetLinkContestBoolean(void); void ResetLinkContestBoolean(void);
void LoadContestBgAfterMoveAnim(void); void LoadContestBgAfterMoveAnim(void);
void sub_80D7B24(void); void CB2_ContestMain(void);
void sub_80DA8C8(u8 partyIndex); void sub_80DA8C8(u8 partyIndex);
void sub_80DAB8C(u8 contestType, u8 rank); void sub_80DAB8C(u8 contestType, u8 rank);
void sub_80DACBC(u8 contestType, u8 rank, bool32 isPostgame); void sub_80DACBC(u8 contestType, u8 rank, bool32 isPostgame);

View File

@ -2,7 +2,9 @@
#define GUARD_NEW_GAME_H #define GUARD_NEW_GAME_H
extern bool8 gDifferentSaveFile; extern bool8 gDifferentSaveFile;
extern bool8 gUnknown_020322D5; // The purpose of this variable is unknown as it's read only 3 times(2 times in contest.c and 1 time in berry_blender.c), never written to. // Shortcuts some randomness in berry_blender.c, and enables debug printing
// in contest.c.
extern bool8 gEnableContestDebugging;
void SetTrainerId(u32 trainerId, u8 *dst); void SetTrainerId(u32 trainerId, u8 *dst);
u32 GetTrainerId(u8 *trainerId); u32 GetTrainerId(u8 *trainerId);

View File

@ -2037,7 +2037,7 @@ static void sub_8081744(void)
sBerryBlenderData->field_4C--; sBerryBlenderData->field_4C--;
sBerryBlenderData->field_72 = 0; sBerryBlenderData->field_72 = 0;
} }
if (gUnknown_020322D5 && gMain.newKeys & L_BUTTON) if (gEnableContestDebugging && gMain.newKeys & L_BUTTON)
sBerryBlenderData->field_123 ^= 1; sBerryBlenderData->field_123 ^= 1;
} }

View File

@ -114,7 +114,7 @@ static void sub_80DC4F0(void);
static void CreateApplauseMeterSprite(void); static void CreateApplauseMeterSprite(void);
static void sub_80DC5E8(void); static void sub_80DC5E8(void);
static void sub_80DC7EC(void); static void sub_80DC7EC(void);
static void sub_80DCD48(void); static void ContestDebugDoPrint(void);
static void sub_80DD04C(void); static void sub_80DD04C(void);
static void ApplyNextTurnOrder(void); static void ApplyNextTurnOrder(void);
static void sub_80DDB0C(void); static void sub_80DDB0C(void);
@ -186,7 +186,7 @@ static void sub_80DEA5C(void);
static void sub_80DF250(void); static void sub_80DF250(void);
static void sub_80DF4F8(void); static void sub_80DF4F8(void);
static void sub_80DF080(u8); static void sub_80DF080(u8);
static void sub_80DF750(void); static void ContestDebugPrintBitStrings(void);
static void sub_80DF9D4(u8 *); static void sub_80DF9D4(u8 *);
static void sub_80DF9E0(u8 *, s32); static void sub_80DF9E0(u8 *, s32);
static void sub_80DB2BC(void); static void sub_80DB2BC(void);
@ -574,7 +574,7 @@ const u16 gUnknown_08587C30[] = INCBIN_U16("graphics/unknown/unknown_587C30.gbap
#include "data/contest_text_tables.h" #include "data/contest_text_tables.h"
const struct BgTemplate gUnknown_08587F34[] = static const struct BgTemplate sContestantInfoBgTemplates[] =
{ {
{ {
.bg = 0, .bg = 0,
@ -614,7 +614,7 @@ const struct BgTemplate gUnknown_08587F34[] =
} }
}; };
const struct WindowTemplate gUnknown_08587F44[] = static const struct WindowTemplate sContestWindowTemplates[] =
{ {
{ {
.bg = 0, .bg = 0,
@ -861,7 +861,7 @@ void ResetLinkContestBoolean(void)
gIsLinkContest = 0; gIsLinkContest = 0;
} }
static void sub_80D7678(void) static void SetupContestGpuRegs(void)
{ {
u16 savedIme; u16 savedIme;
@ -905,22 +905,22 @@ void LoadContestBgAfterMoveAnim(void)
} }
} }
static void sub_80D779C(void) static void InitContestInfoBgs(void)
{ {
s32 i; s32 i;
ResetBgsAndClearDma3BusyFlags(0); ResetBgsAndClearDma3BusyFlags(0);
InitBgsFromTemplates(0, gUnknown_08587F34, ARRAY_COUNT(gUnknown_08587F34)); InitBgsFromTemplates(0, sContestantInfoBgTemplates, ARRAY_COUNT(sContestantInfoBgTemplates));
SetBgAttribute(3, BG_ATTR_WRAPAROUND, 1); SetBgAttribute(3, BG_ATTR_WRAPAROUND, 1);
for (i = 0; i < 4; i++) for (i = 0; i < CONTESTANT_COUNT; i++)
{ {
SetBgTilemapBuffer(i, gContestResources->field_24[i]); SetBgTilemapBuffer(i, gContestResources->ContestantInfoTilemaps[i]);
} }
} }
static void sub_80D77E4(void) static void InitContestWindows(void)
{ {
InitWindows(gUnknown_08587F44); InitWindows(sContestWindowTemplates);
DeactivateAllTextPrinters(); DeactivateAllTextPrinters();
if (gIsLinkContest & 1) if (gIsLinkContest & 1)
{ {
@ -973,8 +973,10 @@ static void InitContestResources(void)
for (i = 0; i < CONTESTANT_COUNT; i++) for (i = 0; i < CONTESTANT_COUNT; i++)
{ {
eContestantStatus[i].nextTurnOrder = 0xFF; eContestantStatus[i].nextTurnOrder = 0xFF;
eContest.unk19218[i] = gContestantTurnOrder[i]; eContest.prevTurnOrder[i] = gContestantTurnOrder[i];
} }
// Calling this here while all the nextTurnOrder values are 0xFF will actually
// just reverse the turn order.
ApplyNextTurnOrder(); ApplyNextTurnOrder();
memset(gContestResources->field_1c, 0, sizeof(*gContestResources->field_1c) * CONTESTANT_COUNT); memset(gContestResources->field_1c, 0, sizeof(*gContestResources->field_1c) * CONTESTANT_COUNT);
} }
@ -991,15 +993,15 @@ static void AllocContestResources(void)
gContestResources->field_18 = AllocZeroed(sizeof(struct ContestStruct_field_18)); gContestResources->field_18 = AllocZeroed(sizeof(struct ContestStruct_field_18));
gContestResources->field_1c = AllocZeroed(sizeof(struct ContestResourcesField1C) * CONTESTANT_COUNT); gContestResources->field_1c = AllocZeroed(sizeof(struct ContestResourcesField1C) * CONTESTANT_COUNT);
gContestResources->field_20 = AllocZeroed(sizeof(struct ContestResourcesField20)); gContestResources->field_20 = AllocZeroed(sizeof(struct ContestResourcesField20));
gContestResources->field_24[0] = AllocZeroed(0x1000); gContestResources->ContestantInfoTilemaps[0] = AllocZeroed(0x1000);
gContestResources->field_24[1] = AllocZeroed(0x1000); gContestResources->ContestantInfoTilemaps[1] = AllocZeroed(0x1000);
gContestResources->field_24[2] = AllocZeroed(0x1000); gContestResources->ContestantInfoTilemaps[2] = AllocZeroed(0x1000);
gContestResources->field_24[3] = AllocZeroed(0x1000); gContestResources->ContestantInfoTilemaps[3] = AllocZeroed(0x1000);
gContestResources->field_34 = AllocZeroed(0x800); gContestResources->field_34 = AllocZeroed(0x800);
gContestResources->field_38 = AllocZeroed(0x800); gContestResources->field_38 = AllocZeroed(0x800);
gContestResources->field_3c = AllocZeroed(0x2000); gContestResources->field_3c = AllocZeroed(0x2000);
gUnknown_0202305C = gContestResources->field_3c; gUnknown_0202305C = gContestResources->field_3c;
gUnknown_02023060 = gContestResources->field_24[1]; gUnknown_02023060 = gContestResources->ContestantInfoTilemaps[1];
} }
static void FreeContestResources(void) static void FreeContestResources(void)
@ -1013,10 +1015,10 @@ static void FreeContestResources(void)
FREE_AND_SET_NULL(gContestResources->field_18); FREE_AND_SET_NULL(gContestResources->field_18);
FREE_AND_SET_NULL(gContestResources->field_1c); FREE_AND_SET_NULL(gContestResources->field_1c);
FREE_AND_SET_NULL(gContestResources->field_20); FREE_AND_SET_NULL(gContestResources->field_20);
FREE_AND_SET_NULL(gContestResources->field_24[0]); FREE_AND_SET_NULL(gContestResources->ContestantInfoTilemaps[0]);
FREE_AND_SET_NULL(gContestResources->field_24[1]); FREE_AND_SET_NULL(gContestResources->ContestantInfoTilemaps[1]);
FREE_AND_SET_NULL(gContestResources->field_24[2]); FREE_AND_SET_NULL(gContestResources->ContestantInfoTilemaps[2]);
FREE_AND_SET_NULL(gContestResources->field_24[3]); FREE_AND_SET_NULL(gContestResources->ContestantInfoTilemaps[3]);
FREE_AND_SET_NULL(gContestResources->field_34); FREE_AND_SET_NULL(gContestResources->field_34);
FREE_AND_SET_NULL(gContestResources->field_38); FREE_AND_SET_NULL(gContestResources->field_38);
FREE_AND_SET_NULL(gContestResources->field_3c); FREE_AND_SET_NULL(gContestResources->field_3c);
@ -1025,7 +1027,7 @@ static void FreeContestResources(void)
gUnknown_02023060 = NULL; gUnknown_02023060 = NULL;
} }
void sub_80D7B24(void) void CB2_ContestMain(void)
{ {
switch (gMain.state) switch (gMain.state)
{ {
@ -1036,9 +1038,9 @@ void sub_80D7B24(void)
FREE_AND_SET_NULL(gMonSpritesGfxPtr->firstDecompressed); FREE_AND_SET_NULL(gMonSpritesGfxPtr->firstDecompressed);
gMonSpritesGfxPtr->firstDecompressed = AllocZeroed(0x4000); gMonSpritesGfxPtr->firstDecompressed = AllocZeroed(0x4000);
SetVBlankCallback(NULL); SetVBlankCallback(NULL);
sub_80D779C(); InitContestInfoBgs();
sub_80D77E4(); InitContestWindows();
sub_80D7678(); SetupContestGpuRegs();
ScanlineEffect_Clear(); ScanlineEffect_Clear();
ResetPaletteFade(); ResetPaletteFade();
gPaletteFade.bufferTransferDisabled = TRUE; gPaletteFade.bufferTransferDisabled = TRUE;
@ -1046,7 +1048,7 @@ void sub_80D7B24(void)
ResetTasks(); ResetTasks();
FreeAllSpritePalettes(); FreeAllSpritePalettes();
gReservedSpritePaletteCount = 4; gReservedSpritePaletteCount = 4;
eUnknownHeap1A000 = 0; eContestDebugMode = CONTEST_DEBUG_MODE_OFF;
ClearBattleMonForms(); ClearBattleMonForms();
InitContestResources(); InitContestResources();
gMain.state++; gMain.state++;
@ -1181,7 +1183,7 @@ static u8 sub_80D7E44(u8 *a)
case 4: case 4:
CopyToBgTilemapBuffer(2, gUnknown_08C17170, 0, 0); CopyToBgTilemapBuffer(2, gUnknown_08C17170, 0, 0);
CopyBgTilemapBufferToVram(2); CopyBgTilemapBufferToVram(2);
DmaCopy32Defvars(3, gContestResources->field_24[2], eUnknownHeap1A004.unk18A04, 0x800); DmaCopy32Defvars(3, gContestResources->ContestantInfoTilemaps[2], eUnknownHeap1A004.unk18A04, 0x800);
break; break;
case 5: case 5:
LoadCompressedPalette(gUnknown_08C16E90, 0, 0x200); LoadCompressedPalette(gUnknown_08C16E90, 0, 0x200);
@ -1326,7 +1328,7 @@ static void sub_80D833C(u8 taskId)
{ {
gBattle_BG0_Y = 0; gBattle_BG0_Y = 0;
gBattle_BG2_Y = 0; gBattle_BG2_Y = 0;
sub_80DCD48(); ContestDebugDoPrint();
DmaCopy32Defvars(3, gPlttBufferUnfaded, eUnknownHeap1A004.unk18204, 0x400); DmaCopy32Defvars(3, gPlttBufferUnfaded, eUnknownHeap1A004.unk18204, 0x400);
ConvertIntToDecimalStringN(gStringVar1, eContest.turnNumber + 1, STR_CONV_MODE_LEFT_ALIGN, 1); ConvertIntToDecimalStringN(gStringVar1, eContest.turnNumber + 1, STR_CONV_MODE_LEFT_ALIGN, 1);
if (!Contest_IsMonsTurnDisabled(gContestPlayerMonIndex)) if (!Contest_IsMonsTurnDisabled(gContestPlayerMonIndex))
@ -1579,7 +1581,7 @@ static void sub_80D8B38(u8 taskId)
switch (gTasks[taskId].data[0]) switch (gTasks[taskId].data[0])
{ {
case 0: case 0:
sub_80DCD48(); ContestDebugDoPrint();
for (i = 0; eContest.unk19214 != gContestResources->field_8->turnOrder[i]; i++) for (i = 0; eContest.unk19214 != gContestResources->field_8->turnOrder[i]; i++)
; ;
eContest.unk19215 = i; eContest.unk19215 = i;
@ -1608,7 +1610,7 @@ static void sub_80D8B38(u8 taskId)
return; return;
case 2: case 2:
sub_80DF080(r6); sub_80DF080(r6);
sub_80DF750(); ContestDebugPrintBitStrings();
if (eContestantStatus[r6].numTurnsSkipped != 0 if (eContestantStatus[r6].numTurnsSkipped != 0
|| eContestantStatus[r6].noMoreTurns) || eContestantStatus[r6].noMoreTurns)
{ {
@ -2018,7 +2020,7 @@ static void sub_80D8B38(u8 taskId)
} }
return; return;
case 18: case 18:
sub_80DCD48(); ContestDebugDoPrint();
if (!gContestResources->field_14[r6].unk2_2) if (!gContestResources->field_14[r6].unk2_2)
{ {
gTasks[taskId].data[10] = 0; gTasks[taskId].data[10] = 0;
@ -2426,7 +2428,7 @@ static void sub_80DA3CC(u8 taskId)
{ {
gTasks[taskId].data[0] = 0; gTasks[taskId].data[0] = 0;
gTasks[taskId].func = sub_80DA464; gTasks[taskId].func = sub_80DA464;
sub_80DCD48(); ContestDebugDoPrint();
} }
} }
} }
@ -2504,7 +2506,7 @@ static void sub_80DA5E8(u8 taskId)
{ {
sub_80DF250(); sub_80DF250();
sub_80DF4F8(); sub_80DF4F8();
sub_80DF750(); ContestDebugPrintBitStrings();
} }
gContestRngValue = gRngValue; gContestRngValue = gRngValue;
StringExpandPlaceholders(gStringVar4, gText_0827D597); StringExpandPlaceholders(gStringVar4, gText_0827D597);
@ -2987,8 +2989,8 @@ bool8 IsSpeciesNotUnown(u16 species)
static void sub_80DB2BC(void) static void sub_80DB2BC(void)
{ {
CpuCopy16(gContestResources->field_24[0], gContestResources->field_24[0] + 0x500, 0x280); CpuCopy16(gContestResources->ContestantInfoTilemaps[0], gContestResources->ContestantInfoTilemaps[0] + 0x500, 0x280);
CpuCopy16(gContestResources->field_24[2], gContestResources->field_24[2] + 0x500, 0x280); CpuCopy16(gContestResources->ContestantInfoTilemaps[2], gContestResources->ContestantInfoTilemaps[2] + 0x500, 0x280);
} }
static u16 sub_80DB2EC(u16 a0, u8 a1) static u16 sub_80DB2EC(u16 a0, u8 a1)
@ -3788,7 +3790,7 @@ static void sub_80DC6A4(u8 taskId)
{ {
gTasks[eContest.unk19211].data[r4 * 4 + 0] = 0xFF; gTasks[eContest.unk19211].data[r4 * 4 + 0] = 0xFF;
gTasks[eContest.unk19211].data[r4 * 4 + 1] = 0; gTasks[eContest.unk19211].data[r4 * 4 + 1] = 0;
BlendPalette((eContest.unk19218[r4] + 5) * 16 + 6, 2, 0, RGB(31, 31, 18)); BlendPalette((eContest.prevTurnOrder[r4] + 5) * 16 + 6, 2, 0, RGB(31, 31, 18));
DestroyTask(taskId); DestroyTask(taskId);
} }
} }
@ -3813,7 +3815,7 @@ static void sub_80DC728(u8 taskId)
gTasks[taskId].data[r3 + 1] ^= 1; gTasks[taskId].data[r3 + 1] ^= 1;
BlendPalette( BlendPalette(
(eContest.unk19218[i] + 5) * 16 + 6, (eContest.prevTurnOrder[i] + 5) * 16 + 6,
2, 2,
gTasks[taskId].data[r3 + 0], gTasks[taskId].data[r3 + 0],
RGB(31, 31, 18)); RGB(31, 31, 18));
@ -4006,45 +4008,45 @@ static void sub_80DCCD8(struct Sprite *sprite)
} }
// Unused. // Unused.
static void sub_80DCD08(void) static void ContestDebugTogglePointTotal(void)
{ {
if(eUnknownHeap1A000 == 1) if(eContestDebugMode == CONTEST_DEBUG_MODE_PRINT_POINT_TOTAL)
eUnknownHeap1A000 = 0; eContestDebugMode = CONTEST_DEBUG_MODE_OFF;
else else
eUnknownHeap1A000 = 1; eContestDebugMode = CONTEST_DEBUG_MODE_PRINT_POINT_TOTAL;
if(eUnknownHeap1A000 == 0) if(eContestDebugMode == CONTEST_DEBUG_MODE_OFF)
{ {
sub_80DAEA4(); sub_80DAEA4();
sub_80DB2BC(); sub_80DB2BC();
} }
else else
{ {
sub_80DCD48(); ContestDebugDoPrint();
} }
} }
static void sub_80DCD48(void) static void ContestDebugDoPrint(void)
{ {
u8 i; u8 i;
s16 value; s16 value;
u8 *txtPtr; u8 *txtPtr;
u8 text[8]; u8 text[8];
if (gUnknown_020322D5 == 0) if (!gEnableContestDebugging)
return; return;
switch (eUnknownHeap1A000) switch (eContestDebugMode)
{ {
case 0: case CONTEST_DEBUG_MODE_OFF:
break; break;
case 2: case CONTEST_DEBUG_MODE_PRINT_UNK_C:
case 3: case CONTEST_DEBUG_MODE_PRINT_UNK_D:
sub_80DF750(); ContestDebugPrintBitStrings();
break; break;
// The only other possible value is 1, which is only set by sub_80DCD08, which is unused. // The only other possible value is 1, which is only set by ContestDebugTogglePointTotal.
// So this code is unreachable. //
// case 1: // case CONTEST_DEBUG_MODE_PRINT_POINT_TOTAL:
default: default:
for (i = 0; i < 4; i++) for (i = 0; i < 4; i++)
FillWindowPixelBuffer(i, PIXEL_FILL(0)); FillWindowPixelBuffer(i, PIXEL_FILL(0));
@ -4842,7 +4844,7 @@ static void sub_80DE224(void)
SetGpuReg(REG_OFFSET_BG1HOFS, gBattle_BG1_X); SetGpuReg(REG_OFFSET_BG1HOFS, gBattle_BG1_X);
SetGpuReg(REG_OFFSET_BG1VOFS, gBattle_BG1_Y); SetGpuReg(REG_OFFSET_BG1VOFS, gBattle_BG1_Y);
CpuFill32(0, gContestResources->field_24[1], 0x1000); CpuFill32(0, gContestResources->ContestantInfoTilemaps[1], 0x1000);
CopyToBgTilemapBuffer(1, gUnknown_08C17980, 0, 0); CopyToBgTilemapBuffer(1, gUnknown_08C17980, 0, 0);
Contest_SetBgCopyFlags(1); Contest_SetBgCopyFlags(1);
@ -4860,7 +4862,7 @@ static void sub_80DE350(void)
u16 bg1Cnt; u16 bg1Cnt;
RequestDma3Fill(0,(void *)(BG_CHAR_ADDR(2)), 0x2000, 0x1); RequestDma3Fill(0,(void *)(BG_CHAR_ADDR(2)), 0x2000, 0x1);
CpuFill32(0, gContestResources->field_24[1], 0x1000); CpuFill32(0, gContestResources->ContestantInfoTilemaps[1], 0x1000);
Contest_SetBgCopyFlags(1); Contest_SetBgCopyFlags(1);
bg1Cnt = GetGpuReg(REG_OFFSET_BG1CNT); bg1Cnt = GetGpuReg(REG_OFFSET_BG1CNT);
((vBgCnt *) &bg1Cnt)->priority = 1; ((vBgCnt *) &bg1Cnt)->priority = 1;
@ -4909,7 +4911,7 @@ static void sub_80DE4A8(u8 taskId)
{ {
case 0: case 0:
for (i = 0; i < 4; i++) for (i = 0; i < 4; i++)
eContest.unk19218[i] = gContestantTurnOrder[i]; eContest.prevTurnOrder[i] = gContestantTurnOrder[i];
sub_80DBF90(); sub_80DBF90();
sub_80DC864(); sub_80DC864();
sub_80DB69C(); sub_80DB69C();
@ -5645,32 +5647,32 @@ static void sub_80DF4F8(void)
} }
// Unused // Unused
void sub_80DF704(u8 arg0) void ContestDebugToggleBitfields(bool8 showUnkD)
{ {
if (eUnknownHeap1A000 == 0) if (eContestDebugMode == CONTEST_DEBUG_MODE_OFF)
{ {
if (arg0 == 0) if (!showUnkD)
eUnknownHeap1A000 = 2; eContestDebugMode = CONTEST_DEBUG_MODE_PRINT_UNK_C;
else else
eUnknownHeap1A000 = 3; eContestDebugMode = CONTEST_DEBUG_MODE_PRINT_UNK_D;
} }
else else
{ {
eUnknownHeap1A000 = 0; eContestDebugMode = CONTEST_DEBUG_MODE_OFF;
} }
if (eUnknownHeap1A000 == 0) if (eContestDebugMode == CONTEST_DEBUG_MODE_OFF)
{ {
sub_80DAEA4(); sub_80DAEA4();
sub_80DB2BC(); sub_80DB2BC();
} }
else else
{ {
sub_80DF750(); ContestDebugPrintBitStrings();
} }
} }
static void sub_80DF750(void) static void ContestDebugPrintBitStrings(void)
{ {
u8 i; u8 i;
s8 j; s8 j;
@ -5679,17 +5681,18 @@ static void sub_80DF750(void)
u8 *txtPtr; u8 *txtPtr;
u32 bits; u32 bits;
if (gUnknown_020322D5 == 0) if (!gEnableContestDebugging)
return; return;
if (eUnknownHeap1A000 != 2 && eUnknownHeap1A000 != 3)
if (eContestDebugMode != CONTEST_DEBUG_MODE_PRINT_UNK_C && eContestDebugMode != CONTEST_DEBUG_MODE_PRINT_UNK_D)
return; return;
for (i = 0; i < 4; i++) for (i = 0; i < CONTESTANT_COUNT; i++)
FillWindowPixelBuffer(i, PIXEL_FILL(0)); FillWindowPixelBuffer(i, PIXEL_FILL(0));
if (eUnknownHeap1A000 == 2) if (eContestDebugMode == CONTEST_DEBUG_MODE_PRINT_UNK_C)
{ {
for (i = 0; i < 4; i++) for (i = 0; i < CONTESTANT_COUNT; i++)
{ {
txtPtr = StringCopy(text1, gText_CDot); txtPtr = StringCopy(text1, gText_CDot);
Contest_PrintTextToBg0WindowAt(gContestantTurnOrder[i], text1, 5, 1, 7); Contest_PrintTextToBg0WindowAt(gContestantTurnOrder[i], text1, 5, 1, 7);
@ -5710,7 +5713,7 @@ static void sub_80DF750(void)
} }
else else
{ {
for (i = 0; i < 4; i++) for (i = 0; i < CONTESTANT_COUNT; i++)
{ {
StringCopy(text1, gText_BDot); StringCopy(text1, gText_BDot);
bits = gContestResources->field_1c[i].unkD; bits = gContestResources->field_1c[i].unkD;

View File

@ -2830,7 +2830,7 @@ void sub_80F8390(void)
void sub_80F83D0(void) void sub_80F83D0(void)
{ {
SetMainCallback2(sub_80D7B24); SetMainCallback2(CB2_ContestMain);
} }
static void sub_80F83E0(u8 taskId) static void sub_80F83E0(u8 taskId)

View File

@ -56,7 +56,7 @@ static void ResetMiniGamesResults(void);
// EWRAM vars // EWRAM vars
EWRAM_DATA bool8 gDifferentSaveFile = FALSE; EWRAM_DATA bool8 gDifferentSaveFile = FALSE;
EWRAM_DATA bool8 gUnknown_020322D5 = FALSE; EWRAM_DATA bool8 gEnableContestDebugging = FALSE;
// const rom data // const rom data
static const struct ContestWinner sContestWinnerPicDummy = static const struct ContestWinner sContestWinnerPicDummy =