From 098b78e21b4dedb0a1d2fafe091a20d4ffc17957 Mon Sep 17 00:00:00 2001 From: FruitieX Date: Sat, 23 Oct 2010 17:24:30 +0300 Subject: [PATCH] no ready restart counter in ca, fix bot behaviour when warmup is enabled in ca, new scoring system for ca (round win = 1 point for team, 10 damage dealt = 1 point for a player) --- defaultXonotic.cfg | 1 + qcsrc/server/arena.qc | 8 ++++++-- qcsrc/server/cl_client.qc | 7 ++++++- qcsrc/server/clientcommands.qc | 4 ++-- qcsrc/server/g_damage.qc | 2 ++ 5 files changed, 17 insertions(+), 5 deletions(-) diff --git a/defaultXonotic.cfg b/defaultXonotic.cfg index e9cd073be1..49c8483a19 100644 --- a/defaultXonotic.cfg +++ b/defaultXonotic.cfg @@ -615,6 +615,7 @@ set g_arena_respawn_delay 0 set g_arena_respawn_waves 0 set g_ca_respawn_delay 0 set g_ca_respawn_waves 0 +set g_ca_damage2score_multiplier 0.1 set g_nexball_respawn_delay 0 set g_nexball_respawn_waves 0 set g_as_respawn_delay 0 diff --git a/qcsrc/server/arena.qc b/qcsrc/server/arena.qc index ee4ce1b87e..0c9d769e4c 100644 --- a/qcsrc/server/arena.qc +++ b/qcsrc/server/arena.qc @@ -122,10 +122,14 @@ void reset_map(float dorespawn) if(g_keyhunt) kh_Controller_SetThink(cvar("g_balance_keyhunt_delay_round")+(game_starttime - time), "", kh_StartRound); - if(g_arena || g_ca) + if(g_arena) if(champion && champion.classname == "player" && player_count > 1) UpdateFrags(champion, +1); + if(g_ca) + if(champion && champion.classname == "player" && player_count > 1) + TeamScore_AddToTeam(champion.team, SP_SCORE, 1); + self = oldself; } @@ -199,7 +203,7 @@ void Arena_Warmup() allowed_to_spawn = 0; - if(g_ca && (ca_players < required_ca_players || inWarmupStage)) + if(inWarmupStage) allowed_to_spawn = 1; msg = NEWLINES; diff --git a/qcsrc/server/cl_client.qc b/qcsrc/server/cl_client.qc index df6c8d4b2a..bb2b753b84 100644 --- a/qcsrc/server/cl_client.qc +++ b/qcsrc/server/cl_client.qc @@ -1305,7 +1305,12 @@ void ClientKill_TeamChange (float targetteam) // 0 = don't change, -1 = auto void ClientKill (void) { - ClientKill_TeamChange(0); + if((g_arena || g_ca) && ((champion && champion.classname == "player" && player_count > 1) || player_count == 1)) // don't allow a kill in this case either + { + // do nothing + } + else + ClientKill_TeamChange(0); } void DoTeamChange(float destteam) diff --git a/qcsrc/server/clientcommands.qc b/qcsrc/server/clientcommands.qc index a9fd886bfe..b705e9c09c 100644 --- a/qcsrc/server/clientcommands.qc +++ b/qcsrc/server/clientcommands.qc @@ -430,7 +430,7 @@ void ReadyRestartForce() readyrestart_happened = 1; game_starttime = time; - if(!g_ca) + if(!g_ca && !g_arena) game_starttime += RESTART_COUNTDOWN; restart_mapalreadyrestarted = 0; //reset this var, needed when cvar sv_ready_restart_repeatable is in use @@ -448,7 +448,7 @@ void ReadyRestartForce() } //initiate the restart-countdown-announcer entity - if(cvar("sv_ready_restart_after_countdown")) + if(cvar("sv_ready_restart_after_countdown") && !g_ca && !g_arena) { restartTimer = spawn(); restartTimer.think = restartTimer_Think; diff --git a/qcsrc/server/g_damage.qc b/qcsrc/server/g_damage.qc index 6a636a16be..e4dc77d219 100644 --- a/qcsrc/server/g_damage.qc +++ b/qcsrc/server/g_damage.qc @@ -756,6 +756,8 @@ void Damage (entity targ, entity inflictor, entity attacker, float damage, float if(deathtype & HITTYPE_HEADSHOT) headshot = 1; } + if(g_ca) + PlayerScore_Add(attacker, SP_SCORE, damage * cvar("g_ca_damage2score_multiplier")); } } else -- 2.39.2