From c28d67f351bd2df30ec7b43e88a1031d482b50b9 Mon Sep 17 00:00:00 2001 From: MrBougo Date: Sun, 18 Sep 2011 14:09:51 +0200 Subject: [PATCH] make weaplast and laser secondary use the best other weapon if previous is unusable this also makes weaplast use the second best weapon on spawn --- qcsrc/server/cl_client.qc | 2 +- qcsrc/server/cl_impulse.qc | 2 +- qcsrc/server/cl_weapons.qc | 9 +++++++++ qcsrc/server/w_laser.qc | 3 ++- 4 files changed, 13 insertions(+), 3 deletions(-) diff --git a/qcsrc/server/cl_client.qc b/qcsrc/server/cl_client.qc index ef05663e5c..dde6a26ab4 100644 --- a/qcsrc/server/cl_client.qc +++ b/qcsrc/server/cl_client.qc @@ -1109,7 +1109,7 @@ void PutClientInServer (void) MUTATOR_CALLHOOK(PlayerSpawn); self.switchweapon = w_getbestweapon(self); - self.cnt = self.switchweapon; + self.cnt = -1; // W_LastWeapon will not complain self.weapon = 0; self.switchingweapon = 0; diff --git a/qcsrc/server/cl_impulse.qc b/qcsrc/server/cl_impulse.qc index 939b6d2580..9e211e5f50 100644 --- a/qcsrc/server/cl_impulse.qc +++ b/qcsrc/server/cl_impulse.qc @@ -70,7 +70,7 @@ void ImpulseCommands (void) W_NextWeapon (0); break; case 11: - W_SwitchWeapon (self.cnt); // previously used + W_LastWeapon(); break; case 12: W_PreviousWeapon (0); diff --git a/qcsrc/server/cl_weapons.qc b/qcsrc/server/cl_weapons.qc index fe67896184..f0981f5e29 100644 --- a/qcsrc/server/cl_weapons.qc +++ b/qcsrc/server/cl_weapons.qc @@ -137,6 +137,15 @@ void W_PreviousWeapon(float list) W_CycleWeapon(self.cvar_cl_weaponpriority, +1); } +// previously used if exists and has ammo, (second) best otherwise +void W_LastWeapon() +{ + if(client_hasweapon(self, self.cnt, TRUE, FALSE)) + W_SwitchWeapon(self.cnt); + else + W_SwitchToOtherWeapon(self); +} + float w_getbestweapon(entity e) { return W_GetCycleWeapon(e, e.cvar_cl_weaponpriority, 0, -1, FALSE, TRUE); diff --git a/qcsrc/server/w_laser.qc b/qcsrc/server/w_laser.qc index 5e034acb90..fa52a6e0df 100644 --- a/qcsrc/server/w_laser.qc +++ b/qcsrc/server/w_laser.qc @@ -3,6 +3,7 @@ REGISTER_WEAPON(LASER, w_laser, 0, 1, WEP_FLAG_NORMAL | WEP_FLAG_RELOADABLE | WE #else #ifdef SVQC void(float imp) W_SwitchWeapon; +void() W_LastWeapon; void W_Laser_Touch (void) { @@ -259,7 +260,7 @@ float w_laser(float req) else { if(self.switchweapon == WEP_LASER) // don't do this if already switching - W_SwitchWeapon (self.cnt); + W_LastWeapon(); } } } -- 2.39.2