Fix: count of time from the start of the round. (Related #77)

Fix: Kicked idle the client's by timeout when mp_roundtime is 0.
Fix: Don't update team score when the round ending by time and game has not started.
Update README.md
This commit is contained in:
s1lentq 2016-12-11 01:27:53 +07:00
parent 54739c62ab
commit 7238f215e2
14 changed files with 152 additions and 76 deletions

View File

@ -10,7 +10,7 @@ Regamedll_CS is a result of reverse engineering of original library mods HLDS (b
## How can use it? ## How can use it?
Regamedll_CS is fully compatible with official mod CS 1.6 / CZero by Valve. All you have to do is to download binaries and replace original mp.dll/cs.so Regamedll_CS is fully compatible with official mod CS 1.6 / CZero by Valve. All you have to do is to download binaries and replace original mp.dll/cs.so
Compiled binaries are available here: [link](http://nexus.rehlds.org/nexus/content/repositories/regamedll-snapshots/regamedll/regamedll/0.2-SNAPSHOT/) Compiled binaries are available here: [link](http://nexus.rehlds.org/nexus/content/repositories/regamedll-dev/regamedll/regamedll/)
Archive's bin directory contains 2 subdirectories, 'bugfixed' and 'pure' Archive's bin directory contains 2 subdirectories, 'bugfixed' and 'pure'
* 'pure' version is designed to work exactly as official mod CS * 'pure' version is designed to work exactly as official mod CS

View File

@ -121,6 +121,14 @@ inline double M_sqrt(double value) {
return ret; return ret;
} }
template<class T>
inline void SWAP(T &first, T &second)
{
T temp = first;
first = second;
second = temp;
}
#define VectorSubtract(a,b,c) {(c)[0]=(a)[0]-(b)[0];(c)[1]=(a)[1]-(b)[1];(c)[2]=(a)[2]-(b)[2];} #define VectorSubtract(a,b,c) {(c)[0]=(a)[0]-(b)[0];(c)[1]=(a)[1]-(b)[1];(c)[2]=(a)[2]-(b)[2];}
#define VectorAdd(a,b,c) {(c)[0]=(a)[0]+(b)[0];(c)[1]=(a)[1]+(b)[1];(c)[2]=(a)[2]+(b)[2];} #define VectorAdd(a,b,c) {(c)[0]=(a)[0]+(b)[0];(c)[1]=(a)[1]+(b)[1];(c)[2]=(a)[2]+(b)[2];}
#define VectorCopy(a,b) {(b)[0]=(a)[0];(b)[1]=(a)[1];(b)[2]=(a)[2];} #define VectorCopy(a,b) {(b)[0]=(a)[0];(b)[1]=(a)[1];(b)[2]=(a)[2];}

View File

@ -181,7 +181,7 @@ void EXT_FUNC ClientKill(edict_t *pEntity)
if (pPlayer->m_fNextSuicideTime > gpGlobals->time) if (pPlayer->m_fNextSuicideTime > gpGlobals->time)
return; return;
pPlayer->m_LastHitGroup = 0; pPlayer->m_LastHitGroup = HITGROUP_GENERIC;
// don't let them suicide for 5 seconds after suiciding // don't let them suicide for 5 seconds after suiciding
pPlayer->m_fNextSuicideTime = gpGlobals->time + 1.0f; pPlayer->m_fNextSuicideTime = gpGlobals->time + 1.0f;
@ -1494,10 +1494,6 @@ LINK_HOOK_CHAIN(BOOL, HandleMenu_ChooseTeam, (CBasePlayer *player, int slot), pl
// can be closed...false if the menu should be displayed again // can be closed...false if the menu should be displayed again
BOOL EXT_FUNC __API_HOOK(HandleMenu_ChooseTeam)(CBasePlayer *player, int slot) BOOL EXT_FUNC __API_HOOK(HandleMenu_ChooseTeam)(CBasePlayer *player, int slot)
{ {
int oldTeam;
char *szOldTeam;
char *szNewTeam;
// If this player is a VIP, don't allow him to switch teams/appearances unless the following conditions are met : // If this player is a VIP, don't allow him to switch teams/appearances unless the following conditions are met :
// a) There is another TEAM_CT player who is in the queue to be a VIP // a) There is another TEAM_CT player who is in the queue to be a VIP
// b) This player is dead // b) This player is dead
@ -1820,6 +1816,9 @@ BOOL EXT_FUNC __API_HOOK(HandleMenu_ChooseTeam)(CBasePlayer *player, int slot)
} }
} }
TeamName oldTeam;
char *szOldTeam, *szNewTeam;
// Switch their actual team... // Switch their actual team...
player->m_bTeamChanged = true; player->m_bTeamChanged = true;
oldTeam = player->m_iTeam; oldTeam = player->m_iTeam;
@ -4746,7 +4745,7 @@ void EXT_FUNC CreateInstancedBaselines()
int EXT_FUNC InconsistentFile(const edict_t *player, const char *filename, char *disconnect_message) int EXT_FUNC InconsistentFile(const edict_t *player, const char *filename, char *disconnect_message)
{ {
// Server doesn't care? // Server doesn't care?
if (CVAR_GET_FLOAT("mp_consistency") != 1) if (!CVAR_GET_FLOAT("mp_consistency"))
return 0; return 0;
// Default behavior is to kick the player // Default behavior is to kick the player

View File

@ -44,6 +44,7 @@
#define WEAPON_RESPAWN_TIME 20 #define WEAPON_RESPAWN_TIME 20
#define AMMO_RESPAWN_TIME 20 #define AMMO_RESPAWN_TIME 20
#define ROUND_RESPAWN_TIME 20 #define ROUND_RESPAWN_TIME 20
#define ROUND_BEGIN_DELAY 5 // delay before beginning new round
// longest the intermission can last, in seconds // longest the intermission can last, in seconds
#define MAX_INTERMISSION_TIME 120 #define MAX_INTERMISSION_TIME 120
@ -727,6 +728,7 @@ public:
void MarkSpawnSkipped() { m_bSkipSpawn = false; } void MarkSpawnSkipped() { m_bSkipSpawn = false; }
void PlayerJoinedTeam(CBasePlayer *pPlayer) { } void PlayerJoinedTeam(CBasePlayer *pPlayer) { }
float GetRoundRemainingTime() const { return m_iRoundTimeSecs - gpGlobals->time + m_fRoundStartTime; } float GetRoundRemainingTime() const { return m_iRoundTimeSecs - gpGlobals->time + m_fRoundStartTime; }
float GetRoundRemainingTimeReal() const;
float GetTimeLeft() const { return m_flTimeLimit - gpGlobals->time; } float GetTimeLeft() const { return m_flTimeLimit - gpGlobals->time; }
BOOL TeamFull(int team_id); BOOL TeamFull(int team_id);
@ -783,7 +785,7 @@ public:
int m_iRoundTime; // (From mp_roundtime) - How many seconds long this round is. int m_iRoundTime; // (From mp_roundtime) - How many seconds long this round is.
int m_iRoundTimeSecs; int m_iRoundTimeSecs;
int m_iIntroRoundTime; // (From mp_freezetime) - How many seconds long the intro round (when players are frozen) is. int m_iIntroRoundTime; // (From mp_freezetime) - How many seconds long the intro round (when players are frozen) is.
float m_fIntroRoundCount; // The global time when the intro round ends and the real one starts float m_fRoundStartTimeReal; // The global time when the intro round ends and the real one starts
// wrote the original "m_flRoundTime" comment for this variable). // wrote the original "m_flRoundTime" comment for this variable).
int m_iAccountTerrorist; int m_iAccountTerrorist;
int m_iAccountCT; int m_iAccountCT;
@ -917,6 +919,15 @@ inline void CHalfLifeMultiplay::TerminateRound(float tmDelay, int iWinStatus)
m_bRoundTerminating = true; m_bRoundTerminating = true;
} }
inline float CHalfLifeMultiplay::GetRoundRemainingTimeReal() const
{
#ifdef REGAMEDLL_FIXES
return m_iRoundTimeSecs - gpGlobals->time + m_fRoundStartTimeReal;
#else
return GetRoundRemainingTime();
#endif
}
inline float CHalfLifeMultiplay::GetRoundRespawnTime() const inline float CHalfLifeMultiplay::GetRoundRespawnTime() const
{ {
#ifdef REGAMEDLL_ADD #ifdef REGAMEDLL_ADD

View File

@ -500,7 +500,12 @@ CHalfLifeMultiplay::CHalfLifeMultiplay()
ReadMultiplayCvars(); ReadMultiplayCvars();
m_iIntroRoundTime += 2; m_iIntroRoundTime += 2;
m_fMaxIdlePeriod = m_iRoundTime * 2;
#ifdef REGAMEDLL_FIXES
m_fMaxIdlePeriod = (((m_iRoundTime < 60) ? 60 : m_iRoundTime) * 2);
#else
m_fMaxIdlePeriod = (m_iRoundTime * 2);
#endif
float flAutoKickIdle = autokick_timeout.value; float flAutoKickIdle = autokick_timeout.value;
if (flAutoKickIdle > 0.0) if (flAutoKickIdle > 0.0)
@ -547,7 +552,7 @@ CHalfLifeMultiplay::CHalfLifeMultiplay()
} }
m_fRoundStartTime = 0; m_fRoundStartTime = 0;
m_fIntroRoundCount = 0; m_fRoundStartTimeReal = 0;
#ifndef CSTRIKE #ifndef CSTRIKE
InstallBotControl(); InstallBotControl();
@ -925,9 +930,15 @@ void EXT_FUNC CHalfLifeMultiplay::__API_VHOOK(CheckWinConditions)()
if (HasRoundInfinite()) if (HasRoundInfinite())
return; return;
#ifdef REGAMEDLL_FIXES
// If a winner has already been determined.. then get the heck out of here
if (m_iRoundWinStatus != WINNER_NONE)
return;
#else
// If a winner has already been determined and game of started.. then get the heck out of here // If a winner has already been determined and game of started.. then get the heck out of here
if (m_bGameStarted && m_iRoundWinStatus != WINNER_NONE) if (m_bGameStarted && m_iRoundWinStatus != WINNER_NONE)
return; return;
#endif
#ifdef REGAMEDLL_ADD #ifdef REGAMEDLL_ADD
int scenarioFlags = UTIL_ReadFlags(round_infinite.string); int scenarioFlags = UTIL_ReadFlags(round_infinite.string);
@ -1173,12 +1184,12 @@ bool CHalfLifeMultiplay::VIPRoundEndCheck()
{ {
if (m_pVIP->m_bEscaped) if (m_pVIP->m_bEscaped)
{ {
return g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::VIP_Escaped_internal, this, WINSTATUS_CTS, ROUND_VIP_ESCAPED, 5); return g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::VIP_Escaped_internal, this, WINSTATUS_CTS, ROUND_VIP_ESCAPED, ROUND_BEGIN_DELAY);
} }
// The VIP is dead // The VIP is dead
else if (m_pVIP->pev->deadflag != DEAD_NO) else if (m_pVIP->pev->deadflag != DEAD_NO)
{ {
return g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::VIP_Died_internal, this, WINSTATUS_TERRORISTS, ROUND_VIP_ASSASSINATED, 5); return g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::VIP_Died_internal, this, WINSTATUS_TERRORISTS, ROUND_VIP_ASSASSINATED, ROUND_BEGIN_DELAY);
} }
} }
@ -1265,15 +1276,15 @@ bool CHalfLifeMultiplay::PrisonRoundEndCheck(int NumAliveTerrorist, int NumAlive
if (m_flEscapeRatio >= m_flRequiredEscapeRatio) if (m_flEscapeRatio >= m_flRequiredEscapeRatio)
{ {
return g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::Prison_Escaped_internal, this, WINSTATUS_TERRORISTS, ROUND_TERRORISTS_ESCAPED, 5); return g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::Prison_Escaped_internal, this, WINSTATUS_TERRORISTS, ROUND_TERRORISTS_ESCAPED, ROUND_BEGIN_DELAY);
} }
else if (NumAliveTerrorist == 0 && m_flEscapeRatio < m_flRequiredEscapeRatio) else if (NumAliveTerrorist == 0 && m_flEscapeRatio < m_flRequiredEscapeRatio)
{ {
return g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::Prison_PreventEscape_internal, this, WINSTATUS_CTS, ROUND_CTS_PREVENT_ESCAPE, 5); return g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::Prison_PreventEscape_internal, this, WINSTATUS_CTS, ROUND_CTS_PREVENT_ESCAPE, ROUND_BEGIN_DELAY);
} }
else if (NumAliveTerrorist == 0 && NumDeadTerrorist != 0 && m_iNumSpawnableCT > 0) else if (NumAliveTerrorist == 0 && NumDeadTerrorist != 0 && m_iNumSpawnableCT > 0)
{ {
return g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::Prison_Neutralized_internal, this, WINSTATUS_CTS, ROUND_ESCAPING_TERRORISTS_NEUTRALIZED, 5); return g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::Prison_Neutralized_internal, this, WINSTATUS_CTS, ROUND_ESCAPING_TERRORISTS_NEUTRALIZED, ROUND_BEGIN_DELAY);
} }
// else return true; // else return true;
} }
@ -1333,11 +1344,11 @@ bool CHalfLifeMultiplay::BombRoundEndCheck()
// Check to see if the bomb target was hit or the bomb defused.. if so, then let's end the round! // Check to see if the bomb target was hit or the bomb defused.. if so, then let's end the round!
if (m_bTargetBombed && m_bMapHasBombTarget) if (m_bTargetBombed && m_bMapHasBombTarget)
{ {
return g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::Target_Bombed_internal, this, WINSTATUS_TERRORISTS, ROUND_TARGET_BOMB, 5); return g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::Target_Bombed_internal, this, WINSTATUS_TERRORISTS, ROUND_TARGET_BOMB, ROUND_BEGIN_DELAY);
} }
else if (m_bBombDefused && m_bMapHasBombTarget) else if (m_bBombDefused && m_bMapHasBombTarget)
{ {
return g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::Target_Defused_internal, this, WINSTATUS_CTS, ROUND_BOMB_DEFUSED, 5); return g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::Target_Defused_internal, this, WINSTATUS_CTS, ROUND_BOMB_DEFUSED, ROUND_BEGIN_DELAY);
} }
return false; return false;
@ -1419,19 +1430,19 @@ bool CHalfLifeMultiplay::TeamExterminationCheck(int NumAliveTerrorist, int NumAl
if (!nowin) if (!nowin)
{ {
return g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::Round_Cts_internal, this, WINSTATUS_CTS, ROUND_CTS_WIN, 5); return g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::Round_Cts_internal, this, WINSTATUS_CTS, ROUND_CTS_WIN, ROUND_BEGIN_DELAY);
} }
} }
// Terrorists WON // Terrorists WON
else if (NumAliveCT == 0 && NumDeadCT != 0) else if (NumAliveCT == 0 && NumDeadCT != 0)
{ {
return g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::Round_Ts_internal, this, WINSTATUS_TERRORISTS, ROUND_TERRORISTS_WIN, 5); return g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::Round_Ts_internal, this, WINSTATUS_TERRORISTS, ROUND_TERRORISTS_WIN, ROUND_BEGIN_DELAY);
} }
} }
else if (NumAliveCT == 0 && NumAliveTerrorist == 0) else if (NumAliveCT == 0 && NumAliveTerrorist == 0)
{ {
return g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::Round_Draw_internal, this, WINSTATUS_DRAW, ROUND_END_DRAW, 5); return g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::Round_Draw_internal, this, WINSTATUS_DRAW, ROUND_END_DRAW, ROUND_BEGIN_DELAY);
} }
return false; return false;
@ -1499,7 +1510,7 @@ bool CHalfLifeMultiplay::HostageRescueRoundEndCheck()
{ {
if (m_iHostagesRescued >= (iHostages * 0.5f)) if (m_iHostagesRescued >= (iHostages * 0.5f))
{ {
return g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::Hostage_Rescue_internal, this, WINSTATUS_CTS, ROUND_ALL_HOSTAGES_RESCUED, 5); return g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::Hostage_Rescue_internal, this, WINSTATUS_CTS, ROUND_ALL_HOSTAGES_RESCUED, ROUND_BEGIN_DELAY);
} }
} }
@ -1813,7 +1824,11 @@ void EXT_FUNC CHalfLifeMultiplay::__API_VHOOK(RestartRound)()
if (flAutoKickIdle > 0) if (flAutoKickIdle > 0)
m_fMaxIdlePeriod = flAutoKickIdle; m_fMaxIdlePeriod = flAutoKickIdle;
else else
#ifdef REGAMEDLL_FIXES
m_fMaxIdlePeriod = (((m_iRoundTime < 60) ? 60 : m_iRoundTime) * 2);
#else
m_fMaxIdlePeriod = (m_iRoundTime * 2); m_fMaxIdlePeriod = (m_iRoundTime * 2);
#endif
// This makes the round timer function as the intro timer on the client side // This makes the round timer function as the intro timer on the client side
m_iRoundTimeSecs = m_iIntroRoundTime; m_iRoundTimeSecs = m_iIntroRoundTime;
@ -1929,7 +1944,7 @@ void EXT_FUNC CHalfLifeMultiplay::__API_VHOOK(RestartRound)()
// Update individual players accounts and respawn players // Update individual players accounts and respawn players
// the round time stamp must be set before players are spawned // the round time stamp must be set before players are spawned
m_fIntroRoundCount = m_fRoundStartTime = gpGlobals->time; m_fRoundStartTime = m_fRoundStartTimeReal = gpGlobals->time;
// Adrian - No cash for anyone at first rounds! ( well, only the default. ) // Adrian - No cash for anyone at first rounds! ( well, only the default. )
if (m_bCompleteReset) if (m_bCompleteReset)
@ -2361,7 +2376,7 @@ void CHalfLifeMultiplay::__MAKE_VHOOK(Think)()
if (!m_fRoundStartTime) if (!m_fRoundStartTime)
{ {
// initialize the timer time stamps, this happens once only // initialize the timer time stamps, this happens once only
m_fIntroRoundCount = m_fRoundStartTime = gpGlobals->time; m_fRoundStartTime = m_fRoundStartTimeReal = gpGlobals->time;
} }
if (m_flForceCameraValue != forcecamera.value if (m_flForceCameraValue != forcecamera.value
@ -2828,8 +2843,19 @@ bool CHalfLifeMultiplay::Target_Saved_internal(int winStatus, ScenarioEventEndRo
Broadcast("ctwin"); Broadcast("ctwin");
m_iAccountCT += m_rgRewardAccountRules[RR_TARGET_BOMB_SAVED]; m_iAccountCT += m_rgRewardAccountRules[RR_TARGET_BOMB_SAVED];
#ifdef REGAMEDLL_FIXES
if (!m_bNeededPlayers)
{
m_iNumCTWins++; m_iNumCTWins++;
// Update the clients team score
UpdateTeamScores();
}
#else
m_iNumCTWins++;
#endif
EndRoundMessage("#Target_Saved", event); EndRoundMessage("#Target_Saved", event);
TerminateRound(tmDelay, winStatus); TerminateRound(tmDelay, winStatus);
@ -2838,9 +2864,10 @@ bool CHalfLifeMultiplay::Target_Saved_internal(int winStatus, ScenarioEventEndRo
QueueCareerRoundEndMenu(tmDelay, winStatus); QueueCareerRoundEndMenu(tmDelay, winStatus);
} }
#ifndef REGAMEDLL_FIXES
UpdateTeamScores(); UpdateTeamScores();
#endif
MarkLivingPlayersOnTeamAsNotReceivingMoneyNextRound(TERRORIST); MarkLivingPlayersOnTeamAsNotReceivingMoneyNextRound(TERRORIST);
return true; return true;
} }
@ -2848,8 +2875,19 @@ bool CHalfLifeMultiplay::Hostage_NotRescued_internal(int winStatus, ScenarioEven
Broadcast("terwin"); Broadcast("terwin");
m_iAccountTerrorist += m_rgRewardAccountRules[RR_HOSTAGE_NOT_RESCUED]; m_iAccountTerrorist += m_rgRewardAccountRules[RR_HOSTAGE_NOT_RESCUED];
#ifdef REGAMEDLL_FIXES
if (!m_bNeededPlayers)
{
m_iNumTerroristWins++; m_iNumTerroristWins++;
// Update the clients team score
UpdateTeamScores();
}
#else
m_iNumTerroristWins++;
#endif
EndRoundMessage("#Hostages_Not_Rescued", event); EndRoundMessage("#Hostages_Not_Rescued", event);
TerminateRound(tmDelay, winStatus); TerminateRound(tmDelay, winStatus);
@ -2858,7 +2896,9 @@ bool CHalfLifeMultiplay::Hostage_NotRescued_internal(int winStatus, ScenarioEven
QueueCareerRoundEndMenu(tmDelay, winStatus); QueueCareerRoundEndMenu(tmDelay, winStatus);
} }
#ifndef REGAMEDLL_FIXES
UpdateTeamScores(); UpdateTeamScores();
#endif
MarkLivingPlayersOnTeamAsNotReceivingMoneyNextRound(CT); MarkLivingPlayersOnTeamAsNotReceivingMoneyNextRound(CT);
return true; return true;
} }
@ -2866,8 +2906,19 @@ bool CHalfLifeMultiplay::Hostage_NotRescued_internal(int winStatus, ScenarioEven
bool CHalfLifeMultiplay::Prison_NotEscaped_internal(int winStatus, ScenarioEventEndRound event, float tmDelay) { bool CHalfLifeMultiplay::Prison_NotEscaped_internal(int winStatus, ScenarioEventEndRound event, float tmDelay) {
Broadcast("ctwin"); Broadcast("ctwin");
#ifdef REGAMEDLL_FIXES
if (!m_bNeededPlayers)
{
m_iNumCTWins++; m_iNumCTWins++;
// Update the clients team score
UpdateTeamScores();
}
#else
m_iNumCTWins++;
#endif
EndRoundMessage("#Terrorists_Not_Escaped", event); EndRoundMessage("#Terrorists_Not_Escaped", event);
TerminateRound(tmDelay, winStatus); TerminateRound(tmDelay, winStatus);
@ -2876,7 +2927,9 @@ bool CHalfLifeMultiplay::Prison_NotEscaped_internal(int winStatus, ScenarioEvent
QueueCareerRoundEndMenu(tmDelay, winStatus); QueueCareerRoundEndMenu(tmDelay, winStatus);
} }
#ifndef REGAMEDLL_FIXES
UpdateTeamScores(); UpdateTeamScores();
#endif
return true; return true;
} }
@ -2884,8 +2937,19 @@ bool CHalfLifeMultiplay::VIP_NotEscaped_internal(int winStatus, ScenarioEventEnd
Broadcast("terwin"); Broadcast("terwin");
m_iAccountTerrorist += m_rgRewardAccountRules[RR_VIP_NOT_ESCAPED]; m_iAccountTerrorist += m_rgRewardAccountRules[RR_VIP_NOT_ESCAPED];
#ifdef REGAMEDLL_FIXES
if (!m_bNeededPlayers)
{
m_iNumTerroristWins++; m_iNumTerroristWins++;
// Update the clients team score
UpdateTeamScores();
}
#else
m_iNumTerroristWins++;
#endif
EndRoundMessage("#VIP_Not_Escaped", event); EndRoundMessage("#VIP_Not_Escaped", event);
TerminateRound(tmDelay, winStatus); TerminateRound(tmDelay, winStatus);
@ -2894,7 +2958,9 @@ bool CHalfLifeMultiplay::VIP_NotEscaped_internal(int winStatus, ScenarioEventEnd
QueueCareerRoundEndMenu(tmDelay, winStatus); QueueCareerRoundEndMenu(tmDelay, winStatus);
} }
#ifndef REGAMEDLL_FIXES
UpdateTeamScores(); UpdateTeamScores();
#endif
return true; return true;
} }
@ -2933,29 +2999,29 @@ void CHalfLifeMultiplay::CheckRoundTimeExpired()
// New code to get rid of round draws!! // New code to get rid of round draws!!
if (m_bMapHasBombTarget) if (m_bMapHasBombTarget)
{ {
if (!g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::Target_Saved_internal, this, WINSTATUS_CTS, ROUND_TARGET_SAVED, 5)) if (!g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::Target_Saved_internal, this, WINSTATUS_CTS, ROUND_TARGET_SAVED, ROUND_BEGIN_DELAY))
return; return;
} }
else if (UTIL_FindEntityByClassname(NULL, "hostage_entity")) else if (UTIL_FindEntityByClassname(NULL, "hostage_entity"))
{ {
if (!g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::Hostage_NotRescued_internal, this, WINSTATUS_TERRORISTS, ROUND_HOSTAGE_NOT_RESCUED, 5)) if (!g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::Hostage_NotRescued_internal, this, WINSTATUS_TERRORISTS, ROUND_HOSTAGE_NOT_RESCUED, ROUND_BEGIN_DELAY))
return; return;
} }
else if (m_bMapHasEscapeZone) else if (m_bMapHasEscapeZone)
{ {
if (!g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::Prison_NotEscaped_internal, this, WINSTATUS_CTS, ROUND_TERRORISTS_NOT_ESCAPED, 5)) if (!g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::Prison_NotEscaped_internal, this, WINSTATUS_CTS, ROUND_TERRORISTS_NOT_ESCAPED, ROUND_BEGIN_DELAY))
return; return;
} }
else if (m_bMapHasVIPSafetyZone) else if (m_bMapHasVIPSafetyZone)
{ {
if (!g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::VIP_NotEscaped_internal, this, WINSTATUS_TERRORISTS, ROUND_VIP_NOT_ESCAPED, 5)) if (!g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::VIP_NotEscaped_internal, this, WINSTATUS_TERRORISTS, ROUND_VIP_NOT_ESCAPED, ROUND_BEGIN_DELAY))
return; return;
} }
#ifdef REGAMEDLL_ADD #ifdef REGAMEDLL_ADD
else if (roundover.value) else if (roundover.value)
{ {
// round is over // round is over
if (!g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::RoundOver_internal, this, WINSTATUS_DRAW, ROUND_GAME_OVER, 5)) if (!g_ReGameHookchains.m_RoundEnd.callChain(&CHalfLifeMultiplay::RoundOver_internal, this, WINSTATUS_DRAW, ROUND_GAME_OVER, ROUND_BEGIN_DELAY))
return; return;
} }
#endif #endif
@ -3659,9 +3725,13 @@ BOOL EXT_FUNC CHalfLifeMultiplay::__API_VHOOK(FPlayerCanRespawn)(CBasePlayer *pP
if (GetRoundRespawnTime() != -1) if (GetRoundRespawnTime() != -1)
#endif #endif
{ {
// TODO: to be correct, need use m_fIntroRoundCount instead of it. // TODO: to be correct, need use time the real one starts of round, m_fRoundStartTimeReal instead of it.
// m_fRoundStartTime able to extend the time to 60 seconds when there is a remaining time of round. // m_fRoundStartTime able to extend the time to 60 seconds when there is a remaining time of round.
#ifdef REGAMEDLL_FIXES
if (gpGlobals->time > m_fRoundStartTimeReal + GetRoundRespawnTime())
#else
if (gpGlobals->time > m_fRoundStartTime + GetRoundRespawnTime()) if (gpGlobals->time > m_fRoundStartTime + GetRoundRespawnTime())
#endif
{ {
// If this player just connected and fadetoblack is on, then maybe // If this player just connected and fadetoblack is on, then maybe
// the server admin doesn't want him peeking around. // the server admin doesn't want him peeking around.

View File

@ -560,7 +560,6 @@ void EXT_FUNC CBasePlayer::__API_HOOK(Radio)(const char *msg_id, const char *msg
{ {
// do this when spectator mode is in // do this when spectator mode is in
int iSpecMode = pPlayer->IsObserver(); int iSpecMode = pPlayer->IsObserver();
if (iSpecMode != OBS_CHASE_LOCKED && iSpecMode != OBS_CHASE_FREE && iSpecMode != OBS_IN_EYE) if (iSpecMode != OBS_CHASE_LOCKED && iSpecMode != OBS_CHASE_FREE && iSpecMode != OBS_IN_EYE)
continue; continue;
@ -633,7 +632,7 @@ void CBasePlayer::SmartRadio()
; ;
} }
void CBasePlayer::Pain(int iLastHitGroup, bool HasArmour) void CBasePlayer::Pain(int iLastHitGroup, bool bHasArmour)
{ {
int temp = RANDOM_LONG(0, 2); int temp = RANDOM_LONG(0, 2);
@ -656,7 +655,7 @@ void CBasePlayer::Pain(int iLastHitGroup, bool HasArmour)
{ {
if (iLastHitGroup != HITGROUP_LEFTLEG && iLastHitGroup != HITGROUP_RIGHTLEG) if (iLastHitGroup != HITGROUP_LEFTLEG && iLastHitGroup != HITGROUP_RIGHTLEG)
{ {
if (HasArmour) if (bHasArmour)
{ {
EMIT_SOUND(ENT(pev), CHAN_VOICE, "player/bhit_kevlar-1.wav", VOL_NORM, ATTN_NORM); EMIT_SOUND(ENT(pev), CHAN_VOICE, "player/bhit_kevlar-1.wav", VOL_NORM, ATTN_NORM);
return; return;
@ -672,7 +671,7 @@ void CBasePlayer::Pain(int iLastHitGroup, bool HasArmour)
} }
} }
Vector VecVelocityForDamage(float flDamage) NOXREF Vector VecVelocityForDamage(float flDamage)
{ {
Vector vec(RANDOM_FLOAT(-100, 100), RANDOM_FLOAT(-100, 100), RANDOM_FLOAT(200, 300)); Vector vec(RANDOM_FLOAT(-100, 100), RANDOM_FLOAT(-100, 100), RANDOM_FLOAT(200, 300));
@ -3286,7 +3285,7 @@ void CBasePlayer::SyncRoundTimer()
if (g_pGameRules->IsMultiplayer()) if (g_pGameRules->IsMultiplayer())
{ {
tmRemaining = CSGameRules()->GetRoundRemainingTime(); tmRemaining = CSGameRules()->GetRoundRemainingTimeReal();
#ifdef REGAMEDLL_FIXES #ifdef REGAMEDLL_FIXES
// hide timer HUD because it is useless. // hide timer HUD because it is useless.
@ -4875,10 +4874,10 @@ void EXT_FUNC CBasePlayer::__API_VHOOK(PostThink)()
{ {
float flFallDamage = g_pGameRules->FlPlayerFallDamage(this); float flFallDamage = g_pGameRules->FlPlayerFallDamage(this);
//splat // splat
if (flFallDamage > pev->health) if (flFallDamage > pev->health)
{ {
// note: play on item channel because we play footstep landing on body channel // NOTE: play on item channel because we play footstep landing on body channel
EMIT_SOUND(ENT(pev), CHAN_ITEM, "common/bodysplat.wav", VOL_NORM, ATTN_NORM); EMIT_SOUND(ENT(pev), CHAN_ITEM, "common/bodysplat.wav", VOL_NORM, ATTN_NORM);
} }
if (flFallDamage > 0) if (flFallDamage > 0)
@ -4926,7 +4925,7 @@ void EXT_FUNC CBasePlayer::__API_VHOOK(PostThink)()
StudioFrameAdvance(); StudioFrameAdvance();
CheckPowerups(); CheckPowerups();
// s1lent: this is useless for CS 1.6 // NOTE: this is useless for CS 1.6 - s1lent
#ifndef REGAMEDLL_FIXES #ifndef REGAMEDLL_FIXES
UpdatePlayerSound(); UpdatePlayerSound();
#endif #endif

View File

@ -461,7 +461,7 @@ public:
bool CanPlayerBuy(bool display = false); bool CanPlayerBuy(bool display = false);
void SwitchTeam(); void SwitchTeam();
void TabulateAmmo(); void TabulateAmmo();
void Pain(int iLastHitGroup, bool HasArmour); void Pain(int iLastHitGroup, bool bHasArmour);
BOOL IsBombGuy(); BOOL IsBombGuy();
bool IsLookingAtPosition(Vector *pos, float angleTolerance = 20.0f); bool IsLookingAtPosition(Vector *pos, float angleTolerance = 20.0f);
void Reset(); void Reset();

View File

@ -70,13 +70,13 @@ void TutorMessageEvent::AddParameter(char *str)
param->m_next = NULL; param->m_next = NULL;
param->m_data = new char[Q_strlen(str) + 1]; param->m_data = new char[Q_strlen(str) + 1];
if (param->m_data != NULL) if (param->m_data)
{ {
Q_strcpy(param->m_data, str); Q_strcpy(param->m_data, str);
param->m_data[Q_strlen(str)] = '\0'; param->m_data[Q_strlen(str)] = '\0';
++m_numParameters; ++m_numParameters;
if (m_paramList != NULL) if (m_paramList)
{ {
TutorMessageEventParam *temp = m_paramList; TutorMessageEventParam *temp = m_paramList;
@ -125,8 +125,7 @@ CBaseTutor::CBaseTutor()
CBaseTutor::~CBaseTutor() CBaseTutor::~CBaseTutor()
{ {
TutorMessageEvent *event = m_eventList; TutorMessageEvent *event = m_eventList;
while (event)
while (event != NULL)
{ {
TutorMessageEvent *temp = event; TutorMessageEvent *temp = event;
event = event->GetNext(); event = event->GetNext();
@ -175,8 +174,7 @@ void CBaseTutor::DisplayMessageToPlayer(CBasePlayer *player, int id, const char
for (int arg = 0; arg < numArgs; ++arg) for (int arg = 0; arg < numArgs; ++arg)
{ {
char *str = event->GetNextParameter(param, sizeof(param)); char *str = event->GetNextParameter(param, sizeof(param));
if (str)
if (str != NULL)
WRITE_STRING(str); WRITE_STRING(str);
else else
WRITE_STRING(""); WRITE_STRING("");
@ -185,7 +183,7 @@ void CBaseTutor::DisplayMessageToPlayer(CBasePlayer *player, int id, const char
WRITE_SHORT(id); WRITE_SHORT(id);
WRITE_SHORT(player->IsAlive() == FALSE); WRITE_SHORT(player->IsAlive() == FALSE);
if (definition != NULL) if (definition)
WRITE_SHORT(definition->m_type); WRITE_SHORT(definition->m_type);
else else
WRITE_SHORT(TUTORMESSAGETYPE_DEFAULT); WRITE_SHORT(TUTORMESSAGETYPE_DEFAULT);
@ -193,7 +191,7 @@ void CBaseTutor::DisplayMessageToPlayer(CBasePlayer *player, int id, const char
m_deadAirStartTime = -1.0f; m_deadAirStartTime = -1.0f;
if (definition != NULL) if (definition)
{ {
if (gpGlobals->time - m_roundStartTime > 1.0f) if (gpGlobals->time - m_roundStartTime > 1.0f)
{ {
@ -246,7 +244,7 @@ void CBaseTutor::CloseCurrentWindow()
{ {
CBasePlayer *localPlayer = (CBasePlayer *)UTIL_GetLocalPlayer(); CBasePlayer *localPlayer = (CBasePlayer *)UTIL_GetLocalPlayer();
if (localPlayer != NULL) if (localPlayer)
{ {
MESSAGE_BEGIN(MSG_ONE, gmsgTutorClose, NULL, localPlayer->pev); MESSAGE_BEGIN(MSG_ONE, gmsgTutorClose, NULL, localPlayer->pev);
MESSAGE_END(); MESSAGE_END();
@ -319,7 +317,7 @@ bool CBaseTutor::__MAKE_VHOOK(IsPlayerLookingAtEntity)(CBaseEntity *entity, CBas
TraceResult result; TraceResult result;
UTIL_TraceLine(srcVec, destVec, dont_ignore_monsters, ignore_glass, ENT(player->pev), &result); UTIL_TraceLine(srcVec, destVec, dont_ignore_monsters, ignore_glass, ENT(player->pev), &result);
if (result.pHit != NULL) if (result.pHit)
{ {
if (!FNullEnt(result.pHit) && CBaseEntity::Instance(result.pHit) == entity) if (!FNullEnt(result.pHit) && CBaseEntity::Instance(result.pHit) == entity)
{ {

View File

@ -366,14 +366,6 @@ inline Vector CrossProduct(const Vector &a, const Vector &b)
return Vector(a.y * b.z - a.z * b.y, a.z * b.x - a.x * b.z, a.x * b.y - a.y * b.x); return Vector(a.y * b.z - a.z * b.y, a.z * b.x - a.x * b.z, a.x * b.y - a.y * b.x);
} }
template<class T>
inline void SWAP(T &first, T &second)
{
T temp = first;
first = second;
second = temp;
}
template< template<
typename X, typename X,
typename Y, typename Y,

View File

@ -504,7 +504,7 @@ void CWorld::__MAKE_VHOOK(Precache)()
g_pGameRules = InstallGameRules(); g_pGameRules = InstallGameRules();
// s1lent: What is the essence of soundent in CS 1.6? I think this is for NPC monsters. // NOTE: What is the essence of soundent in CS 1.6? I think this is for NPC monsters - s1lent
#ifndef REGAMEDLL_FIXES #ifndef REGAMEDLL_FIXES
// UNDONE why is there so much Spawn code in the Precache function? I'll just keep it here // UNDONE why is there so much Spawn code in the Precache function? I'll just keep it here

View File

@ -20,7 +20,6 @@ void CC4::__MAKE_VHOOK(Spawn)()
{ {
pev->effects |= EF_NODRAW; pev->effects |= EF_NODRAW;
DROP_TO_FLOOR(edict()); DROP_TO_FLOOR(edict());
return; return;
} }

View File

@ -552,6 +552,7 @@ public:
void MarkSpawnSkipped() { m_bSkipSpawn = false; } void MarkSpawnSkipped() { m_bSkipSpawn = false; }
float GetRoundRemainingTime() const { return m_iRoundTimeSecs - gpGlobals->time + m_fRoundStartTime; } float GetRoundRemainingTime() const { return m_iRoundTimeSecs - gpGlobals->time + m_fRoundStartTime; }
float GetRoundRemainingTimeReal() const { return m_iRoundTimeSecs - gpGlobals->time + m_fRoundStartTimeReal; }
float GetTimeLeft() const { return m_flTimeLimit - gpGlobals->time; } float GetTimeLeft() const { return m_flTimeLimit - gpGlobals->time; }
bool IsMatchStarted() { return (m_flRestartRoundTime != 0.0f || m_fCareerRoundMenuTime != 0.0f || m_fCareerMatchMenuTime != 0.0f); } bool IsMatchStarted() { return (m_flRestartRoundTime != 0.0f || m_fCareerRoundMenuTime != 0.0f || m_fCareerMatchMenuTime != 0.0f); }
@ -565,7 +566,7 @@ public:
int m_iRoundTime; // (From mp_roundtime) - How many seconds long this round is. int m_iRoundTime; // (From mp_roundtime) - How many seconds long this round is.
int m_iRoundTimeSecs; int m_iRoundTimeSecs;
int m_iIntroRoundTime; // (From mp_freezetime) - How many seconds long the intro round (when players are frozen) is. int m_iIntroRoundTime; // (From mp_freezetime) - How many seconds long the intro round (when players are frozen) is.
float m_fIntroRoundCount; // The global time when the intro round ends and the real one starts float m_fRoundStartTimeReal; // The global time when the intro round ends and the real one starts
// wrote the original "m_flRoundTime" comment for this variable). // wrote the original "m_flRoundTime" comment for this variable).
int m_iAccountTerrorist; int m_iAccountTerrorist;
int m_iAccountCT; int m_iAccountCT;

View File

@ -962,7 +962,7 @@ qboolean PM_CheckWater();
void PM_CatagorizePosition(); void PM_CatagorizePosition();
int PM_GetRandomStuckOffsets(int nIndex, int server, vec_t *offset); int PM_GetRandomStuckOffsets(int nIndex, int server, vec_t *offset);
void PM_ResetStuckOffsets(int nIndex, int server); void PM_ResetStuckOffsets(int nIndex, int server);
int PM_CheckStuck(); qboolean PM_CheckStuck();
void PM_SpectatorMove(); void PM_SpectatorMove();
float PM_SplineFraction(float value, float scale); float PM_SplineFraction(float value, float scale);
float PM_SimpleSpline(float value); float PM_SimpleSpline(float value);

View File

@ -75,7 +75,7 @@ void PM_InitTextureTypes()
int i, j; int i, j;
byte *pMemFile; byte *pMemFile;
int fileSize, filePos; int fileSize, filePos;
static qboolean bTextureTypeInit = false; static bool bTextureTypeInit = false;
if (bTextureTypeInit) if (bTextureTypeInit)
return; return;
@ -1511,7 +1511,7 @@ void PM_ResetStuckOffsets(int nIndex, int server)
// If pmove->origin is in a solid position, // If pmove->origin is in a solid position,
// try nudging slightly on all axis to // try nudging slightly on all axis to
// allow for the cut precision of the net coordinates // allow for the cut precision of the net coordinates
int PM_CheckStuck() qboolean PM_CheckStuck()
{ {
vec3_t base; vec3_t base;
vec3_t offset; vec3_t offset;
@ -1530,7 +1530,7 @@ int PM_CheckStuck()
if (hitent == -1) if (hitent == -1)
{ {
PM_ResetStuckOffsets(pmove->player_index, pmove->server); PM_ResetStuckOffsets(pmove->player_index, pmove->server);
return 0; return FALSE;
} }
VectorCopy(pmove->origin, base); VectorCopy(pmove->origin, base);
@ -1552,7 +1552,7 @@ int PM_CheckStuck()
{ {
PM_ResetStuckOffsets(pmove->player_index, pmove->server); PM_ResetStuckOffsets(pmove->player_index, pmove->server);
VectorCopy(test, pmove->origin); VectorCopy(test, pmove->origin);
return 0; return FALSE;
} }
nReps++; nReps++;
@ -1562,7 +1562,6 @@ int PM_CheckStuck()
} }
// Only an issue on the client. // Only an issue on the client.
if (pmove->server) if (pmove->server)
idx = 0; idx = 0;
else else
@ -1573,7 +1572,7 @@ int PM_CheckStuck()
// Too soon? // Too soon?
if (rgStuckCheckTime[pmove->player_index][idx] >= (fTime - PM_CHECKSTUCK_MINTIME)) if (rgStuckCheckTime[pmove->player_index][idx] >= (fTime - PM_CHECKSTUCK_MINTIME))
{ {
return 1; return TRUE;
} }
rgStuckCheckTime[pmove->player_index][idx] = fTime; rgStuckCheckTime[pmove->player_index][idx] = fTime;
@ -1592,7 +1591,7 @@ int PM_CheckStuck()
VectorCopy(test, pmove->origin); VectorCopy(test, pmove->origin);
} }
return 0; return FALSE;
} }
// If player is flailing while stuck in another player (should never happen), then see // If player is flailing while stuck in another player (should never happen), then see
@ -1620,14 +1619,14 @@ int PM_CheckStuck()
if (pmove->PM_TestPlayerPosition(test, NULL) == -1) if (pmove->PM_TestPlayerPosition(test, NULL) == -1)
{ {
VectorCopy(test, pmove->origin); VectorCopy(test, pmove->origin);
return 0; return FALSE;
} }
} }
} }
} }
} }
return 1; return TRUE;
} }
void PM_SpectatorMove() void PM_SpectatorMove()
@ -1937,7 +1936,7 @@ void PM_LadderMove(physent_t *pLadder)
{ {
vec3_t ladderCenter; vec3_t ladderCenter;
trace_t trace; trace_t trace;
qboolean onFloor; bool onFloor;
vec3_t floor; vec3_t floor;
vec3_t modelmins, modelmaxs; vec3_t modelmins, modelmaxs;