mirror of
https://github.com/halpz/re3.git
synced 2025-01-09 20:35:27 +00:00
commit
ec7d702185
|
@ -2613,14 +2613,12 @@ void CGarages::SetAllDoorsBackToOriginalHeight()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define GARAGE_SIZE 208
|
||||||
|
|
||||||
void CGarages::Save(uint8 * buf, uint32 * size)
|
void CGarages::Save(uint8 * buf, uint32 * size)
|
||||||
{
|
{
|
||||||
//INITSAVEBUF
|
INITSAVEBUF
|
||||||
*size = 10692; // for some reason it's not actual size again
|
*size = (6 * sizeof(uint32) + TOTAL_COLLECTCARS_GARAGES * sizeof(*CarTypesCollected) + sizeof(uint32) + TOTAL_HIDEOUT_GARAGES * NUM_GARAGE_STORED_CARS * sizeof(CStoredCar) + NUM_GARAGES * GARAGE_SIZE);
|
||||||
//*size = (6 * sizeof(uint32) + TOTAL_COLLECTCARS_GARAGES * sizeof(*CarTypesCollected) + sizeof(uint32) + TOTAL_HIDEOUT_GARAGES * NUM_GARAGE_STORED_CARS * sizeof(CStoredCar) + NUM_GARAGES * sizeof(CGarage));
|
|
||||||
#if !defined THIS_IS_STUPID && defined COMPATIBLE_SAVES
|
|
||||||
memset(buf + 7340, 0, *size - 7340); // garbage data is written otherwise
|
|
||||||
#endif
|
|
||||||
CloseHideOutGaragesBeforeSave();
|
CloseHideOutGaragesBeforeSave();
|
||||||
WriteSaveBuf(buf, NumGarages);
|
WriteSaveBuf(buf, NumGarages);
|
||||||
WriteSaveBuf(buf, (uint32)BombsAreFree);
|
WriteSaveBuf(buf, (uint32)BombsAreFree);
|
||||||
|
@ -2661,12 +2659,16 @@ void CGarages::Save(uint8 * buf, uint32 * size)
|
||||||
WriteSaveBuf(buf, aGarages[i].m_vDir1);
|
WriteSaveBuf(buf, aGarages[i].m_vDir1);
|
||||||
WriteSaveBuf(buf, aGarages[i].m_vDir2);
|
WriteSaveBuf(buf, aGarages[i].m_vDir2);
|
||||||
WriteSaveBuf(buf, aGarages[i].m_fSupZ);
|
WriteSaveBuf(buf, aGarages[i].m_fSupZ);
|
||||||
|
WriteSaveBuf(buf, aGarages[i].m_vecSSGaragePos);
|
||||||
|
WriteSaveBuf(buf, aGarages[i].m_fSSGarageAngle);
|
||||||
WriteSaveBuf(buf, aGarages[i].m_fDir1Len);
|
WriteSaveBuf(buf, aGarages[i].m_fDir1Len);
|
||||||
WriteSaveBuf(buf, aGarages[i].m_fDir2Len);
|
WriteSaveBuf(buf, aGarages[i].m_fDir2Len);
|
||||||
WriteSaveBuf(buf, aGarages[i].m_fInfX);
|
WriteSaveBuf(buf, aGarages[i].m_fInfX);
|
||||||
WriteSaveBuf(buf, aGarages[i].m_fSupX);
|
WriteSaveBuf(buf, aGarages[i].m_fSupX);
|
||||||
WriteSaveBuf(buf, aGarages[i].m_fInfY);
|
WriteSaveBuf(buf, aGarages[i].m_fInfY);
|
||||||
WriteSaveBuf(buf, aGarages[i].m_fSupY);
|
WriteSaveBuf(buf, aGarages[i].m_fSupY);
|
||||||
|
WriteSaveBuf(buf, aGarages[i].m_nTimeCrusherCraneActivated);
|
||||||
|
ZeroSaveBuf(buf, 4);
|
||||||
WriteSaveBuf(buf, aGarages[i].m_fDoorPos);
|
WriteSaveBuf(buf, aGarages[i].m_fDoorPos);
|
||||||
WriteSaveBuf(buf, aGarages[i].m_fDoorHeight);
|
WriteSaveBuf(buf, aGarages[i].m_fDoorHeight);
|
||||||
WriteSaveBuf(buf, aGarages[i].m_fDoor1X);
|
WriteSaveBuf(buf, aGarages[i].m_fDoor1X);
|
||||||
|
@ -2679,18 +2681,26 @@ void CGarages::Save(uint8 * buf, uint32 * size)
|
||||||
WriteSaveBuf(buf, aGarages[i].m_bCollectedCarsState);
|
WriteSaveBuf(buf, aGarages[i].m_bCollectedCarsState);
|
||||||
ZeroSaveBuf(buf, 3 + 4);
|
ZeroSaveBuf(buf, 3 + 4);
|
||||||
ZeroSaveBuf(buf, sizeof(aGarages[i].m_sStoredCar));
|
ZeroSaveBuf(buf, sizeof(aGarages[i].m_sStoredCar));
|
||||||
|
WriteSaveBuf(buf, aGarages[i].m_bInitialized);
|
||||||
|
ZeroSaveBuf(buf, 3);
|
||||||
|
#ifdef GTA_NETWORK
|
||||||
|
ZeroSaveBuf(buf, 4);
|
||||||
|
#endif
|
||||||
|
WriteSaveBuf(buf, aGarages[i].m_bSSGarageAcceptedVehicle);
|
||||||
|
WriteSaveBuf(buf, aGarages[i].m_bLocked);
|
||||||
|
WriteSaveBuf(buf, aGarages[i].m_nSSGarageState);
|
||||||
|
WriteSaveBuf(buf, aGarages[i].m_bSSGarageStateChanging);
|
||||||
#else
|
#else
|
||||||
WriteSaveBuf(buf, aGarages[i]);
|
WriteSaveBuf(buf, aGarages[i]);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
//VALIDATESAVEBUF(*size);
|
VALIDATESAVEBUF(*size);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CGarages::Load(uint8* buf, uint32 size)
|
void CGarages::Load(uint8* buf, uint32 size)
|
||||||
{
|
{
|
||||||
//INITSAVEBUF
|
INITSAVEBUF
|
||||||
assert(size == 10692);
|
assert(size == (6 * sizeof(uint32) + TOTAL_COLLECTCARS_GARAGES * sizeof(*CarTypesCollected) + sizeof(uint32) + TOTAL_HIDEOUT_GARAGES * NUM_GARAGE_STORED_CARS * sizeof(CStoredCar) + NUM_GARAGES * GARAGE_SIZE));
|
||||||
//assert(size == (6 * sizeof(uint32) + TOTAL_COLLECTCARS_GARAGES * sizeof(*CarTypesCollected) + sizeof(uint32) + TOTAL_HIDEOUT_GARAGES * NUM_GARAGE_STORED_CARS * sizeof(CStoredCar) + NUM_GARAGES * sizeof(CGarage)));
|
|
||||||
CloseHideOutGaragesBeforeSave();
|
CloseHideOutGaragesBeforeSave();
|
||||||
ReadSaveBuf(&NumGarages, buf);
|
ReadSaveBuf(&NumGarages, buf);
|
||||||
int32 tempInt;
|
int32 tempInt;
|
||||||
|
@ -2734,12 +2744,16 @@ void CGarages::Load(uint8* buf, uint32 size)
|
||||||
ReadSaveBuf(&aGarages[i].m_vDir1, buf);
|
ReadSaveBuf(&aGarages[i].m_vDir1, buf);
|
||||||
ReadSaveBuf(&aGarages[i].m_vDir2, buf);
|
ReadSaveBuf(&aGarages[i].m_vDir2, buf);
|
||||||
ReadSaveBuf(&aGarages[i].m_fSupZ, buf);
|
ReadSaveBuf(&aGarages[i].m_fSupZ, buf);
|
||||||
|
ReadSaveBuf(&aGarages[i].m_vecSSGaragePos, buf);
|
||||||
|
ReadSaveBuf(&aGarages[i].m_fSSGarageAngle, buf);
|
||||||
ReadSaveBuf(&aGarages[i].m_fDir1Len, buf);
|
ReadSaveBuf(&aGarages[i].m_fDir1Len, buf);
|
||||||
ReadSaveBuf(&aGarages[i].m_fDir2Len, buf);
|
ReadSaveBuf(&aGarages[i].m_fDir2Len, buf);
|
||||||
ReadSaveBuf(&aGarages[i].m_fInfX, buf);
|
ReadSaveBuf(&aGarages[i].m_fInfX, buf);
|
||||||
ReadSaveBuf(&aGarages[i].m_fSupX, buf);
|
ReadSaveBuf(&aGarages[i].m_fSupX, buf);
|
||||||
ReadSaveBuf(&aGarages[i].m_fInfY, buf);
|
ReadSaveBuf(&aGarages[i].m_fInfY, buf);
|
||||||
ReadSaveBuf(&aGarages[i].m_fSupY, buf);
|
ReadSaveBuf(&aGarages[i].m_fSupY, buf);
|
||||||
|
ReadSaveBuf(&aGarages[i].m_nTimeCrusherCraneActivated, buf);
|
||||||
|
SkipSaveBuf(buf, 4);
|
||||||
ReadSaveBuf(&aGarages[i].m_fDoorPos, buf);
|
ReadSaveBuf(&aGarages[i].m_fDoorPos, buf);
|
||||||
ReadSaveBuf(&aGarages[i].m_fDoorHeight, buf);
|
ReadSaveBuf(&aGarages[i].m_fDoorHeight, buf);
|
||||||
ReadSaveBuf(&aGarages[i].m_fDoor1X, buf);
|
ReadSaveBuf(&aGarages[i].m_fDoor1X, buf);
|
||||||
|
@ -2752,6 +2766,15 @@ void CGarages::Load(uint8* buf, uint32 size)
|
||||||
ReadSaveBuf(&aGarages[i].m_bCollectedCarsState, buf);
|
ReadSaveBuf(&aGarages[i].m_bCollectedCarsState, buf);
|
||||||
SkipSaveBuf(buf, 3 + 4);
|
SkipSaveBuf(buf, 3 + 4);
|
||||||
SkipSaveBuf(buf, sizeof(aGarages[i].m_sStoredCar));
|
SkipSaveBuf(buf, sizeof(aGarages[i].m_sStoredCar));
|
||||||
|
ReadSaveBuf(&aGarages[i].m_bInitialized, buf);
|
||||||
|
SkipSaveBuf(buf, 3);
|
||||||
|
#ifdef GTA_NETWORK
|
||||||
|
SkipSaveBuf(buf, 4);
|
||||||
|
#endif
|
||||||
|
ReadSaveBuf(&aGarages[i].m_bSSGarageAcceptedVehicle, buf);
|
||||||
|
ReadSaveBuf(&aGarages[i].m_bLocked, buf);
|
||||||
|
ReadSaveBuf(&aGarages[i].m_nSSGarageState, buf);
|
||||||
|
ReadSaveBuf(&aGarages[i].m_bSSGarageStateChanging, buf);
|
||||||
#else
|
#else
|
||||||
ReadSaveBuf(&aGarages[i], buf);
|
ReadSaveBuf(&aGarages[i], buf);
|
||||||
#endif
|
#endif
|
||||||
|
@ -2765,11 +2788,14 @@ void CGarages::Load(uint8* buf, uint32 size)
|
||||||
else
|
else
|
||||||
aGarages[i].UpdateDoorsHeight();
|
aGarages[i].UpdateDoorsHeight();
|
||||||
}
|
}
|
||||||
//VALIDATESAVEBUF(size);
|
VALIDATESAVEBUF(size);
|
||||||
|
|
||||||
MessageEndTime = 0;
|
MessageEndTime = 0;
|
||||||
bCamShouldBeOutisde = false;
|
bCamShouldBeOutisde = false;
|
||||||
MessageStartTime = 0;
|
MessageStartTime = 0;
|
||||||
|
hGarages = DMAudio.CreateEntity(AUDIOTYPE_GARAGE, (void*)1);
|
||||||
|
if (hGarages >= 0)
|
||||||
|
DMAudio.SetEntityStatus(hGarages, TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool
|
bool
|
||||||
|
|
|
@ -18,9 +18,7 @@
|
||||||
#include "FileMgr.h"
|
#include "FileMgr.h"
|
||||||
#include "Frontend.h"
|
#include "Frontend.h"
|
||||||
#include "General.h"
|
#include "General.h"
|
||||||
#ifdef MISSION_REPLAY
|
|
||||||
#include "GenericGameStorage.h"
|
#include "GenericGameStorage.h"
|
||||||
#endif
|
|
||||||
#include "HandlingMgr.h"
|
#include "HandlingMgr.h"
|
||||||
#include "Heli.h"
|
#include "Heli.h"
|
||||||
#include "Hud.h"
|
#include "Hud.h"
|
||||||
|
@ -1853,7 +1851,7 @@ void FlushLog()
|
||||||
|
|
||||||
const uint32 CRunningScript::nSaveStructSize =
|
const uint32 CRunningScript::nSaveStructSize =
|
||||||
#ifdef COMPATIBLE_SAVES
|
#ifdef COMPATIBLE_SAVES
|
||||||
136;
|
536;
|
||||||
#else
|
#else
|
||||||
sizeof(CRunningScript);
|
sizeof(CRunningScript);
|
||||||
#endif
|
#endif
|
||||||
|
@ -2691,7 +2689,7 @@ bool CTheScripts::Init(bool loaddata)
|
||||||
InvisibilitySettingArray[i] = nil;
|
InvisibilitySettingArray[i] = nil;
|
||||||
if (loaddata) {
|
if (loaddata) {
|
||||||
printf("loaddata = true\n");
|
printf("loaddata = true\n");
|
||||||
//retval = GenericLoad(); // TODO
|
retval = GenericLoad();
|
||||||
}
|
}
|
||||||
for (int i = 0; i < MAX_ALLOWED_COLLISIONS; i++)
|
for (int i = 0; i < MAX_ALLOWED_COLLISIONS; i++)
|
||||||
AllowedCollision[i] = 0;
|
AllowedCollision[i] = 0;
|
||||||
|
|
|
@ -2262,8 +2262,10 @@ void CTheScripts::SwapNearestBuildingModel(float x, float y, float z, float radi
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
CBuilding* pReplacedBuilding = ((CBuilding*)pClosestEntity);
|
CBuilding* pReplacedBuilding = ((CBuilding*)pClosestEntity);
|
||||||
|
if (pReplacedBuilding) {
|
||||||
pReplacedBuilding->ReplaceWithNewModel(mi2);
|
pReplacedBuilding->ReplaceWithNewModel(mi2);
|
||||||
AddToBuildingSwapArray(pReplacedBuilding, mi1, mi2);
|
AddToBuildingSwapArray(pReplacedBuilding, mi1, mi2);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void CTheScripts::AddToBuildingSwapArray(CBuilding* pBuilding, int32 old_model, int32 new_model)
|
void CTheScripts::AddToBuildingSwapArray(CBuilding* pBuilding, int32 old_model, int32 new_model)
|
||||||
|
|
|
@ -2114,8 +2114,8 @@ void CTheScripts::RenderTheScriptDebugLines()
|
||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define SCRIPT_DATA_SIZE sizeof(CTheScripts::OnAMissionFlag) +\
|
#define SCRIPT_DATA_SIZE sizeof(CTheScripts::OnAMissionFlag) + sizeof(tCollectiveData) * MAX_NUM_COLLECTIVES +\
|
||||||
4 * sizeof(uint32) * MAX_NUM_BUILDING_SWAPS + 2 * sizeof(uint32) * MAX_NUM_INVISIBILITY_SETTINGS + 5 * sizeof(uint32)
|
4 * sizeof(uint32) * MAX_NUM_BUILDING_SWAPS + 2 * sizeof(uint32) * MAX_NUM_INVISIBILITY_SETTINGS + 4 * sizeof(uint32)
|
||||||
|
|
||||||
void CTheScripts::SaveAllScripts(uint8* buf, uint32* size)
|
void CTheScripts::SaveAllScripts(uint8* buf, uint32* size)
|
||||||
{
|
{
|
||||||
|
@ -2124,7 +2124,7 @@ INITSAVEBUF
|
||||||
uint32 runningScripts = 0;
|
uint32 runningScripts = 0;
|
||||||
for (CRunningScript* pScript = pActiveScripts; pScript; pScript = pScript->GetNext())
|
for (CRunningScript* pScript = pActiveScripts; pScript; pScript = pScript->GetNext())
|
||||||
runningScripts++;
|
runningScripts++;
|
||||||
*size = CRunningScript::nSaveStructSize * runningScripts + varSpace + SCRIPT_DATA_SIZE + SAVE_HEADER_SIZE + 3 * sizeof(uint32);
|
*size = CRunningScript::nSaveStructSize * runningScripts + varSpace + SCRIPT_DATA_SIZE + SAVE_HEADER_SIZE + 5 * sizeof(uint32);
|
||||||
WriteSaveHeader(buf, 'S', 'C', 'R', '\0', *size - SAVE_HEADER_SIZE);
|
WriteSaveHeader(buf, 'S', 'C', 'R', '\0', *size - SAVE_HEADER_SIZE);
|
||||||
WriteSaveBuf(buf, varSpace);
|
WriteSaveBuf(buf, varSpace);
|
||||||
for (uint32 i = 0; i < varSpace; i++)
|
for (uint32 i = 0; i < varSpace; i++)
|
||||||
|
@ -2200,10 +2200,8 @@ INITSAVEBUF
|
||||||
VALIDATESAVEBUF(*size)
|
VALIDATESAVEBUF(*size)
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: I don't really understand how script loading works, so I leave it the VC way for now.
|
|
||||||
bool CTheScripts::LoadAllScripts(uint8* buf, uint32 size)
|
bool CTheScripts::LoadAllScripts(uint8* buf, uint32 size)
|
||||||
{
|
{
|
||||||
Init(); // TODO: in LCS CTheScripts::Init call GenericLoad, which then calls LoadAllScripts
|
|
||||||
INITSAVEBUF
|
INITSAVEBUF
|
||||||
CheckSaveHeader(buf, 'S', 'C', 'R', '\0', size - SAVE_HEADER_SIZE);
|
CheckSaveHeader(buf, 'S', 'C', 'R', '\0', size - SAVE_HEADER_SIZE);
|
||||||
uint32 varSpace, type, handle;
|
uint32 varSpace, type, handle;
|
||||||
|
@ -2222,7 +2220,6 @@ INITSAVEBUF
|
||||||
else
|
else
|
||||||
SkipSaveBuf(buf, 1);
|
SkipSaveBuf(buf, 1);
|
||||||
}
|
}
|
||||||
// everything else is... gone? TODO
|
|
||||||
ReadSaveBuf(&tmp, buf);
|
ReadSaveBuf(&tmp, buf);
|
||||||
script_assert(tmp == SCRIPT_DATA_SIZE);
|
script_assert(tmp == SCRIPT_DATA_SIZE);
|
||||||
ReadSaveBuf(&OnAMissionFlag, buf);
|
ReadSaveBuf(&OnAMissionFlag, buf);
|
||||||
|
@ -2304,7 +2301,6 @@ INITSAVEBUF
|
||||||
ReadSaveBuf(&runningScripts, buf);
|
ReadSaveBuf(&runningScripts, buf);
|
||||||
for (uint32 i = 0; i < runningScripts; i++)
|
for (uint32 i = 0; i < runningScripts; i++)
|
||||||
CRunningScript().Load(buf);
|
CRunningScript().Load(buf);
|
||||||
StartTestScript(); // <- tmp hack
|
|
||||||
return true;
|
return true;
|
||||||
VALIDATESAVEBUF(size)
|
VALIDATESAVEBUF(size)
|
||||||
}
|
}
|
||||||
|
|
|
@ -648,7 +648,7 @@ bool CGame::ShutDown(void)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void CGame::ReInitGameObjectVariables(void)
|
bool CGame::ReInitGameObjectVariables(bool load)
|
||||||
{
|
{
|
||||||
CGameLogic::InitAtStartOfGame();
|
CGameLogic::InitAtStartOfGame();
|
||||||
#ifdef PS2_MENU
|
#ifdef PS2_MENU
|
||||||
|
@ -693,7 +693,7 @@ void CGame::ReInitGameObjectVariables(void)
|
||||||
gPhoneInfo.Initialise();
|
gPhoneInfo.Initialise();
|
||||||
|
|
||||||
PUSH_MEMID(MEMID_SCRIPT);
|
PUSH_MEMID(MEMID_SCRIPT);
|
||||||
CTheScripts::Init();
|
bool res = CTheScripts::Init(load);
|
||||||
CGangs::Initialise();
|
CGangs::Initialise();
|
||||||
POP_MEMID();
|
POP_MEMID();
|
||||||
|
|
||||||
|
@ -706,12 +706,14 @@ void CGame::ReInitGameObjectVariables(void)
|
||||||
CStats::Init();
|
CStats::Init();
|
||||||
CPickups::Init();
|
CPickups::Init();
|
||||||
CPacManPickups::Init();
|
CPacManPickups::Init();
|
||||||
|
if (!load)
|
||||||
CGarages::Init();
|
CGarages::Init();
|
||||||
CSpecialFX::Init();
|
CSpecialFX::Init();
|
||||||
CRopes::Init();
|
CRopes::Init();
|
||||||
CWaterCannons::Init();
|
CWaterCannons::Init();
|
||||||
CScriptPaths::Init();
|
CScriptPaths::Init();
|
||||||
CParticle::ReloadConfig();
|
CParticle::ReloadConfig();
|
||||||
|
CParticle::SetPixelData();
|
||||||
|
|
||||||
#ifdef PS2_MENU
|
#ifdef PS2_MENU
|
||||||
if ( !TheMemoryCard.m_bWantToLoad )
|
if ( !TheMemoryCard.m_bWantToLoad )
|
||||||
|
@ -730,6 +732,8 @@ void CGame::ReInitGameObjectVariables(void)
|
||||||
|
|
||||||
for (int32 i = 0; i < MAX_PADS; i++)
|
for (int32 i = 0; i < MAX_PADS; i++)
|
||||||
CPad::GetPad(i)->Clear(true);
|
CPad::GetPad(i)->Clear(true);
|
||||||
|
|
||||||
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
void CGame::ReloadIPLs(void)
|
void CGame::ReloadIPLs(void)
|
||||||
|
@ -800,13 +804,12 @@ void CGame::InitialiseWhenRestarting(void)
|
||||||
RestoreForStartLoad();
|
RestoreForStartLoad();
|
||||||
}
|
}
|
||||||
|
|
||||||
ReInitGameObjectVariables();
|
bool bLoadSuccessful = ReInitGameObjectVariables(FrontEndMenuManager.m_bWantToLoad);
|
||||||
|
|
||||||
if ( FrontEndMenuManager.m_bWantToLoad == true )
|
if ( FrontEndMenuManager.m_bWantToLoad == true )
|
||||||
{
|
{
|
||||||
FrontEndMenuManager.m_bWantToLoad = false;
|
|
||||||
InitRadioStationPositionList();
|
InitRadioStationPositionList();
|
||||||
if ( GenericLoad() == true )
|
if ( bLoadSuccessful == true )
|
||||||
{
|
{
|
||||||
DMAudio.ResetTimers(CTimer::GetTimeInMilliseconds());
|
DMAudio.ResetTimers(CTimer::GetTimeInMilliseconds());
|
||||||
CFerry::InitFerrys();
|
CFerry::InitFerrys();
|
||||||
|
@ -825,8 +828,8 @@ void CGame::InitialiseWhenRestarting(void)
|
||||||
ShutDownForRestart();
|
ShutDownForRestart();
|
||||||
CTimer::Stop();
|
CTimer::Stop();
|
||||||
CTimer::Initialise();
|
CTimer::Initialise();
|
||||||
FrontEndMenuManager.m_bWantToLoad = false;
|
//FrontEndMenuManager.m_bWantToLoad = false;
|
||||||
ReInitGameObjectVariables();
|
ReInitGameObjectVariables(false);
|
||||||
currLevel = LEVEL_GENERIC;
|
currLevel = LEVEL_GENERIC;
|
||||||
CCollision::SortOutCollisionAfterLoad();
|
CCollision::SortOutCollisionAfterLoad();
|
||||||
}
|
}
|
||||||
|
@ -835,6 +838,7 @@ void CGame::InitialiseWhenRestarting(void)
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FrontEndMenuManager.m_bWantToLoad = true;
|
||||||
CTimer::Update();
|
CTimer::Update();
|
||||||
|
|
||||||
DMAudio.ChangeMusicMode(MUSICMODE_GAME);
|
DMAudio.ChangeMusicMode(MUSICMODE_GAME);
|
||||||
|
@ -845,6 +849,20 @@ void CGame::InitialiseWhenRestarting(void)
|
||||||
|
|
||||||
void CGame::Process(void)
|
void CGame::Process(void)
|
||||||
{
|
{
|
||||||
|
if (FrontEndMenuManager.m_bWantToLoad) {
|
||||||
|
CTheScripts::StartTestScript();
|
||||||
|
CTheScripts::Process();
|
||||||
|
TheCamera.Process();
|
||||||
|
CStreaming::LoadScene(TheCamera.GetPosition());
|
||||||
|
//CGame::GenerateTempPedAtStartOfNetworkGame();
|
||||||
|
if (/* ?*/true){
|
||||||
|
CStreaming::RequestSpecialModel(MI_PLAYER, "player", STREAMFLAGS_DEPENDENCY | STREAMFLAGS_DONT_REMOVE);
|
||||||
|
CStreaming::LoadAllRequestedModels(false);
|
||||||
|
}
|
||||||
|
TheCamera.Process();
|
||||||
|
CStreaming::LoadScene(TheCamera.GetPosition());
|
||||||
|
FrontEndMenuManager.m_bWantToLoad = false;
|
||||||
|
}
|
||||||
CPad::UpdatePads();
|
CPad::UpdatePads();
|
||||||
#ifdef USE_CUSTOM_ALLOCATOR
|
#ifdef USE_CUSTOM_ALLOCATOR
|
||||||
ProcessTidyUpMemory();
|
ProcessTidyUpMemory();
|
||||||
|
|
|
@ -62,7 +62,7 @@ public:
|
||||||
static void FinalShutdown(void);
|
static void FinalShutdown(void);
|
||||||
static bool Initialise(const char *datFile);
|
static bool Initialise(const char *datFile);
|
||||||
static bool ShutDown(void);
|
static bool ShutDown(void);
|
||||||
static void ReInitGameObjectVariables(void);
|
static bool ReInitGameObjectVariables(bool);
|
||||||
static void ReloadIPLs(void);
|
static void ReloadIPLs(void);
|
||||||
static void ShutDownForRestart(void);
|
static void ShutDownForRestart(void);
|
||||||
static void InitialiseWhenRestarting(void);
|
static void InitialiseWhenRestarting(void);
|
||||||
|
|
|
@ -274,7 +274,7 @@ enum Config {
|
||||||
#define FIX_BUGS // fixes bugs that we've came across during reversing. You can undefine this only on release builds.
|
#define FIX_BUGS // fixes bugs that we've came across during reversing. You can undefine this only on release builds.
|
||||||
//#define MORE_LANGUAGES // Add more translations to the game
|
//#define MORE_LANGUAGES // Add more translations to the game
|
||||||
#define COMPATIBLE_SAVES // this allows changing structs while keeping saves compatible, and keeps saves compatible between platforms
|
#define COMPATIBLE_SAVES // this allows changing structs while keeping saves compatible, and keeps saves compatible between platforms
|
||||||
#define FIX_INCOMPATIBLE_SAVES // try to fix incompatible saves, requires COMPATIBLE_SAVES
|
//#define FIX_INCOMPATIBLE_SAVES // try to fix incompatible saves, requires COMPATIBLE_SAVES
|
||||||
#define LOAD_INI_SETTINGS // as the name suggests. fundamental for CUSTOM_FRONTEND_OPTIONS
|
#define LOAD_INI_SETTINGS // as the name suggests. fundamental for CUSTOM_FRONTEND_OPTIONS
|
||||||
|
|
||||||
#define NO_MOVIES // add option to disable intro videos
|
#define NO_MOVIES // add option to disable intro videos
|
||||||
|
|
|
@ -512,12 +512,18 @@ void CParticle::Initialise()
|
||||||
gpFireHoseRaster = RwTextureGetRaster(gpFireHoseTex);
|
gpFireHoseRaster = RwTextureGetRaster(gpFireHoseTex);
|
||||||
|
|
||||||
CTxdStore::PopCurrentTxd();
|
CTxdStore::PopCurrentTxd();
|
||||||
|
SetPixelData();
|
||||||
|
|
||||||
for ( int32 i = 0; i < MAX_PARTICLES; i++ )
|
debug("CParticle ready");
|
||||||
|
}
|
||||||
|
|
||||||
|
void CParticle::SetPixelData()
|
||||||
|
{
|
||||||
|
for (int32 i = 0; i < MAX_PARTICLES; i++)
|
||||||
{
|
{
|
||||||
tParticleSystemData *entry = &mod_ParticleSystemManager.m_aParticles[i];
|
tParticleSystemData* entry = &mod_ParticleSystemManager.m_aParticles[i];
|
||||||
|
|
||||||
switch( i )
|
switch (i)
|
||||||
{
|
{
|
||||||
case PARTICLE_SPARK:
|
case PARTICLE_SPARK:
|
||||||
entry->m_ppRaster = &gpRainDropSmallRaster;
|
entry->m_ppRaster = &gpRainDropSmallRaster;
|
||||||
|
@ -821,8 +827,6 @@ void CParticle::Initialise()
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
debug("CParticle ready");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CParticle::Shutdown()
|
void CParticle::Shutdown()
|
||||||
|
|
|
@ -91,6 +91,8 @@ public:
|
||||||
|
|
||||||
static void HandleShipsAtHorizonStuff();
|
static void HandleShipsAtHorizonStuff();
|
||||||
static void HandleShootableBirdsStuff(CEntity *entity, CVector const&camPos);
|
static void HandleShootableBirdsStuff(CEntity *entity, CVector const&camPos);
|
||||||
|
|
||||||
|
static void SetPixelData();
|
||||||
};
|
};
|
||||||
|
|
||||||
extern RwRaster *gpCarSplashRaster[];
|
extern RwRaster *gpCarSplashRaster[];
|
||||||
|
|
|
@ -181,7 +181,7 @@ GenericSave(int file)
|
||||||
WriteDataToBufferPointer(buf, CClock::ms_nGameClockMinutes);
|
WriteDataToBufferPointer(buf, CClock::ms_nGameClockMinutes);
|
||||||
currPad = CPad::GetPad(0);
|
currPad = CPad::GetPad(0);
|
||||||
WriteDataToBufferPointer(buf, currPad->Mode);
|
WriteDataToBufferPointer(buf, currPad->Mode);
|
||||||
WriteDataToBufferPointer(buf, CTimer::m_snTimeInMilliseconds);
|
//WriteDataToBufferPointer(buf, CTimer::m_snTimeInMilliseconds);
|
||||||
WriteDataToBufferPointer(buf, CTimer::ms_fTimeScale);
|
WriteDataToBufferPointer(buf, CTimer::ms_fTimeScale);
|
||||||
WriteDataToBufferPointer(buf, CTimer::ms_fTimeStep);
|
WriteDataToBufferPointer(buf, CTimer::ms_fTimeStep);
|
||||||
WriteDataToBufferPointer(buf, CTimer::ms_fTimeStepNonClipped);
|
WriteDataToBufferPointer(buf, CTimer::ms_fTimeStepNonClipped);
|
||||||
|
@ -213,7 +213,7 @@ GenericSave(int file)
|
||||||
WriteDataToBufferPointer(buf, CTimeCycle::m_ExtraColourInter);
|
WriteDataToBufferPointer(buf, CTimeCycle::m_ExtraColourInter);
|
||||||
PopulateRadioStationPositionList();
|
PopulateRadioStationPositionList();
|
||||||
WriteDataToBufferPointer(buf, RadioStationPosition);
|
WriteDataToBufferPointer(buf, RadioStationPosition);
|
||||||
assert(buf - work_buff == SIZE_OF_SIMPLEVARS);
|
//assert(buf - work_buff == SIZE_OF_SIMPLEVARS);
|
||||||
|
|
||||||
// Save scripts, block is nested within the same block as simple vars for some reason
|
// Save scripts, block is nested within the same block as simple vars for some reason
|
||||||
presize = buf;
|
presize = buf;
|
||||||
|
@ -230,26 +230,26 @@ GenericSave(int file)
|
||||||
// Save the rest
|
// Save the rest
|
||||||
//WriteSaveDataBlock(CPools::SavePedPool, "PedPoolSize");
|
//WriteSaveDataBlock(CPools::SavePedPool, "PedPoolSize");
|
||||||
WriteSaveDataBlock(CGarages::Save, "GaragesSize");
|
WriteSaveDataBlock(CGarages::Save, "GaragesSize");
|
||||||
WriteSaveDataBlock(CGameLogic::Save, "GameLogicSize");
|
//WriteSaveDataBlock(CGameLogic::Save, "GameLogicSize");
|
||||||
WriteSaveDataBlock(CPools::SaveVehiclePool, "VehPoolSize");
|
//WriteSaveDataBlock(CPools::SaveVehiclePool, "VehPoolSize");
|
||||||
WriteSaveDataBlock(CPools::SaveObjectPool, "ObjectPoolSize");
|
//WriteSaveDataBlock(CPools::SaveObjectPool, "ObjectPoolSize");
|
||||||
WriteSaveDataBlock(ThePaths.Save, "ThePathsSize");
|
//WriteSaveDataBlock(ThePaths.Save, "ThePathsSize");
|
||||||
WriteSaveDataBlock(CCranes::Save, "CranesSize");
|
//WriteSaveDataBlock(CCranes::Save, "CranesSize");
|
||||||
WriteSaveDataBlock(CPickups::Save, "PickUpsSize");
|
//WriteSaveDataBlock(CPickups::Save, "PickUpsSize");
|
||||||
WriteSaveDataBlock(gPhoneInfo.Save, "PhoneInfoSize");
|
//WriteSaveDataBlock(gPhoneInfo.Save, "PhoneInfoSize");
|
||||||
WriteSaveDataBlock(CRestart::SaveAllRestartPoints, "RestartPointsBufferSize");
|
//WriteSaveDataBlock(CRestart::SaveAllRestartPoints, "RestartPointsBufferSize");
|
||||||
WriteSaveDataBlock(CRadar::SaveAllRadarBlips, "RadarBlipsBufferSize");
|
//WriteSaveDataBlock(CRadar::SaveAllRadarBlips, "RadarBlipsBufferSize");
|
||||||
WriteSaveDataBlock(CTheZones::SaveAllZones, "AllZonesBufferSize");
|
//WriteSaveDataBlock(CTheZones::SaveAllZones, "AllZonesBufferSize");
|
||||||
WriteSaveDataBlock(CGangs::SaveAllGangData, "AllGangDataSize");
|
//WriteSaveDataBlock(CGangs::SaveAllGangData, "AllGangDataSize");
|
||||||
WriteSaveDataBlock(CTheCarGenerators::SaveAllCarGenerators, "AllCarGeneratorsSize");
|
//WriteSaveDataBlock(CTheCarGenerators::SaveAllCarGenerators, "AllCarGeneratorsSize");
|
||||||
WriteSaveDataBlock(CParticleObject::SaveParticle, "ParticlesSize");
|
//WriteSaveDataBlock(CParticleObject::SaveParticle, "ParticlesSize");
|
||||||
WriteSaveDataBlock(cAudioScriptObject::SaveAllAudioScriptObjects, "AllAudioScriptObjectsSize");
|
//WriteSaveDataBlock(cAudioScriptObject::SaveAllAudioScriptObjects, "AllAudioScriptObjectsSize");
|
||||||
WriteSaveDataBlock(CScriptPaths::Save, "ScriptPathsSize");
|
//WriteSaveDataBlock(CScriptPaths::Save, "ScriptPathsSize");
|
||||||
WriteSaveDataBlock(CWorld::Players[CWorld::PlayerInFocus].SavePlayerInfo, "PlayerInfoSize");
|
WriteSaveDataBlock(CWorld::Players[CWorld::PlayerInFocus].SavePlayerInfo, "PlayerInfoSize");
|
||||||
WriteSaveDataBlock(CStats::SaveStats, "StatsSize");
|
WriteSaveDataBlock(CStats::SaveStats, "StatsSize");
|
||||||
WriteSaveDataBlock(CSetPieces::Save, "SetPiecesSize");
|
//WriteSaveDataBlock(CSetPieces::Save, "SetPiecesSize");
|
||||||
WriteSaveDataBlock(CStreaming::MemoryCardSave, "StreamingSize");
|
//WriteSaveDataBlock(CStreaming::MemoryCardSave, "StreamingSize");
|
||||||
WriteSaveDataBlock(CPedType::Save, "PedTypeSize");
|
//WriteSaveDataBlock(CPedType::Save, "PedTypeSize");
|
||||||
|
|
||||||
// sure just write garbage data repeatedly ...
|
// sure just write garbage data repeatedly ...
|
||||||
#ifndef THIS_IS_STUPID
|
#ifndef THIS_IS_STUPID
|
||||||
|
@ -318,7 +318,7 @@ GenericLoad()
|
||||||
ReadDataFromBufferPointer(buf, CClock::ms_nGameClockMinutes);
|
ReadDataFromBufferPointer(buf, CClock::ms_nGameClockMinutes);
|
||||||
currPad = CPad::GetPad(0);
|
currPad = CPad::GetPad(0);
|
||||||
ReadDataFromBufferPointer(buf, currPad->Mode);
|
ReadDataFromBufferPointer(buf, currPad->Mode);
|
||||||
ReadDataFromBufferPointer(buf, CTimer::m_snTimeInMilliseconds);
|
//ReadDataFromBufferPointer(buf, CTimer::m_snTimeInMilliseconds);
|
||||||
ReadDataFromBufferPointer(buf, CTimer::ms_fTimeScale);
|
ReadDataFromBufferPointer(buf, CTimer::ms_fTimeScale);
|
||||||
ReadDataFromBufferPointer(buf, CTimer::ms_fTimeStep);
|
ReadDataFromBufferPointer(buf, CTimer::ms_fTimeStep);
|
||||||
ReadDataFromBufferPointer(buf, CTimer::ms_fTimeStepNonClipped);
|
ReadDataFromBufferPointer(buf, CTimer::ms_fTimeStepNonClipped);
|
||||||
|
@ -359,7 +359,7 @@ GenericLoad()
|
||||||
ReadDataFromBufferPointer(buf, CTimeCycle::m_bExtraColourOn);
|
ReadDataFromBufferPointer(buf, CTimeCycle::m_bExtraColourOn);
|
||||||
ReadDataFromBufferPointer(buf, CTimeCycle::m_ExtraColourInter);
|
ReadDataFromBufferPointer(buf, CTimeCycle::m_ExtraColourInter);
|
||||||
ReadDataFromBufferPointer(buf, RadioStationPosition);
|
ReadDataFromBufferPointer(buf, RadioStationPosition);
|
||||||
assert(buf - work_buff == SIZE_OF_SIMPLEVARS);
|
//assert(buf - work_buff == SIZE_OF_SIMPLEVARS);
|
||||||
#ifdef MISSION_REPLAY
|
#ifdef MISSION_REPLAY
|
||||||
WaitForSave = 0;
|
WaitForSave = 0;
|
||||||
if (FrontEndMenuManager.m_nCurrSaveSlot == PAUSE_SAVE_SLOT && qs == 3)
|
if (FrontEndMenuManager.m_nCurrSaveSlot == PAUSE_SAVE_SLOT && qs == 3)
|
||||||
|
@ -372,50 +372,50 @@ GenericLoad()
|
||||||
//ReadDataFromBlock("Loading PedPool \n", CPools::LoadPedPool);
|
//ReadDataFromBlock("Loading PedPool \n", CPools::LoadPedPool);
|
||||||
LoadSaveDataBlock();
|
LoadSaveDataBlock();
|
||||||
ReadDataFromBlock("Loading Garages \n", CGarages::Load);
|
ReadDataFromBlock("Loading Garages \n", CGarages::Load);
|
||||||
LoadSaveDataBlock();
|
//LoadSaveDataBlock();
|
||||||
ReadDataFromBlock("Loading GameLogic \n", CGameLogic::Load);
|
//ReadDataFromBlock("Loading GameLogic \n", CGameLogic::Load);
|
||||||
LoadSaveDataBlock();
|
//LoadSaveDataBlock();
|
||||||
ReadDataFromBlock("Loading Vehicles \n", CPools::LoadVehiclePool);
|
//ReadDataFromBlock("Loading Vehicles \n", CPools::LoadVehiclePool);
|
||||||
LoadSaveDataBlock();
|
//LoadSaveDataBlock();
|
||||||
CProjectileInfo::RemoveAllProjectiles();
|
CProjectileInfo::RemoveAllProjectiles();
|
||||||
CObject::DeleteAllTempObjects();
|
CObject::DeleteAllTempObjects();
|
||||||
ReadDataFromBlock("Loading Objects \n", CPools::LoadObjectPool);
|
//ReadDataFromBlock("Loading Objects \n", CPools::LoadObjectPool);
|
||||||
LoadSaveDataBlock();
|
//LoadSaveDataBlock();
|
||||||
ReadDataFromBlock("Loading Paths \n", ThePaths.Load);
|
//ReadDataFromBlock("Loading Paths \n", ThePaths.Load);
|
||||||
LoadSaveDataBlock();
|
//LoadSaveDataBlock();
|
||||||
ReadDataFromBlock("Loading Cranes \n", CCranes::Load);
|
//ReadDataFromBlock("Loading Cranes \n", CCranes::Load);
|
||||||
LoadSaveDataBlock();
|
//LoadSaveDataBlock();
|
||||||
ReadDataFromBlock("Loading Pickups \n", CPickups::Load);
|
//ReadDataFromBlock("Loading Pickups \n", CPickups::Load);
|
||||||
LoadSaveDataBlock();
|
//LoadSaveDataBlock();
|
||||||
ReadDataFromBlock("Loading Phoneinfo \n", gPhoneInfo.Load);
|
//ReadDataFromBlock("Loading Phoneinfo \n", gPhoneInfo.Load);
|
||||||
LoadSaveDataBlock();
|
//LoadSaveDataBlock();
|
||||||
ReadDataFromBlock("Loading Restart \n", CRestart::LoadAllRestartPoints);
|
//ReadDataFromBlock("Loading Restart \n", CRestart::LoadAllRestartPoints);
|
||||||
LoadSaveDataBlock();
|
//LoadSaveDataBlock();
|
||||||
ReadDataFromBlock("Loading Radar Blips \n", CRadar::LoadAllRadarBlips);
|
//ReadDataFromBlock("Loading Radar Blips \n", CRadar::LoadAllRadarBlips);
|
||||||
LoadSaveDataBlock();
|
//LoadSaveDataBlock();
|
||||||
ReadDataFromBlock("Loading Zones \n", CTheZones::LoadAllZones);
|
//ReadDataFromBlock("Loading Zones \n", CTheZones::LoadAllZones);
|
||||||
LoadSaveDataBlock();
|
//LoadSaveDataBlock();
|
||||||
ReadDataFromBlock("Loading Gang Data \n", CGangs::LoadAllGangData);
|
//ReadDataFromBlock("Loading Gang Data \n", CGangs::LoadAllGangData);
|
||||||
LoadSaveDataBlock();
|
//LoadSaveDataBlock();
|
||||||
ReadDataFromBlock("Loading Car Generators \n", CTheCarGenerators::LoadAllCarGenerators);
|
//ReadDataFromBlock("Loading Car Generators \n", CTheCarGenerators::LoadAllCarGenerators);
|
||||||
CParticle::ReloadConfig();
|
//CParticle::ReloadConfig();
|
||||||
LoadSaveDataBlock();
|
//LoadSaveDataBlock();
|
||||||
ReadDataFromBlock("Loading Particles \n", CParticleObject::LoadParticle);
|
//ReadDataFromBlock("Loading Particles \n", CParticleObject::LoadParticle);
|
||||||
LoadSaveDataBlock();
|
//LoadSaveDataBlock();
|
||||||
ReadDataFromBlock("Loading AudioScript Objects \n", cAudioScriptObject::LoadAllAudioScriptObjects);
|
//ReadDataFromBlock("Loading AudioScript Objects \n", cAudioScriptObject::LoadAllAudioScriptObjects);
|
||||||
LoadSaveDataBlock();
|
//LoadSaveDataBlock();
|
||||||
ReadDataFromBlock("Loading ScriptPaths \n", CScriptPaths::Load);
|
//ReadDataFromBlock("Loading ScriptPaths \n", CScriptPaths::Load);
|
||||||
LoadSaveDataBlock();
|
LoadSaveDataBlock();
|
||||||
ReadDataFromBlock("Loading Player Info \n", CWorld::Players[CWorld::PlayerInFocus].LoadPlayerInfo);
|
ReadDataFromBlock("Loading Player Info \n", CWorld::Players[CWorld::PlayerInFocus].LoadPlayerInfo);
|
||||||
LoadSaveDataBlock();
|
LoadSaveDataBlock();
|
||||||
ReadDataFromBlock("Loading Stats \n", CStats::LoadStats);
|
ReadDataFromBlock("Loading Stats \n", CStats::LoadStats);
|
||||||
LoadSaveDataBlock();
|
//LoadSaveDataBlock();
|
||||||
ReadDataFromBlock("Loading Set Pieces \n", CSetPieces::Load);
|
//ReadDataFromBlock("Loading Set Pieces \n", CSetPieces::Load);
|
||||||
LoadSaveDataBlock();
|
//LoadSaveDataBlock();
|
||||||
ReadDataFromBlock("Loading Streaming Stuff \n", CStreaming::MemoryCardLoad);
|
//ReadDataFromBlock("Loading Streaming Stuff \n", CStreaming::MemoryCardLoad);
|
||||||
LoadSaveDataBlock();
|
//LoadSaveDataBlock();
|
||||||
ReadDataFromBlock("Loading PedType Stuff \n", CPedType::Load);
|
//ReadDataFromBlock("Loading PedType Stuff \n", CPedType::Load);
|
||||||
|
CStreaming::ReInit();
|
||||||
DMAudio.SetMusicMasterVolume(FrontEndMenuManager.m_PrefsMusicVolume);
|
DMAudio.SetMusicMasterVolume(FrontEndMenuManager.m_PrefsMusicVolume);
|
||||||
DMAudio.SetEffectsMasterVolume(FrontEndMenuManager.m_PrefsSfxVolume);
|
DMAudio.SetEffectsMasterVolume(FrontEndMenuManager.m_PrefsSfxVolume);
|
||||||
if (!CloseFile(file)) {
|
if (!CloseFile(file)) {
|
||||||
|
@ -423,7 +423,7 @@ GenericLoad()
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
DoGameSpecificStuffAfterSucessLoad();
|
//DoGameSpecificStuffAfterSucessLoad();
|
||||||
debug("Game successfully loaded \n");
|
debug("Game successfully loaded \n");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -2558,7 +2558,7 @@ WinMain(HINSTANCE instance,
|
||||||
CGame::InitialiseWhenRestarting();
|
CGame::InitialiseWhenRestarting();
|
||||||
DMAudio.ChangeMusicMode(MUSICMODE_GAME);
|
DMAudio.ChangeMusicMode(MUSICMODE_GAME);
|
||||||
LoadSplash(GetLevelSplashScreen(CGame::currLevel));
|
LoadSplash(GetLevelSplashScreen(CGame::currLevel));
|
||||||
FrontEndMenuManager.m_bWantToLoad = false;
|
//FrontEndMenuManager.m_bWantToLoad = false;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue