Misc missing constant use

This commit is contained in:
GriffinR 2023-08-10 01:21:38 -04:00
parent da238562f0
commit 18319e8da3
22 changed files with 254 additions and 218 deletions

View File

@ -6,6 +6,8 @@
#define CONTEST_LAST_APPEAL (CONTEST_NUM_APPEALS - 1) #define CONTEST_LAST_APPEAL (CONTEST_NUM_APPEALS - 1)
#define MAX_CONTEST_MOVE_HEARTS 8 #define MAX_CONTEST_MOVE_HEARTS 8
#define CONTESTANT_NONE 0xFF
#define LINK_CONTEST_FLAG_IS_LINK (1 << 0) #define LINK_CONTEST_FLAG_IS_LINK (1 << 0)
#define LINK_CONTEST_FLAG_IS_WIRELESS (1 << 1) #define LINK_CONTEST_FLAG_IS_WIRELESS (1 << 1)
#define LINK_CONTEST_FLAG_HAS_RS_PLAYER (1 << 2) #define LINK_CONTEST_FLAG_HAS_RS_PLAYER (1 << 2)

View File

@ -13,16 +13,13 @@
#include "constants/abilities.h" #include "constants/abilities.h"
#include "constants/battle_ai.h" #include "constants/battle_ai.h"
#include "constants/battle_move_effects.h" #include "constants/battle_move_effects.h"
#include "constants/items.h"
#include "constants/moves.h" #include "constants/moves.h"
#define AI_ACTION_DONE 0x0001 #define AI_ACTION_DONE (1 << 0)
#define AI_ACTION_FLEE 0x0002 #define AI_ACTION_FLEE (1 << 1)
#define AI_ACTION_WATCH 0x0004 #define AI_ACTION_WATCH (1 << 2)
#define AI_ACTION_DO_NOT_ATTACK 0x0008 #define AI_ACTION_DO_NOT_ATTACK (1 << 3)
#define AI_ACTION_UNK5 0x0010
#define AI_ACTION_UNK6 0x0020
#define AI_ACTION_UNK7 0x0040
#define AI_ACTION_UNK8 0x0080
#define AI_THINKING_STRUCT ((struct AI_ThinkingStruct *)(gBattleResources->ai)) #define AI_THINKING_STRUCT ((struct AI_ThinkingStruct *)(gBattleResources->ai))
#define BATTLE_HISTORY ((struct BattleHistory *)(gBattleResources->battleHistory)) #define BATTLE_HISTORY ((struct BattleHistory *)(gBattleResources->battleHistory))
@ -283,7 +280,6 @@ static const u16 sIgnoredPowerfulMoveEffects[] =
IGNORED_MOVES_END IGNORED_MOVES_END
}; };
// code
void BattleAI_HandleItemUseBeforeAISetup(u8 defaultScoreMoves) void BattleAI_HandleItemUseBeforeAISetup(u8 defaultScoreMoves)
{ {
s32 i; s32 i;
@ -302,7 +298,7 @@ void BattleAI_HandleItemUseBeforeAISetup(u8 defaultScoreMoves)
{ {
for (i = 0; i < MAX_TRAINER_ITEMS; i++) for (i = 0; i < MAX_TRAINER_ITEMS; i++)
{ {
if (gTrainers[gTrainerBattleOpponent_A].items[i] != 0) if (gTrainers[gTrainerBattleOpponent_A].items[i] != ITEM_NONE)
{ {
BATTLE_HISTORY->trainerItems[BATTLE_HISTORY->itemsNo] = gTrainers[gTrainerBattleOpponent_A].items[i]; BATTLE_HISTORY->trainerItems[BATTLE_HISTORY->itemsNo] = gTrainers[gTrainerBattleOpponent_A].items[i];
BATTLE_HISTORY->itemsNo++; BATTLE_HISTORY->itemsNo++;

View File

@ -687,7 +687,7 @@ u8 GetMostSuitableMonToSwitchInto(void)
invalidMons = 0; invalidMons = 0;
while (invalidMons != 0x3F) // All mons are invalid. while (invalidMons != (1 << PARTY_SIZE) - 1) // All mons are invalid.
{ {
bestDmg = TYPE_MUL_NO_EFFECT; bestDmg = TYPE_MUL_NO_EFFECT;
bestMonId = PARTY_SIZE; bestMonId = PARTY_SIZE;
@ -741,7 +741,7 @@ u8 GetMostSuitableMonToSwitchInto(void)
} }
else else
{ {
invalidMons = 0x3F; // No viable mon to switch. invalidMons = (1 << PARTY_SIZE) - 1; // No viable mon to switch.
} }
} }
@ -862,7 +862,7 @@ static bool8 ShouldUseItem(void)
shouldUse = TRUE; shouldUse = TRUE;
break; break;
case AI_ITEM_HEAL_HP: case AI_ITEM_HEAL_HP:
paramOffset = GetItemEffectParamOffset(item, 4, 4); paramOffset = GetItemEffectParamOffset(item, 4, ITEM4_HEAL_HP);
if (paramOffset == 0) if (paramOffset == 0)
break; break;
if (gBattleMons[gActiveBattler].hp == 0) if (gBattleMons[gActiveBattler].hp == 0)
@ -935,7 +935,7 @@ static bool8 ShouldUseItem(void)
{ {
BtlController_EmitTwoReturnValues(BUFFER_B, B_ACTION_USE_ITEM, 0); BtlController_EmitTwoReturnValues(BUFFER_B, B_ACTION_USE_ITEM, 0);
*(gBattleStruct->chosenItem + (gActiveBattler / 2) * 2) = item; *(gBattleStruct->chosenItem + (gActiveBattler / 2) * 2) = item;
gBattleResources->battleHistory->trainerItems[i] = 0; gBattleResources->battleHistory->trainerItems[i] = ITEM_NONE;
return shouldUse; return shouldUse;
} }
} }

View File

@ -7812,9 +7812,18 @@ static void Cmd_metronome(void)
{ {
s32 i; s32 i;
#if MOVES_COUNT < 512
// Original GF method of move selection is to pick a random
// number between 1-511. 355-511 are not valid moves, so if it
// picks in this range it retries. If MOVES_COUNT exceeds 511 we
// instead use a simpler solution.
gCurrentMove = (Random() & 0x1FF) + 1; gCurrentMove = (Random() & 0x1FF) + 1;
if (gCurrentMove >= MOVES_COUNT) if (gCurrentMove >= MOVES_COUNT)
continue; continue;
#else
// Just pick a valid move value (between 1 and MOVES_COUNT-1)
gCurrentMove = (Random() % (MOVES_COUNT - 1)) + 1;
#endif
for (i = 0; i < MAX_MON_MOVES; i++); // ? for (i = 0; i < MAX_MON_MOVES; i++); // ?

View File

@ -342,7 +342,11 @@ void HandleAction_UseItem(void)
gBattleCommunication[MULTISTRING_CHOOSER] = AI_HEAL_CONFUSION; gBattleCommunication[MULTISTRING_CHOOSER] = AI_HEAL_CONFUSION;
if (*(gBattleStruct->AI_itemFlags + gBattlerAttacker / 2) & (1 << AI_HEAL_CONFUSION)) if (*(gBattleStruct->AI_itemFlags + gBattlerAttacker / 2) & (1 << AI_HEAL_CONFUSION))
{ {
if (*(gBattleStruct->AI_itemFlags + gBattlerAttacker / 2) & 0x3E) if (*(gBattleStruct->AI_itemFlags + gBattlerAttacker / 2) & ((1 << AI_HEAL_PARALYSIS)
| (1 << AI_HEAL_FREEZE)
| (1 << AI_HEAL_BURN)
| (1 << AI_HEAL_POISON)
| (1 << AI_HEAL_SLEEP)))
gBattleCommunication[MULTISTRING_CHOOSER] = AI_HEAL_SLEEP; gBattleCommunication[MULTISTRING_CHOOSER] = AI_HEAL_SLEEP;
} }
else else

View File

@ -310,6 +310,8 @@ static void HandleInitBackgrounds(void)
ShowBg(3); ShowBg(3);
} }
#define BG_TILE 0x42
static bool8 LoadBerryTagGfx(void) static bool8 LoadBerryTagGfx(void)
{ {
u16 i; u16 i;
@ -333,15 +335,16 @@ static bool8 LoadBerryTagGfx(void)
sBerryTag->gfxState++; sBerryTag->gfxState++;
break; break;
case 3: case 3:
// Palette of the bg tiles changes depending on the player's gender
if (gSaveBlock2Ptr->playerGender == MALE) if (gSaveBlock2Ptr->playerGender == MALE)
{ {
for (i = 0; i < ARRAY_COUNT(sBerryTag->tilemapBuffers[1]); i++) for (i = 0; i < ARRAY_COUNT(sBerryTag->tilemapBuffers[1]); i++)
sBerryTag->tilemapBuffers[1][i] = 0x4042; sBerryTag->tilemapBuffers[1][i] = (4 << 12) | BG_TILE;
} }
else else
{ {
for (i = 0; i < ARRAY_COUNT(sBerryTag->tilemapBuffers[1]); i++) for (i = 0; i < ARRAY_COUNT(sBerryTag->tilemapBuffers[1]); i++)
sBerryTag->tilemapBuffers[1][i] = 0x5042; sBerryTag->tilemapBuffers[1][i] = (5 << 12) | BG_TILE;
} }
sBerryTag->gfxState++; sBerryTag->gfxState++;
break; break;
@ -545,6 +548,9 @@ static void Task_HandleInput(u8 taskId)
} }
} }
#define tBerryY data[0]
#define tBgOp data[1]
static void TryChangeDisplayedBerry(u8 taskId, s8 toMove) static void TryChangeDisplayedBerry(u8 taskId, s8 toMove)
{ {
s16 *data = gTasks[taskId].data; s16 *data = gTasks[taskId].data;
@ -553,11 +559,11 @@ static void TryChangeDisplayedBerry(u8 taskId, s8 toMove)
if (newPocketPosition < ITEM_TO_BERRY(MAX_BERRY_INDEX) && BagGetItemIdByPocketPosition(POCKET_BERRIES, newPocketPosition) != ITEM_NONE) if (newPocketPosition < ITEM_TO_BERRY(MAX_BERRY_INDEX) && BagGetItemIdByPocketPosition(POCKET_BERRIES, newPocketPosition) != ITEM_NONE)
{ {
if (toMove < 0) if (toMove < 0)
data[1] = 2; tBgOp = BG_COORD_SUB;
else else
data[1] = 1; tBgOp = BG_COORD_ADD;
data[0] = 0; tBerryY = 0;
PlaySE(SE_SELECT); PlaySE(SE_SELECT);
HandleBagCursorPositionChange(toMove); HandleBagCursorPositionChange(toMove);
gTasks[taskId].func = Task_DisplayAnotherBerry; gTasks[taskId].func = Task_DisplayAnotherBerry;
@ -586,101 +592,103 @@ static void HandleBagCursorPositionChange(s8 toMove)
sBerryTag->berryId = ItemIdToBerryType(BagGetItemIdByPocketPosition(POCKET_BERRIES, *scrollPos + *cursorPos)); sBerryTag->berryId = ItemIdToBerryType(BagGetItemIdByPocketPosition(POCKET_BERRIES, *scrollPos + *cursorPos));
} }
#define DISPLAY_SPEED 16
static void Task_DisplayAnotherBerry(u8 taskId) static void Task_DisplayAnotherBerry(u8 taskId)
{ {
u16 i; u16 i;
s16 posY; s16 y;
s16 *data = gTasks[taskId].data; s16 *data = gTasks[taskId].data;
data[0] += 0x10; tBerryY += DISPLAY_SPEED;
data[0] &= 0xFF; tBerryY &= 0xFF;
if (data[1] == 1) if (tBgOp == BG_COORD_ADD)
{ {
switch (data[0]) switch (tBerryY)
{ {
case 0x30: case 3 * DISPLAY_SPEED:
FillWindowPixelBuffer(WIN_BERRY_NAME, PIXEL_FILL(0)); FillWindowPixelBuffer(WIN_BERRY_NAME, PIXEL_FILL(0));
break; break;
case 0x40: case 4 * DISPLAY_SPEED:
PrintBerryNumberAndName(); PrintBerryNumberAndName();
break; break;
case 0x50: case 5 * DISPLAY_SPEED:
DestroyBerrySprite(); DestroyBerrySprite();
CreateBerrySprite(); CreateBerrySprite();
break; break;
case 0x60: case 6 * DISPLAY_SPEED:
FillWindowPixelBuffer(WIN_SIZE_FIRM, PIXEL_FILL(0)); FillWindowPixelBuffer(WIN_SIZE_FIRM, PIXEL_FILL(0));
break; break;
case 0x70: case 7 * DISPLAY_SPEED:
PrintBerrySize(); PrintBerrySize();
break; break;
case 0x80: case 8 * DISPLAY_SPEED:
PrintBerryFirmness(); PrintBerryFirmness();
break; break;
case 0x90: case 9 * DISPLAY_SPEED:
SetFlavorCirclesVisiblity(); SetFlavorCirclesVisiblity();
break; break;
case 0xA0: case 10 * DISPLAY_SPEED:
FillWindowPixelBuffer(WIN_DESC, PIXEL_FILL(0)); FillWindowPixelBuffer(WIN_DESC, PIXEL_FILL(0));
break; break;
case 0xB0: case 11 * DISPLAY_SPEED:
PrintBerryDescription1(); PrintBerryDescription1();
break; break;
case 0xC0: case 12 * DISPLAY_SPEED:
PrintBerryDescription2(); PrintBerryDescription2();
break; break;
} }
} }
else else // BG_COORD_SUB
{ {
switch (data[0]) switch (tBerryY)
{ {
case 0x30: case 3 * DISPLAY_SPEED:
FillWindowPixelBuffer(WIN_DESC, PIXEL_FILL(0)); FillWindowPixelBuffer(WIN_DESC, PIXEL_FILL(0));
break; break;
case 0x40: case 4 * DISPLAY_SPEED:
PrintBerryDescription2(); PrintBerryDescription2();
break; break;
case 0x50: case 5 * DISPLAY_SPEED:
PrintBerryDescription1(); PrintBerryDescription1();
break; break;
case 0x60: case 6 * DISPLAY_SPEED:
SetFlavorCirclesVisiblity(); SetFlavorCirclesVisiblity();
break; break;
case 0x70: case 7 * DISPLAY_SPEED:
FillWindowPixelBuffer(WIN_SIZE_FIRM, PIXEL_FILL(0)); FillWindowPixelBuffer(WIN_SIZE_FIRM, PIXEL_FILL(0));
break; break;
case 0x80: case 8 * DISPLAY_SPEED:
PrintBerryFirmness(); PrintBerryFirmness();
break; break;
case 0x90: case 9 * DISPLAY_SPEED:
PrintBerrySize(); PrintBerrySize();
break; break;
case 0xA0: case 10 * DISPLAY_SPEED:
DestroyBerrySprite(); DestroyBerrySprite();
CreateBerrySprite(); CreateBerrySprite();
break; break;
case 0xB0: case 11 * DISPLAY_SPEED:
FillWindowPixelBuffer(WIN_BERRY_NAME, PIXEL_FILL(0)); FillWindowPixelBuffer(WIN_BERRY_NAME, PIXEL_FILL(0));
break; break;
case 0xC0: case 12 * DISPLAY_SPEED:
PrintBerryNumberAndName(); PrintBerryNumberAndName();
break; break;
} }
} }
if (data[1] == 1) if (tBgOp == BG_COORD_ADD)
posY = -data[0]; y = -tBerryY;
else else
posY = data[0]; y = tBerryY;
gSprites[sBerryTag->berrySpriteId].y2 = posY; gSprites[sBerryTag->berrySpriteId].y2 = y;
for (i = 0; i < FLAVOR_COUNT; i++) for (i = 0; i < FLAVOR_COUNT; i++)
gSprites[sBerryTag->flavorCircleIds[i]].y2 = posY; gSprites[sBerryTag->flavorCircleIds[i]].y2 = y;
ChangeBgY(1, 0x1000, data[1]); ChangeBgY(1, 0x1000, tBgOp);
ChangeBgY(2, 0x1000, data[1]); ChangeBgY(2, 0x1000, tBgOp);
if (data[0] == 0) if (tBerryY == 0)
gTasks[taskId].func = Task_HandleInput; gTasks[taskId].func = Task_HandleInput;
} }

View File

@ -725,7 +725,7 @@ void TryContestEModeLinkup(void)
u8 CreateTask_ReestablishCableClubLink(void) u8 CreateTask_ReestablishCableClubLink(void)
{ {
if (FuncIsActiveTask(Task_ReestablishLink) != FALSE) if (FuncIsActiveTask(Task_ReestablishLink) != FALSE)
return 0xFF; return TASK_NONE;
switch (gSpecialVar_0x8004) switch (gSpecialVar_0x8004)
{ {

View File

@ -1112,10 +1112,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 = CONTESTANT_NONE;
eContest.prevTurnOrder[i] = gContestantTurnOrder[i]; eContest.prevTurnOrder[i] = gContestantTurnOrder[i];
} }
// Calling this here while all the nextTurnOrder values are 0xFF will actually // Calling this here while all the nextTurnOrder values are CONTESTANT_NONE will actually
// just reverse the turn order. // just reverse the turn order.
ApplyNextTurnOrder(); ApplyNextTurnOrder();
memset(gContestResources->tv, 0, sizeof(*gContestResources->tv) * CONTESTANT_COUNT); memset(gContestResources->tv, 0, sizeof(*gContestResources->tv) * CONTESTANT_COUNT);
@ -2891,7 +2891,7 @@ void SetContestants(u8 contestType, u8 rank)
opponents[opponentsCount++] = i; opponents[opponentsCount++] = i;
} }
} }
opponents[opponentsCount] = 0xFF; opponents[opponentsCount] = CONTESTANT_NONE;
// Choose three random opponents from the list // Choose three random opponents from the list
for (i = 0; i < CONTESTANT_COUNT - 1; i++) for (i = 0; i < CONTESTANT_COUNT - 1; i++)
@ -2900,7 +2900,7 @@ void SetContestants(u8 contestType, u8 rank)
s32 j; s32 j;
gContestMons[i] = gContestOpponents[opponents[rnd]]; gContestMons[i] = gContestOpponents[opponents[rnd]];
for (j = rnd; opponents[j] != 0xFF; j++) for (j = rnd; opponents[j] != CONTESTANT_NONE; j++)
opponents[j] = opponents[j + 1]; opponents[j] = opponents[j + 1];
opponentsCount--; opponentsCount--;
} }
@ -2940,7 +2940,7 @@ void SetLinkAIContestants(u8 contestType, u8 rank, bool32 isPostgame)
|| (contestType == CONTEST_CATEGORY_TOUGH && gContestOpponents[i].aiPool_Tough)) || (contestType == CONTEST_CATEGORY_TOUGH && gContestOpponents[i].aiPool_Tough))
opponents[opponentsCount++] = i; opponents[opponentsCount++] = i;
} }
opponents[opponentsCount] = 0xFF; opponents[opponentsCount] = CONTESTANT_NONE;
// Fill remaining contestant slots with random AI opponents from the list // Fill remaining contestant slots with random AI opponents from the list
for (i = 0; i < CONTESTANT_COUNT - gNumLinkContestPlayers; i++) for (i = 0; i < CONTESTANT_COUNT - gNumLinkContestPlayers; i++)
@ -2950,7 +2950,7 @@ void SetLinkAIContestants(u8 contestType, u8 rank, bool32 isPostgame)
gContestMons[gNumLinkContestPlayers + i] = gContestOpponents[opponents[rnd]]; gContestMons[gNumLinkContestPlayers + i] = gContestOpponents[opponents[rnd]];
StripPlayerNameForLinkContest(gContestMons[gNumLinkContestPlayers + i].trainerName); StripPlayerNameForLinkContest(gContestMons[gNumLinkContestPlayers + i].trainerName);
StripMonNameForLinkContest(gContestMons[gNumLinkContestPlayers + i].nickname, GAME_LANGUAGE); StripMonNameForLinkContest(gContestMons[gNumLinkContestPlayers + i].nickname, GAME_LANGUAGE);
for (j = rnd; opponents[j] != 0xFF; j++) for (j = rnd; opponents[j] != CONTESTANT_NONE; j++)
opponents[j] = opponents[j + 1]; opponents[j] = opponents[j + 1];
opponentsCount--; opponentsCount--;
} }
@ -4370,7 +4370,7 @@ void SortContestants(bool8 useRanking)
// Note that ranking is calculated so that shared places still take up a ranking // Note that ranking is calculated so that shared places still take up a ranking
// space. A ranking like [1, 2, 2, 3] is not possible; it would be [1, 2, 2, 4] // space. A ranking like [1, 2, 2, 3] is not possible; it would be [1, 2, 2, 4]
// instead. // instead.
memset(scratch, 0xFF, sizeof(scratch)); memset(scratch, CONTESTANT_NONE, sizeof(scratch));
for (i = 0; i < CONTESTANT_COUNT; i++) for (i = 0; i < CONTESTANT_COUNT; i++)
{ {
u8 j = eContestantStatus[i].ranking; u8 j = eContestantStatus[i].ranking;
@ -4378,7 +4378,7 @@ void SortContestants(bool8 useRanking)
while (1) while (1)
{ {
u8 *ptr = &scratch[j]; u8 *ptr = &scratch[j];
if (*ptr == 0xFF) if (*ptr == CONTESTANT_NONE)
{ {
*ptr = i; *ptr = i;
gContestantTurnOrder[i] = j; gContestantTurnOrder[i] = j;
@ -4636,7 +4636,7 @@ static void ApplyNextTurnOrder(void)
// First, look for the first unassigned contestant. // First, look for the first unassigned contestant.
for (j = 0; j < CONTESTANT_COUNT; j++) for (j = 0; j < CONTESTANT_COUNT; j++)
{ {
if (!isContestantOrdered[j] && eContestantStatus[j].nextTurnOrder == 0xFF) if (!isContestantOrdered[j] && eContestantStatus[j].nextTurnOrder == CONTESTANT_NONE)
{ {
nextContestant = j; nextContestant = j;
j++; j++;
@ -4647,7 +4647,7 @@ static void ApplyNextTurnOrder(void)
// Then, look for a better candidate, with a higher turn order. // Then, look for a better candidate, with a higher turn order.
for (; j < CONTESTANT_COUNT; j++) for (; j < CONTESTANT_COUNT; j++)
{ {
if (!isContestantOrdered[j] && eContestantStatus[j].nextTurnOrder == 0xFF if (!isContestantOrdered[j] && eContestantStatus[j].nextTurnOrder == CONTESTANT_NONE
&& gContestantTurnOrder[nextContestant] > gContestantTurnOrder[j]) && gContestantTurnOrder[nextContestant] > gContestantTurnOrder[j])
nextContestant = j; nextContestant = j;
} }
@ -4661,7 +4661,7 @@ static void ApplyNextTurnOrder(void)
for (i = 0; i < CONTESTANT_COUNT; i++) for (i = 0; i < CONTESTANT_COUNT; i++)
{ {
eContestAppealResults.turnOrder[i] = newTurnOrder[i]; eContestAppealResults.turnOrder[i] = newTurnOrder[i];
eContestantStatus[i].nextTurnOrder = 0xFF; eContestantStatus[i].nextTurnOrder = CONTESTANT_NONE;
eContestantStatus[i].turnOrderMod = 0; eContestantStatus[i].turnOrderMod = 0;
gContestantTurnOrder[i] = newTurnOrder[i]; gContestantTurnOrder[i] = newTurnOrder[i];
} }

View File

@ -6,6 +6,8 @@
#include "contest_effect.h" #include "contest_effect.h"
#include "constants/moves.h" #include "constants/moves.h"
#define AI_ACTION_DONE (1 << 0)
extern const u8 *gAIScriptPtr; extern const u8 *gAIScriptPtr;
extern const u8 *gContestAI_ScriptsTable[]; extern const u8 *gContestAI_ScriptsTable[];
@ -362,9 +364,9 @@ static void ContestAI_DoAIProcessing(void)
else else
{ {
eContestAI.moveScores[eContestAI.nextMoveIndex] = 0; // don't consider a move that doesn't exist. eContestAI.moveScores[eContestAI.nextMoveIndex] = 0; // don't consider a move that doesn't exist.
eContestAI.aiAction |= 1; eContestAI.aiAction |= AI_ACTION_DONE;
} }
if (eContestAI.aiAction & 1) if (eContestAI.aiAction & AI_ACTION_DONE)
{ {
eContestAI.nextMoveIndex++; eContestAI.nextMoveIndex++;
if (eContestAI.nextMoveIndex < MAX_MON_MOVES) if (eContestAI.nextMoveIndex < MAX_MON_MOVES)
@ -372,7 +374,7 @@ static void ContestAI_DoAIProcessing(void)
else else
// aiState = CONTESTAI_FINISHED // aiState = CONTESTAI_FINISHED
eContestAI.aiState++; eContestAI.aiState++;
eContestAI.aiAction &= 0xFE; // TODO: Define action flags eContestAI.aiAction &= ~AI_ACTION_DONE;
} }
break; break;
} }
@ -1667,7 +1669,7 @@ static void ContestAICmd_call(void)
static void ContestAICmd_end(void) static void ContestAICmd_end(void)
{ {
if (!AIStackPop()) if (!AIStackPop())
eContestAI.aiAction |= 1; eContestAI.aiAction |= AI_ACTION_DONE;
} }
static void AIStackPushVar(const u8 *ptr) static void AIStackPushVar(const u8 *ptr)

View File

@ -147,7 +147,7 @@ static void ContestEffect_StartleFrontMon(void)
break; break;
} }
eContestAppealResults.jamQueue[0] = i; eContestAppealResults.jamQueue[0] = i;
eContestAppealResults.jamQueue[1] = 0xFF; eContestAppealResults.jamQueue[1] = CONTESTANT_NONE;
idx = WasAtLeastOneOpponentJammed(); idx = WasAtLeastOneOpponentJammed();
} }
if (idx == 0) if (idx == 0)
@ -171,7 +171,7 @@ static void ContestEffect_StartlePrevMons(void)
eContestAppealResults.jamQueue[j++] = i; eContestAppealResults.jamQueue[j++] = i;
} }
eContestAppealResults.jamQueue[j] = 0xFF; eContestAppealResults.jamQueue[j] = CONTESTANT_NONE;
idx = WasAtLeastOneOpponentJammed(); idx = WasAtLeastOneOpponentJammed();
} }
if (idx == 0) if (idx == 0)
@ -214,7 +214,7 @@ static void ContestEffect_StartlePrevMons2(void)
u8 rval, jam; u8 rval, jam;
eContestAppealResults.jamQueue[0] = i; eContestAppealResults.jamQueue[0] = i;
eContestAppealResults.jamQueue[1] = 0xFF; eContestAppealResults.jamQueue[1] = CONTESTANT_NONE;
rval = Random() % 10; rval = Random() % 10;
if (rval == 0) if (rval == 0)
@ -291,7 +291,7 @@ static void ContestEffect_StartleMonWithJudgesAttention(void)
else else
eContestAppealResults.jam = 10; eContestAppealResults.jam = 10;
eContestAppealResults.jamQueue[0] = i; eContestAppealResults.jamQueue[0] = i;
eContestAppealResults.jamQueue[1] = 0xFF; eContestAppealResults.jamQueue[1] = CONTESTANT_NONE;
if (WasAtLeastOneOpponentJammed()) if (WasAtLeastOneOpponentJammed())
numStartled++; numStartled++;
} }
@ -396,7 +396,7 @@ static void ContestEffect_MakeFollowingMonsNervous(void)
s16 oddsMod[CONTESTANT_COUNT]; s16 oddsMod[CONTESTANT_COUNT];
s16 odds[CONTESTANT_COUNT]; s16 odds[CONTESTANT_COUNT];
memset(contestantIds, 0xFF, ARRAY_COUNT(contestantIds)); memset(contestantIds, CONTESTANT_NONE, ARRAY_COUNT(contestantIds));
for (i = 0, numAfter = 0; i < CONTESTANT_COUNT; i++) for (i = 0, numAfter = 0; i < CONTESTANT_COUNT; i++)
{ {
if (eContestAppealResults.turnOrder[eContestAppealResults.contestant] < eContestAppealResults.turnOrder[i] && if (eContestAppealResults.turnOrder[eContestAppealResults.contestant] < eContestAppealResults.turnOrder[i] &&
@ -434,7 +434,7 @@ static void ContestEffect_MakeFollowingMonsNervous(void)
} }
if (odds[0] != 0) if (odds[0] != 0)
{ {
for (i = 0; contestantIds[i] != 0xFF; i++) for (i = 0; contestantIds[i] != CONTESTANT_NONE; i++)
{ {
if (Random() % 100 < odds[i] + oddsMod[contestantIds[i]]) if (Random() % 100 < odds[i] + oddsMod[contestantIds[i]])
{ {
@ -507,7 +507,7 @@ static void ContestEffect_BadlyStartlesMonsInGoodCondition(void)
else else
eContestAppealResults.jam = 10; eContestAppealResults.jam = 10;
eContestAppealResults.jamQueue[0] = i; eContestAppealResults.jamQueue[0] = i;
eContestAppealResults.jamQueue[1] = 0xFF; eContestAppealResults.jamQueue[1] = CONTESTANT_NONE;
if (WasAtLeastOneOpponentJammed()) if (WasAtLeastOneOpponentJammed())
numHit++; numHit++;
} }
@ -758,7 +758,7 @@ static void ContestEffect_NextAppealEarlier(void)
for (i = 0; i < CONTESTANT_COUNT; i++) for (i = 0; i < CONTESTANT_COUNT; i++)
turnOrder[i] = eContestantStatus[i].nextTurnOrder; turnOrder[i] = eContestantStatus[i].nextTurnOrder;
turnOrder[eContestAppealResults.contestant] = 0xFF; turnOrder[eContestAppealResults.contestant] = CONTESTANT_NONE;
for (i = 0; i < CONTESTANT_COUNT; i++) for (i = 0; i < CONTESTANT_COUNT; i++)
{ {
@ -800,7 +800,7 @@ static void ContestEffect_NextAppealLater(void)
for (i = 0; i < CONTESTANT_COUNT; i++) for (i = 0; i < CONTESTANT_COUNT; i++)
turnOrder[i] = eContestantStatus[i].nextTurnOrder; turnOrder[i] = eContestantStatus[i].nextTurnOrder;
turnOrder[eContestAppealResults.contestant] = 0xFF; turnOrder[eContestAppealResults.contestant] = CONTESTANT_NONE;
for (i = CONTESTANT_COUNT - 1; i > -1; i--) for (i = CONTESTANT_COUNT - 1; i > -1; i--)
{ {
@ -858,12 +858,12 @@ static void ContestEffect_ScrambleNextTurnOrder(void)
for (j = 0; j < CONTESTANT_COUNT; j++) for (j = 0; j < CONTESTANT_COUNT; j++)
{ {
if (unselectedContestants[j] != 0xFF) if (unselectedContestants[j] != CONTESTANT_NONE)
{ {
if (rval == 0) if (rval == 0)
{ {
turnOrder[j] = i; turnOrder[j] = i;
unselectedContestants[j] = 0xFF; unselectedContestants[j] = CONTESTANT_NONE;
break; break;
} }
else else
@ -909,7 +909,7 @@ static void ContestEffect_BadlyStartleMonsWithGoodAppeals(void)
else else
eContestAppealResults.jam = 10; eContestAppealResults.jam = 10;
eContestAppealResults.jamQueue[0] = i; eContestAppealResults.jamQueue[0] = i;
eContestAppealResults.jamQueue[1] = 0xFF; eContestAppealResults.jamQueue[1] = CONTESTANT_NONE;
if (WasAtLeastOneOpponentJammed()) if (WasAtLeastOneOpponentJammed())
numJammed++; numJammed++;
} }
@ -977,7 +977,7 @@ static void JamByMoveCategory(u8 category)
else else
eContestAppealResults.jam = 10; eContestAppealResults.jam = 10;
eContestAppealResults.jamQueue[0] = i; eContestAppealResults.jamQueue[0] = i;
eContestAppealResults.jamQueue[1] = 0xFF; eContestAppealResults.jamQueue[1] = CONTESTANT_NONE;
if (WasAtLeastOneOpponentJammed()) if (WasAtLeastOneOpponentJammed())
numJammed++; numJammed++;
} }
@ -1016,7 +1016,7 @@ static bool8 WasAtLeastOneOpponentJammed(void)
s16 jamBuffer[CONTESTANT_COUNT] = {0}; s16 jamBuffer[CONTESTANT_COUNT] = {0};
int i; int i;
for (i = 0; eContestAppealResults.jamQueue[i] != 0xFF; i++) for (i = 0; eContestAppealResults.jamQueue[i] != CONTESTANT_NONE; i++)
{ {
u8 contestant = eContestAppealResults.jamQueue[i]; u8 contestant = eContestAppealResults.jamQueue[i];
if (CanUnnerveContestant(contestant)) if (CanUnnerveContestant(contestant))

View File

@ -2011,7 +2011,7 @@ void GiveMonContestRibbon(void)
{ {
case CONTEST_CATEGORY_COOL: case CONTEST_CATEGORY_COOL:
ribbonData = GetMonData(&gPlayerParty[gContestMonPartyIndex], MON_DATA_COOL_RIBBON); ribbonData = GetMonData(&gPlayerParty[gContestMonPartyIndex], MON_DATA_COOL_RIBBON);
if (ribbonData <= gSpecialVar_ContestRank && ribbonData < 4) if (ribbonData <= gSpecialVar_ContestRank && ribbonData <= CONTEST_RANK_MASTER)
{ {
ribbonData++; ribbonData++;
SetMonData(&gPlayerParty[gContestMonPartyIndex], MON_DATA_COOL_RIBBON, &ribbonData); SetMonData(&gPlayerParty[gContestMonPartyIndex], MON_DATA_COOL_RIBBON, &ribbonData);
@ -2021,7 +2021,7 @@ void GiveMonContestRibbon(void)
break; break;
case CONTEST_CATEGORY_BEAUTY: case CONTEST_CATEGORY_BEAUTY:
ribbonData = GetMonData(&gPlayerParty[gContestMonPartyIndex], MON_DATA_BEAUTY_RIBBON); ribbonData = GetMonData(&gPlayerParty[gContestMonPartyIndex], MON_DATA_BEAUTY_RIBBON);
if (ribbonData <= gSpecialVar_ContestRank && ribbonData < 4) if (ribbonData <= gSpecialVar_ContestRank && ribbonData <= CONTEST_RANK_MASTER)
{ {
ribbonData++; ribbonData++;
SetMonData(&gPlayerParty[gContestMonPartyIndex], MON_DATA_BEAUTY_RIBBON, &ribbonData); SetMonData(&gPlayerParty[gContestMonPartyIndex], MON_DATA_BEAUTY_RIBBON, &ribbonData);
@ -2031,7 +2031,7 @@ void GiveMonContestRibbon(void)
break; break;
case CONTEST_CATEGORY_CUTE: case CONTEST_CATEGORY_CUTE:
ribbonData = GetMonData(&gPlayerParty[gContestMonPartyIndex], MON_DATA_CUTE_RIBBON); ribbonData = GetMonData(&gPlayerParty[gContestMonPartyIndex], MON_DATA_CUTE_RIBBON);
if (ribbonData <= gSpecialVar_ContestRank && ribbonData < 4) if (ribbonData <= gSpecialVar_ContestRank && ribbonData <= CONTEST_RANK_MASTER)
{ {
ribbonData++; ribbonData++;
SetMonData(&gPlayerParty[gContestMonPartyIndex], MON_DATA_CUTE_RIBBON, &ribbonData); SetMonData(&gPlayerParty[gContestMonPartyIndex], MON_DATA_CUTE_RIBBON, &ribbonData);
@ -2041,7 +2041,7 @@ void GiveMonContestRibbon(void)
break; break;
case CONTEST_CATEGORY_SMART: case CONTEST_CATEGORY_SMART:
ribbonData = GetMonData(&gPlayerParty[gContestMonPartyIndex], MON_DATA_SMART_RIBBON); ribbonData = GetMonData(&gPlayerParty[gContestMonPartyIndex], MON_DATA_SMART_RIBBON);
if (ribbonData <= gSpecialVar_ContestRank && ribbonData < 4) if (ribbonData <= gSpecialVar_ContestRank && ribbonData <= CONTEST_RANK_MASTER)
{ {
ribbonData++; ribbonData++;
SetMonData(&gPlayerParty[gContestMonPartyIndex], MON_DATA_SMART_RIBBON, &ribbonData); SetMonData(&gPlayerParty[gContestMonPartyIndex], MON_DATA_SMART_RIBBON, &ribbonData);
@ -2051,7 +2051,7 @@ void GiveMonContestRibbon(void)
break; break;
case CONTEST_CATEGORY_TOUGH: case CONTEST_CATEGORY_TOUGH:
ribbonData = GetMonData(&gPlayerParty[gContestMonPartyIndex], MON_DATA_TOUGH_RIBBON); ribbonData = GetMonData(&gPlayerParty[gContestMonPartyIndex], MON_DATA_TOUGH_RIBBON);
if (ribbonData <= gSpecialVar_ContestRank && ribbonData < 4) if (ribbonData <= gSpecialVar_ContestRank && ribbonData <= CONTEST_RANK_MASTER)
{ {
ribbonData++; ribbonData++;
SetMonData(&gPlayerParty[gContestMonPartyIndex], MON_DATA_TOUGH_RIBBON, &ribbonData); SetMonData(&gPlayerParty[gContestMonPartyIndex], MON_DATA_TOUGH_RIBBON, &ribbonData);

View File

@ -138,11 +138,14 @@ enum {
#define CONTEST_AI_SET_20 (CONTEST_AI_COMMON | CONTEST_AI_DUMMY_12 | CONTEST_AI_DUMMY_25) #define CONTEST_AI_SET_20 (CONTEST_AI_COMMON | CONTEST_AI_DUMMY_12 | CONTEST_AI_DUMMY_25)
#define CONTEST_AI_SET_21 (CONTEST_AI_COMMON | CONTEST_AI_DUMMY_7 | CONTEST_AI_DUMMY_25) #define CONTEST_AI_SET_21 (CONTEST_AI_COMMON | CONTEST_AI_DUMMY_7 | CONTEST_AI_DUMMY_25)
// All AI contestants have the same trainer ID
#define CONTEST_AI_TRAINER_ID 0xFFFF
const struct ContestWinner gDefaultContestWinners[] = const struct ContestWinner gDefaultContestWinners[] =
{ {
[CONTEST_WINNER_HALL_1 - 1] = { [CONTEST_WINNER_HALL_1 - 1] = {
.personality = 0, .personality = 0,
.trainerId = 0xFFFF, .trainerId = CONTEST_AI_TRAINER_ID,
.species = SPECIES_ELECTRIKE, .species = SPECIES_ELECTRIKE,
.contestCategory = CONTEST_CATEGORY_CUTE, .contestCategory = CONTEST_CATEGORY_CUTE,
.monName = _("ELECTER"), .monName = _("ELECTER"),
@ -151,7 +154,7 @@ const struct ContestWinner gDefaultContestWinners[] =
}, },
[CONTEST_WINNER_HALL_2 - 1] = { [CONTEST_WINNER_HALL_2 - 1] = {
.personality = 0, .personality = 0,
.trainerId = 0xFFFF, .trainerId = CONTEST_AI_TRAINER_ID,
.species = SPECIES_TROPIUS, .species = SPECIES_TROPIUS,
.contestCategory = CONTEST_CATEGORY_COOL, .contestCategory = CONTEST_CATEGORY_COOL,
.monName = _("TROPO"), .monName = _("TROPO"),
@ -160,7 +163,7 @@ const struct ContestWinner gDefaultContestWinners[] =
}, },
[CONTEST_WINNER_HALL_3 - 1] = { [CONTEST_WINNER_HALL_3 - 1] = {
.personality = 0, .personality = 0,
.trainerId = 0xFFFF, .trainerId = CONTEST_AI_TRAINER_ID,
.species = SPECIES_XATU, .species = SPECIES_XATU,
.contestCategory = CONTEST_CATEGORY_BEAUTY, .contestCategory = CONTEST_CATEGORY_BEAUTY,
.monName = _("TUXA"), .monName = _("TUXA"),
@ -169,7 +172,7 @@ const struct ContestWinner gDefaultContestWinners[] =
}, },
[CONTEST_WINNER_HALL_4 - 1] = { [CONTEST_WINNER_HALL_4 - 1] = {
.personality = 0, .personality = 0,
.trainerId = 0xFFFF, .trainerId = CONTEST_AI_TRAINER_ID,
.species = SPECIES_PLUSLE, .species = SPECIES_PLUSLE,
.contestCategory = CONTEST_CATEGORY_TOUGH, .contestCategory = CONTEST_CATEGORY_TOUGH,
.monName = _("PULSE"), .monName = _("PULSE"),
@ -178,7 +181,7 @@ const struct ContestWinner gDefaultContestWinners[] =
}, },
[CONTEST_WINNER_HALL_5 - 1] = { [CONTEST_WINNER_HALL_5 - 1] = {
.personality = 0, .personality = 0,
.trainerId = 0xFFFF, .trainerId = CONTEST_AI_TRAINER_ID,
.species = SPECIES_SHUPPET, .species = SPECIES_SHUPPET,
.contestCategory = CONTEST_CATEGORY_SMART, .contestCategory = CONTEST_CATEGORY_SMART,
.monName = _("SHUPUP"), .monName = _("SHUPUP"),
@ -187,7 +190,7 @@ const struct ContestWinner gDefaultContestWinners[] =
}, },
[CONTEST_WINNER_HALL_6 - 1] = { [CONTEST_WINNER_HALL_6 - 1] = {
.personality = 0, .personality = 0,
.trainerId = 0xFFFF, .trainerId = CONTEST_AI_TRAINER_ID,
.species = SPECIES_ZANGOOSE, .species = SPECIES_ZANGOOSE,
.contestCategory = CONTEST_CATEGORY_COOL, .contestCategory = CONTEST_CATEGORY_COOL,
.monName = _("GOOZAN"), .monName = _("GOOZAN"),
@ -196,7 +199,7 @@ const struct ContestWinner gDefaultContestWinners[] =
}, },
[CONTEST_WINNER_HALL_UNUSED_1 - 1] = { [CONTEST_WINNER_HALL_UNUSED_1 - 1] = {
.personality = 0, .personality = 0,
.trainerId = 0xFFFF, .trainerId = CONTEST_AI_TRAINER_ID,
.species = SPECIES_LOUDRED, .species = SPECIES_LOUDRED,
.contestCategory = CONTEST_CATEGORY_BEAUTY, .contestCategory = CONTEST_CATEGORY_BEAUTY,
.monName = _("LOUDED"), .monName = _("LOUDED"),
@ -205,7 +208,7 @@ const struct ContestWinner gDefaultContestWinners[] =
}, },
[CONTEST_WINNER_HALL_UNUSED_2 - 1] = { [CONTEST_WINNER_HALL_UNUSED_2 - 1] = {
.personality = 0, .personality = 0,
.trainerId = 0xFFFF, .trainerId = CONTEST_AI_TRAINER_ID,
.species = SPECIES_DELCATTY, .species = SPECIES_DELCATTY,
.contestCategory = CONTEST_CATEGORY_CUTE, .contestCategory = CONTEST_CATEGORY_CUTE,
.monName = _("KITSY"), .monName = _("KITSY"),
@ -242,7 +245,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 4, .tough = 4,
.sheen = 50, .sheen = 50,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_EDITH] = { [CONTEST_OPPONENT_EDITH] = {
.species = SPECIES_ILLUMISE, .species = SPECIES_ILLUMISE,
@ -270,7 +273,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 2, .tough = 2,
.sheen = 60, .sheen = 60,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_EVAN] = { [CONTEST_OPPONENT_EVAN] = {
.species = SPECIES_DUSTOX, .species = SPECIES_DUSTOX,
@ -298,7 +301,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 4, .tough = 4,
.sheen = 70, .sheen = 70,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_KELSEY] = { [CONTEST_OPPONENT_KELSEY] = {
.species = SPECIES_SEEDOT, .species = SPECIES_SEEDOT,
@ -326,7 +329,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 7, .tough = 7,
.sheen = 80, .sheen = 80,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_MADISON] = { [CONTEST_OPPONENT_MADISON] = {
.species = SPECIES_TAILLOW, .species = SPECIES_TAILLOW,
@ -354,7 +357,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 4, .tough = 4,
.sheen = 90, .sheen = 90,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_RAYMOND] = { [CONTEST_OPPONENT_RAYMOND] = {
.species = SPECIES_NINCADA, .species = SPECIES_NINCADA,
@ -382,7 +385,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 8, .tough = 8,
.sheen = 100, .sheen = 100,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_GRANT] = { [CONTEST_OPPONENT_GRANT] = {
.species = SPECIES_SHROOMISH, .species = SPECIES_SHROOMISH,
@ -410,7 +413,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 2, .tough = 2,
.sheen = 50, .sheen = 50,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_PAIGE] = { [CONTEST_OPPONENT_PAIGE] = {
.species = SPECIES_SPHEAL, .species = SPECIES_SPHEAL,
@ -438,7 +441,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 10, .tough = 10,
.sheen = 60, .sheen = 60,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_ALEC] = { [CONTEST_OPPONENT_ALEC] = {
.species = SPECIES_SLAKOTH, .species = SPECIES_SLAKOTH,
@ -466,7 +469,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 18, .tough = 18,
.sheen = 70, .sheen = 70,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_SYDNEY] = { [CONTEST_OPPONENT_SYDNEY] = {
.species = SPECIES_WHISMUR, .species = SPECIES_WHISMUR,
@ -494,7 +497,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 7, .tough = 7,
.sheen = 80, .sheen = 80,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_MORRIS] = { [CONTEST_OPPONENT_MORRIS] = {
.species = SPECIES_MAKUHITA, .species = SPECIES_MAKUHITA,
@ -522,7 +525,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 1, .tough = 1,
.sheen = 90, .sheen = 90,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_MARIAH] = { [CONTEST_OPPONENT_MARIAH] = {
.species = SPECIES_ARON, .species = SPECIES_ARON,
@ -550,7 +553,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 2, .tough = 2,
.sheen = 100, .sheen = 100,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_RUSSELL] = { [CONTEST_OPPONENT_RUSSELL] = {
.species = SPECIES_CROBAT, .species = SPECIES_CROBAT,
@ -578,7 +581,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 10, .tough = 10,
.sheen = 50, .sheen = 50,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_MELANIE] = { [CONTEST_OPPONENT_MELANIE] = {
.species = SPECIES_GULPIN, .species = SPECIES_GULPIN,
@ -606,7 +609,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 5, .tough = 5,
.sheen = 60, .sheen = 60,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_CHANCE] = { [CONTEST_OPPONENT_CHANCE] = {
.species = SPECIES_MANECTRIC, .species = SPECIES_MANECTRIC,
@ -634,7 +637,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 1, .tough = 1,
.sheen = 70, .sheen = 70,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_AGATHA] = { [CONTEST_OPPONENT_AGATHA] = {
.species = SPECIES_BULBASAUR, .species = SPECIES_BULBASAUR,
@ -662,7 +665,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 4, .tough = 4,
.sheen = 50, .sheen = 50,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_BEAU] = { [CONTEST_OPPONENT_BEAU] = {
.species = SPECIES_BUTTERFREE, .species = SPECIES_BUTTERFREE,
@ -690,7 +693,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 4, .tough = 4,
.sheen = 60, .sheen = 60,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_KAY] = { [CONTEST_OPPONENT_KAY] = {
.species = SPECIES_PIDGEOTTO, .species = SPECIES_PIDGEOTTO,
@ -718,7 +721,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 3, .tough = 3,
.sheen = 70, .sheen = 70,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_CALE] = { [CONTEST_OPPONENT_CALE] = {
.species = SPECIES_DIGLETT, .species = SPECIES_DIGLETT,
@ -746,7 +749,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 10, .tough = 10,
.sheen = 80, .sheen = 80,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_CAITLIN] = { [CONTEST_OPPONENT_CAITLIN] = {
.species = SPECIES_POLIWAG, .species = SPECIES_POLIWAG,
@ -774,7 +777,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 10, .tough = 10,
.sheen = 90, .sheen = 90,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_COLBY] = { [CONTEST_OPPONENT_COLBY] = {
.species = SPECIES_TOTODILE, .species = SPECIES_TOTODILE,
@ -802,7 +805,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 5, .tough = 5,
.sheen = 100, .sheen = 100,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_KYLIE] = { [CONTEST_OPPONENT_KYLIE] = {
.species = SPECIES_LEDYBA, .species = SPECIES_LEDYBA,
@ -830,7 +833,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 2, .tough = 2,
.sheen = 90, .sheen = 90,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_LIAM] = { [CONTEST_OPPONENT_LIAM] = {
.species = SPECIES_DELIBIRD, .species = SPECIES_DELIBIRD,
@ -858,7 +861,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 3, .tough = 3,
.sheen = 80, .sheen = 80,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_MILO] = { [CONTEST_OPPONENT_MILO] = {
.species = SPECIES_LARVITAR, .species = SPECIES_LARVITAR,
@ -886,7 +889,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 10, .tough = 10,
.sheen = 70, .sheen = 70,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_KARINA] = { [CONTEST_OPPONENT_KARINA] = {
.species = SPECIES_ROSELIA, .species = SPECIES_ROSELIA,
@ -914,7 +917,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 20, .tough = 20,
.sheen = 100, .sheen = 100,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_BOBBY] = { [CONTEST_OPPONENT_BOBBY] = {
.species = SPECIES_DODRIO, .species = SPECIES_DODRIO,
@ -942,7 +945,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 35, .tough = 35,
.sheen = 110, .sheen = 110,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_CLAIRE] = { [CONTEST_OPPONENT_CLAIRE] = {
.species = SPECIES_TRAPINCH, .species = SPECIES_TRAPINCH,
@ -970,7 +973,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 25, .tough = 25,
.sheen = 120, .sheen = 120,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_WILLIE] = { [CONTEST_OPPONENT_WILLIE] = {
.species = SPECIES_CACNEA, .species = SPECIES_CACNEA,
@ -998,7 +1001,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 25, .tough = 25,
.sheen = 130, .sheen = 130,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_CASSIDY] = { [CONTEST_OPPONENT_CASSIDY] = {
.species = SPECIES_SANDSLASH, .species = SPECIES_SANDSLASH,
@ -1026,7 +1029,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 100, .tough = 100,
.sheen = 140, .sheen = 140,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_MORGAN] = { [CONTEST_OPPONENT_MORGAN] = {
.species = SPECIES_BALTOY, .species = SPECIES_BALTOY,
@ -1054,7 +1057,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 35, .tough = 35,
.sheen = 150, .sheen = 150,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_SUMMER] = { [CONTEST_OPPONENT_SUMMER] = {
.species = SPECIES_MEDICHAM, .species = SPECIES_MEDICHAM,
@ -1082,7 +1085,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 40, .tough = 40,
.sheen = 100, .sheen = 100,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_MILES] = { [CONTEST_OPPONENT_MILES] = {
.species = SPECIES_SPINDA, .species = SPECIES_SPINDA,
@ -1110,7 +1113,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 25, .tough = 25,
.sheen = 110, .sheen = 110,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_AUDREY] = { [CONTEST_OPPONENT_AUDREY] = {
.species = SPECIES_SWABLU, .species = SPECIES_SWABLU,
@ -1138,7 +1141,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 25, .tough = 25,
.sheen = 120, .sheen = 120,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_AVERY] = { [CONTEST_OPPONENT_AVERY] = {
.species = SPECIES_SPOINK, .species = SPECIES_SPOINK,
@ -1166,7 +1169,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 30, .tough = 30,
.sheen = 130, .sheen = 130,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_ARIANA] = { [CONTEST_OPPONENT_ARIANA] = {
.species = SPECIES_KECLEON, .species = SPECIES_KECLEON,
@ -1194,7 +1197,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 35, .tough = 35,
.sheen = 140, .sheen = 140,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_ASHTON] = { [CONTEST_OPPONENT_ASHTON] = {
.species = SPECIES_GOLDEEN, .species = SPECIES_GOLDEEN,
@ -1222,7 +1225,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 25, .tough = 25,
.sheen = 150, .sheen = 150,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_SANDRA] = { [CONTEST_OPPONENT_SANDRA] = {
.species = SPECIES_BARBOACH, .species = SPECIES_BARBOACH,
@ -1250,7 +1253,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 15, .tough = 15,
.sheen = 100, .sheen = 100,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_CARSON] = { [CONTEST_OPPONENT_CARSON] = {
.species = SPECIES_SKARMORY, .species = SPECIES_SKARMORY,
@ -1278,7 +1281,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 20, .tough = 20,
.sheen = 110, .sheen = 110,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_KATRINA] = { [CONTEST_OPPONENT_KATRINA] = {
.species = SPECIES_LOTAD, .species = SPECIES_LOTAD,
@ -1306,7 +1309,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 75, .tough = 75,
.sheen = 120, .sheen = 120,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_LUKE] = { [CONTEST_OPPONENT_LUKE] = {
.species = SPECIES_SLOWBRO, .species = SPECIES_SLOWBRO,
@ -1334,7 +1337,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 20, .tough = 20,
.sheen = 100, .sheen = 100,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_RAUL] = { [CONTEST_OPPONENT_RAUL] = {
.species = SPECIES_FARFETCHD, .species = SPECIES_FARFETCHD,
@ -1362,7 +1365,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 20, .tough = 20,
.sheen = 110, .sheen = 110,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_JADA] = { [CONTEST_OPPONENT_JADA] = {
.species = SPECIES_SEEL, .species = SPECIES_SEEL,
@ -1390,7 +1393,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 20, .tough = 20,
.sheen = 120, .sheen = 120,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_ZEEK] = { [CONTEST_OPPONENT_ZEEK] = {
.species = SPECIES_DROWZEE, .species = SPECIES_DROWZEE,
@ -1418,7 +1421,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 45, .tough = 45,
.sheen = 130, .sheen = 130,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_DIEGO] = { [CONTEST_OPPONENT_DIEGO] = {
.species = SPECIES_HITMONCHAN, .species = SPECIES_HITMONCHAN,
@ -1446,7 +1449,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 45, .tough = 45,
.sheen = 140, .sheen = 140,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_ALIYAH] = { [CONTEST_OPPONENT_ALIYAH] = {
.species = SPECIES_BLISSEY, .species = SPECIES_BLISSEY,
@ -1474,7 +1477,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 20, .tough = 20,
.sheen = 150, .sheen = 150,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_NATALIA] = { [CONTEST_OPPONENT_NATALIA] = {
.species = SPECIES_ELEKID, .species = SPECIES_ELEKID,
@ -1502,7 +1505,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 25, .tough = 25,
.sheen = 140, .sheen = 140,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_DEVIN] = { [CONTEST_OPPONENT_DEVIN] = {
.species = SPECIES_SNUBBULL, .species = SPECIES_SNUBBULL,
@ -1530,7 +1533,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 20, .tough = 20,
.sheen = 130, .sheen = 130,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_TYLOR] = { [CONTEST_OPPONENT_TYLOR] = {
.species = SPECIES_MISDREAVUS, .species = SPECIES_MISDREAVUS,
@ -1558,7 +1561,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 20, .tough = 20,
.sheen = 120, .sheen = 120,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_RONNIE] = { [CONTEST_OPPONENT_RONNIE] = {
.species = SPECIES_LAIRON, .species = SPECIES_LAIRON,
@ -1586,7 +1589,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 90, .tough = 90,
.sheen = 200, .sheen = 200,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_CLAUDIA] = { [CONTEST_OPPONENT_CLAUDIA] = {
.species = SPECIES_SHIFTRY, .species = SPECIES_SHIFTRY,
@ -1614,7 +1617,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 70, .tough = 70,
.sheen = 210, .sheen = 210,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_ELIAS] = { [CONTEST_OPPONENT_ELIAS] = {
.species = SPECIES_NINJASK, .species = SPECIES_NINJASK,
@ -1642,7 +1645,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 70, .tough = 70,
.sheen = 220, .sheen = 220,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_JADE] = { [CONTEST_OPPONENT_JADE] = {
.species = SPECIES_SWELLOW, .species = SPECIES_SWELLOW,
@ -1670,7 +1673,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 40, .tough = 40,
.sheen = 230, .sheen = 230,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_FRANCIS] = { [CONTEST_OPPONENT_FRANCIS] = {
.species = SPECIES_MIGHTYENA, .species = SPECIES_MIGHTYENA,
@ -1698,7 +1701,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 70, .tough = 70,
.sheen = 240, .sheen = 240,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_ALISHA] = { [CONTEST_OPPONENT_ALISHA] = {
.species = SPECIES_BEAUTIFLY, .species = SPECIES_BEAUTIFLY,
@ -1726,7 +1729,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 100, .tough = 100,
.sheen = 250, .sheen = 250,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_SAUL] = { [CONTEST_OPPONENT_SAUL] = {
.species = SPECIES_SEAKING, .species = SPECIES_SEAKING,
@ -1754,7 +1757,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 90, .tough = 90,
.sheen = 200, .sheen = 200,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_FELICIA] = { [CONTEST_OPPONENT_FELICIA] = {
.species = SPECIES_CASTFORM, .species = SPECIES_CASTFORM,
@ -1782,7 +1785,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 65, .tough = 65,
.sheen = 210, .sheen = 210,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_EMILIO] = { [CONTEST_OPPONENT_EMILIO] = {
.species = SPECIES_MACHOKE, .species = SPECIES_MACHOKE,
@ -1810,7 +1813,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 50, .tough = 50,
.sheen = 220, .sheen = 220,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_KARLA] = { [CONTEST_OPPONENT_KARLA] = {
.species = SPECIES_LOMBRE, .species = SPECIES_LOMBRE,
@ -1838,7 +1841,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 70, .tough = 70,
.sheen = 230, .sheen = 230,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_DARRYL] = { [CONTEST_OPPONENT_DARRYL] = {
.species = SPECIES_SEVIPER, .species = SPECIES_SEVIPER,
@ -1866,7 +1869,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 100, .tough = 100,
.sheen = 240, .sheen = 240,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_SELENA] = { [CONTEST_OPPONENT_SELENA] = {
.species = SPECIES_WAILMER, .species = SPECIES_WAILMER,
@ -1894,7 +1897,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 30, .tough = 30,
.sheen = 250, .sheen = 250,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_NOEL] = { [CONTEST_OPPONENT_NOEL] = {
.species = SPECIES_MAGIKARP, .species = SPECIES_MAGIKARP,
@ -1922,7 +1925,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 160, .tough = 160,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_LACEY] = { [CONTEST_OPPONENT_LACEY] = {
.species = SPECIES_LUNATONE, .species = SPECIES_LUNATONE,
@ -1950,7 +1953,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 50, .tough = 50,
.sheen = 210, .sheen = 210,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_CORBIN] = { [CONTEST_OPPONENT_CORBIN] = {
.species = SPECIES_ABSOL, .species = SPECIES_ABSOL,
@ -1978,7 +1981,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 35, .tough = 35,
.sheen = 220, .sheen = 220,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_GRACIE] = { [CONTEST_OPPONENT_GRACIE] = {
.species = SPECIES_EXEGGUTOR, .species = SPECIES_EXEGGUTOR,
@ -2006,7 +2009,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 80, .tough = 80,
.sheen = 200, .sheen = 200,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_COLTIN] = { [CONTEST_OPPONENT_COLTIN] = {
.species = SPECIES_CUBONE, .species = SPECIES_CUBONE,
@ -2034,7 +2037,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 100, .tough = 100,
.sheen = 210, .sheen = 210,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_ELLIE] = { [CONTEST_OPPONENT_ELLIE] = {
.species = SPECIES_HITMONLEE, .species = SPECIES_HITMONLEE,
@ -2062,7 +2065,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 100, .tough = 100,
.sheen = 220, .sheen = 220,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_MARCUS] = { [CONTEST_OPPONENT_MARCUS] = {
.species = SPECIES_SQUIRTLE, .species = SPECIES_SQUIRTLE,
@ -2090,7 +2093,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 95, .tough = 95,
.sheen = 230, .sheen = 230,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_KIARA] = { [CONTEST_OPPONENT_KIARA] = {
.species = SPECIES_KANGASKHAN, .species = SPECIES_KANGASKHAN,
@ -2118,7 +2121,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 100, .tough = 100,
.sheen = 240, .sheen = 240,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_BRYCE] = { [CONTEST_OPPONENT_BRYCE] = {
.species = SPECIES_PINECO, .species = SPECIES_PINECO,
@ -2146,7 +2149,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 80, .tough = 80,
.sheen = 250, .sheen = 250,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_JAMIE] = { [CONTEST_OPPONENT_JAMIE] = {
.species = SPECIES_DUNSPARCE, .species = SPECIES_DUNSPARCE,
@ -2174,7 +2177,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 110, .tough = 110,
.sheen = 240, .sheen = 240,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_JORGE] = { [CONTEST_OPPONENT_JORGE] = {
.species = SPECIES_HOUNDOOM, .species = SPECIES_HOUNDOOM,
@ -2202,7 +2205,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 80, .tough = 80,
.sheen = 230, .sheen = 230,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_DEVON] = { [CONTEST_OPPONENT_DEVON] = {
.species = SPECIES_MILTANK, .species = SPECIES_MILTANK,
@ -2230,7 +2233,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 40, .tough = 40,
.sheen = 220, .sheen = 220,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_JUSTINA] = { [CONTEST_OPPONENT_JUSTINA] = {
.species = SPECIES_GYARADOS, .species = SPECIES_GYARADOS,
@ -2258,7 +2261,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 160, .tough = 160,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_RALPH] = { [CONTEST_OPPONENT_RALPH] = {
.species = SPECIES_LOUDRED, .species = SPECIES_LOUDRED,
@ -2286,7 +2289,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 160, .tough = 160,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_ROSA] = { [CONTEST_OPPONENT_ROSA] = {
.species = SPECIES_SKITTY, .species = SPECIES_SKITTY,
@ -2314,7 +2317,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 60, .tough = 60,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_KEATON] = { [CONTEST_OPPONENT_KEATON] = {
.species = SPECIES_SLAKING, .species = SPECIES_SLAKING,
@ -2342,7 +2345,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 150, .tough = 150,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_MAYRA] = { [CONTEST_OPPONENT_MAYRA] = {
.species = SPECIES_ALTARIA, .species = SPECIES_ALTARIA,
@ -2370,7 +2373,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 90, .tough = 90,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_LAMAR] = { [CONTEST_OPPONENT_LAMAR] = {
.species = SPECIES_KIRLIA, .species = SPECIES_KIRLIA,
@ -2398,7 +2401,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 80, .tough = 80,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_AUBREY] = { [CONTEST_OPPONENT_AUBREY] = {
.species = SPECIES_BELLOSSOM, .species = SPECIES_BELLOSSOM,
@ -2426,7 +2429,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 40, .tough = 40,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_NIGEL] = { [CONTEST_OPPONENT_NIGEL] = {
.species = SPECIES_SABLEYE, .species = SPECIES_SABLEYE,
@ -2454,7 +2457,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 160, .tough = 160,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_CAMILLE] = { [CONTEST_OPPONENT_CAMILLE] = {
.species = SPECIES_NATU, .species = SPECIES_NATU,
@ -2482,7 +2485,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 170, .tough = 170,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_DEON] = { [CONTEST_OPPONENT_DEON] = {
.species = SPECIES_SHARPEDO, .species = SPECIES_SHARPEDO,
@ -2510,7 +2513,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 100, .tough = 100,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_JANELLE] = { [CONTEST_OPPONENT_JANELLE] = {
.species = SPECIES_LUVDISC, .species = SPECIES_LUVDISC,
@ -2538,7 +2541,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 190, .tough = 190,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_HEATH] = { [CONTEST_OPPONENT_HEATH] = {
.species = SPECIES_HERACROSS, .species = SPECIES_HERACROSS,
@ -2566,7 +2569,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 140, .tough = 140,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_SASHA] = { [CONTEST_OPPONENT_SASHA] = {
.species = SPECIES_ELECTRODE, .species = SPECIES_ELECTRODE,
@ -2594,7 +2597,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 50, .tough = 50,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_FRANKIE] = { [CONTEST_OPPONENT_FRANKIE] = {
.species = SPECIES_PICHU, .species = SPECIES_PICHU,
@ -2622,7 +2625,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 120, .tough = 120,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_HELEN] = { [CONTEST_OPPONENT_HELEN] = {
.species = SPECIES_WOBBUFFET, .species = SPECIES_WOBBUFFET,
@ -2650,7 +2653,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 210, .tough = 210,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_CAMILE] = { [CONTEST_OPPONENT_CAMILE] = {
.species = SPECIES_GENGAR, .species = SPECIES_GENGAR,
@ -2678,7 +2681,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 180, .tough = 180,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_MARTIN] = { [CONTEST_OPPONENT_MARTIN] = {
.species = SPECIES_PORYGON, .species = SPECIES_PORYGON,
@ -2706,7 +2709,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 130, .tough = 130,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_SERGIO] = { [CONTEST_OPPONENT_SERGIO] = {
.species = SPECIES_DRAGONITE, .species = SPECIES_DRAGONITE,
@ -2734,7 +2737,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 150, .tough = 150,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_KAILEY] = { [CONTEST_OPPONENT_KAILEY] = {
.species = SPECIES_MEOWTH, .species = SPECIES_MEOWTH,
@ -2762,7 +2765,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 80, .tough = 80,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_PERLA] = { [CONTEST_OPPONENT_PERLA] = {
.species = SPECIES_JYNX, .species = SPECIES_JYNX,
@ -2790,7 +2793,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 120, .tough = 120,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_CLARA] = { [CONTEST_OPPONENT_CLARA] = {
.species = SPECIES_TOGEPI, .species = SPECIES_TOGEPI,
@ -2818,7 +2821,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 80, .tough = 80,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_JAKOB] = { [CONTEST_OPPONENT_JAKOB] = {
.species = SPECIES_ESPEON, .species = SPECIES_ESPEON,
@ -2846,7 +2849,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 150, .tough = 150,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_TREY] = { [CONTEST_OPPONENT_TREY] = {
.species = SPECIES_SLOWKING, .species = SPECIES_SLOWKING,
@ -2874,7 +2877,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 170, .tough = 170,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
}, },
[CONTEST_OPPONENT_LANE] = { [CONTEST_OPPONENT_LANE] = {
.species = SPECIES_URSARING, .species = SPECIES_URSARING,
@ -2902,7 +2905,7 @@ const struct ContestPokemon gContestOpponents[] =
.tough = 190, .tough = 190,
.sheen = 255, .sheen = 255,
.personality = 0, .personality = 0,
.otId = 0xFFFF .otId = CONTEST_AI_TRAINER_ID,
} }
}; };

View File

@ -422,7 +422,16 @@ static const u8 sDecorationSlideElevation[] =
}; };
static const u16 sDecorShapeSizes[] = { static const u16 sDecorShapeSizes[] = {
0x04, 0x08, 0x10, 0x20, 0x10, 0x08, 0x10, 0x20, 0x40, 0x20 [DECORSHAPE_1x1] = 4,
[DECORSHAPE_2x1] = 8,
[DECORSHAPE_3x1] = 16,
[DECORSHAPE_4x2] = 32,
[DECORSHAPE_2x2] = 16,
[DECORSHAPE_1x2] = 8,
[DECORSHAPE_1x3] = 16,
[DECORSHAPE_2x4] = 32,
[DECORSHAPE_3x3] = 64,
[DECORSHAPE_3x2] = 32,
}; };
static const u16 sBrendanPalette[] = INCBIN_U16("graphics/decorations/brendan.gbapal"); static const u16 sBrendanPalette[] = INCBIN_U16("graphics/decorations/brendan.gbapal");

View File

@ -224,7 +224,7 @@ static void SortTrends(struct DewfordTrend *trends, u16 numTrends, u8 mode)
} }
#define SAVED_TRENDS_SIZE (sizeof(struct DewfordTrend) * SAVED_TRENDS_COUNT) #define SAVED_TRENDS_SIZE (sizeof(struct DewfordTrend) * SAVED_TRENDS_COUNT)
#define BUFFER_SIZE (SAVED_TRENDS_SIZE * MAX_LINK_PLAYERS > 0x100 ? SAVED_TRENDS_SIZE * MAX_LINK_PLAYERS : 0x100) // More space was allocated than needed #define BUFFER_SIZE max(SAVED_TRENDS_SIZE * MAX_LINK_PLAYERS, 0x100) // More space was allocated than needed
void ReceiveDewfordTrendData(struct DewfordTrend *linkedTrends, size_t size, u8 unused) void ReceiveDewfordTrendData(struct DewfordTrend *linkedTrends, size_t size, u8 unused)
{ {

View File

@ -753,11 +753,11 @@ void EReaderHelper_SerialCallback(void)
switch (sSendRecvMgr.state) switch (sSendRecvMgr.state)
{ {
case EREADER_XFR_STATE_HANDSHAKE: case EREADER_XFR_STATE_HANDSHAKE:
REG_SIOMLT_SEND = 0xCCD0; // Handshake id REG_SIOMLT_SEND = EREADER_HANDSHAKE;
*(u64 *)recv = REG_SIOMLT_RECV; *(u64 *)recv = REG_SIOMLT_RECV;
for (i = 0, cnt1 = 0, cnt2 = 0; i < 4; i++) for (i = 0, cnt1 = 0, cnt2 = 0; i < 4; i++)
{ {
if (recv[i] == 0xCCD0) if (recv[i] == EREADER_HANDSHAKE)
cnt1++; cnt1++;
else if (recv[i] != 0xFFFF) else if (recv[i] != 0xFFFF)
cnt2++; cnt2++;

View File

@ -3260,6 +3260,7 @@ void ScrollableMultichoice_ClosePersistentMenu(void)
#undef tTaskId #undef tTaskId
#define DEOXYS_ROCK_LEVELS 11 #define DEOXYS_ROCK_LEVELS 11
#define ROCK_PAL_ID 10
void DoDeoxysRockInteraction(void) void DoDeoxysRockInteraction(void)
{ {
@ -3339,7 +3340,7 @@ static void Task_DeoxysRockInteraction(u8 taskId)
static void ChangeDeoxysRockLevel(u8 rockLevel) static void ChangeDeoxysRockLevel(u8 rockLevel)
{ {
u8 objectEventId; u8 objectEventId;
LoadPalette(&sDeoxysRockPalettes[rockLevel], OBJ_PLTT_ID(10), PLTT_SIZEOF(4)); LoadPalette(&sDeoxysRockPalettes[rockLevel], OBJ_PLTT_ID(ROCK_PAL_ID), PLTT_SIZEOF(4));
TryGetObjectEventIdByLocalIdAndMap(LOCALID_BIRTH_ISLAND_EXTERIOR_ROCK, gSaveBlock1Ptr->location.mapNum, gSaveBlock1Ptr->location.mapGroup, &objectEventId); TryGetObjectEventIdByLocalIdAndMap(LOCALID_BIRTH_ISLAND_EXTERIOR_ROCK, gSaveBlock1Ptr->location.mapNum, gSaveBlock1Ptr->location.mapGroup, &objectEventId);
if (rockLevel == 0) if (rockLevel == 0)
@ -3376,21 +3377,20 @@ static void WaitForDeoxysRockMovement(u8 taskId)
void IncrementBirthIslandRockStepCount(void) void IncrementBirthIslandRockStepCount(void)
{ {
u16 var = VarGet(VAR_DEOXYS_ROCK_STEP_COUNT); u16 stepCount = VarGet(VAR_DEOXYS_ROCK_STEP_COUNT);
if (gSaveBlock1Ptr->location.mapNum == MAP_NUM(BIRTH_ISLAND_EXTERIOR) && gSaveBlock1Ptr->location.mapGroup == MAP_GROUP(BIRTH_ISLAND_EXTERIOR)) if (gSaveBlock1Ptr->location.mapNum == MAP_NUM(BIRTH_ISLAND_EXTERIOR) && gSaveBlock1Ptr->location.mapGroup == MAP_GROUP(BIRTH_ISLAND_EXTERIOR))
{ {
var++; if (++stepCount > 99)
if (var > 99)
VarSet(VAR_DEOXYS_ROCK_STEP_COUNT, 0); VarSet(VAR_DEOXYS_ROCK_STEP_COUNT, 0);
else else
VarSet(VAR_DEOXYS_ROCK_STEP_COUNT, var); VarSet(VAR_DEOXYS_ROCK_STEP_COUNT, stepCount);
} }
} }
void SetDeoxysRockPalette(void) void SetDeoxysRockPalette(void)
{ {
LoadPalette(&sDeoxysRockPalettes[(u8)VarGet(VAR_DEOXYS_ROCK_LEVEL)], OBJ_PLTT_ID(10), PLTT_SIZEOF(4)); LoadPalette(&sDeoxysRockPalettes[(u8)VarGet(VAR_DEOXYS_ROCK_LEVEL)], OBJ_PLTT_ID(ROCK_PAL_ID), PLTT_SIZEOF(4));
BlendPalettes(0x04000000, 16, 0); BlendPalettes(1 << (ROCK_PAL_ID + 16), 16, 0);
} }
void SetPCBoxToSendMon(u8 boxId) void SetPCBoxToSendMon(u8 boxId)
@ -3957,16 +3957,15 @@ bool8 InPokemonCenter(void)
#define FANCLUB_BITFIELD (gSaveBlock1Ptr->vars[VAR_FANCLUB_FAN_COUNTER - VARS_START]) #define FANCLUB_BITFIELD (gSaveBlock1Ptr->vars[VAR_FANCLUB_FAN_COUNTER - VARS_START])
#define FANCLUB_COUNTER 0x007F #define FANCLUB_COUNTER 0x007F
#define FANCLUB_FAN_FLAGS 0xFF80
#define GET_TRAINER_FAN_CLUB_FLAG(flag) (FANCLUB_BITFIELD >> (flag) & 1) #define GET_TRAINER_FAN_CLUB_FLAG(flag) (FANCLUB_BITFIELD >> (flag) & 1)
#define SET_TRAINER_FAN_CLUB_FLAG(flag) (FANCLUB_BITFIELD |= 1 << (flag)) #define SET_TRAINER_FAN_CLUB_FLAG(flag) (FANCLUB_BITFIELD |= 1 << (flag))
#define FLIP_TRAINER_FAN_CLUB_FLAG(flag)(FANCLUB_BITFIELD ^= 1 << (flag)) #define FLIP_TRAINER_FAN_CLUB_FLAG(flag)(FANCLUB_BITFIELD ^= 1 << (flag))
#define GET_TRAINER_FAN_CLUB_COUNTER (FANCLUB_BITFIELD & FANCLUB_COUNTER) #define GET_TRAINER_FAN_CLUB_COUNTER (FANCLUB_BITFIELD & FANCLUB_COUNTER)
#define SET_TRAINER_FAN_CLUB_COUNTER(count) (FANCLUB_BITFIELD = (FANCLUB_BITFIELD & FANCLUB_FAN_FLAGS) | (count)) #define SET_TRAINER_FAN_CLUB_COUNTER(count) (FANCLUB_BITFIELD = (FANCLUB_BITFIELD & ~FANCLUB_COUNTER) | (count))
#define INCR_TRAINER_FAN_CLUB_COUNTER(count)(FANCLUB_BITFIELD += (count)) #define INCR_TRAINER_FAN_CLUB_COUNTER(count)(FANCLUB_BITFIELD += (count))
#define CLEAR_TRAINER_FAN_CLUB_COUNTER (FANCLUB_BITFIELD &= ~(FANCLUB_COUNTER)) #define CLEAR_TRAINER_FAN_CLUB_COUNTER (FANCLUB_BITFIELD &= ~FANCLUB_COUNTER)
void ResetFanClub(void) void ResetFanClub(void)
{ {

View File

@ -139,7 +139,7 @@ u16 rfu_initializeAPI(u32 *APIBuffer, u16 buffByteSize, IntrFunc *sioIntrTable_p
u16 buffByteSizeMax; u16 buffByteSizeMax;
// is in EWRAM? // is in EWRAM?
if (((uintptr_t)APIBuffer & 0xF000000) == 0x2000000 && copyInterruptToRam) if (((uintptr_t)APIBuffer & 0xF000000) == EWRAM_START && copyInterruptToRam)
return ERR_RFU_API_BUFF_ADR; return ERR_RFU_API_BUFF_ADR;
// is not 4-byte aligned? // is not 4-byte aligned?
if ((u32)APIBuffer & 3) if ((u32)APIBuffer & 3)
@ -338,7 +338,7 @@ u16 rfu_getRFUStatus(u8 *rfuState)
u16 rfu_MBOOT_CHILD_inheritanceLinkStatus(void) u16 rfu_MBOOT_CHILD_inheritanceLinkStatus(void)
{ {
const char *s1 = str_checkMbootLL; const char *s1 = str_checkMbootLL;
char *s2 = (char *)0x30000F0; char *s2 = (char *)(IWRAM_START + 0xF0);
u16 checksum; u16 checksum;
u16 *mb_buff_iwram_p; u16 *mb_buff_iwram_p;
u8 i; u8 i;
@ -347,15 +347,15 @@ u16 rfu_MBOOT_CHILD_inheritanceLinkStatus(void)
while (*s1 != '\0') while (*s1 != '\0')
if (*s1++ != *s2++) if (*s1++ != *s2++)
return 1; return 1;
mb_buff_iwram_p = (u16 *)0x3000000; mb_buff_iwram_p = (u16 *)IWRAM_START;
// The size of struct RfuLinkStatus is 180 // The size of struct RfuLinkStatus is 180
checksum = 0; checksum = 0;
for (i = 0; i < 180/2; ++i) for (i = 0; i < 180/2; ++i)
checksum += *mb_buff_iwram_p++; checksum += *mb_buff_iwram_p++;
if (checksum != *(u16 *)0x30000FA) if (checksum != *(u16 *)(IWRAM_START + 0xFA))
return 1; return 1;
CpuCopy16((u16 *)0x3000000, gRfuLinkStatus, sizeof(struct RfuLinkStatus)); CpuCopy16((u16 *)IWRAM_START, gRfuLinkStatus, sizeof(struct RfuLinkStatus));
gRfuStatic->flags |= 0x80; // mboot gRfuStatic->flags |= 0x80; // mboot
return 0; return 0;
} }

View File

@ -1918,7 +1918,8 @@ static void Task_PlayerExchangeUpdate(u8 taskId)
for (i = 0; i < RFU_CHILD_MAX; i++) for (i = 0; i < RFU_CHILD_MAX; i++)
sio->linkPlayerIdx[i] = gRfu.linkPlayerIdx[i]; sio->linkPlayerIdx[i] = gRfu.linkPlayerIdx[i];
memcpy(sio->linkPlayers, gLinkPlayers, sizeof(gLinkPlayers)); memcpy(sio->linkPlayers, gLinkPlayers, sizeof(gLinkPlayers));
if (SendBlock(0, gBlockSendBuffer, 0xa0)) // Send SioInfo but exclude the 92 unused bytes at the end
if (SendBlock(0, gBlockSendBuffer, offsetof(struct SioInfo, filler)))
gTasks[taskId].tState++; gTasks[taskId].tState++;
break; break;
case 5: case 5:

View File

@ -4,6 +4,7 @@
#include "constants/rgb.h" #include "constants/rgb.h"
#include "constants/songs.h" #include "constants/songs.h"
#include "constants/trainers.h" #include "constants/trainers.h"
#include "data.h"
#include "decompress.h" #include "decompress.h"
#include "event_data.h" #include "event_data.h"
#include "field_effect.h" #include "field_effect.h"
@ -1900,7 +1901,7 @@ static void AddBirchSpeechObjects(u8 taskId)
gSprites[brendanSpriteId].invisible = TRUE; gSprites[brendanSpriteId].invisible = TRUE;
gSprites[brendanSpriteId].oam.priority = 0; gSprites[brendanSpriteId].oam.priority = 0;
gTasks[taskId].tBrendanSpriteId = brendanSpriteId; gTasks[taskId].tBrendanSpriteId = brendanSpriteId;
maySpriteId = CreateTrainerSprite(FacilityClassToPicIndex(FACILITY_CLASS_MAY), 120, 60, 0, &gDecompressionBuffer[0x800]); maySpriteId = CreateTrainerSprite(FacilityClassToPicIndex(FACILITY_CLASS_MAY), 120, 60, 0, &gDecompressionBuffer[TRAINER_PIC_SIZE]);
gSprites[maySpriteId].callback = SpriteCB_Null; gSprites[maySpriteId].callback = SpriteCB_Null;
gSprites[maySpriteId].invisible = TRUE; gSprites[maySpriteId].invisible = TRUE;
gSprites[maySpriteId].oam.priority = 0; gSprites[maySpriteId].oam.priority = 0;

View File

@ -440,7 +440,7 @@ static u8 UpdateNormalPaletteFade(void)
else else
{ {
selectedPalettes = gPaletteFade_selectedPalettes >> 16; selectedPalettes = gPaletteFade_selectedPalettes >> 16;
paletteOffset = 256; paletteOffset = OBJ_PLTT_OFFSET;
} }
while (selectedPalettes) while (selectedPalettes)

View File

@ -1419,7 +1419,7 @@ void CreateRegionMapCursor(u16 tileTag, u16 paletteTag)
sRegionMap->cursorSprite->y = 8 * sRegionMap->cursorPosY + 4; sRegionMap->cursorSprite->y = 8 * sRegionMap->cursorPosY + 4;
} }
sRegionMap->cursorSprite->data[1] = 2; sRegionMap->cursorSprite->data[1] = 2;
sRegionMap->cursorSprite->data[2] = (IndexOfSpritePaletteTag(paletteTag) << 4) + 0x101; sRegionMap->cursorSprite->data[2] = OBJ_PLTT_ID(IndexOfSpritePaletteTag(paletteTag)) + 1;
sRegionMap->cursorSprite->data[3] = TRUE; sRegionMap->cursorSprite->data[3] = TRUE;
} }
} }

View File

@ -47,6 +47,8 @@
#include "constants/songs.h" #include "constants/songs.h"
#include "constants/trainers.h" #include "constants/trainers.h"
#define TAG_SCROLL_ARROW 5112
// Values for registryStatus // Values for registryStatus
enum { enum {
UNREGISTERED, UNREGISTERED,
@ -985,7 +987,7 @@ static void FinalizeRegistryMenu(u8 taskId)
static void AddRegistryMenuScrollArrows(u8 taskId) static void AddRegistryMenuScrollArrows(u8 taskId)
{ {
s16 *data = gTasks[taskId].data; s16 *data = gTasks[taskId].data;
tArrowTaskId = AddScrollIndicatorArrowPairParameterized(SCROLL_ARROW_UP, 188, 12, 148, tNumBases - tMaxShownItems, 0x13f8, 0x13f8, &tScrollOffset); tArrowTaskId = AddScrollIndicatorArrowPairParameterized(SCROLL_ARROW_UP, 188, 12, 148, tNumBases - tMaxShownItems, TAG_SCROLL_ARROW, TAG_SCROLL_ARROW, &tScrollOffset);
} }
static void HandleRegistryMenuInput(u8 taskId) static void HandleRegistryMenuInput(u8 taskId)