Optimize ExtensionCableSystem (#6158)

This commit is contained in:
Leon Friedrich
2022-01-18 21:08:57 +13:00
committed by GitHub
parent 3de5848e0b
commit 3413dc732c
5 changed files with 67 additions and 20 deletions

View File

@@ -25,7 +25,8 @@ namespace Content.Server.Power.EntitySystems
SubscribeLocalEvent<ExtensionCableReceiverComponent, ComponentShutdown>(OnReceiverShutdown); SubscribeLocalEvent<ExtensionCableReceiverComponent, ComponentShutdown>(OnReceiverShutdown);
//Anchoring //Anchoring
SubscribeLocalEvent<ExtensionCableReceiverComponent, AnchorStateChangedEvent>(AnchorStateChanged); SubscribeLocalEvent<ExtensionCableReceiverComponent, AnchorStateChangedEvent>(OnReceiverAnchorStateChanged);
SubscribeLocalEvent<ExtensionCableProviderComponent, AnchorStateChangedEvent>(OnProviderAnchorStateChanged);
} }
#region Provider #region Provider
@@ -65,9 +66,34 @@ namespace Content.Server.Power.EntitySystems
ResetReceivers(provider); ResetReceivers(provider);
} }
private void OnProviderAnchorStateChanged(EntityUid uid, ExtensionCableProviderComponent provider, ref AnchorStateChangedEvent args)
{
if (args.Anchored)
{
provider.Connectable = true;
// same as OnProviderStarted
foreach (var receiver in FindAvailableReceivers(uid, provider.TransferRange))
{
receiver.Provider?.LinkedReceivers.Remove(receiver);
receiver.Provider = provider;
provider.LinkedReceivers.Add(receiver);
RaiseLocalEvent(receiver.Owner, new ProviderConnectedEvent(provider), broadcast: false);
RaiseLocalEvent(uid, new ReceiverConnectedEvent(receiver), broadcast: false);
}
}
else
{
// same as OnProviderShutdown
provider.Connectable = false;
ResetReceivers(provider);
}
}
private void ResetReceivers(ExtensionCableProviderComponent provider) private void ResetReceivers(ExtensionCableProviderComponent provider)
{ {
var receivers = provider.LinkedReceivers.ToArray(); var receivers = provider.LinkedReceivers.ToArray();
provider.LinkedReceivers.Clear();
foreach (var receiver in receivers) foreach (var receiver in receivers)
{ {
@@ -80,32 +106,41 @@ namespace Content.Server.Power.EntitySystems
{ {
// No point resetting what the receiver is doing if it's deleting, plus significant perf savings // No point resetting what the receiver is doing if it's deleting, plus significant perf savings
// in not doing needless lookups // in not doing needless lookups
if (MetaData(receiver.Owner).EntityLifeStage > EntityLifeStage.MapInitialized) continue; if (!EntityManager.IsQueuedForDeletion(receiver.Owner)
&& MetaData(receiver.Owner).EntityLifeStage <= EntityLifeStage.MapInitialized)
{
TryFindAndSetProvider(receiver); TryFindAndSetProvider(receiver);
} }
} }
}
private IEnumerable<ExtensionCableReceiverComponent> FindAvailableReceivers(EntityUid owner, float range) private IEnumerable<ExtensionCableReceiverComponent> FindAvailableReceivers(EntityUid owner, float range)
{ {
var xform = Transform(owner); var xform = Transform(owner);
var coordinates = xform.Coordinates; var coordinates = xform.Coordinates;
var nearbyEntities = _lookup.GetEntitiesInRange(coordinates, range); if (!_mapManager.TryGetGrid(xform.GridID, out var grid))
yield break;
var nearbyEntities = grid.GetCellsInSquareArea(coordinates, (int) Math.Ceiling(range / grid.TileSize));
foreach (var entity in nearbyEntities) foreach (var entity in nearbyEntities)
{ {
if (entity != owner && if (entity == owner) continue;
EntityManager.TryGetComponent<ExtensionCableReceiverComponent>(entity, out var receiver) &&
receiver.Connectable && if (EntityManager.IsQueuedForDeletion(entity) || MetaData(entity).EntityLifeStage > EntityLifeStage.MapInitialized)
receiver.Provider == null && continue;
Transform(entity).Coordinates.TryDistance(EntityManager, coordinates, out var distance) &&
distance < Math.Min(range, receiver.ReceptionRange)) if (!TryComp(entity, out ExtensionCableReceiverComponent? receiver))
{ continue;
if (!receiver.Connectable || receiver.Provider != null)
continue;
if ((Transform(entity).LocalPosition - xform.LocalPosition).Length < Math.Min(range, receiver.ReceptionRange))
yield return receiver; yield return receiver;
} }
} }
}
#endregion #endregion
@@ -152,7 +187,7 @@ namespace Content.Server.Power.EntitySystems
RaiseLocalEvent(receiver.Provider.Owner, new ReceiverDisconnectedEvent(receiver), broadcast: false); RaiseLocalEvent(receiver.Provider.Owner, new ReceiverDisconnectedEvent(receiver), broadcast: false);
} }
private void AnchorStateChanged(EntityUid uid, ExtensionCableReceiverComponent receiver, ref AnchorStateChangedEvent args) private void OnReceiverAnchorStateChanged(EntityUid uid, ExtensionCableReceiverComponent receiver, ref AnchorStateChangedEvent args)
{ {
if (args.Anchored) if (args.Anchored)
{ {
@@ -178,6 +213,8 @@ namespace Content.Server.Power.EntitySystems
private void TryFindAndSetProvider(ExtensionCableReceiverComponent receiver, TransformComponent? xform = null) private void TryFindAndSetProvider(ExtensionCableReceiverComponent receiver, TransformComponent? xform = null)
{ {
if (!receiver.Connectable) return;
if (!TryFindAvailableProvider(receiver.Owner, receiver.ReceptionRange, out var provider, xform)) return; if (!TryFindAvailableProvider(receiver.Owner, receiver.ReceptionRange, out var provider, xform)) return;
receiver.Provider = provider; receiver.Provider = provider;
@@ -188,24 +225,26 @@ namespace Content.Server.Power.EntitySystems
private bool TryFindAvailableProvider(EntityUid owner, float range, [NotNullWhen(true)] out ExtensionCableProviderComponent? foundProvider, TransformComponent? xform = null) private bool TryFindAvailableProvider(EntityUid owner, float range, [NotNullWhen(true)] out ExtensionCableProviderComponent? foundProvider, TransformComponent? xform = null)
{ {
if (!Resolve(owner, ref xform)) if (!Resolve(owner, ref xform) || !_mapManager.TryGetGrid(xform.GridID, out var grid))
{ {
foundProvider = null; foundProvider = null;
return false; return false;
} }
var coordinates = xform.Coordinates; var coordinates = xform.Coordinates;
var nearbyEntities = _lookup.GetEntitiesInRange(coordinates, range); var nearbyEntities = grid.GetCellsInSquareArea(coordinates, (int) Math.Ceiling(range / grid.TileSize));
foreach (var entity in nearbyEntities) foreach (var entity in nearbyEntities)
{ {
if (entity == owner || !EntityManager.TryGetComponent<ExtensionCableProviderComponent?>(entity, out var provider)) continue; if (entity == owner || !EntityManager.TryGetComponent<ExtensionCableProviderComponent?>(entity, out var provider)) continue;
if (EntityManager.IsQueuedForDeletion(entity)) continue;
if (MetaData(entity).EntityLifeStage > EntityLifeStage.MapInitialized) continue;
if (!provider.Connectable) continue; if (!provider.Connectable) continue;
if (!Transform(entity).Coordinates.TryDistance(EntityManager, coordinates, out var distance)) continue; if ((Transform(entity).LocalPosition - xform.LocalPosition).Length > Math.Min(range, provider.TransferRange)) continue;
if (!(distance < Math.Min(range, provider.TransferRange))) continue;
foundProvider = provider; foundProvider = provider;
return true; return true;

View File

@@ -2,6 +2,8 @@
name: cell recharger name: cell recharger
id: PowerCellRecharger id: PowerCellRecharger
components: components:
- type: Transform
anchored: true
- type: Sprite - type: Sprite
netsync: false netsync: false
sprite: Structures/Power/cell_recharger.rsi sprite: Structures/Power/cell_recharger.rsi

View File

@@ -4,6 +4,8 @@
description: "An unpowered light." description: "An unpowered light."
suffix: Unpowered suffix: Unpowered
components: components:
- type: Transform
anchored: true
- type: Clickable - type: Clickable
- type: InteractionOutline - type: InteractionOutline
- type: Construction - type: Construction

View File

@@ -54,6 +54,8 @@
- type: Clickable - type: Clickable
- type: InteractionOutline - type: InteractionOutline
- type: Physics - type: Physics
- type: Transform
anchored: true
- type: Sprite - type: Sprite
sprite: Structures/Wallmounts/switch.rsi sprite: Structures/Wallmounts/switch.rsi
state: on state: on

View File

@@ -7,6 +7,8 @@
- type: InteractionOutline - type: InteractionOutline
- type: Physics - type: Physics
bodyType: Static bodyType: Static
- type: Transform
anchored: true
- type: Fixtures - type: Fixtures
fixtures: fixtures:
- shape: - shape: