2
0
mirror of https://github.com/rehlds/rehlds.git synced 2025-01-19 10:08:04 +03:00

Fixed local gametime ticking when server is paused

This commit is contained in:
WPMGPRoSToTeMa 2017-02-06 02:43:59 +03:00
parent 34f23b1577
commit dacd3bf14e
3 changed files with 21 additions and 16 deletions

View File

@ -1389,23 +1389,18 @@ void SV_WriteClientdataToMessage(client_t *client, sizebuf_t *msg)
// FIXME: there is a loss of precision, because gamedll has already written float gametime in them
if (sv_rehlds_local_gametime.value != 0.0f)
{
auto convertGameTimeToLocal =
[](float &gameTime)
auto convertGlobalGameTimeToLocal =
[](float &globalGameTime)
{
if (gameTime > 0.0f)
{
auto currentLocalGameTime = realtime - host_client->connection_started;
auto currentGameTime = g_psv.time;
auto difference = gameTime - currentGameTime;
gameTime = (float)(currentLocalGameTime + difference);
}
if (globalGameTime > 0.0f)
globalGameTime -= (float)g_GameClients[host_client - g_psvs.clients]->GetLocalGameTimeBase();
};
if (g_bIsCStrike || g_bIsCZero)
convertGameTimeToLocal(std::ref(tdata->m_fAimedDamage));
convertGlobalGameTimeToLocal(std::ref(tdata->m_fAimedDamage));
if (g_bIsHL1 || g_bIsCStrike || g_bIsCZero)
{
convertGameTimeToLocal(std::ref(tdata->fuser2));
convertGameTimeToLocal(std::ref(tdata->fuser3));
convertGlobalGameTimeToLocal(std::ref(tdata->fuser2));
convertGlobalGameTimeToLocal(std::ref(tdata->fuser3));
}
}
#endif
@ -1488,7 +1483,7 @@ void SV_WriteSpawn(sizebuf_t *msg)
#ifdef REHLDS_FIXES
if (sv_rehlds_local_gametime.value != 0.0f)
{
MSG_WriteFloat(msg, (float)(realtime - host_client->connection_started));
MSG_WriteFloat(msg, (float)g_GameClients[host_client - g_psvs.clients]->GetLocalGameTime());
}
else
#endif
@ -1591,6 +1586,7 @@ void SV_New_f(void)
host_client->connected = TRUE;
host_client->connection_started = realtime;
g_GameClients[host_client - g_psvs.clients]->SetupLocalGameTime();
host_client->m_sendrescount = 0;
SZ_Clear(&host_client->netchan.message);
@ -4665,7 +4661,7 @@ qboolean SV_SendClientDatagram(client_t *client)
#ifdef REHLDS_FIXES
if (sv_rehlds_local_gametime.value != 0.0f)
{
MSG_WriteFloat(&msg, (float)(realtime - client->connection_started));
MSG_WriteFloat(&msg, (float)g_GameClients[client - g_psvs.clients]->GetLocalGameTime());
}
else
#endif

View File

@ -31,8 +31,7 @@
CGameClient** g_GameClients;
CGameClient::CGameClient(int id, client_t* cl)
: m_NetChan(&cl->netchan)
{
: m_NetChan(&cl->netchan), m_localGameTimeBase(0) {
m_Id = id;
m_pClient = cl;
m_bSpawnedOnce = false;

View File

@ -64,6 +64,10 @@ private:
// we would also use the field client_t:connected, but actually can't because there is a bug in CS client when server sends TeamScore
// and client is not yet initialized ScoreBoard which leads to memory corruption in the client.
bool m_bSpawnedOnce;
#ifdef REHLDS_FIXES
double m_localGameTimeBase;
#endif
public:
CGameClient(int id, client_t* cl);
@ -102,6 +106,12 @@ public:
#ifdef REHLDS_FIXES
uint8_t* GetExtendedMessageBuffer() { return m_NetChan.GetExtendedMessageBuffer(); };
#endif
#ifdef REHLDS_FIXES
void SetupLocalGameTime() { m_localGameTimeBase = g_psv.time; }
double GetLocalGameTime() const { return g_psv.time - m_localGameTimeBase; }
double GetLocalGameTimeBase() const { return m_localGameTimeBase; }
#endif
};
class CRehldsServerStatic : public IRehldsServerStatic {