X-Git-Url: http://de.git.xonotic.org/?p=xonotic%2Fxonotic-data.pk3dir.git;a=blobdiff_plain;f=qcsrc%2Fserver%2Fscores_rules.qc;h=7511162aa57748ab2f3385185c3bd26f541b814f;hp=39dbd49a35ddc630c85c849624330e1785d30d01;hb=HEAD;hpb=791f300d2660d6b75a51c6e7f302d6fa6b64861a diff --git a/qcsrc/server/scores_rules.qc b/qcsrc/server/scores_rules.qc index 39dbd49a3..95f8b482e 100644 --- a/qcsrc/server/scores_rules.qc +++ b/qcsrc/server/scores_rules.qc @@ -1,22 +1,22 @@ #include "scores_rules.qh" -#include -#include -#include "client.qh" -#include "scores.qh" #include -#include "teamplay.qh" +#include +#include +#include +#include +#include int ScoreRules_teams; -int NumTeams(int teams) +bool IsTeamAvailable(int team_num) { - return boolean(teams & BIT(0)) + boolean(teams & BIT(1)) + boolean(teams & BIT(2)) + boolean(teams & BIT(3)); + return boolean(ScoreRules_teams & Team_TeamToBit(team_num)); } -int AvailableTeams() +int NumTeams(int teams) { - return NumTeams(ScoreRules_teams); + return boolean(teams & BIT(0)) + boolean(teams & BIT(1)) + boolean(teams & BIT(2)) + boolean(teams & BIT(3)); } // NOTE: ST_constants may not be >= MAX_TEAMSCORE @@ -25,43 +25,51 @@ void ScoreRules_basics(int teams, float sprio, float stprio, float score_enabled { FOREACH(Scores, true, { ScoreInfo_SetLabel_PlayerScore(it, "", 0); - }); + }); for(int i = 0; i < MAX_TEAMSCORE; ++i) ScoreInfo_SetLabel_TeamScore(i, "", 0); ScoreRules_teams = teams; + AVAILABLE_TEAMS = NumTeams(teams); if(score_enabled) - ScoreInfo_SetLabel_TeamScore (ST_SCORE, "score", stprio); + ScoreInfo_SetLabel_TeamScore(ST_SCORE, "score", stprio); if (!INDEPENDENT_PLAYERS) - ScoreInfo_SetLabel_PlayerScore(SP_KILLS, "kills", 0); + ScoreInfo_SetLabel_PlayerScore(SP_KILLS, "kills", 0); - ScoreInfo_SetLabel_PlayerScore(SP_DEATHS, "deaths", SFL_LOWER_IS_BETTER); + ScoreInfo_SetLabel_PlayerScore(SP_DEATHS, "deaths", SFL_LOWER_IS_BETTER); if (!INDEPENDENT_PLAYERS) { - ScoreInfo_SetLabel_PlayerScore(SP_SUICIDES, "suicides", SFL_LOWER_IS_BETTER); - ScoreInfo_SetLabel_PlayerScore(SP_TEAMKILLS, "teamkills", SFL_LOWER_IS_BETTER); + ScoreInfo_SetLabel_PlayerScore(SP_SUICIDES, "suicides", SFL_LOWER_IS_BETTER); + if (teamplay) + ScoreInfo_SetLabel_PlayerScore(SP_TEAMKILLS, "teamkills", SFL_LOWER_IS_BETTER); } if(score_enabled) - ScoreInfo_SetLabel_PlayerScore(SP_SCORE, "score", sprio); + ScoreInfo_SetLabel_PlayerScore(SP_SCORE, "score", sprio); + + if (!INDEPENDENT_PLAYERS) + { + ScoreInfo_SetLabel_PlayerScore(SP_DMG, "dmg", 0); + ScoreInfo_SetLabel_PlayerScore(SP_DMGTAKEN, "dmgtaken", SFL_LOWER_IS_BETTER); - ScoreInfo_SetLabel_PlayerScore(SP_DMG, "dmg", 0); - ScoreInfo_SetLabel_PlayerScore(SP_DMGTAKEN, "dmgtaken", SFL_LOWER_IS_BETTER); - ScoreInfo_SetLabel_PlayerScore(SP_ELO, "elo", 0); + ScoreInfo_SetLabel_PlayerScore(SP_ELO, "elo", SFL_NOT_SORTABLE); + } if(STAT(SHOWFPS)) - ScoreInfo_SetLabel_PlayerScore(SP_FPS, "fps", 0); + ScoreInfo_SetLabel_PlayerScore(SP_FPS, "fps", SFL_NOT_SORTABLE); } + void ScoreRules_basics_end() { ScoreInfo_Init(ScoreRules_teams); } + void ScoreRules_generic() { - int teams = 0; + int teams = 0; if (teamplay) { entity balance = TeamBalance_CheckAllowedTeams(NULL);