summaryrefslogtreecommitdiff
path: root/src/recorded_battle.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/recorded_battle.c')
-rw-r--r--src/recorded_battle.c100
1 files changed, 50 insertions, 50 deletions
diff --git a/src/recorded_battle.c b/src/recorded_battle.c
index 6fcbe04f1..fa30c9863 100644
--- a/src/recorded_battle.c
+++ b/src/recorded_battle.c
@@ -75,10 +75,10 @@ struct RecordedBattleSave
EWRAM_DATA u32 gRecordedBattleRngSeed = 0;
EWRAM_DATA u32 gBattlePalaceMoveSelectionRngValue = 0;
EWRAM_DATA static u8 sBattleRecords[MAX_BATTLERS_COUNT][BATTLER_RECORD_SIZE] = {0};
-EWRAM_DATA static u16 sRecordedBytesNo[MAX_BATTLERS_COUNT] = {0};
-EWRAM_DATA static u16 sUnknown_0203C79C[4] = {0};
-EWRAM_DATA static u16 sUnknown_0203C7A4[4] = {0};
-EWRAM_DATA static u8 sUnknown_0203C7AC = 0;
+EWRAM_DATA static u16 sBattlerRecordSizes[MAX_BATTLERS_COUNT] = {0};
+EWRAM_DATA static u16 sBattlerPrevRecordSizes[MAX_BATTLERS_COUNT] = {0};
+EWRAM_DATA static u16 sBattlerSavedRecordSizes[MAX_BATTLERS_COUNT] = {0};
+EWRAM_DATA static u8 sRecordMode = 0;
EWRAM_DATA static u8 sLvlMode = 0;
EWRAM_DATA static u8 sFrontierFacility = 0;
EWRAM_DATA static u8 sFrontierBrainSymbol = 0;
@@ -93,7 +93,7 @@ EWRAM_DATA static struct Pokemon sSavedPlayerParty[PARTY_SIZE] = {0};
EWRAM_DATA static struct Pokemon sSavedOpponentParty[PARTY_SIZE] = {0};
EWRAM_DATA static u16 sPlayerMonMoves[2][MAX_MON_MOVES] = {0};
EWRAM_DATA static struct PlayerInfo sPlayers[MAX_BATTLERS_COUNT] = {0};
-EWRAM_DATA static u8 sUnknown_0203CCD0 = 0;
+EWRAM_DATA static bool8 sUnknown_0203CCD0 = 0;
EWRAM_DATA static u8 sRecordMixFriendName[PLAYER_NAME_LENGTH + 1] = {0};
EWRAM_DATA static u8 sRecordMixFriendClass = 0;
EWRAM_DATA static u8 sApprenticeId = 0;
@@ -103,26 +103,25 @@ EWRAM_DATA static u8 sBattleOutcome = 0;
static u8 sRecordMixFriendLanguage;
static u8 sApprenticeLanguage;
-// this file's functions
-static u8 sub_8185278(u8 *arg0, u8 *arg1, u8 *arg2);
-static bool32 CopyRecordedBattleFromSave(struct RecordedBattleSave *dst);
+static u8 GetNextRecordedDataByte(u8 *, u8 *, u8 *);
+static bool32 CopyRecordedBattleFromSave(struct RecordedBattleSave *);
static void RecordedBattle_RestoreSavedParties(void);
static void CB2_RecordedBattle(void);
-void sub_8184DA4(u8 arg0)
+void RecordedBattle_Init(u8 mode)
{
s32 i, j;
- sUnknown_0203C7AC = arg0;
- sUnknown_0203CCD0 = 0;
+ sRecordMode = mode;
+ sUnknown_0203CCD0 = FALSE;
for (i = 0; i < MAX_BATTLERS_COUNT; i++)
{
- sRecordedBytesNo[i] = 0;
- sUnknown_0203C79C[i] = 0;
- sUnknown_0203C7A4[i] = 0;
+ sBattlerRecordSizes[i] = 0;
+ sBattlerPrevRecordSizes[i] = 0;
+ sBattlerSavedRecordSizes[i] = 0;
- if (arg0 == 1)
+ if (mode == B_RECORD_MODE_RECORDING)
{
for (j = 0; j < BATTLER_RECORD_SIZE; j++)
{
@@ -138,13 +137,13 @@ void sub_8184E58(void)
{
s32 i, j;
- if (sUnknown_0203C7AC == 1)
+ if (sRecordMode == B_RECORD_MODE_RECORDING)
{
gRecordedBattleRngSeed = gRngValue;
sFrontierFacility = VarGet(VAR_FRONTIER_FACILITY);
sFrontierBrainSymbol = GetFronterBrainSymbol();
}
- else if (sUnknown_0203C7AC == 2)
+ else if (sRecordMode == B_RECORD_MODE_PLAYBACK)
{
gRngValue = gRecordedBattleRngSeed;
}
@@ -195,9 +194,9 @@ void sub_8184E58(void)
void RecordedBattle_SetBattlerAction(u8 battlerId, u8 action)
{
- if (sRecordedBytesNo[battlerId] < BATTLER_RECORD_SIZE && sUnknown_0203C7AC != 2)
+ if (sBattlerRecordSizes[battlerId] < BATTLER_RECORD_SIZE && sRecordMode != B_RECORD_MODE_PLAYBACK)
{
- sBattleRecords[battlerId][sRecordedBytesNo[battlerId]++] = action;
+ sBattleRecords[battlerId][sBattlerRecordSizes[battlerId]++] = action;
}
}
@@ -207,9 +206,9 @@ void RecordedBattle_ClearBattlerAction(u8 battlerId, u8 bytesToClear)
for (i = 0; i < bytesToClear; i++)
{
- sRecordedBytesNo[battlerId]--;
- sBattleRecords[battlerId][sRecordedBytesNo[battlerId]] = 0xFF;
- if (sRecordedBytesNo[battlerId] == 0)
+ sBattlerRecordSizes[battlerId]--;
+ sBattleRecords[battlerId][sBattlerRecordSizes[battlerId]] = 0xFF;
+ if (sBattlerRecordSizes[battlerId] == 0)
break;
}
}
@@ -217,7 +216,7 @@ void RecordedBattle_ClearBattlerAction(u8 battlerId, u8 bytesToClear)
u8 RecordedBattle_GetBattlerAction(u8 battlerId)
{
// Trying to read past array or invalid action byte, battle is over.
- if (sRecordedBytesNo[battlerId] >= BATTLER_RECORD_SIZE || sBattleRecords[battlerId][sRecordedBytesNo[battlerId]] == 0xFF)
+ if (sBattlerRecordSizes[battlerId] >= BATTLER_RECORD_SIZE || sBattleRecords[battlerId][sBattlerRecordSizes[battlerId]] == 0xFF)
{
gSpecialVar_Result = gBattleOutcome = B_OUTCOME_PLAYER_TELEPORTED; // hah
ResetPaletteFadeControl();
@@ -227,44 +226,45 @@ u8 RecordedBattle_GetBattlerAction(u8 battlerId)
}
else
{
- return sBattleRecords[battlerId][sRecordedBytesNo[battlerId]++];
+ return sBattleRecords[battlerId][sBattlerRecordSizes[battlerId]++];
}
}
-u8 sub_81850D0(void)
+// Unused
+static u8 GetRecordedBattleMode(void)
{
- return sUnknown_0203C7AC;
+ return sRecordMode;
}
-u8 sub_81850DC(u8 *arg0)
+u8 RecordedBattle_BufferNewBattlerData(u8 *dst)
{
u8 i, j;
- u8 ret = 0;
+ u8 idx = 0;
for (i = 0; i < MAX_BATTLERS_COUNT; i++)
{
- if (sRecordedBytesNo[i] != sUnknown_0203C79C[i])
+ if (sBattlerRecordSizes[i] != sBattlerPrevRecordSizes[i])
{
- arg0[ret++] = i;
- arg0[ret++] = sRecordedBytesNo[i] - sUnknown_0203C79C[i];
+ dst[idx++] = i;
+ dst[idx++] = sBattlerRecordSizes[i] - sBattlerPrevRecordSizes[i];
- for (j = 0; j < sRecordedBytesNo[i] - sUnknown_0203C79C[i]; j++)
+ for (j = 0; j < sBattlerRecordSizes[i] - sBattlerPrevRecordSizes[i]; j++)
{
- arg0[ret++] = sBattleRecords[i][sUnknown_0203C79C[i] + j];
+ dst[idx++] = sBattleRecords[i][sBattlerPrevRecordSizes[i] + j];
}
- sUnknown_0203C79C[i] = sRecordedBytesNo[i];
+ sBattlerPrevRecordSizes[i] = sBattlerRecordSizes[i];
}
}
- return ret;
+ return idx;
}
-void sub_81851A8(u8 *arg0)
+void RecordedBattle_RecordAllBattlerData(u8 *src)
{
s32 i;
- u8 var1 = 2;
- u8 var2;
+ u8 idx = 2;
+ u8 size;
if (!(gBattleTypeFlags & BATTLE_TYPE_LINK))
return;
@@ -277,23 +277,23 @@ void sub_81851A8(u8 *arg0)
if (!(gBattleTypeFlags & BATTLE_TYPE_IS_MASTER))
{
- for (var2 = *arg0; var2 != 0;)
+ for (size = *src; size != 0;)
{
- u8 unkVar = sub_8185278(arg0, &var1, &var2);
- u8 unkVar2 = sub_8185278(arg0, &var1, &var2);
+ u8 battlerId = GetNextRecordedDataByte(src, &idx, &size);
+ u8 numActions = GetNextRecordedDataByte(src, &idx, &size);
- for (i = 0; i < unkVar2; i++)
+ for (i = 0; i < numActions; i++)
{
- sBattleRecords[unkVar][sUnknown_0203C7A4[unkVar]++] = sub_8185278(arg0, &var1, &var2);
+ sBattleRecords[battlerId][sBattlerSavedRecordSizes[battlerId]++] = GetNextRecordedDataByte(src, &idx, &size);
}
}
}
}
-static u8 sub_8185278(u8 *arg0, u8 *arg1, u8 *arg2)
+static u8 GetNextRecordedDataByte(u8 *data, u8 *idx, u8 *size)
{
- (*arg2)--;
- return arg0[(*arg1)++];
+ (*size)--;
+ return data[(*idx)++];
}
bool32 CanCopyRecordedBattleSaveData(void)
@@ -720,7 +720,7 @@ void RecordedBattle_CopyBattlerMoves(void)
return;
if (gBattleTypeFlags & (BATTLE_TYPE_LINK | BATTLE_TYPE_RECORDED_LINK))
return;
- if (sUnknown_0203C7AC == 2)
+ if (sRecordMode == B_RECORD_MODE_PLAYBACK)
return;
for (i = 0; i < MAX_MON_MOVES; i++)
@@ -767,7 +767,7 @@ void sub_818603C(u8 arg0)
}
else
{
- if (sBattleRecords[battlerId][sRecordedBytesNo[battlerId]] == ACTION_MOVE_CHANGE)
+ if (sBattleRecords[battlerId][sBattlerRecordSizes[battlerId]] == ACTION_MOVE_CHANGE)
{
u8 ppBonuses[MAX_MON_MOVES];
u8 array1[MAX_MON_MOVES];
@@ -841,12 +841,12 @@ u32 GetAiScriptsInRecordedBattle(void)
void sub_8186444(void)
{
- sUnknown_0203CCD0 = 1;
+ sUnknown_0203CCD0 = TRUE;
}
bool8 sub_8186450(void)
{
- return (sUnknown_0203CCD0 == 0);
+ return (sUnknown_0203CCD0 == FALSE);
}
void GetRecordedBattleRecordMixFriendName(u8 *dst)