Skip to content

Commit

Permalink
Refactoring (rehlds#540)
Browse files Browse the repository at this point in the history
* Rename CMD mp_swapteams
* Remove unused CVar mp_mirrordamage
* Refactoring checks
  • Loading branch information
Vaqtincha authored Apr 12, 2021
1 parent 913bfc6 commit fc52871
Show file tree
Hide file tree
Showing 4 changed files with 10 additions and 7 deletions.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ Archive's bin directory contains 2 subdirectories, 'bugfixed' and 'pure'
| :---------------------------------- | :---------------------------------------------- |
| game version | Will show GameDLL build version, date & URL. |
| endround | Args:<br/>`T` force round end with Terrorists win. <br/>`CT` force round end with Counter-Terrorists win. <br/> or terminate round draw when called without arguments. |
| mp_swapteams | Swap the teams and restart the game. |
| swapteams | Swap the teams and restart the game. |

## Configuration (cvars)
<details>
Expand Down
6 changes: 5 additions & 1 deletion regamedll/dlls/game.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -243,7 +243,11 @@ void EXT_FUNC GameDLLInit()
CVAR_REGISTER(&autoteambalance);
CVAR_REGISTER(&tkpunish);
CVAR_REGISTER(&hostagepenalty);

#ifndef REGAMEDLL_FIXES
CVAR_REGISTER(&mirrordamage);
#endif

CVAR_REGISTER(&logmessages);
CVAR_REGISTER(&forcecamera);
CVAR_REGISTER(&forcechasecam);
Expand Down Expand Up @@ -320,7 +324,7 @@ void EXT_FUNC GameDLLInit()

ADD_SERVER_COMMAND("game", GameDLL_Version_f);
ADD_SERVER_COMMAND("endround", GameDLL_EndRound_f);
ADD_SERVER_COMMAND("mp_swapteams", GameDLL_SwapTeams_f);
ADD_SERVER_COMMAND("swapteams", GameDLL_SwapTeams_f);

CVAR_REGISTER(&game_version);
CVAR_REGISTER(&maxmoney);
Expand Down
3 changes: 1 addition & 2 deletions regamedll/dlls/multiplay_gamerules.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -3910,9 +3910,8 @@ void EXT_FUNC CHalfLifeMultiplay::__API_HOOK(PlayerKilled)(CBasePlayer *pVictim,
{
// if a player dies in a deathmatch game and the killer is a client, award the killer some points
CBasePlayer *killer = GetClassPtr<CCSPlayer>((CBasePlayer *)pKiller);
bool killedByFFA = IsFreeForAll();

if (killer->m_iTeam == pVictim->m_iTeam && !killedByFFA)
if (g_pGameRules->PlayerRelationship(pVictim, killer) == GR_TEAMMATE)
{
// if a player dies by from teammate
pKiller->frags -= IPointsForKill(peKiller, pVictim);
Expand Down
6 changes: 3 additions & 3 deletions regamedll/dlls/player.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -835,7 +835,7 @@ BOOL EXT_FUNC CBasePlayer::__API_HOOK(TakeDamage)(entvars_t *pevInflictor, entva
CBaseEntity *pAttacker = GET_PRIVATE<CBaseEntity>(ENT(pevAttacker));

// don't take damage if victim has protection
if (((pAttacker && pAttacker->IsPlayer()) || (bitsDamageType & DMG_FALL)) && CSPlayer()->GetProtectionState() == CCSPlayer::ProtectionSt_Active)
if (((pAttacker && pAttacker->IsPlayer()) || (bitsDamageType & DMG_FALL)) && CSPlayer()->GetProtectionState() == CCSPlayer::ProtectionSt_Active)
return FALSE;
}
#endif
Expand Down Expand Up @@ -1034,7 +1034,7 @@ BOOL EXT_FUNC CBasePlayer::__API_HOOK(TakeDamage)(entvars_t *pevInflictor, entva
pAttack = GetClassPtr<CCSPlayer>((CBasePlayer *)pevAttacker);

// warn about team attacks
if (!CSGameRules()->IsFreeForAll() && pAttack->m_iTeam == m_iTeam)
if (g_pGameRules->PlayerRelationship(this, pAttack) == GR_TEAMMATE)
{
if (pAttack != this)
{
Expand Down Expand Up @@ -7748,7 +7748,7 @@ void CBasePlayer::UpdateStatusBar()
{
CBasePlayer *pTarget = (CBasePlayer *)pEntity;

bool sameTeam = !CSGameRules()->IsFreeForAll() && pTarget->m_iTeam == m_iTeam;
bool sameTeam = g_pGameRules->PlayerRelationship(this, pTarget) == GR_TEAMMATE;

newSBarState[SBAR_ID_TARGETNAME] = ENTINDEX(pTarget->edict());
newSBarState[SBAR_ID_TARGETTYPE] = sameTeam ? SBAR_TARGETTYPE_TEAMMATE : SBAR_TARGETTYPE_ENEMY;
Expand Down

0 comments on commit fc52871

Please sign in to comment.