From 61cb733c0ef5f26597bdddf530deece52992658c Mon Sep 17 00:00:00 2001 From: Mircea Kitsune Date: Fri, 11 Feb 2011 18:57:32 +0200 Subject: [PATCH] Set self.current_ammo in each weapon's WR_SETUP stage. That way, this float can be used for many things throughout the code, and is always updated. Not fully finished. --- qcsrc/server/cl_weaponsystem.qc | 5 +---- qcsrc/server/w_crylink.qc | 1 + qcsrc/server/w_electro.qc | 1 + qcsrc/server/w_fireball.qc | 1 + qcsrc/server/w_grenadelauncher.qc | 1 + qcsrc/server/w_hagar.qc | 1 + qcsrc/server/w_hlac.qc | 1 + qcsrc/server/w_hook.qc | 1 + qcsrc/server/w_laser.qc | 1 + qcsrc/server/w_minelayer.qc | 1 + qcsrc/server/w_minstanex.qc | 1 + qcsrc/server/w_nex.qc | 1 + qcsrc/server/w_porto.qc | 1 + qcsrc/server/w_rocketlauncher.qc | 1 + qcsrc/server/w_seeker.qc | 1 + qcsrc/server/w_shotgun.qc | 1 + qcsrc/server/w_sniperrifle.qc | 1 + qcsrc/server/w_tuba.qc | 1 + 18 files changed, 18 insertions(+), 4 deletions(-) diff --git a/qcsrc/server/cl_weaponsystem.qc b/qcsrc/server/cl_weaponsystem.qc index 222c0f9fdb..cea3c92fca 100644 --- a/qcsrc/server/cl_weaponsystem.qc +++ b/qcsrc/server/cl_weaponsystem.qc @@ -1623,10 +1623,7 @@ void W_DecreaseAmmo(.float ammo_type, float ammo_use, float ammo_reload) self.weapon_load[self.weapon] = self.clip_load; } else - { - self.current_ammo = ammo_type; self.(self.current_ammo) -= ammo_use; - } } } @@ -1722,7 +1719,7 @@ void W_ReloadStart() void W_Reload(.float sent_ammo_player, float sent_ammo_min, float sent_ammo_amount, float sent_time, string sent_sound) { - self.current_ammo = sent_ammo_player; + //self.current_ammo = sent_ammo_player; self.reload_ammo_min = sent_ammo_min; self.reload_ammo_amount = sent_ammo_amount; self.reload_time = sent_time; diff --git a/qcsrc/server/w_crylink.qc b/qcsrc/server/w_crylink.qc index a663df0f8e..4109807753 100644 --- a/qcsrc/server/w_crylink.qc +++ b/qcsrc/server/w_crylink.qc @@ -601,6 +601,7 @@ float w_crylink(float req) else if (req == WR_SETUP) { weapon_setup(WEP_CRYLINK); + self.current_ammo = ammo_cells; } else if (req == WR_CHECKAMMO1) { diff --git a/qcsrc/server/w_electro.qc b/qcsrc/server/w_electro.qc index 6fb410019e..31686c821c 100644 --- a/qcsrc/server/w_electro.qc +++ b/qcsrc/server/w_electro.qc @@ -494,6 +494,7 @@ float w_electro(float req) else if (req == WR_SETUP) { weapon_setup(WEP_ELECTRO); + self.current_ammo = ammo_cells; } else if (req == WR_CHECKAMMO1) { diff --git a/qcsrc/server/w_fireball.qc b/qcsrc/server/w_fireball.qc index a269c65563..65b944ffe3 100644 --- a/qcsrc/server/w_fireball.qc +++ b/qcsrc/server/w_fireball.qc @@ -360,6 +360,7 @@ float w_fireball(float req) else if (req == WR_SETUP) { weapon_setup(WEP_FIREBALL); + self.current_ammo = ammo_fuel; } else if (req == WR_CHECKAMMO1) { diff --git a/qcsrc/server/w_grenadelauncher.qc b/qcsrc/server/w_grenadelauncher.qc index 5ea482a4c5..a50f47d37f 100644 --- a/qcsrc/server/w_grenadelauncher.qc +++ b/qcsrc/server/w_grenadelauncher.qc @@ -336,6 +336,7 @@ float w_glauncher(float req) else if (req == WR_SETUP) { weapon_setup(WEP_GRENADE_LAUNCHER); + self.current_ammo = ammo_rockets; } else if (req == WR_CHECKAMMO1) { diff --git a/qcsrc/server/w_hagar.qc b/qcsrc/server/w_hagar.qc index cb6fad0039..7a6adffa92 100644 --- a/qcsrc/server/w_hagar.qc +++ b/qcsrc/server/w_hagar.qc @@ -160,6 +160,7 @@ float w_hagar(float req) else if (req == WR_SETUP) { weapon_setup(WEP_HAGAR); + self.current_ammo = ammo_rockets; } else if (req == WR_CHECKAMMO1) { diff --git a/qcsrc/server/w_hlac.qc b/qcsrc/server/w_hlac.qc index c1de434ed4..1809ab1770 100644 --- a/qcsrc/server/w_hlac.qc +++ b/qcsrc/server/w_hlac.qc @@ -199,6 +199,7 @@ float w_hlac(float req) else if (req == WR_SETUP) { weapon_setup(WEP_HLAC); + self.current_ammo = ammo_cells; } else if (req == WR_CHECKAMMO1) { diff --git a/qcsrc/server/w_hook.qc b/qcsrc/server/w_hook.qc index ebf7c24e5f..c3a1768beb 100644 --- a/qcsrc/server/w_hook.qc +++ b/qcsrc/server/w_hook.qc @@ -228,6 +228,7 @@ float w_hook(float req) else if (req == WR_SETUP) { weapon_setup(WEP_HOOK); + self.current_ammo = ammo_fuel; self.hook_state &~= HOOK_WAITING_FOR_RELEASE; } else if (req == WR_CHECKAMMO1) diff --git a/qcsrc/server/w_laser.qc b/qcsrc/server/w_laser.qc index ad29d442a0..9ba19f9d50 100644 --- a/qcsrc/server/w_laser.qc +++ b/qcsrc/server/w_laser.qc @@ -269,6 +269,7 @@ float w_laser(float req) else if (req == WR_SETUP) { weapon_setup(WEP_LASER); + self.current_ammo = zero_ammo; } else if (req == WR_CHECKAMMO1) { diff --git a/qcsrc/server/w_minelayer.qc b/qcsrc/server/w_minelayer.qc index 3c9aac6cc2..b52493fd51 100644 --- a/qcsrc/server/w_minelayer.qc +++ b/qcsrc/server/w_minelayer.qc @@ -416,6 +416,7 @@ float w_minelayer(float req) else if (req == WR_SETUP) { weapon_setup(WEP_MINE_LAYER); + self.current_ammo = ammo_rockets; } else if (req == WR_CHECKAMMO1) { diff --git a/qcsrc/server/w_minstanex.qc b/qcsrc/server/w_minstanex.qc index a15a6b2587..d5dd7d0f60 100644 --- a/qcsrc/server/w_minstanex.qc +++ b/qcsrc/server/w_minstanex.qc @@ -234,6 +234,7 @@ float w_minstanex(float req) else if (req == WR_SETUP) { weapon_setup(WEP_MINSTANEX); + self.current_ammo = ammo_cells; self.minstanex_lasthit = 0; } else if (req == WR_CHECKAMMO1) diff --git a/qcsrc/server/w_nex.qc b/qcsrc/server/w_nex.qc index e3f4659c90..670d8a3eb0 100644 --- a/qcsrc/server/w_nex.qc +++ b/qcsrc/server/w_nex.qc @@ -220,6 +220,7 @@ float w_nex(float req) else if (req == WR_SETUP) { weapon_setup(WEP_NEX); + self.current_ammo = ammo_cells; } else if (req == WR_CHECKAMMO1) { diff --git a/qcsrc/server/w_porto.qc b/qcsrc/server/w_porto.qc index 76b5a50729..503fdde316 100644 --- a/qcsrc/server/w_porto.qc +++ b/qcsrc/server/w_porto.qc @@ -272,6 +272,7 @@ float w_porto(float req) else if (req == WR_SETUP) { weapon_setup(WEP_PORTO); + self.current_ammo = zero_ammo; } else if (req == WR_RESETPLAYER) { diff --git a/qcsrc/server/w_rocketlauncher.qc b/qcsrc/server/w_rocketlauncher.qc index c33e0e7648..8e45a61daf 100644 --- a/qcsrc/server/w_rocketlauncher.qc +++ b/qcsrc/server/w_rocketlauncher.qc @@ -450,6 +450,7 @@ float w_rlauncher(float req) else if (req == WR_SETUP) { weapon_setup(WEP_ROCKET_LAUNCHER); + self.current_ammo = ammo_rockets; self.rl_release = 1; } else if (req == WR_CHECKAMMO1) diff --git a/qcsrc/server/w_seeker.qc b/qcsrc/server/w_seeker.qc index 3659a2ec48..cfe7df6345 100644 --- a/qcsrc/server/w_seeker.qc +++ b/qcsrc/server/w_seeker.qc @@ -451,6 +451,7 @@ float w_seeker(float req) else if (req == WR_SETUP) { weapon_setup(WEP_SEEKER); + self.current_ammo = ammo_rockets; } else if (req == WR_CHECKAMMO1) { diff --git a/qcsrc/server/w_shotgun.qc b/qcsrc/server/w_shotgun.qc index f92a3d356e..538e1de27d 100644 --- a/qcsrc/server/w_shotgun.qc +++ b/qcsrc/server/w_shotgun.qc @@ -152,6 +152,7 @@ float w_shotgun(float req) else if (req == WR_SETUP) { weapon_setup(WEP_SHOTGUN); + self.current_ammo = ammo_shells; } else if (req == WR_CHECKAMMO1) { diff --git a/qcsrc/server/w_sniperrifle.qc b/qcsrc/server/w_sniperrifle.qc index ec5743d0b1..deeab0ad06 100644 --- a/qcsrc/server/w_sniperrifle.qc +++ b/qcsrc/server/w_sniperrifle.qc @@ -180,6 +180,7 @@ float w_sniperrifle(float req) else if (req == WR_SETUP) { weapon_setup(WEP_SNIPERRIFLE); + self.current_ammo = ammo_nails; } else if (req == WR_CHECKAMMO1) { diff --git a/qcsrc/server/w_tuba.qc b/qcsrc/server/w_tuba.qc index 00c083956d..9849c37db5 100644 --- a/qcsrc/server/w_tuba.qc +++ b/qcsrc/server/w_tuba.qc @@ -238,6 +238,7 @@ float w_tuba(float req) else if (req == WR_SETUP) { weapon_setup(WEP_TUBA); + self.current_ammo = zero_ammo; } else if (req == WR_CHECKAMMO1) return TRUE; // TODO use fuel? -- 2.39.2