mirror of
https://github.com/s1lentq/ReGameDLL_CS.git
synced 2025-01-16 00:28:15 +03:00
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:
parent
54739c62ab
commit
7238f215e2
@ -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
|
||||||
|
@ -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];}
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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.
|
||||||
|
@ -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
|
||||||
|
@ -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();
|
||||||
|
@ -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)
|
||||||
{
|
{
|
||||||
|
@ -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,
|
||||||
|
@ -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
|
||||||
|
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
@ -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);
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user