]> git.rm.cloudns.org Git - xonotic/xonotic-data.pk3dir.git/commitdiff
handle the electro lightning refire as -1 to hopefully prevent the occasional "switch...
authorFruitieX <rasse@rasse-lappy.localdomain>
Tue, 31 Aug 2010 16:58:34 +0000 (19:58 +0300)
committerFruitieX <rasse@rasse-lappy.localdomain>
Tue, 31 Aug 2010 16:58:34 +0000 (19:58 +0300)
qcsrc/server/w_electro.qc
qcsrc/server/w_shotgun.qc

index a98c5a9153a0214842e84a67edc3bbb1bdf8529c..4ec7ca55c3c66e5a49b72a0be9eecc560e95553c 100644 (file)
@@ -348,7 +348,7 @@ float w_electro(float req)
        {
                if (self.BUTTON_ATCK)
                {
-                       if (weapon_prepareattack(0, (cvar("g_balance_electro_lightning") ? 0 : cvar("g_balance_electro_primary_refire"))))
+                       if (weapon_prepareattack(0, (cvar("g_balance_electro_lightning") ? -1 : cvar("g_balance_electro_primary_refire"))))
                        {
                                if(cvar("g_balance_electro_lightning"))
                                {
index 65812153318e1ff2919d56e3e336e2dabede09cc..29343c8f749dd73e591dc325d237f10f27d54c62 100644 (file)
@@ -94,6 +94,8 @@ void W_Shotgun_Attack2 (void)
 
 void spawnfunc_weapon_shotgun(); // defined in t_items.qc
 
+.float shotgun_primarytime;
+
 float w_shotgun(float req)
 {
        if (req == WR_AIM)
@@ -104,10 +106,16 @@ float w_shotgun(float req)
        else if (req == WR_THINK)
        {
                if (self.BUTTON_ATCK)
-               if (weapon_prepareattack(0, cvar("g_balance_shotgun_primary_refire")))
                {
-                       W_Shotgun_Attack();
-                       weapon_thinkf(WFRAME_FIRE1, cvar("g_balance_shotgun_primary_animtime"), w_ready);
+                       if (time >= self.shotgun_primarytime) // handle refire separately so the secondary can be fired straight after a primary
+                       {
+                               if(weapon_prepareattack(0, cvar("g_balance_shotgun_primary_animtime")))
+                               {
+                                       W_Shotgun_Attack();
+                                       self.shotgun_primarytime = time + cvar("g_balance_shotgun_primary_refire");
+                                       weapon_thinkf(WFRAME_FIRE1, cvar("g_balance_shotgun_primary_animtime"), w_ready);
+                               }
+                       }
                }
                if (self.BUTTON_ATCK2 && cvar("g_balance_shotgun_secondary"))
                if (weapon_prepareattack(1, cvar("g_balance_shotgun_secondary_refire")))