merge stable into master (#40369)

This commit is contained in:
slarticodefast
2025-09-15 13:45:40 +02:00
committed by GitHub
3 changed files with 10 additions and 3 deletions

View File

@@ -242,13 +242,18 @@ namespace Content.Shared.Cuffs
args.Cancel(); args.Cancel();
} }
private void HandleStopPull(EntityUid uid, CuffableComponent component, AttemptStopPullingEvent args) private void HandleStopPull(EntityUid uid, CuffableComponent component, ref AttemptStopPullingEvent args)
{ {
if (args.User == null || !Exists(args.User.Value)) if (args.User == null || !Exists(args.User.Value))
return; return;
if (args.User.Value == uid && !component.CanStillInteract) if (args.User.Value == uid && !component.CanStillInteract)
{
//TODO: UX feedback. Simply blocking the normal interaction feels like an interface bug
args.Cancelled = true; args.Cancelled = true;
}
} }
private void OnRemoveCuffsAlert(Entity<CuffableComponent> ent, ref RemoveCuffsAlertEvent args) private void OnRemoveCuffsAlert(Entity<CuffableComponent> ent, ref RemoveCuffsAlertEvent args)

View File

@@ -3,6 +3,8 @@ namespace Content.Shared.Pulling.Events;
/// <summary> /// <summary>
/// Raised when a request is made to stop pulling an entity. /// Raised when a request is made to stop pulling an entity.
/// </summary> /// </summary>
[ByRefEvent]
public record struct AttemptStopPullingEvent(EntityUid? User = null) public record struct AttemptStopPullingEvent(EntityUid? User = null)
{ {
public readonly EntityUid? User = User; public readonly EntityUid? User = User;

View File

@@ -599,7 +599,7 @@ public sealed class PullingSystem : EntitySystem
return true; return true;
var msg = new AttemptStopPullingEvent(user); var msg = new AttemptStopPullingEvent(user);
RaiseLocalEvent(pullableUid, msg, true); RaiseLocalEvent(pullableUid, ref msg, true);
if (msg.Cancelled) if (msg.Cancelled)
return false; return false;