From af8fb3a29a37ada30b7d3d5da3ec753ebcc776e3 Mon Sep 17 00:00:00 2001 From: terencehill Date: Sat, 17 Nov 2012 16:29:09 +0100 Subject: [PATCH] Better handling of the initial game delay in freezetag --- qcsrc/server/arena.qc | 2 +- qcsrc/server/mutators/gamemode_freezetag.qc | 9 ++++++--- 2 files changed, 7 insertions(+), 4 deletions(-) diff --git a/qcsrc/server/arena.qc b/qcsrc/server/arena.qc index 71457c0e51..6917458152 100644 --- a/qcsrc/server/arena.qc +++ b/qcsrc/server/arena.qc @@ -38,7 +38,7 @@ void reset_map(float dorespawn) } else if(g_freezetag) { - warmup = time + autocvar_g_freezetag_warmup; + warmup = max(time, game_starttime) + autocvar_g_freezetag_warmup; } lms_lowest_lives = 999; diff --git a/qcsrc/server/mutators/gamemode_freezetag.qc b/qcsrc/server/mutators/gamemode_freezetag.qc index aedfd6364c..de325c3d1b 100644 --- a/qcsrc/server/mutators/gamemode_freezetag.qc +++ b/qcsrc/server/mutators/gamemode_freezetag.qc @@ -1,7 +1,7 @@ void freezetag_Initialize() { precache_model("models/ice/ice.md3"); - warmup = time + autocvar_g_start_delay + autocvar_g_freezetag_warmup; + warmup = max(time, game_starttime) + autocvar_g_freezetag_warmup; ScoreRules_freezetag(); } @@ -302,9 +302,12 @@ MUTATOR_HOOKFUNCTION(freezetag_PlayerDies) MUTATOR_HOOKFUNCTION(freezetag_PlayerSpawn) { + if(time <= game_starttime) + return 1; + freezetag_Unfreeze(world); // start by making sure that all ice blocks are removed - if(total_players == 1 && time > game_starttime) // only one player active on server, start a new match immediately + if(total_players == 1) // only one player active on server, start a new match immediately if(!next_round && warmup && (time < warmup - autocvar_g_freezetag_warmup || time > warmup)) // not awaiting next round { next_round = time; @@ -452,7 +455,7 @@ MUTATOR_HOOKFUNCTION(freezetag_BotRoles) else self.havocbot_role = havocbot_role_ft_offense; } - + return TRUE; } -- 2.39.5