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:
@@ -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;
|
||||||
|
|||||||
@@ -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
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -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
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
@@ -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
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -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)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -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();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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;
|
||||||
@@ -99,9 +100,9 @@ namespace Content.Server.GameTicking
|
|||||||
|
|
||||||
|
|
||||||
[ViewVariables] public bool Paused { get; private set; }
|
[ViewVariables] public bool Paused { get; private set; }
|
||||||
|
|
||||||
[ViewVariables] public MapId DefaultMap { get; private set; }
|
[ViewVariables] public MapId DefaultMap { get; private set; }
|
||||||
|
|
||||||
[ViewVariables] public GridId DefaultGridId { get; private set; }
|
[ViewVariables] public GridId DefaultGridId { get; private set; }
|
||||||
|
|
||||||
[ViewVariables]
|
[ViewVariables]
|
||||||
@@ -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();
|
||||||
@@ -694,7 +697,7 @@ namespace Content.Server.GameTicking
|
|||||||
DefaultMap = _mapManager.CreateMap();
|
DefaultMap = _mapManager.CreateMap();
|
||||||
var startTime = _gameTiming.RealTime;
|
var startTime = _gameTiming.RealTime;
|
||||||
var grid = _mapLoader.LoadBlueprint(DefaultMap, MapFile);
|
var grid = _mapLoader.LoadBlueprint(DefaultMap, MapFile);
|
||||||
|
|
||||||
DefaultGridId = grid.Index;
|
DefaultGridId = grid.Index;
|
||||||
_spawnPoint = grid.ToCoordinates();
|
_spawnPoint = grid.ToCoordinates();
|
||||||
|
|
||||||
@@ -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
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
7
Content.Shared/GameTicking/IResettingEntitySystem.cs
Normal file
7
Content.Shared/GameTicking/IResettingEntitySystem.cs
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
namespace Content.Shared.GameTicking
|
||||||
|
{
|
||||||
|
public interface IResettingEntitySystem
|
||||||
|
{
|
||||||
|
void Reset();
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -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
|
||||||
{
|
{
|
||||||
@@ -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;
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
Reference in New Issue
Block a user