Refactors machine linking to use generics (#2462)
Co-authored-by: Paul <ritter.paul1+git@googlemail.com>
This commit is contained in:
@@ -1,14 +1,9 @@
|
||||
namespace Content.Server.GameObjects.Components.MachineLinking
|
||||
{
|
||||
public interface ISignalReceiver
|
||||
{
|
||||
void TriggerSignal(SignalState state);
|
||||
}
|
||||
using System;
|
||||
|
||||
public enum SignalState
|
||||
namespace Content.Server.GameObjects.Components.MachineLinking
|
||||
{
|
||||
public interface ISignalReceiver<in T>
|
||||
{
|
||||
On,
|
||||
Off,
|
||||
Toggle
|
||||
void TriggerSignal(T signal);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,4 +1,5 @@
|
||||
using Content.Shared.Interfaces;
|
||||
using Content.Server.GameObjects.Components.MachineLinking.Signals;
|
||||
using Content.Shared.Interfaces;
|
||||
using Content.Shared.Interfaces.GameObjects.Components;
|
||||
using Robust.Shared.GameObjects;
|
||||
using Robust.Shared.Interfaces.GameObjects;
|
||||
@@ -29,7 +30,7 @@ namespace Content.Server.GameObjects.Components.MachineLinking
|
||||
return;
|
||||
}
|
||||
|
||||
if (transmitter.TransmitSignal(user, SignalState.Toggle))
|
||||
if (transmitter.TransmitSignal(user, new ToggleSignal()))
|
||||
{
|
||||
// Since the button doesn't have an animation, I'm going to use a popup message
|
||||
Owner.PopupMessage(user, Loc.GetString("Click."));
|
||||
|
||||
@@ -26,9 +26,9 @@ namespace Content.Server.GameObjects.Components.MachineLinking
|
||||
_transmitters = new List<SignalTransmitterComponent>();
|
||||
}
|
||||
|
||||
public void DistributeSignal(SignalState state)
|
||||
public void DistributeSignal<T>(T state)
|
||||
{
|
||||
foreach (var comp in Owner.GetAllComponents<ISignalReceiver>())
|
||||
foreach (var comp in Owner.GetAllComponents<ISignalReceiver<T>>())
|
||||
{
|
||||
comp.TriggerSignal(state);
|
||||
}
|
||||
|
||||
@@ -52,7 +52,7 @@ namespace Content.Server.GameObjects.Components.MachineLinking
|
||||
return;
|
||||
}
|
||||
|
||||
transmitter.TransmitSignal(user, _on ? SignalState.On : SignalState.Off);
|
||||
transmitter.TransmitSignal(user, _on);
|
||||
}
|
||||
|
||||
private void UpdateSprite()
|
||||
|
||||
@@ -87,7 +87,7 @@ namespace Content.Server.GameObjects.Components.MachineLinking
|
||||
}
|
||||
}
|
||||
|
||||
public bool TransmitSignal(IEntity user, SignalState state)
|
||||
public bool TransmitSignal<T>(IEntity user, T signal)
|
||||
{
|
||||
if (_receivers.Count == 0)
|
||||
{
|
||||
@@ -102,7 +102,7 @@ namespace Content.Server.GameObjects.Components.MachineLinking
|
||||
continue;
|
||||
}
|
||||
|
||||
receiver.DistributeSignal(state);
|
||||
receiver.DistributeSignal(signal);
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
@@ -0,0 +1,4 @@
|
||||
namespace Content.Server.GameObjects.Components.MachineLinking.Signals
|
||||
{
|
||||
public class ToggleSignal {}
|
||||
}
|
||||
Reference in New Issue
Block a user