2020-03-27 21:47:29 +01:00
|
|
|
#include "THISDUST.H"
|
|
|
|
#include "REPLAYS.H"
|
2020-05-09 10:00:06 +02:00
|
|
|
#include "MAP.H"
|
|
|
|
#include "SPOOL.H"
|
2020-05-18 20:32:30 +02:00
|
|
|
#include "SYSTEM.H"
|
|
|
|
#include "CUTSCENE.H"
|
|
|
|
#include "PLAYERS.H"
|
|
|
|
#include "GLAUNCH.H"
|
|
|
|
#include "MISSION.H"
|
|
|
|
#include "DIRECTOR.H"
|
2020-05-18 21:10:55 +02:00
|
|
|
#include "CAMERA.H"
|
|
|
|
#include "CIV_AI.H"
|
2020-03-27 21:47:29 +01:00
|
|
|
|
2020-05-20 20:30:02 +02:00
|
|
|
#include "STRINGS.H"
|
|
|
|
|
2020-05-19 21:00:39 +02:00
|
|
|
char AnalogueUnpack[16] = {
|
|
|
|
0, -51, -63, -75, -87, -99, -111, -123,
|
|
|
|
0, 51, 63, 75, 87, 99, 111, 123
|
|
|
|
};
|
2020-03-27 21:47:29 +01:00
|
|
|
|
2020-04-17 20:27:24 +02:00
|
|
|
int gOutOfTape = 0;
|
|
|
|
|
2020-04-17 21:55:31 +02:00
|
|
|
REPLAY_PARAMETER_BLOCK *ReplayParameterPtr = NULL;
|
|
|
|
|
- implement MRCommitThreadGenocide, MRStartThread, MRFunction, MRHandleCarRequests, MRCreateCar, MRCancelCarRequest, SetPlayerMessage, SetMissionMessage, PauseMissionTimer, PreProcessTargets, HandleGameOver, CompleteAllActiveTargets, SetMissionComplete, SetMissionOver, ActivateNextFlag, CalcLapTime, SetCarToBeStolen, MakePhantomCarEqualPlayerCar
- bunch of pretty mission code
2020-05-16 17:42:55 +02:00
|
|
|
REPLAY_STREAM ReplayStreams[8];
|
|
|
|
int NumReplayStreams = 1;
|
|
|
|
|
2020-05-18 20:32:30 +02:00
|
|
|
char *ReplayStart;
|
|
|
|
char *replayptr = NULL;
|
|
|
|
int ReplaySize = 0;
|
|
|
|
|
|
|
|
unsigned long PingBufferPos = 0;
|
|
|
|
_PING_PACKET *PingBuffer = NULL;
|
|
|
|
|
|
|
|
SXYPAIR *PlayerWayRecordPtr = NULL;
|
|
|
|
PLAYBACKCAMERA *PlaybackCamera = NULL;
|
|
|
|
|
|
|
|
int TimeToWay = 0;
|
|
|
|
short PlayerWaypoints = 0;
|
|
|
|
int way_distance = 0;
|
|
|
|
|
2020-05-27 18:02:16 +02:00
|
|
|
#define MISSIOH_IDENT (('D' << 24) | ('2' << 16) | ('R' << 8) | 'P' )
|
|
|
|
|
2020-03-27 21:47:29 +01:00
|
|
|
// decompiled code
|
|
|
|
// original method signature:
|
|
|
|
// void /*$ra*/ InitPadRecording()
|
|
|
|
// line 498, offset 0x0001a09c
|
|
|
|
/* begin block 1 */
|
|
|
|
// Start line: 500
|
|
|
|
// Start offset: 0x0001A09C
|
|
|
|
// Variables:
|
|
|
|
// int i; // $s0
|
|
|
|
// int remain; // $s0
|
|
|
|
/* end block 1 */
|
|
|
|
// End offset: 0x0001A234
|
|
|
|
// End Line: 650
|
|
|
|
|
|
|
|
/* begin block 2 */
|
|
|
|
// Start line: 996
|
|
|
|
/* end block 2 */
|
|
|
|
// End Line: 997
|
|
|
|
|
|
|
|
/* begin block 3 */
|
|
|
|
// Start line: 997
|
|
|
|
/* end block 3 */
|
|
|
|
// End Line: 998
|
|
|
|
|
|
|
|
/* begin block 4 */
|
|
|
|
// Start line: 1001
|
|
|
|
/* end block 4 */
|
|
|
|
// End Line: 1002
|
|
|
|
|
|
|
|
/* WARNING: Unknown calling convention yet parameter storage is locked */
|
|
|
|
|
2020-05-18 20:32:30 +02:00
|
|
|
// [D]
|
2020-03-27 21:47:29 +01:00
|
|
|
void InitPadRecording(void)
|
|
|
|
{
|
2020-03-29 22:33:32 +02:00
|
|
|
char *pcVar1;
|
|
|
|
char *pcVar2;
|
2020-05-18 20:32:30 +02:00
|
|
|
|
|
|
|
int i;
|
2020-03-29 22:33:32 +02:00
|
|
|
REPLAY_STREAM *stream;
|
|
|
|
|
|
|
|
gOutOfTape = 0;
|
2020-05-18 20:32:30 +02:00
|
|
|
|
|
|
|
if (gLoadedReplay == 0)
|
|
|
|
{
|
2020-03-29 22:33:32 +02:00
|
|
|
NumReplayStreams = 0;
|
2020-05-18 20:32:30 +02:00
|
|
|
|
|
|
|
ReplayStart = _replay_buffer;
|
|
|
|
ReplayParameterPtr = (REPLAY_PARAMETER_BLOCK *)ReplayStart;
|
|
|
|
|
2020-05-20 17:34:30 +02:00
|
|
|
PlayerWayRecordPtr = (SXYPAIR *)(ReplayParameterPtr + 1);
|
2020-05-18 20:32:30 +02:00
|
|
|
|
2020-05-20 17:34:30 +02:00
|
|
|
PlaybackCamera = (PLAYBACKCAMERA *)(PlayerWayRecordPtr + 150);
|
2020-05-18 20:32:30 +02:00
|
|
|
|
2020-05-20 17:34:30 +02:00
|
|
|
PingBuffer = (_PING_PACKET *)(PlaybackCamera + 60);
|
2020-05-18 20:32:30 +02:00
|
|
|
setMem8((u_char*)PingBuffer, -1, sizeof(_PING_PACKET) * 400);
|
|
|
|
|
2020-05-20 17:34:30 +02:00
|
|
|
replayptr = (char*)(PingBuffer + 400);
|
2020-05-18 20:32:30 +02:00
|
|
|
|
2020-03-29 22:33:32 +02:00
|
|
|
pcVar1 = ReplayStart;
|
2020-05-18 20:32:30 +02:00
|
|
|
pcVar2 = replayptr-0x3444;
|
|
|
|
|
|
|
|
int cutsceneSize = CalcInGameCutsceneSize();
|
|
|
|
|
|
|
|
for (i = 0; i < NumPlayers; i++)
|
2020-05-19 17:45:40 +02:00
|
|
|
{
|
2020-05-18 20:32:30 +02:00
|
|
|
AllocateReplayStream(&ReplayStreams[i], ((int)(pcVar1 + (-cutsceneSize - (int)pcVar2)) / sizeof(PADRECORD)) / NumPlayers);
|
2020-05-19 17:45:40 +02:00
|
|
|
NumReplayStreams++;
|
|
|
|
}
|
2020-05-18 20:32:30 +02:00
|
|
|
|
|
|
|
ReplaySize = (replayptr - ReplayStart);
|
2020-03-29 22:33:32 +02:00
|
|
|
}
|
2020-05-18 20:32:30 +02:00
|
|
|
else
|
|
|
|
{
|
|
|
|
for (i = 0; i < NumReplayStreams; i++)
|
|
|
|
{
|
|
|
|
ReplayStreams[i].playbackrun = 0;
|
2020-05-20 23:33:21 +02:00
|
|
|
ReplayStreams[i].PadRecordBuffer = ReplayStreams[i].InitialPadRecordBuffer;
|
2020-03-29 22:33:32 +02:00
|
|
|
}
|
|
|
|
}
|
2020-05-18 20:32:30 +02:00
|
|
|
|
|
|
|
TimeToWay = 150;
|
2020-03-29 22:33:32 +02:00
|
|
|
PlayerWaypoints = 0;
|
|
|
|
way_distance = 100;
|
2020-05-18 20:32:30 +02:00
|
|
|
|
2020-03-29 22:33:32 +02:00
|
|
|
InitDirectorVariables();
|
|
|
|
InitInGameCutsceneVariables();
|
2020-03-27 21:47:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// decompiled code
|
|
|
|
// original method signature:
|
|
|
|
// int /*$ra*/ SaveReplayToBuffer(char *buffer /*$s0*/)
|
|
|
|
// line 657, offset 0x0001a234
|
|
|
|
/* begin block 1 */
|
|
|
|
// Start line: 658
|
|
|
|
// Start offset: 0x0001A234
|
|
|
|
// Variables:
|
|
|
|
// struct REPLAY_SAVE_HEADER *header; // $s2
|
|
|
|
// int i; // $a2
|
|
|
|
// int size; // $s1
|
|
|
|
// int numstreams; // $s6
|
|
|
|
/* end block 1 */
|
|
|
|
// End offset: 0x0001A798
|
|
|
|
// End Line: 733
|
|
|
|
|
|
|
|
/* begin block 2 */
|
|
|
|
// Start line: 1340
|
|
|
|
/* end block 2 */
|
|
|
|
// End Line: 1341
|
|
|
|
|
|
|
|
/* begin block 3 */
|
|
|
|
// Start line: 1348
|
|
|
|
/* end block 3 */
|
|
|
|
// End Line: 1349
|
|
|
|
|
2020-05-27 18:02:16 +02:00
|
|
|
// [D]
|
2020-03-27 21:47:29 +01:00
|
|
|
int SaveReplayToBuffer(char *buffer)
|
|
|
|
{
|
2020-05-27 18:02:16 +02:00
|
|
|
REPLAY_STREAM_HEADER *sheader;
|
|
|
|
REPLAY_SAVE_HEADER *header;
|
|
|
|
|
|
|
|
if (buffer == NULL)
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
char* pt = buffer;
|
|
|
|
header = (REPLAY_SAVE_HEADER*)pt;
|
|
|
|
pt += sizeof(REPLAY_SAVE_HEADER);
|
|
|
|
|
|
|
|
header->magic = 0x14793209; // TODO: custom
|
|
|
|
header->GameLevel = GameLevel;
|
|
|
|
header->GameType = GameType;
|
|
|
|
header->NumReplayStreams = NumReplayStreams;
|
|
|
|
header->MissionNumber = gCurrentMissionNumber;
|
|
|
|
|
|
|
|
header->NumPlayers = NumPlayers;
|
|
|
|
header->CutsceneEvent = -1;
|
|
|
|
header->RandomChase = gRandomChase;
|
|
|
|
|
|
|
|
header->gCopDifficultyLevel = gCopDifficultyLevel;
|
|
|
|
header->ActiveCheats = ActiveCheats;
|
|
|
|
|
|
|
|
header->wantedCar[0] = wantedCar[0];
|
|
|
|
header->wantedCar[1] = wantedCar[1];
|
|
|
|
|
|
|
|
memcpy(&header->SavedData, &MissionEndData, sizeof(MISSION_DATA));
|
|
|
|
|
|
|
|
// write each stream data
|
2020-05-27 20:07:54 +02:00
|
|
|
#ifdef CUTSCENE_RECORDER
|
|
|
|
int numStreams = gCutsceneAsReplay ? NumReplayStreams : NumPlayers;
|
|
|
|
|
|
|
|
for (int i = 0; i < numStreams; i++)
|
|
|
|
#else
|
|
|
|
for (int i = 0; i < NumPlayers; i++)
|
|
|
|
#endif
|
2020-05-27 18:02:16 +02:00
|
|
|
{
|
|
|
|
sheader = (REPLAY_STREAM_HEADER *)pt;
|
|
|
|
pt += sizeof(REPLAY_STREAM_HEADER);
|
|
|
|
|
|
|
|
REPLAY_STREAM* srcStream = &ReplayStreams[i];
|
|
|
|
|
|
|
|
// copy source type
|
|
|
|
memcpy(&sheader->SourceType, &srcStream->SourceType, sizeof(STREAM_SOURCE));
|
|
|
|
sheader->Size = srcStream->PadRecordBufferEnd - srcStream->InitialPadRecordBuffer;
|
|
|
|
sheader->Length = srcStream->length;
|
|
|
|
|
|
|
|
int size = (sheader->Size + sizeof(PADRECORD)) & -4;
|
|
|
|
|
|
|
|
// copy pad data to write buffer
|
|
|
|
memcpy(pt, srcStream->InitialPadRecordBuffer, size);
|
|
|
|
|
|
|
|
pt += size;
|
2020-03-29 22:33:32 +02:00
|
|
|
}
|
2020-05-27 18:02:16 +02:00
|
|
|
|
|
|
|
#ifdef CUTSCENE_RECORDER
|
|
|
|
if (gCutsceneAsReplay == 0)
|
|
|
|
#endif
|
|
|
|
{
|
|
|
|
memcpy(pt, ReplayParameterPtr, sizeof(REPLAY_PARAMETER_BLOCK));
|
|
|
|
pt += sizeof(REPLAY_PARAMETER_BLOCK);
|
2020-03-29 22:33:32 +02:00
|
|
|
}
|
2020-05-27 18:02:16 +02:00
|
|
|
|
|
|
|
#ifdef CUTSCENE_RECORDER
|
|
|
|
if (gCutsceneAsReplay == 0)
|
|
|
|
#endif
|
|
|
|
{
|
|
|
|
memcpy(pt, PlayerWayRecordPtr, sizeof(SXYPAIR) * 150);
|
|
|
|
pt += sizeof(SXYPAIR) * 150;
|
|
|
|
}
|
|
|
|
|
|
|
|
memcpy(pt, PlaybackCamera, sizeof(PLAYBACKCAMERA) * 60);
|
|
|
|
pt += sizeof(PLAYBACKCAMERA) * 60;
|
|
|
|
|
|
|
|
memcpy(pt, PingBuffer, sizeof(_PING_PACKET) * 400);
|
|
|
|
pt += sizeof(_PING_PACKET) * 400;
|
|
|
|
|
2020-05-27 20:07:54 +02:00
|
|
|
// [A] is that ever valid?
|
|
|
|
if (gHaveStoredData)
|
2020-05-27 18:02:16 +02:00
|
|
|
{
|
|
|
|
header->HaveStoredData = 0x91827364; // -0x6e7d8c9c
|
|
|
|
memcpy(pt, &MissionStartData, sizeof(MISSION_DATA));
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0x3644; // size?
|
2020-03-27 21:47:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// decompiled code
|
|
|
|
// original method signature:
|
|
|
|
// int /*$ra*/ LoadReplayFromBuffer(char *buffer /*$s1*/)
|
|
|
|
// line 740, offset 0x0001a798
|
|
|
|
/* begin block 1 */
|
|
|
|
// Start line: 742
|
|
|
|
// Start offset: 0x0001A798
|
|
|
|
// Variables:
|
|
|
|
// struct REPLAY_SAVE_HEADER *header; // $s3
|
|
|
|
// struct REPLAY_STREAM_HEADER *sheader; // $t0
|
|
|
|
// int i; // $a1
|
|
|
|
// int size; // $s0
|
|
|
|
/* end block 1 */
|
|
|
|
// End offset: 0x0001AD50
|
|
|
|
// End Line: 813
|
|
|
|
|
|
|
|
/* begin block 2 */
|
|
|
|
// Start line: 1574
|
|
|
|
/* end block 2 */
|
|
|
|
// End Line: 1575
|
|
|
|
|
|
|
|
/* begin block 3 */
|
|
|
|
// Start line: 1582
|
|
|
|
/* end block 3 */
|
|
|
|
// End Line: 1583
|
|
|
|
|
|
|
|
/* begin block 4 */
|
|
|
|
// Start line: 1583
|
|
|
|
/* end block 4 */
|
|
|
|
// End Line: 1584
|
|
|
|
|
|
|
|
/* begin block 5 */
|
|
|
|
// Start line: 1587
|
|
|
|
/* end block 5 */
|
|
|
|
// End Line: 1588
|
|
|
|
|
2020-05-20 23:33:21 +02:00
|
|
|
#ifdef CUTSCENE_RECORDER
|
|
|
|
int gCutsceneAsReplay = 0;
|
|
|
|
int gCutsceneAsReplay_PlayerId = 0;
|
|
|
|
int gCutsceneAsReplay_PlayerChanged = 0;
|
|
|
|
char gCutsceneRecorderPauseText[64] = { 0 };
|
|
|
|
|
|
|
|
void NextCutsceneRecorderPlayer(int dir)
|
|
|
|
{
|
|
|
|
int old_player = gCutsceneAsReplay_PlayerId;
|
|
|
|
|
|
|
|
if(dir > 0)
|
|
|
|
gCutsceneAsReplay_PlayerId++;
|
|
|
|
else if(dir < 0)
|
|
|
|
gCutsceneAsReplay_PlayerId--;
|
|
|
|
|
|
|
|
if (gCutsceneAsReplay_PlayerId >= NumReplayStreams)
|
|
|
|
gCutsceneAsReplay_PlayerId -= NumReplayStreams;
|
|
|
|
else if (gCutsceneAsReplay_PlayerId < 0)
|
|
|
|
gCutsceneAsReplay_PlayerId += NumReplayStreams;
|
|
|
|
|
|
|
|
if (old_player != gCutsceneAsReplay_PlayerId)
|
|
|
|
gCutsceneAsReplay_PlayerChanged = 1;
|
|
|
|
|
|
|
|
sprintf(gCutsceneRecorderPauseText, "CUTSCENE PLAYER ID: %d", gCutsceneAsReplay_PlayerId);
|
|
|
|
}
|
|
|
|
|
|
|
|
int LoadCutsceneAsReplay(int subindex)
|
|
|
|
{
|
|
|
|
int offset;
|
|
|
|
int size;
|
|
|
|
|
|
|
|
if (gCutsceneAsReplay_PlayerId > 0)
|
|
|
|
gCutsceneAsReplay_PlayerChanged = 1;
|
|
|
|
|
|
|
|
NextCutsceneRecorderPlayer(0);
|
|
|
|
|
|
|
|
CUTSCENE_HEADER header;
|
|
|
|
char filename[64];
|
|
|
|
|
|
|
|
if (gCutsceneAsReplay < 21)
|
|
|
|
sprintf(filename, "REPLAYS\\CUT%d.R", gCutsceneAsReplay);
|
|
|
|
else
|
|
|
|
sprintf(filename, "REPLAYS\\A\\CUT%d.R", gCutsceneAsReplay);
|
|
|
|
|
|
|
|
if (FileExists(filename))
|
|
|
|
{
|
|
|
|
LoadfileSeg(filename, (char *)&header, 0, sizeof(CUTSCENE_HEADER));
|
|
|
|
|
|
|
|
if (header.data[subindex].offset != 0xffff)
|
|
|
|
{
|
|
|
|
offset = header.data[subindex].offset * 4;
|
|
|
|
size = header.data[subindex].size;
|
|
|
|
|
|
|
|
LoadfileSeg(filename, _other_buffer, offset, size);
|
|
|
|
|
|
|
|
return LoadReplayFromBuffer(_other_buffer);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
printError("Invalid cutscene subindex or mission!\n");
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
#endif // CUTSCENE_RECORDER
|
|
|
|
|
2020-05-20 20:30:02 +02:00
|
|
|
// [D]
|
2020-03-27 21:47:29 +01:00
|
|
|
int LoadReplayFromBuffer(char *buffer)
|
|
|
|
{
|
2020-05-20 20:30:02 +02:00
|
|
|
REPLAY_SAVE_HEADER *header;
|
|
|
|
REPLAY_STREAM_HEADER *sheader;
|
|
|
|
|
|
|
|
char* pt = buffer;
|
|
|
|
|
|
|
|
header = (REPLAY_SAVE_HEADER*)pt;
|
|
|
|
|
|
|
|
if (header->magic != 0x14793209)
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
ReplayStart = replayptr = _replay_buffer;
|
|
|
|
|
|
|
|
GameLevel = header->GameLevel;
|
|
|
|
GameType = (GAMETYPE)header->GameType;
|
2020-05-20 23:33:21 +02:00
|
|
|
|
|
|
|
#ifdef CUTSCENE_RECORDER
|
|
|
|
if(gCutsceneAsReplay == 0)
|
|
|
|
#endif
|
|
|
|
gCurrentMissionNumber = header->MissionNumber;
|
|
|
|
|
2020-05-20 20:30:02 +02:00
|
|
|
NumReplayStreams = header->NumReplayStreams;
|
|
|
|
NumPlayers = header->NumPlayers;
|
|
|
|
gRandomChase = header->RandomChase;
|
|
|
|
CutsceneEventTrigger = header->CutsceneEvent;
|
|
|
|
gCopDifficultyLevel = header->gCopDifficultyLevel;
|
|
|
|
ActiveCheats = header->ActiveCheats; // TODO: restore old value
|
|
|
|
|
|
|
|
wantedCar[0] = header->wantedCar[0];
|
|
|
|
wantedCar[1] = header->wantedCar[1];
|
|
|
|
|
|
|
|
memcpy(&MissionEndData, &header->SavedData, sizeof(MISSION_DATA));
|
|
|
|
|
|
|
|
pt = (char*)(header+1);
|
|
|
|
|
2020-05-20 23:33:21 +02:00
|
|
|
int maxLength = 0;
|
2020-05-20 20:30:02 +02:00
|
|
|
for (int i = 0; i < NumReplayStreams; i++)
|
|
|
|
{
|
|
|
|
sheader = (REPLAY_STREAM_HEADER *)pt;
|
|
|
|
pt += sizeof(REPLAY_STREAM_HEADER);
|
|
|
|
|
|
|
|
REPLAY_STREAM* destStream = &ReplayStreams[i];
|
|
|
|
|
|
|
|
// copy source type
|
|
|
|
memcpy(&destStream->SourceType, &sheader->SourceType, sizeof(STREAM_SOURCE));
|
|
|
|
|
|
|
|
// init buffers
|
|
|
|
destStream->InitialPadRecordBuffer = (PADRECORD*)replayptr;
|
|
|
|
destStream->PadRecordBuffer = (PADRECORD*)replayptr;
|
|
|
|
destStream->PadRecordBufferEnd = (PADRECORD *)(replayptr + sheader->Size);
|
|
|
|
destStream->length = sheader->Length;
|
|
|
|
|
2020-05-20 23:33:21 +02:00
|
|
|
if (sheader->Length > maxLength)
|
|
|
|
maxLength = sheader->Length;
|
|
|
|
|
2020-05-20 20:30:02 +02:00
|
|
|
int size = (sheader->Size + sizeof(PADRECORD)) & -4;
|
|
|
|
|
|
|
|
// copy pad data and advance buffer
|
|
|
|
memcpy(replayptr, pt, size);
|
|
|
|
replayptr += size;
|
|
|
|
|
|
|
|
pt += size;
|
|
|
|
}
|
|
|
|
|
|
|
|
ReplayParameterPtr = (REPLAY_PARAMETER_BLOCK *)replayptr;
|
2020-05-20 23:33:21 +02:00
|
|
|
#ifdef CUTSCENE_RECORDER
|
|
|
|
if (gCutsceneAsReplay != 0)
|
|
|
|
{
|
|
|
|
memset(ReplayParameterPtr, 0, sizeof(REPLAY_PARAMETER_BLOCK));
|
|
|
|
ReplayParameterPtr->RecordingEnd = maxLength;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
#endif
|
|
|
|
{
|
|
|
|
memcpy(ReplayParameterPtr, pt, sizeof(REPLAY_PARAMETER_BLOCK));
|
|
|
|
pt += sizeof(REPLAY_PARAMETER_BLOCK);
|
|
|
|
}
|
|
|
|
|
2020-05-20 20:30:02 +02:00
|
|
|
|
|
|
|
PlayerWayRecordPtr = (SXYPAIR *)(ReplayParameterPtr + 1);
|
2020-05-20 23:33:21 +02:00
|
|
|
#ifdef CUTSCENE_RECORDER
|
|
|
|
if (gCutsceneAsReplay != 0)
|
|
|
|
{
|
|
|
|
memset(PlayerWayRecordPtr, 0, sizeof(SXYPAIR) * 150);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
#endif
|
|
|
|
{
|
|
|
|
memcpy(PlayerWayRecordPtr, pt, sizeof(SXYPAIR) * 150);
|
|
|
|
pt += sizeof(SXYPAIR) * 150;
|
|
|
|
}
|
|
|
|
|
2020-05-20 20:30:02 +02:00
|
|
|
|
|
|
|
PlaybackCamera = (PLAYBACKCAMERA *)(PlayerWayRecordPtr + 150);
|
|
|
|
memcpy(PlaybackCamera, pt, sizeof(PLAYBACKCAMERA) * 60);
|
|
|
|
pt += sizeof(PLAYBACKCAMERA) * 60;
|
|
|
|
|
|
|
|
PingBufferPos = 0;
|
|
|
|
PingBuffer = (_PING_PACKET *)(PlaybackCamera + 60);
|
|
|
|
memcpy(PingBuffer, pt, sizeof(_PING_PACKET) * 400);
|
|
|
|
pt += sizeof(_PING_PACKET) * 400;
|
|
|
|
|
|
|
|
replayptr = (char*)(PingBuffer + 400);
|
|
|
|
|
|
|
|
if (header->HaveStoredData == 0x91827364) // -0x6e7d8c9c
|
|
|
|
{
|
|
|
|
memcpy(&MissionStartData, pt, sizeof(MISSION_DATA));
|
|
|
|
gHaveStoredData = 1;
|
2020-03-29 22:33:32 +02:00
|
|
|
}
|
2020-05-20 20:30:02 +02:00
|
|
|
|
|
|
|
return 1;
|
2020-03-27 21:47:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// decompiled code
|
|
|
|
// original method signature:
|
|
|
|
// int /*$ra*/ LoadAttractReplay(int mission /*$a2*/)
|
|
|
|
// line 1059, offset 0x0001b118
|
|
|
|
/* begin block 1 */
|
|
|
|
// Start line: 1060
|
|
|
|
// Start offset: 0x0001B118
|
|
|
|
// Variables:
|
|
|
|
// char filename[32]; // stack offset -40
|
|
|
|
/* end block 1 */
|
|
|
|
// End offset: 0x0001B17C
|
|
|
|
// End Line: 1071
|
|
|
|
|
|
|
|
/* begin block 2 */
|
|
|
|
// Start line: 2231
|
|
|
|
/* end block 2 */
|
|
|
|
// End Line: 2232
|
|
|
|
|
|
|
|
/* begin block 3 */
|
|
|
|
// Start line: 2118
|
|
|
|
/* end block 3 */
|
|
|
|
// End Line: 2119
|
|
|
|
|
2020-05-20 20:30:02 +02:00
|
|
|
// [D]
|
2020-03-27 21:47:29 +01:00
|
|
|
int LoadAttractReplay(int mission)
|
|
|
|
{
|
2020-05-20 20:30:02 +02:00
|
|
|
char filename[32];
|
2020-03-29 22:33:32 +02:00
|
|
|
|
2020-05-20 20:30:02 +02:00
|
|
|
sprintf(filename,"REPLAYS\\ATTRACT.%d", mission);
|
|
|
|
|
|
|
|
if (!FileExists(filename))
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
if (!Loadfile(filename, _other_buffer))
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
return LoadReplayFromBuffer(_other_buffer);
|
2020-03-27 21:47:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// decompiled code
|
|
|
|
// original method signature:
|
|
|
|
// char /*$ra*/ GetPingInfo(char *cookieCount /*$a2*/)
|
|
|
|
// line 1182, offset 0x0001b090
|
|
|
|
/* begin block 1 */
|
|
|
|
// Start line: 1183
|
|
|
|
// Start offset: 0x0001B090
|
|
|
|
// Variables:
|
|
|
|
// struct _PING_PACKET *pp; // $a1
|
|
|
|
// char retCarId; // $v0
|
|
|
|
/* end block 1 */
|
|
|
|
// End offset: 0x0001B118
|
|
|
|
// End Line: 1206
|
|
|
|
|
|
|
|
/* begin block 2 */
|
|
|
|
// Start line: 2864
|
|
|
|
/* end block 2 */
|
|
|
|
// End Line: 2865
|
|
|
|
|
|
|
|
/* begin block 3 */
|
|
|
|
// Start line: 2364
|
|
|
|
/* end block 3 */
|
|
|
|
// End Line: 2365
|
|
|
|
|
2020-05-18 21:10:55 +02:00
|
|
|
// [D]
|
2020-03-27 21:47:29 +01:00
|
|
|
char GetPingInfo(char *cookieCount)
|
|
|
|
{
|
2020-03-29 22:33:32 +02:00
|
|
|
char cVar1;
|
|
|
|
_PING_PACKET *p_Var2;
|
|
|
|
|
|
|
|
p_Var2 = PingBuffer + PingBufferPos;
|
2020-05-18 21:10:55 +02:00
|
|
|
|
|
|
|
if (PingBuffer != NULL && PingBufferPos < 400)
|
|
|
|
{
|
2020-03-29 22:33:32 +02:00
|
|
|
cVar1 = -1;
|
2020-05-18 21:10:55 +02:00
|
|
|
if (p_Var2->frame != 0xffff)
|
|
|
|
{
|
|
|
|
if ((CameraCnt - frameStart & 0xffffU) < p_Var2->frame)
|
2020-03-29 22:33:32 +02:00
|
|
|
return -1;
|
2020-05-18 21:10:55 +02:00
|
|
|
|
2020-03-29 22:33:32 +02:00
|
|
|
cVar1 = p_Var2->carId;
|
|
|
|
*cookieCount = p_Var2->cookieCount;
|
|
|
|
PingBufferPos = PingBufferPos + 1;
|
|
|
|
}
|
|
|
|
return cVar1;
|
|
|
|
}
|
2020-05-18 21:10:55 +02:00
|
|
|
|
2020-03-29 22:33:32 +02:00
|
|
|
return -1;
|
2020-03-27 21:47:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// decompiled code
|
|
|
|
// original method signature:
|
|
|
|
// int /*$ra*/ valid_region(int x /*$a0*/, int z /*$a1*/)
|
|
|
|
// line 1222, offset 0x0001af34
|
|
|
|
/* begin block 1 */
|
|
|
|
// Start line: 1224
|
|
|
|
// Start offset: 0x0001AF34
|
|
|
|
// Variables:
|
|
|
|
// struct XYPAIR region_coords; // stack offset -8
|
|
|
|
// int region; // $a0
|
|
|
|
/* end block 1 */
|
|
|
|
// End offset: 0x0001AFFC
|
|
|
|
// End Line: 1269
|
|
|
|
|
|
|
|
/* begin block 2 */
|
|
|
|
// Start line: 2441
|
|
|
|
/* end block 2 */
|
|
|
|
// End Line: 2442
|
|
|
|
|
|
|
|
/* begin block 3 */
|
|
|
|
// Start line: 2828
|
|
|
|
/* end block 3 */
|
|
|
|
// End Line: 2829
|
|
|
|
|
|
|
|
/* begin block 4 */
|
|
|
|
// Start line: 2829
|
|
|
|
/* end block 4 */
|
|
|
|
// End Line: 2830
|
|
|
|
|
|
|
|
/* begin block 5 */
|
|
|
|
// Start line: 2832
|
|
|
|
/* end block 5 */
|
|
|
|
// End Line: 2833
|
|
|
|
|
2020-05-09 10:00:06 +02:00
|
|
|
// [D]
|
2020-03-29 22:33:32 +02:00
|
|
|
int valid_region(int x, int z)
|
2020-03-27 21:47:29 +01:00
|
|
|
{
|
2020-03-29 22:33:32 +02:00
|
|
|
int iVar1;
|
|
|
|
int iVar2;
|
|
|
|
|
|
|
|
iVar1 = (x >> 0x10) + regions_across / 2;
|
|
|
|
iVar2 = (z >> 0x10) + regions_down / 2;
|
2020-05-09 10:00:06 +02:00
|
|
|
|
2020-03-29 22:33:32 +02:00
|
|
|
if (-1 < iVar1) {
|
2020-05-09 10:00:06 +02:00
|
|
|
if (regions_across < iVar1)
|
2020-03-29 22:33:32 +02:00
|
|
|
return 0;
|
2020-05-09 10:00:06 +02:00
|
|
|
|
|
|
|
if (-1 < iVar2)
|
|
|
|
{
|
|
|
|
if (regions_down < iVar2)
|
2020-03-29 22:33:32 +02:00
|
|
|
return 0;
|
2020-05-09 10:00:06 +02:00
|
|
|
|
2020-03-29 22:33:32 +02:00
|
|
|
iVar1 = iVar1 + iVar2 * regions_across;
|
2020-05-09 10:00:06 +02:00
|
|
|
|
|
|
|
if (iVar1 != regions_unpacked[0])
|
|
|
|
{
|
|
|
|
if (iVar1 == regions_unpacked[1])
|
2020-03-29 22:33:32 +02:00
|
|
|
return iVar1 + 1;
|
2020-05-09 10:00:06 +02:00
|
|
|
|
|
|
|
if (iVar1 == regions_unpacked[2])
|
2020-03-29 22:33:32 +02:00
|
|
|
return iVar1 + 1;
|
2020-05-09 10:00:06 +02:00
|
|
|
|
|
|
|
if (iVar1 != regions_unpacked[3])
|
2020-03-29 22:33:32 +02:00
|
|
|
return 0;
|
|
|
|
}
|
2020-05-09 10:00:06 +02:00
|
|
|
|
2020-03-29 22:33:32 +02:00
|
|
|
return iVar1 + 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return 0;
|
2020-03-27 21:47:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// decompiled code
|
|
|
|
// original method signature:
|
|
|
|
// int /*$ra*/ cjpPlay(int stream /*$a0*/, unsigned long *ppad /*$s2*/, char *psteer /*$s0*/, char *ptype /*$s1*/)
|
|
|
|
// line 1271, offset 0x0001affc
|
|
|
|
/* begin block 1 */
|
|
|
|
// Start line: 1272
|
|
|
|
// Start offset: 0x0001AFFC
|
|
|
|
// Variables:
|
|
|
|
// int ret; // $a0
|
|
|
|
// unsigned long t0; // stack offset -24
|
|
|
|
// int t1; // $v1
|
|
|
|
/* end block 1 */
|
|
|
|
// End offset: 0x0001B090
|
|
|
|
// End Line: 1291
|
|
|
|
|
|
|
|
/* begin block 2 */
|
|
|
|
// Start line: 2928
|
|
|
|
/* end block 2 */
|
|
|
|
// End Line: 2929
|
|
|
|
|
|
|
|
/* begin block 3 */
|
|
|
|
// Start line: 2931
|
|
|
|
/* end block 3 */
|
|
|
|
// End Line: 2932
|
|
|
|
|
2020-05-19 21:00:39 +02:00
|
|
|
// [D]
|
2020-03-29 22:33:32 +02:00
|
|
|
int cjpPlay(int stream, ulong *ppad, char *psteer, char *ptype)
|
2020-03-27 21:47:29 +01:00
|
|
|
{
|
2020-05-19 21:00:39 +02:00
|
|
|
int ret;
|
|
|
|
int t1;
|
|
|
|
ulong t0;
|
|
|
|
|
2020-05-20 23:33:21 +02:00
|
|
|
#ifdef CUTSCENE_RECORDER
|
|
|
|
if (stream < 0)
|
|
|
|
stream = -stream;
|
|
|
|
#endif
|
|
|
|
|
2020-05-19 21:00:39 +02:00
|
|
|
ret = Get(stream, &t0);
|
|
|
|
|
2020-05-20 13:06:29 +02:00
|
|
|
t1 = (t0 >> 8) & 0xF;
|
2020-05-19 21:00:39 +02:00
|
|
|
|
2020-05-20 13:06:29 +02:00
|
|
|
*ppad = t0 & 0xF0FC;
|
2020-05-19 21:00:39 +02:00
|
|
|
|
|
|
|
if (t1 == 0)
|
|
|
|
{
|
|
|
|
*psteer = 0;
|
|
|
|
*ptype = 0;
|
2020-03-29 22:33:32 +02:00
|
|
|
}
|
2020-05-19 21:00:39 +02:00
|
|
|
else
|
|
|
|
{
|
|
|
|
*psteer = AnalogueUnpack[t1];
|
|
|
|
*ptype = 4;
|
2020-03-29 22:33:32 +02:00
|
|
|
}
|
2020-05-19 21:00:39 +02:00
|
|
|
|
|
|
|
return ret;
|
2020-03-27 21:47:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// decompiled code
|
|
|
|
// original method signature:
|
|
|
|
// void /*$ra*/ cjpRecord(int stream /*$s1*/, unsigned long *ppad /*$s4*/, char *psteer /*$s2*/, char *ptype /*$s3*/)
|
|
|
|
// line 1310, offset 0x0001ad50
|
|
|
|
/* begin block 1 */
|
|
|
|
// Start line: 1311
|
|
|
|
// Start offset: 0x0001AD50
|
|
|
|
// Variables:
|
|
|
|
// unsigned long t0; // stack offset -32
|
|
|
|
// int t1; // $s0
|
|
|
|
/* end block 1 */
|
|
|
|
// End offset: 0x0001AF14
|
|
|
|
// End Line: 1370
|
|
|
|
|
|
|
|
/* begin block 2 */
|
|
|
|
// Start line: 2348
|
|
|
|
/* end block 2 */
|
|
|
|
// End Line: 2349
|
|
|
|
|
|
|
|
/* begin block 3 */
|
|
|
|
// Start line: 2846
|
|
|
|
/* end block 3 */
|
|
|
|
// End Line: 2847
|
|
|
|
|
2020-05-20 10:28:23 +02:00
|
|
|
char ReplayMode = 0;
|
|
|
|
|
2020-05-27 12:03:46 +02:00
|
|
|
// [D]
|
2020-03-29 22:33:32 +02:00
|
|
|
void cjpRecord(int stream, ulong *ppad, char *psteer, char *ptype)
|
2020-03-27 21:47:29 +01:00
|
|
|
{
|
2020-03-29 22:33:32 +02:00
|
|
|
int iVar2;
|
|
|
|
int iVar3;
|
2020-05-20 13:06:29 +02:00
|
|
|
int t1;
|
2020-05-20 10:28:23 +02:00
|
|
|
ulong t0;
|
2020-03-29 22:33:32 +02:00
|
|
|
|
2020-05-20 13:06:29 +02:00
|
|
|
if (stream > -1 && stream < NumReplayStreams)
|
2020-05-20 10:28:23 +02:00
|
|
|
{
|
2020-03-29 22:33:32 +02:00
|
|
|
iVar3 = (int)*psteer;
|
2020-05-20 10:28:23 +02:00
|
|
|
|
2020-03-29 22:33:32 +02:00
|
|
|
RecordWaypoint();
|
2020-05-20 10:28:23 +02:00
|
|
|
|
|
|
|
if ((*ptype & 4U) == 0)
|
|
|
|
{
|
2020-05-20 13:06:29 +02:00
|
|
|
t1 = 0;
|
2020-03-29 22:33:32 +02:00
|
|
|
}
|
2020-05-20 10:28:23 +02:00
|
|
|
else
|
|
|
|
{
|
|
|
|
if (iVar3 < -45)
|
|
|
|
{
|
2020-05-20 13:06:29 +02:00
|
|
|
iVar2 = -45 - iVar3 >> 0x1f;
|
|
|
|
t1 = (((-45 - iVar3) / 6 + iVar2 >> 1) - iVar2) + 1;
|
2020-03-29 22:33:32 +02:00
|
|
|
}
|
2020-05-20 10:28:23 +02:00
|
|
|
else if (iVar3 < 46)
|
|
|
|
{
|
2020-05-20 13:06:29 +02:00
|
|
|
t1 = 8;
|
2020-05-20 10:28:23 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2020-05-20 13:06:29 +02:00
|
|
|
iVar2 = iVar3 - 45 >> 0x1f;
|
|
|
|
t1 = (((iVar3 - 45) / 6 + iVar2 >> 1) - iVar2) + 9;
|
2020-03-29 22:33:32 +02:00
|
|
|
}
|
|
|
|
}
|
2020-05-20 10:28:23 +02:00
|
|
|
|
2020-05-20 13:06:29 +02:00
|
|
|
t0 = (t1 & 0xF) << 8 | *ppad & 0xF0FC;
|
2020-05-20 10:28:23 +02:00
|
|
|
|
|
|
|
if (Put(stream, &t0) == 0)
|
|
|
|
{
|
2020-03-29 22:33:32 +02:00
|
|
|
gOutOfTape = 1;
|
|
|
|
}
|
2020-05-20 13:06:29 +02:00
|
|
|
else if(NoPlayerControl == 0)
|
2020-05-20 10:28:23 +02:00
|
|
|
{
|
2020-05-20 13:06:29 +02:00
|
|
|
ClearCameras = 1;
|
|
|
|
|
|
|
|
if (ReplayMode != 3 && ReplayMode != 8)
|
2020-05-20 10:28:23 +02:00
|
|
|
{
|
2020-03-29 22:33:32 +02:00
|
|
|
ReplayStreams[stream].length = CameraCnt;
|
2020-05-20 10:28:23 +02:00
|
|
|
ReplayParameterPtr->RecordingEnd = CameraCnt;
|
2020-03-29 22:33:32 +02:00
|
|
|
}
|
|
|
|
}
|
2020-05-20 10:28:23 +02:00
|
|
|
|
2020-05-20 13:06:29 +02:00
|
|
|
t1 = (t0 >> 8) & 0xF;
|
2020-05-20 10:28:23 +02:00
|
|
|
|
2020-05-20 13:06:29 +02:00
|
|
|
if (t1 == 0)
|
2020-05-20 10:28:23 +02:00
|
|
|
{
|
|
|
|
*psteer = 0;
|
|
|
|
*ptype = 0;
|
2020-03-29 22:33:32 +02:00
|
|
|
}
|
2020-05-20 10:28:23 +02:00
|
|
|
else
|
|
|
|
{
|
2020-05-20 13:06:29 +02:00
|
|
|
*psteer = AnalogueUnpack[t1];
|
2020-05-20 10:28:23 +02:00
|
|
|
*ptype = 4;
|
2020-03-29 22:33:32 +02:00
|
|
|
}
|
2020-05-20 10:28:23 +02:00
|
|
|
|
2020-05-20 13:06:29 +02:00
|
|
|
*ppad = t0 & 0xF0FC;
|
2020-03-29 22:33:32 +02:00
|
|
|
}
|
2020-03-27 21:47:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// decompiled code
|
|
|
|
// original method signature:
|
|
|
|
// void /*$ra*/ AllocateReplayStream(struct REPLAY_STREAM *stream /*$a0*/, int maxpad /*$a1*/)
|
|
|
|
// line 1383, offset 0x0001b17c
|
|
|
|
/* begin block 1 */
|
|
|
|
// Start line: 3101
|
|
|
|
/* end block 1 */
|
|
|
|
// End Line: 3102
|
|
|
|
|
|
|
|
/* begin block 2 */
|
|
|
|
// Start line: 3414
|
|
|
|
/* end block 2 */
|
|
|
|
// End Line: 3415
|
|
|
|
|
|
|
|
/* begin block 3 */
|
|
|
|
// Start line: 3415
|
|
|
|
/* end block 3 */
|
|
|
|
// End Line: 3416
|
|
|
|
|
|
|
|
/* begin block 4 */
|
|
|
|
// Start line: 3417
|
|
|
|
/* end block 4 */
|
|
|
|
// End Line: 3418
|
|
|
|
|
2020-05-18 20:32:30 +02:00
|
|
|
// [D]
|
2020-03-29 22:33:32 +02:00
|
|
|
void AllocateReplayStream(REPLAY_STREAM *stream, int maxpad)
|
2020-03-27 21:47:29 +01:00
|
|
|
{
|
2020-05-18 20:32:30 +02:00
|
|
|
stream->playbackrun = 0;
|
2020-03-29 22:33:32 +02:00
|
|
|
stream->length = 0;
|
2020-05-18 20:32:30 +02:00
|
|
|
|
|
|
|
stream->InitialPadRecordBuffer = (PADRECORD*)replayptr;
|
|
|
|
stream->PadRecordBuffer = (PADRECORD*)replayptr;
|
|
|
|
|
|
|
|
stream->PadRecordBufferEnd = (PADRECORD *)(replayptr + maxpad * sizeof(PADRECORD));
|
|
|
|
|
|
|
|
if (NoPlayerControl == 0)
|
|
|
|
{
|
|
|
|
*replayptr = 0;
|
|
|
|
|
|
|
|
stream->InitialPadRecordBuffer->analogue = 0;
|
|
|
|
stream->InitialPadRecordBuffer->run = 0xEE;
|
2020-03-29 22:33:32 +02:00
|
|
|
}
|
2020-05-18 20:32:30 +02:00
|
|
|
|
2020-05-20 13:06:29 +02:00
|
|
|
replayptr = (char *)(((uint)replayptr + (maxpad+1) * sizeof(PADRECORD)) & -4);
|
2020-03-27 21:47:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// decompiled code
|
|
|
|
// original method signature:
|
|
|
|
// int /*$ra*/ Get(int stream /*$a0*/, unsigned long *pt0 /*$a1*/)
|
|
|
|
// line 1402, offset 0x0001b1f0
|
|
|
|
/* begin block 1 */
|
|
|
|
// Start line: 1403
|
|
|
|
// Start offset: 0x0001B1F0
|
|
|
|
// Variables:
|
|
|
|
// struct REPLAY_STREAM *rstream; // $a2
|
|
|
|
// unsigned long t0; // $a0
|
|
|
|
/* end block 1 */
|
|
|
|
// End offset: 0x0001B280
|
|
|
|
// End Line: 1438
|
|
|
|
|
|
|
|
/* begin block 2 */
|
|
|
|
// Start line: 3459
|
|
|
|
/* end block 2 */
|
|
|
|
// End Line: 3460
|
|
|
|
|
|
|
|
/* begin block 3 */
|
|
|
|
// Start line: 3466
|
|
|
|
/* end block 3 */
|
|
|
|
// End Line: 3467
|
|
|
|
|
2020-05-19 21:00:39 +02:00
|
|
|
// [D]
|
2020-03-29 22:33:32 +02:00
|
|
|
int Get(int stream, ulong *pt0)
|
2020-03-27 21:47:29 +01:00
|
|
|
{
|
2020-05-19 21:00:39 +02:00
|
|
|
REPLAY_STREAM* rstream;
|
|
|
|
|
|
|
|
if (stream < NumReplayStreams)
|
|
|
|
{
|
|
|
|
rstream = &ReplayStreams[stream];
|
|
|
|
|
|
|
|
if (rstream->PadRecordBuffer+1 <= rstream->PadRecordBufferEnd)
|
|
|
|
{
|
2020-05-20 13:06:29 +02:00
|
|
|
ulong t0 = (rstream->PadRecordBuffer->pad << 8) | rstream->PadRecordBuffer->analogue;
|
|
|
|
*pt0 = t0;
|
2020-05-19 21:00:39 +02:00
|
|
|
|
|
|
|
if (rstream->playbackrun < rstream->PadRecordBuffer->run)
|
|
|
|
{
|
|
|
|
rstream->playbackrun++;
|
2020-03-29 22:33:32 +02:00
|
|
|
}
|
2020-05-19 21:00:39 +02:00
|
|
|
else
|
|
|
|
{
|
|
|
|
rstream->PadRecordBuffer++;
|
|
|
|
rstream->playbackrun = 0;
|
2020-03-29 22:33:32 +02:00
|
|
|
}
|
2020-05-19 21:00:39 +02:00
|
|
|
|
2020-03-29 22:33:32 +02:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
}
|
2020-05-19 21:00:39 +02:00
|
|
|
|
2020-05-20 10:28:23 +02:00
|
|
|
*pt0 = 0x10;
|
2020-05-19 21:00:39 +02:00
|
|
|
|
2020-03-29 22:33:32 +02:00
|
|
|
return 0;
|
2020-03-27 21:47:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// decompiled code
|
|
|
|
// original method signature:
|
|
|
|
// int /*$ra*/ Put(int stream /*$a0*/, unsigned long *pt0 /*$a1*/)
|
|
|
|
// line 1440, offset 0x0001b280
|
|
|
|
/* begin block 1 */
|
|
|
|
// Start line: 1442
|
|
|
|
// Start offset: 0x0001B280
|
|
|
|
// Variables:
|
|
|
|
// struct REPLAY_STREAM *rstream; // $a0
|
|
|
|
// unsigned char **pstream; // $a3
|
|
|
|
// unsigned long t0; // $a1
|
|
|
|
/* end block 1 */
|
|
|
|
// End offset: 0x0001B364
|
|
|
|
// End Line: 1477
|
|
|
|
|
|
|
|
/* begin block 2 */
|
|
|
|
// Start line: 3534
|
|
|
|
/* end block 2 */
|
|
|
|
// End Line: 3535
|
|
|
|
|
|
|
|
/* begin block 3 */
|
|
|
|
// Start line: 3537
|
|
|
|
/* end block 3 */
|
|
|
|
// End Line: 3538
|
|
|
|
|
|
|
|
/* begin block 4 */
|
|
|
|
// Start line: 3538
|
|
|
|
/* end block 4 */
|
|
|
|
// End Line: 3539
|
|
|
|
|
|
|
|
/* begin block 5 */
|
|
|
|
// Start line: 3544
|
|
|
|
/* end block 5 */
|
|
|
|
// End Line: 3545
|
|
|
|
|
2020-05-20 10:28:23 +02:00
|
|
|
// [D]
|
2020-03-29 22:33:32 +02:00
|
|
|
int Put(int stream, ulong *pt0)
|
2020-03-27 21:47:29 +01:00
|
|
|
{
|
2020-05-20 10:28:23 +02:00
|
|
|
REPLAY_STREAM *rstream;
|
|
|
|
ulong t0;
|
|
|
|
PADRECORD *padbuf;
|
|
|
|
|
|
|
|
rstream = &ReplayStreams[stream];
|
|
|
|
|
|
|
|
if (rstream->PadRecordBuffer+1 >= rstream->PadRecordBufferEnd)
|
2020-03-29 22:33:32 +02:00
|
|
|
return 0;
|
2020-05-20 10:28:23 +02:00
|
|
|
|
|
|
|
padbuf = rstream->PadRecordBuffer;
|
|
|
|
t0 = *pt0;
|
|
|
|
|
2020-05-20 13:06:29 +02:00
|
|
|
if (CameraCnt != 0 && padbuf->run != 0xEE)
|
2020-05-20 10:28:23 +02:00
|
|
|
{
|
2020-05-20 13:06:29 +02:00
|
|
|
if (padbuf->pad == ((t0 >> 8) & 0xff) &&
|
2020-05-20 10:28:23 +02:00
|
|
|
padbuf->analogue == (t0 & 0xff) &&
|
2020-05-20 13:06:29 +02:00
|
|
|
padbuf->run != 0x8F)
|
2020-05-20 10:28:23 +02:00
|
|
|
{
|
|
|
|
padbuf->run++;
|
2020-03-29 22:33:32 +02:00
|
|
|
return 1;
|
|
|
|
}
|
2020-05-20 10:28:23 +02:00
|
|
|
|
|
|
|
padbuf++;
|
|
|
|
|
2020-05-20 13:06:29 +02:00
|
|
|
padbuf->pad = (t0 >> 8) & 0xFF;
|
|
|
|
padbuf->analogue = t0 & 0xFF;
|
2020-05-20 10:28:23 +02:00
|
|
|
padbuf->run = 0;
|
|
|
|
|
|
|
|
rstream->PadRecordBuffer = padbuf;
|
|
|
|
|
|
|
|
return 1;
|
2020-03-29 22:33:32 +02:00
|
|
|
}
|
2020-05-20 10:28:23 +02:00
|
|
|
|
2020-05-20 13:06:29 +02:00
|
|
|
padbuf->pad = (t0 >> 8) & 0xFF;
|
|
|
|
padbuf->analogue = t0 & 0xFF;
|
2020-05-20 10:28:23 +02:00
|
|
|
padbuf->run = 0;
|
|
|
|
|
2020-03-29 22:33:32 +02:00
|
|
|
return 1;
|
2020-03-27 21:47:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// decompiled code
|
|
|
|
// original method signature:
|
|
|
|
// void /*$ra*/ RecordWaypoint()
|
|
|
|
// line 1479, offset 0x0001b364
|
|
|
|
/* begin block 1 */
|
|
|
|
// Start line: 3613
|
|
|
|
/* end block 1 */
|
|
|
|
// End Line: 3614
|
|
|
|
|
|
|
|
/* begin block 2 */
|
|
|
|
// Start line: 3616
|
|
|
|
/* end block 2 */
|
|
|
|
// End Line: 3617
|
|
|
|
|
|
|
|
/* begin block 3 */
|
|
|
|
// Start line: 3617
|
|
|
|
/* end block 3 */
|
|
|
|
// End Line: 3618
|
|
|
|
|
|
|
|
/* WARNING: Unknown calling convention yet parameter storage is locked */
|
|
|
|
|
|
|
|
void RecordWaypoint(void)
|
|
|
|
{
|
2020-03-29 22:33:32 +02:00
|
|
|
UNIMPLEMENTED();
|
|
|
|
/*
|
|
|
|
int iVar1;
|
|
|
|
int iVar2;
|
|
|
|
int iVar3;
|
|
|
|
|
|
|
|
iVar2 = PlayerCar;
|
|
|
|
if (TimeToWay == 0) {
|
|
|
|
if (PlayerWaypoints < 0x96) {
|
|
|
|
PlayerWaypoints = PlayerWaypoints + 1;
|
|
|
|
iVar3 = car_data[PlayerCar].hd.where.t[0];
|
|
|
|
iVar1 = iVar3 + 0x200;
|
|
|
|
if (iVar1 < 0) {
|
|
|
|
iVar1 = iVar3 + 0x5ff;
|
|
|
|
}
|
|
|
|
PlayerWayRecordPtr->x = (short)(iVar1 >> 10);
|
|
|
|
TimeToWay = way_distance;
|
|
|
|
iVar1 = car_data[iVar2].hd.where.t[2];
|
|
|
|
iVar2 = iVar1 + 0x200;
|
|
|
|
if (iVar2 < 0) {
|
|
|
|
iVar2 = iVar1 + 0x5ff;
|
|
|
|
}
|
|
|
|
PlayerWayRecordPtr->y = (short)(iVar2 >> 10);
|
|
|
|
PlayerWayRecordPtr = PlayerWayRecordPtr + 1;
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
TimeToWay = TimeToWay + -1;
|
|
|
|
return;
|
|
|
|
*/
|
2020-03-27 21:47:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|