Files
crystall-punk-14/Content.Server/EntryPoint.cs

105 lines
3.0 KiB
C#
Raw Normal View History

2020-06-12 18:31:57 +02:00
using Content.Server.Interfaces;
2019-07-31 15:02:36 +02:00
using Content.Server.Interfaces.Chat;
using Content.Server.Interfaces.GameTicking;
using Content.Server.Interfaces.PDA;
2019-10-02 10:45:06 +02:00
using Content.Server.Sandbox;
2020-04-30 18:08:51 -05:00
using Content.Shared.Kitchen;
using Robust.Server.Interfaces.Player;
using Robust.Shared.ContentPack;
using Robust.Shared.Interfaces.GameObjects;
2019-07-31 15:02:36 +02:00
using Robust.Shared.Interfaces.Log;
using Robust.Shared.IoC;
using Robust.Shared.Log;
using Robust.Shared.Timing;
namespace Content.Server
{
public class EntryPoint : GameServer
{
private IGameTicker _gameTicker;
2018-11-26 10:02:47 +01:00
private StatusShell _statusShell;
/// <inheritdoc />
public override void Init()
{
base.Init();
var factory = IoCManager.Resolve<IComponentFactory>();
2019-07-31 15:02:36 +02:00
factory.DoAutoRegistrations();
2019-07-31 15:02:36 +02:00
var registerIgnore = new[]
{
"ConstructionGhost",
"IconSmooth",
"SubFloorHide",
"LowWall",
2020-05-22 17:59:13 +01:00
"ReinforcedWall",
"Window",
"CharacterInfo",
"InteractionOutline",
"MeleeWeaponArcAnimation",
"AnimationsTest",
"ItemStatus",
"Marker",
"EmergencyLight",
2019-07-31 15:02:36 +02:00
};
2019-07-31 15:02:36 +02:00
foreach (var ignoreName in registerIgnore)
{
factory.RegisterIgnore(ignoreName);
}
ServerContentIoC.Register();
2019-06-29 01:58:16 +02:00
if (TestingCallbacks != null)
{
var cast = (ServerModuleTestingCallbacks) TestingCallbacks;
cast.ServerBeforeIoC?.Invoke();
}
IoCManager.BuildGraph();
_gameTicker = IoCManager.Resolve<IGameTicker>();
IoCManager.Resolve<IServerNotifyManager>().Initialize();
IoCManager.Resolve<IChatManager>().Initialize();
2018-11-26 10:02:47 +01:00
var playerManager = IoCManager.Resolve<IPlayerManager>();
_statusShell = new StatusShell();
2019-05-06 19:31:04 +02:00
var logManager = IoCManager.Resolve<ILogManager>();
logManager.GetSawmill("Storage").Level = LogLevel.Info;
IoCManager.Resolve<IServerPreferencesManager>().StartInit();
2020-04-30 18:08:51 -05:00
}
public override void PostInit()
{
base.PostInit();
_gameTicker.Initialize();
2019-10-02 10:45:06 +02:00
IoCManager.Resolve<ISandboxManager>().Initialize();
IoCManager.Resolve<IServerPreferencesManager>().FinishInit();
2020-04-30 18:08:51 -05:00
IoCManager.Resolve<RecipeManager>().Initialize();
IoCManager.Resolve<IPDAUplinkManager>().Initialize();
}
2019-08-04 01:08:55 +02:00
public override void Update(ModUpdateLevel level, FrameEventArgs frameEventArgs)
{
2019-08-04 01:08:55 +02:00
base.Update(level, frameEventArgs);
switch (level)
{
case ModUpdateLevel.PreEngine:
{
2020-06-08 01:18:33 +02:00
_gameTicker.Update(frameEventArgs);
break;
}
}
}
}
}