From 2d09d84c4cffe1cafe2bf084eb9e59a5f9c138b0 Mon Sep 17 00:00:00 2001 From: Lyberta Date: Sun, 4 Jun 2017 21:42:12 +0300 Subject: [PATCH] Survival: Added GetTeamCount(s) hook. --- .../mutators/mutator/gamemode_survival.qc | 104 ++++++++++++++++++ 1 file changed, 104 insertions(+) diff --git a/qcsrc/server/mutators/mutator/gamemode_survival.qc b/qcsrc/server/mutators/mutator/gamemode_survival.qc index 0aeefec61..3f701bc24 100644 --- a/qcsrc/server/mutators/mutator/gamemode_survival.qc +++ b/qcsrc/server/mutators/mutator/gamemode_survival.qc @@ -1642,6 +1642,110 @@ MUTATOR_HOOKFUNCTION(surv, CheckAllowedTeams, CBC_ORDER_EXCLUSIVE) return; } +/// \brief Hook that override team counts. +MUTATOR_HOOKFUNCTION(surv, GetTeamCounts, CBC_ORDER_EXCLUSIVE) +{ + return true; +} + +/// \brief Hook that sets the team count. +MUTATOR_HOOKFUNCTION(surv, GetTeamCount, CBC_ORDER_EXCLUSIVE) +{ + float teamnum = M_ARGV(0, float); + entity ignore = M_ARGV(1, entity); + switch (teamnum) + { + case surv_attackerteam: + { + M_ARGV(2, float) = surv_numattackers; + M_ARGV(3, float) = surv_numattackers - surv_numattackerhumans; + entity lowestplayer = NULL; + float lowestplayerscore = FLOAT_MAX; + entity lowestbot = NULL; + float lowestbotscore = FLOAT_MAX; + FOREACH_CLIENT((it.team == surv_attackerteam) && (it.surv_role == + SURVIVAL_ROLE_PLAYER), + { + if (it == ignore) + { + continue; + } + if (IS_BOT_CLIENT(it)) + { + float tempscore = PlayerScore_Get(it, SP_SCORE); + if (tempscore < lowestbotscore) + { + lowestbot = it; + lowestbotscore = tempscore; + continue; + } + } + float tempscore = PlayerScore_Get(it, SP_SCORE); + if (tempscore < lowestplayerscore) + { + lowestplayer = it; + lowestplayerscore = tempscore; + } + }); + M_ARGV(4, entity) = lowestplayer; + M_ARGV(5, entity) = lowestbot; + if (ignore.team == surv_attackerteam) + { + --M_ARGV(2, float); + if (IS_BOT_CLIENT(ignore)) + { + --M_ARGV(3, float); + } + } + break; + } + case surv_defenderteam: + { + M_ARGV(2, float) = surv_numdefenders; + M_ARGV(3, float) = surv_numdefenders - surv_numdefenderhumans; + entity lowestplayer = NULL; + float lowestplayerscore = FLOAT_MAX; + entity lowestbot = NULL; + float lowestbotscore = FLOAT_MAX; + FOREACH_CLIENT((it.team == surv_defenderteam), + { + if (it == ignore) + { + continue; + } + if (IS_BOT_CLIENT(it)) + { + float tempscore = PlayerScore_Get(it, SP_SCORE); + if (tempscore < lowestbotscore) + { + lowestbot = it; + lowestbotscore = tempscore; + continue; + } + } + float tempscore = PlayerScore_Get(it, SP_SCORE); + if (tempscore < lowestplayerscore) + { + lowestplayer = it; + lowestplayerscore = tempscore; + } + }); + M_ARGV(4, entity) = lowestplayer; + M_ARGV(5, entity) = lowestbot; + if (ignore.team == surv_defenderteam) + { + --M_ARGV(2, float); + if (IS_BOT_CLIENT(ignore)) + { + --M_ARGV(3, float); + } + } + break; + } + } + return true; +} + /// \brief Hook that determines the best team for the player to join. MUTATOR_HOOKFUNCTION(surv, JoinBestTeam, CBC_ORDER_EXCLUSIVE) { -- 2.39.5