]> git.smokeofanarchy.ru Git - space-station-14.git/commitdiff
Limit hydraulic clamps to one DoAfter at a time (#23982)
authorthemias <89101928+themias@users.noreply.github.com>
Fri, 12 Jan 2024 20:33:47 +0000 (15:33 -0500)
committerGitHub <noreply@github.com>
Fri, 12 Jan 2024 20:33:47 +0000 (13:33 -0700)
Limit Ripleys to one DoAfter at a time

Content.Server/Mech/Equipment/Components/MechGrabberComponent.cs
Content.Server/Mech/Equipment/EntitySystems/MechGrabberSystem.cs

index df94bc94eefa8967ab69317b0d6fccafb9d2c953..f4b3a985bfc7325a3dcc2be24cc5aa60738f16e3 100644 (file)
@@ -1,5 +1,6 @@
 using System.Numerics;
 using System.Threading;
+using Content.Shared.DoAfter;
 using Robust.Shared.Audio;
 using Robust.Shared.Containers;
 
@@ -47,4 +48,7 @@ public sealed partial class MechGrabberComponent : Component
 
     [ViewVariables(VVAccess.ReadWrite)]
     public Container ItemContainer = default!;
+
+    [DataField, ViewVariables(VVAccess.ReadOnly)]
+    public DoAfterId? DoAfter;
 }
index 9f5d564d5a2632b97cd8aec6525aee3ade3d6046..fa46792d2af91c86b94f4ca3864d617a6e9ac492 100644 (file)
@@ -128,6 +128,9 @@ public sealed class MechGrabberSystem : EntitySystem
         if (args.Handled || args.Target is not {} target)
             return;
 
+        if (args.Target == args.User || component.DoAfter != null)
+            return;
+
         if (TryComp<PhysicsComponent>(target, out var physics) && physics.BodyType == BodyType.Static ||
             HasComp<WallMountComponent>(target) ||
             HasComp<MobStateComponent>(target))
@@ -152,15 +155,19 @@ public sealed class MechGrabberSystem : EntitySystem
 
         args.Handled = true;
         component.AudioStream = _audio.PlayPvs(component.GrabSound, uid).Value.Entity;
-        _doAfter.TryStartDoAfter(new DoAfterArgs(EntityManager, args.User, component.GrabDelay, new GrabberDoAfterEvent(), uid, target: target, used: uid)
+        var doAfterArgs = new DoAfterArgs(EntityManager, args.User, component.GrabDelay, new GrabberDoAfterEvent(), uid, target: target, used: uid)
         {
             BreakOnTargetMove = true,
             BreakOnUserMove = true
-        });
+        };
+
+        _doAfter.TryStartDoAfter(doAfterArgs, out component.DoAfter);
     }
 
     private void OnMechGrab(EntityUid uid, MechGrabberComponent component, DoAfterEvent args)
     {
+        component.DoAfter = null;
+
         if (args.Cancelled)
         {
             component.AudioStream = _audio.Stop(component.AudioStream);