X-Git-Url: http://de.git.xonotic.org/?p=voretournament%2Fvoretournament.git;a=blobdiff_plain;f=data%2Fqcsrc%2Fserver%2Fw_grabber.qc;h=dbf470f3d44b61c50f2b1ddc4a12d170389c1042;hp=b9ac88cce7e4ada1a296f67eee44ba43f164f966;hb=8e9b77f4630d1ae72de5f324b9a232f426651193;hpb=9ff04a44c0df8ef195db6d2c47e1071e61d307e7 diff --git a/data/qcsrc/server/w_grabber.qc b/data/qcsrc/server/w_grabber.qc index b9ac88cc..dbf470f3 100644 --- a/data/qcsrc/server/w_grabber.qc +++ b/data/qcsrc/server/w_grabber.qc @@ -46,6 +46,7 @@ void W_Grabber_Attack2() if (trace_fraction < 1) { Damage(trace_ent, self, self, cvar("g_balance_grabber_secondary_damage"), WEP_GRABBER | HITTYPE_SECONDARY, trace_endpos, cvar("g_balance_grabber_secondary_force") * w_shotdir); + pointparticles(particleeffectnum("grabber_impact2"), trace_endpos, '0 0 0', 1); W_Grabber_UpdateStats(self, FALSE, TRUE); // the shot is recorded above } @@ -62,7 +63,7 @@ void spawnfunc_weapon_grabber (void) float w_grabber(float req) { - if(self.predator.classname == "player") // we can't use weapons while in the stomach + if(self.stat_eaten) // we can't use weapons while in the stomach { self.grabber_state |= GRABBER_REMOVING; return FALSE; @@ -87,7 +88,7 @@ float w_grabber(float req) } else if not(self.clip_load < 0) // we're not currently reloading { - if (self.BUTTON_ATCK) + if (self.BUTTON_ATCK && weapon_action(self.weapon, WR_CHECKAMMO1)) { if(time < self.weapon_delay) return FALSE; @@ -105,7 +106,7 @@ float w_grabber(float req) weapon_thinkf(WFRAME_FIRE1, cvar("g_balance_grabber_primary_animtime"), w_ready); } } - if (self.BUTTON_ATCK2) + if (self.BUTTON_ATCK2 && weapon_action(self.weapon, WR_CHECKAMMO2)) { if (weapon_prepareattack(1, cvar("g_balance_grabber_secondary_refire"))) { @@ -141,7 +142,13 @@ float w_grabber(float req) { if not(self.items & IT_UNLIMITED_WEAPON_AMMO) { - if ( self.ammo_fuel >= (time - self.grabber_time_fueldecrease) * grabbered_fuel ) + float active_ammo; + if(cvar("g_balance_grabber_reload_ammo")) + active_ammo = self.clip_load; + else + active_ammo = self.ammo_fuel; + + if (active_ammo >= (time - self.grabber_time_fueldecrease) * grabbered_fuel ) { W_DecreaseAmmo(ammo_fuel, (time - self.grabber_time_fueldecrease) * grabbered_fuel, cvar("g_balance_grabber_reload_ammo")); self.grabber_time_fueldecrease = time;