X-Git-Url: http://de.git.xonotic.org/?a=blobdiff_plain;f=qcsrc%2Fserver%2Fmutators%2Fgamemode_ca.qc;h=9ad532e909e4dcfd2b56d3d187308db93a999b15;hb=c1b058929459a95a525deff9e0ebb76a513a7c22;hp=d430f1b00748774083534ce19420b5f1abff0f16;hpb=402c9d84fe00cc341e02db9b6e3db5b617301ed6;p=xonotic%2Fxonotic-data.pk3dir.git diff --git a/qcsrc/server/mutators/gamemode_ca.qc b/qcsrc/server/mutators/gamemode_ca.qc index d430f1b00..9ad532e90 100644 --- a/qcsrc/server/mutators/gamemode_ca.qc +++ b/qcsrc/server/mutators/gamemode_ca.qc @@ -1,9 +1,19 @@ -float total_players; -float redalive, bluealive, yellowalive, pinkalive; -.float redalive_stat, bluealive_stat, yellowalive_stat, pinkalive_stat; +#include "gamemode_ca.qh" +#include "../_all.qh" + +#include "gamemode.qh" + float ca_teams; float allowed_to_spawn; +const float ST_CA_ROUNDS = 1; +void ca_ScoreRules(float teams) +{ + ScoreRules_basics(teams, SFL_SORT_PRIO_PRIMARY, 0, true); + ScoreInfo_SetLabel_TeamScore(ST_CA_ROUNDS, "rounds", SFL_SORT_PRIO_PRIMARY); + ScoreRules_basics_end(); +} + void CA_count_alive_players() { entity e; @@ -72,7 +82,7 @@ float CA_CheckWinner() { Send_Notification(NOTIF_ALL, world, MSG_CENTER, CENTER_ROUND_OVER); Send_Notification(NOTIF_ALL, world, MSG_INFO, INFO_ROUND_OVER); - allowed_to_spawn = FALSE; + allowed_to_spawn = false; round_handler_Init(5, autocvar_g_ca_warmup, autocvar_g_ca_round_timelimit); FOR_EACH_PLAYER(e) nades_Clear(e); @@ -96,7 +106,7 @@ float CA_CheckWinner() Send_Notification(NOTIF_ALL, world, MSG_INFO, INFO_ROUND_TIED); } - allowed_to_spawn = FALSE; + allowed_to_spawn = false; round_handler_Init(5, autocvar_g_ca_warmup, autocvar_g_ca_round_timelimit); FOR_EACH_PLAYER(e) @@ -108,15 +118,15 @@ float CA_CheckWinner() void CA_RoundStart() { if(warmup_stage) - allowed_to_spawn = TRUE; + allowed_to_spawn = true; else - allowed_to_spawn = FALSE; + allowed_to_spawn = false; } -float prev_missing_teams_mask; float CA_CheckTeams() { - allowed_to_spawn = TRUE; + static float prev_missing_teams_mask; + allowed_to_spawn = true; CA_count_alive_players(); if(CA_ALIVE_TEAMS_OK()) { @@ -146,10 +156,10 @@ float CA_CheckTeams() float ca_isEliminated(entity e) { if(e.caplayer == 1 && (e.deadflag != DEAD_NO || e.frags == FRAGS_LMS_LOSER)) - return TRUE; + return true; if(e.caplayer == 0.5) - return TRUE; - return FALSE; + return true; + return false; } MUTATOR_HOOKFUNCTION(ca_PlayerSpawn) @@ -205,7 +215,7 @@ MUTATOR_HOOKFUNCTION(ca_ClientConnect) MUTATOR_HOOKFUNCTION(ca_reset_map_global) { - allowed_to_spawn = TRUE; + allowed_to_spawn = true; return 1; } @@ -312,19 +322,19 @@ MUTATOR_HOOKFUNCTION(ca_PlayerDamage) frag_mirrordamage = 0; - return FALSE; + return false; } MUTATOR_HOOKFUNCTION(ca_FilterItem) { if(autocvar_g_powerups <= 0) if(self.flags & FL_POWERUP) - return TRUE; + return true; if(autocvar_g_pickup_items <= 0) - return TRUE; + return true; - return FALSE; + return false; } MUTATOR_HOOKFUNCTION(ca_PlayerDamage_SplitHealthArmor) @@ -334,25 +344,25 @@ MUTATOR_HOOKFUNCTION(ca_PlayerDamage_SplitHealthArmor) if(frag_target != frag_attacker && IS_PLAYER(frag_attacker)) PlayerTeamScore_Add(frag_attacker, SP_SCORE, ST_SCORE, (frag_damage - excess) * autocvar_g_ca_damage2score_multiplier); - return FALSE; + return false; } MUTATOR_HOOKFUNCTION(ca_PlayerRegen) { // no regeneration in CA - return TRUE; + return true; } void ca_Initialize() { - allowed_to_spawn = TRUE; + allowed_to_spawn = true; ca_teams = autocvar_g_ca_teams_override; if(ca_teams < 2) ca_teams = autocvar_g_ca_teams; ca_teams = bound(2, ca_teams, 4); ret_float = ca_teams; - ScoreRules_ca(ca_teams); + ca_ScoreRules(ca_teams); round_handler_Spawn(CA_CheckTeams, CA_CheckWinner, CA_RoundStart); round_handler_Init(5, autocvar_g_ca_warmup, autocvar_g_ca_round_timelimit);