Add IResettingEntitySystem for entity systems that do resetting cleanup (#2257)

* Add IResettingEntitySystem for entity systems that do resetting cleanup

* You got a license for that submodule update?
This commit is contained in:
DrSmugleaf
2020-10-14 22:45:53 +02:00
committed by GitHub
parent 6be80c119b
commit 50bc61b672
17 changed files with 76 additions and 54 deletions

View File

@@ -4,6 +4,7 @@ using Content.Client.Interfaces;
using Content.Client.State; using Content.Client.State;
using Content.Client.UserInterface; using Content.Client.UserInterface;
using Content.Shared; using Content.Shared;
using Content.Shared.GameTicking;
using Content.Shared.Network.NetMessages; using Content.Shared.Network.NetMessages;
using Robust.Client.Interfaces.Graphics; using Robust.Client.Interfaces.Graphics;
using Robust.Client.Interfaces.State; using Robust.Client.Interfaces.State;

View File

@@ -1,7 +1,7 @@
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using Robust.Shared.Network; using Robust.Shared.Network;
using static Content.Shared.SharedGameTicker; using static Content.Shared.GameTicking.SharedGameTicker;
namespace Content.Client.Interfaces namespace Content.Client.Interfaces
{ {

View File

@@ -18,7 +18,7 @@ using Robust.Shared.Localization;
using Robust.Shared.Prototypes; using Robust.Shared.Prototypes;
using Robust.Shared.Timing; using Robust.Shared.Timing;
using Robust.Shared.ViewVariables; using Robust.Shared.ViewVariables;
using static Content.Shared.SharedGameTicker; using static Content.Shared.GameTicking.SharedGameTicker;
namespace Content.Client.State namespace Content.Client.State
{ {

View File

@@ -4,6 +4,7 @@ using System.Linq;
using Content.Client.GameObjects.Components; using Content.Client.GameObjects.Components;
using Content.Client.Interfaces; using Content.Client.Interfaces;
using Content.Shared; using Content.Shared;
using Content.Shared.GameTicking;
using Content.Shared.Preferences; using Content.Shared.Preferences;
using Content.Shared.Roles; using Content.Shared.Roles;
using Robust.Client.Graphics.Drawing; using Robust.Client.Graphics.Drawing;

View File

@@ -3,6 +3,7 @@ using Content.Client.GameObjects.Components.HUD.Inventory;
using Content.Client.GameObjects.Components.Mobs; using Content.Client.GameObjects.Components.Mobs;
using Content.Client.Interfaces; using Content.Client.Interfaces;
using Content.Shared; using Content.Shared;
using Content.Shared.GameTicking;
using Content.Shared.Preferences; using Content.Shared.Preferences;
using Content.Shared.Roles; using Content.Shared.Roles;
using Robust.Client.Interfaces.GameObjects.Components; using Robust.Client.Interfaces.GameObjects.Components;

View File

@@ -7,7 +7,7 @@ using Robust.Client.UserInterface.Controls;
using Robust.Client.UserInterface.CustomControls; using Robust.Client.UserInterface.CustomControls;
using Robust.Shared.Localization; using Robust.Shared.Localization;
using Robust.Shared.Maths; using Robust.Shared.Maths;
using static Content.Shared.SharedGameTicker; using static Content.Shared.GameTicking.SharedGameTicker;
namespace Content.Client.UserInterface namespace Content.Client.UserInterface
{ {

View File

@@ -3,6 +3,7 @@ using System.Collections.Generic;
using Content.Server.GameObjects.Components.Access; using Content.Server.GameObjects.Components.Access;
using Content.Server.GameObjects.EntitySystems.AI.Pathfinding.Pathfinders; using Content.Server.GameObjects.EntitySystems.AI.Pathfinding.Pathfinders;
using Content.Shared.AI; using Content.Shared.AI;
using Content.Shared.GameTicking;
using JetBrains.Annotations; using JetBrains.Annotations;
using Robust.Server.GameObjects; using Robust.Server.GameObjects;
using Robust.Shared.GameObjects.Components; using Robust.Shared.GameObjects.Components;
@@ -22,7 +23,7 @@ namespace Content.Server.GameObjects.EntitySystems.AI.Pathfinding.Accessible
/// </summary> /// </summary>
/// Long-term can be used to do hierarchical pathfinding /// Long-term can be used to do hierarchical pathfinding
[UsedImplicitly] [UsedImplicitly]
public sealed class AiReachableSystem : EntitySystem public sealed class AiReachableSystem : EntitySystem, IResettingEntitySystem
{ {
/* /*
* The purpose of this is to provide a higher-level / hierarchical abstraction of the actual pathfinding graph * The purpose of this is to provide a higher-level / hierarchical abstraction of the actual pathfinding graph
@@ -134,14 +135,6 @@ namespace Content.Server.GameObjects.EntitySystems.AI.Pathfinding.Accessible
_mapManager.OnGridRemoved -= GridRemoved; _mapManager.OnGridRemoved -= GridRemoved;
} }
public void ResettingCleanup()
{
_queuedUpdates.Clear();
_regions.Clear();
_cachedAccessible.Clear();
_queuedCacheDeletions.Clear();
}
private void RecalculateNodeRegions(PathfindingChunkUpdateMessage message) private void RecalculateNodeRegions(PathfindingChunkUpdateMessage message)
{ {
// TODO: Only need to do changed nodes ideally // TODO: Only need to do changed nodes ideally
@@ -683,6 +676,14 @@ namespace Content.Server.GameObjects.EntitySystems.AI.Pathfinding.Accessible
#endif #endif
} }
public void Reset()
{
_queuedUpdates.Clear();
_regions.Clear();
_cachedAccessible.Clear();
_queuedCacheDeletions.Clear();
}
#if DEBUG #if DEBUG
private void SendDebugMessage(PlayerAttachSystemMessage message) private void SendDebugMessage(PlayerAttachSystemMessage message)
{ {

View File

@@ -5,6 +5,7 @@ using Content.Server.GameObjects.Components.Access;
using Content.Server.GameObjects.EntitySystems.AI.Pathfinding.Pathfinders; using Content.Server.GameObjects.EntitySystems.AI.Pathfinding.Pathfinders;
using Content.Server.GameObjects.EntitySystems.JobQueues; using Content.Server.GameObjects.EntitySystems.JobQueues;
using Content.Server.GameObjects.EntitySystems.JobQueues.Queues; using Content.Server.GameObjects.EntitySystems.JobQueues.Queues;
using Content.Shared.GameTicking;
using Content.Shared.Physics; using Content.Shared.Physics;
using Robust.Shared.GameObjects.Components; using Robust.Shared.GameObjects.Components;
using Robust.Shared.GameObjects.Components.Transform; using Robust.Shared.GameObjects.Components.Transform;
@@ -28,7 +29,7 @@ namespace Content.Server.GameObjects.EntitySystems.AI.Pathfinding
/// This system handles pathfinding graph updates as well as dispatches to the pathfinder /// This system handles pathfinding graph updates as well as dispatches to the pathfinder
/// (90% of what it's doing is graph updates so not much point splitting the 2 roles) /// (90% of what it's doing is graph updates so not much point splitting the 2 roles)
/// </summary> /// </summary>
public class PathfindingSystem : EntitySystem public class PathfindingSystem : EntitySystem, IResettingEntitySystem
{ {
[Dependency] private readonly IMapManager _mapManager = default!; [Dependency] private readonly IMapManager _mapManager = default!;
[Dependency] private readonly IEntityManager _entityManager = default!; [Dependency] private readonly IEntityManager _entityManager = default!;
@@ -230,16 +231,6 @@ namespace Content.Server.GameObjects.EntitySystems.AI.Pathfinding
node.UpdateTile(tile); node.UpdateTile(tile);
} }
public void ResettingCleanup()
{
_graph.Clear();
_collidableUpdateQueue.Clear();
_moveUpdateQueue.Clear();
_accessReaderUpdateQueue.Clear();
_tileUpdateQueue.Clear();
_lastKnownPositions.Clear();
}
private void HandleGridRemoval(GridId gridId) private void HandleGridRemoval(GridId gridId)
{ {
if (_graph.ContainsKey(gridId)) if (_graph.ContainsKey(gridId))
@@ -389,5 +380,15 @@ namespace Content.Server.GameObjects.EntitySystems.AI.Pathfinding
return true; return true;
} }
public void Reset()
{
_graph.Clear();
_collidableUpdateQueue.Clear();
_moveUpdateQueue.Clear();
_accessReaderUpdateQueue.Clear();
_tileUpdateQueue.Clear();
_lastKnownPositions.Clear();
}
} }
} }

View File

@@ -6,6 +6,7 @@ using System.Runtime.CompilerServices;
using Content.Server.GameObjects.Components.Atmos; using Content.Server.GameObjects.Components.Atmos;
using Content.Shared.Atmos; using Content.Shared.Atmos;
using Content.Shared.GameObjects.EntitySystems.Atmos; using Content.Shared.GameObjects.EntitySystems.Atmos;
using Content.Shared.GameTicking;
using JetBrains.Annotations; using JetBrains.Annotations;
using Robust.Server.Interfaces.Player; using Robust.Server.Interfaces.Player;
using Robust.Server.Player; using Robust.Server.Player;
@@ -21,7 +22,7 @@ using Robust.Shared.Timing;
namespace Content.Server.GameObjects.EntitySystems.Atmos namespace Content.Server.GameObjects.EntitySystems.Atmos
{ {
[UsedImplicitly] [UsedImplicitly]
internal sealed class GasTileOverlaySystem : SharedGasTileOverlaySystem internal sealed class GasTileOverlaySystem : SharedGasTileOverlaySystem, IResettingEntitySystem
{ {
[Robust.Shared.IoC.Dependency] private readonly IGameTiming _gameTiming = default!; [Robust.Shared.IoC.Dependency] private readonly IGameTiming _gameTiming = default!;
[Robust.Shared.IoC.Dependency] private readonly IPlayerManager _playerManager = default!; [Robust.Shared.IoC.Dependency] private readonly IPlayerManager _playerManager = default!;
@@ -113,17 +114,6 @@ namespace Content.Server.GameObjects.EntitySystems.Atmos
} }
} }
public void ResettingCleanup()
{
_invalidTiles.Clear();
_overlay.Clear();
foreach (var (_, data) in _knownPlayerChunks)
{
data.Reset();
}
}
private void OnPlayerStatusChanged(object? sender, SessionStatusEventArgs e) private void OnPlayerStatusChanged(object? sender, SessionStatusEventArgs e)
{ {
if (e.NewStatus != SessionStatus.InGame) if (e.NewStatus != SessionStatus.InGame)
@@ -483,5 +473,16 @@ namespace Content.Server.GameObjects.EntitySystems.Atmos
return new GasOverlayMessage(chunk.GridIndices, tileData); return new GasOverlayMessage(chunk.GridIndices, tileData);
} }
} }
public void Reset()
{
_invalidTiles.Clear();
_overlay.Clear();
foreach (var (_, data) in _knownPlayerChunks)
{
data.Reset();
}
}
} }
} }

View File

@@ -4,6 +4,7 @@ using System.Text;
using Content.Server.GameTicking; using Content.Server.GameTicking;
using Content.Server.Interfaces.GameTicking; using Content.Server.Interfaces.GameTicking;
using Content.Server.StationEvents; using Content.Server.StationEvents;
using Content.Shared.GameTicking;
using JetBrains.Annotations; using JetBrains.Annotations;
using Robust.Server.Console; using Robust.Server.Console;
using Robust.Server.Interfaces.Player; using Robust.Server.Interfaces.Player;
@@ -20,7 +21,7 @@ namespace Content.Server.GameObjects.EntitySystems.StationEvents
{ {
[UsedImplicitly] [UsedImplicitly]
// Somewhat based off of TG's implementation of events // Somewhat based off of TG's implementation of events
public sealed class StationEventSystem : EntitySystem public sealed class StationEventSystem : EntitySystem, IResettingEntitySystem
{ {
[Dependency] private readonly IServerNetManager _netManager = default!; [Dependency] private readonly IServerNetManager _netManager = default!;
[Dependency] private readonly IPlayerManager _playerManager = default!; [Dependency] private readonly IPlayerManager _playerManager = default!;
@@ -339,7 +340,13 @@ namespace Content.Server.GameObjects.EntitySystems.StationEvents
return true; return true;
} }
public void ResettingCleanup() public override void Shutdown()
{
base.Shutdown();
CurrentEvent?.Shutdown();
}
public void Reset()
{ {
if (CurrentEvent != null && CurrentEvent.Running) if (CurrentEvent != null && CurrentEvent.Running)
{ {
@@ -354,11 +361,5 @@ namespace Content.Server.GameObjects.EntitySystems.StationEvents
_timeUntilNextEvent = MinimumTimeUntilFirstEvent; _timeUntilNextEvent = MinimumTimeUntilFirstEvent;
} }
public override void Shutdown()
{
base.Shutdown();
CurrentEvent?.Shutdown();
}
} }
} }

View File

@@ -1,11 +1,12 @@
using System.Collections.Generic; using System.Collections.Generic;
using Content.Shared.GameTicking;
using Robust.Shared.GameObjects.Systems; using Robust.Shared.GameObjects.Systems;
using Robust.Shared.ViewVariables; using Robust.Shared.ViewVariables;
using static Content.Shared.GameObjects.Components.SharedWiresComponent; using static Content.Shared.GameObjects.Components.SharedWiresComponent;
namespace Content.Server.GameObjects.EntitySystems namespace Content.Server.GameObjects.EntitySystems
{ {
public class WireHackingSystem : EntitySystem public class WireHackingSystem : EntitySystem, IResettingEntitySystem
{ {
[ViewVariables] private readonly Dictionary<string, WireLayout> _layouts = [ViewVariables] private readonly Dictionary<string, WireLayout> _layouts =
new Dictionary<string, WireLayout>(); new Dictionary<string, WireLayout>();
@@ -20,7 +21,7 @@ namespace Content.Server.GameObjects.EntitySystems
_layouts.Add(id, layout); _layouts.Add(id, layout);
} }
public void ResetLayouts() public void Reset()
{ {
_layouts.Clear(); _layouts.Clear();
} }

View File

@@ -23,6 +23,7 @@ using Content.Server.Mobs.Roles;
using Content.Server.Players; using Content.Server.Players;
using Content.Shared; using Content.Shared;
using Content.Shared.Chat; using Content.Shared.Chat;
using Content.Shared.GameTicking;
using Content.Shared.Network.NetMessages; using Content.Shared.Network.NetMessages;
using Content.Shared.Preferences; using Content.Shared.Preferences;
using Content.Shared.Roles; using Content.Shared.Roles;
@@ -678,11 +679,13 @@ namespace Content.Server.GameTicking
_playerJoinLobby(player); _playerJoinLobby(player);
} }
EntitySystem.Get<GasTileOverlaySystem>().ResettingCleanup(); foreach (var system in _entitySystemManager.AllSystems)
EntitySystem.Get<PathfindingSystem>().ResettingCleanup(); {
EntitySystem.Get<AiReachableSystem>().ResettingCleanup(); if (system is IResettingEntitySystem resetting)
EntitySystem.Get<WireHackingSystem>().ResetLayouts(); {
EntitySystem.Get<StationEventSystem>().ResettingCleanup(); resetting.Reset();
}
}
_spawnedPositions.Clear(); _spawnedPositions.Clear();
_manifest.Clear(); _manifest.Clear();
@@ -1006,6 +1009,7 @@ The current game mode is: [color=white]{0}[/color].
[Dependency] private readonly IServerPreferencesManager _prefsManager = default!; [Dependency] private readonly IServerPreferencesManager _prefsManager = default!;
[Dependency] private readonly IBaseServer _baseServer = default!; [Dependency] private readonly IBaseServer _baseServer = default!;
[Dependency] private readonly IWatchdogApi _watchdogApi = default!; [Dependency] private readonly IWatchdogApi _watchdogApi = default!;
[Dependency] private readonly IEntitySystemManager _entitySystemManager = default!;
} }
public enum GameRunLevel public enum GameRunLevel

View File

@@ -1,5 +1,6 @@
using Content.Server.Players; using Content.Server.Players;
using Content.Shared; using Content.Shared;
using Content.Shared.GameTicking;
using Robust.Server.Interfaces.Player; using Robust.Server.Interfaces.Player;
using Robust.Server.Player; using Robust.Server.Player;
using Robust.Shared.Enums; using Robust.Shared.Enums;

View File

@@ -0,0 +1,7 @@
namespace Content.Shared.GameTicking
{
public interface IResettingEntitySystem
{
void Reset();
}
}

View File

@@ -7,7 +7,7 @@ using Robust.Shared.Interfaces.Serialization;
using Robust.Shared.IoC; using Robust.Shared.IoC;
using Robust.Shared.Network; using Robust.Shared.Network;
namespace Content.Shared namespace Content.Shared.GameTicking
{ {
public abstract class SharedGameTicker public abstract class SharedGameTicker
{ {

View File

@@ -2,6 +2,7 @@
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.Linq; using System.Linq;
using Content.Shared.GameTicking;
using Content.Shared.Roles; using Content.Shared.Roles;
using Content.Shared.Text; using Content.Shared.Text;
using Robust.Shared.Interfaces.Random; using Robust.Shared.Interfaces.Random;

View File

@@ -4,6 +4,7 @@ using System.Linq;
using System.Threading.Tasks; using System.Threading.Tasks;
using Content.Server.Database; using Content.Server.Database;
using Content.Shared; using Content.Shared;
using Content.Shared.GameTicking;
using Content.Shared.Preferences; using Content.Shared.Preferences;
using Microsoft.Data.Sqlite; using Microsoft.Data.Sqlite;
using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore;