2019-11-21 16:37:15 -08:00
|
|
|
|
using Content.Server.Cargo;
|
2019-07-31 15:02:36 +02:00
|
|
|
|
using Content.Server.Interfaces;
|
|
|
|
|
|
using Content.Server.Interfaces.Chat;
|
|
|
|
|
|
using Content.Server.Interfaces.GameTicking;
|
2019-12-22 13:47:34 +01:00
|
|
|
|
using Content.Server.Preferences;
|
2019-10-02 10:45:06 +02:00
|
|
|
|
using Content.Server.Sandbox;
|
2019-04-15 21:11:38 -06:00
|
|
|
|
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;
|
2019-04-15 21:11:38 -06:00
|
|
|
|
using Robust.Shared.IoC;
|
|
|
|
|
|
using Robust.Shared.Log;
|
|
|
|
|
|
using Robust.Shared.Timing;
|
2017-08-04 14:24:01 +02:00
|
|
|
|
|
|
|
|
|
|
namespace Content.Server
|
|
|
|
|
|
{
|
|
|
|
|
|
public class EntryPoint : GameServer
|
|
|
|
|
|
{
|
2018-11-22 10:37:58 +01:00
|
|
|
|
private IGameTicker _gameTicker;
|
2018-11-26 10:02:47 +01:00
|
|
|
|
private StatusShell _statusShell;
|
2018-08-21 00:59:04 +02:00
|
|
|
|
|
2018-01-18 13:00:35 -06:00
|
|
|
|
/// <inheritdoc />
|
2017-08-04 14:24:01 +02:00
|
|
|
|
public override void Init()
|
|
|
|
|
|
{
|
2018-01-18 13:00:35 -06:00
|
|
|
|
base.Init();
|
|
|
|
|
|
|
2017-09-24 23:19:47 +02:00
|
|
|
|
var factory = IoCManager.Resolve<IComponentFactory>();
|
|
|
|
|
|
|
2019-07-31 15:02:36 +02:00
|
|
|
|
factory.DoAutoRegistrations();
|
2018-08-02 08:29:55 +02:00
|
|
|
|
|
2019-07-31 15:02:36 +02:00
|
|
|
|
var registerIgnore = new[]
|
|
|
|
|
|
{
|
|
|
|
|
|
"ConstructionGhost",
|
|
|
|
|
|
"IconSmooth",
|
2019-07-31 22:42:36 +02:00
|
|
|
|
"SubFloorHide",
|
|
|
|
|
|
"LowWall",
|
|
|
|
|
|
"Window",
|
2019-09-03 22:51:19 +02:00
|
|
|
|
"CharacterInfo",
|
2019-12-06 02:08:17 +01:00
|
|
|
|
"InteractionOutline",
|
|
|
|
|
|
"MeleeWeaponArcAnimation",
|
|
|
|
|
|
"AnimationsTest",
|
2020-01-21 12:12:50 -05:00
|
|
|
|
"ItemStatus"
|
2019-07-31 15:02:36 +02:00
|
|
|
|
};
|
2019-06-30 00:01:41 +02:00
|
|
|
|
|
2019-07-31 15:02:36 +02:00
|
|
|
|
foreach (var ignoreName in registerIgnore)
|
|
|
|
|
|
{
|
|
|
|
|
|
factory.RegisterIgnore(ignoreName);
|
|
|
|
|
|
}
|
2019-07-19 10:45:04 +02:00
|
|
|
|
|
2019-11-23 15:55:31 -05:00
|
|
|
|
ServerContentIoC.Register();
|
|
|
|
|
|
|
2019-06-29 01:58:16 +02:00
|
|
|
|
if (TestingCallbacks != null)
|
|
|
|
|
|
{
|
|
|
|
|
|
var cast = (ServerModuleTestingCallbacks) TestingCallbacks;
|
|
|
|
|
|
cast.ServerBeforeIoC?.Invoke();
|
|
|
|
|
|
}
|
2019-12-06 02:08:17 +01:00
|
|
|
|
|
2018-11-21 21:11:30 +01:00
|
|
|
|
IoCManager.BuildGraph();
|
|
|
|
|
|
|
2018-11-22 10:37:58 +01:00
|
|
|
|
_gameTicker = IoCManager.Resolve<IGameTicker>();
|
|
|
|
|
|
|
2018-11-21 21:11:30 +01:00
|
|
|
|
IoCManager.Resolve<IServerNotifyManager>().Initialize();
|
2019-04-13 09:45:09 +02:00
|
|
|
|
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;
|
2020-01-25 16:16:34 +01:00
|
|
|
|
|
|
|
|
|
|
IoCManager.Resolve<IServerPreferencesManager>().StartInit();
|
2018-01-18 13:00:35 -06:00
|
|
|
|
}
|
|
|
|
|
|
|
2018-11-21 21:21:29 +01:00
|
|
|
|
public override void PostInit()
|
|
|
|
|
|
{
|
|
|
|
|
|
base.PostInit();
|
|
|
|
|
|
|
2018-11-22 10:37:58 +01:00
|
|
|
|
_gameTicker.Initialize();
|
2019-10-02 10:45:06 +02:00
|
|
|
|
IoCManager.Resolve<ISandboxManager>().Initialize();
|
2020-01-25 16:16:34 +01:00
|
|
|
|
IoCManager.Resolve<IServerPreferencesManager>().FinishInit();
|
2018-11-21 21:21:29 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
2019-08-04 01:08:55 +02:00
|
|
|
|
public override void Update(ModUpdateLevel level, FrameEventArgs frameEventArgs)
|
2018-11-22 10:37:58 +01:00
|
|
|
|
{
|
2019-08-04 01:08:55 +02:00
|
|
|
|
base.Update(level, frameEventArgs);
|
2018-11-22 10:37:58 +01:00
|
|
|
|
|
2019-08-04 01:08:55 +02:00
|
|
|
|
_gameTicker.Update(frameEventArgs);
|
2019-11-21 16:37:15 -08:00
|
|
|
|
switch (level)
|
|
|
|
|
|
{
|
|
|
|
|
|
case ModUpdateLevel.PreEngine:
|
|
|
|
|
|
{
|
|
|
|
|
|
IoCManager.Resolve<IGalacticBankManager>().Update(frameEventArgs);
|
|
|
|
|
|
break;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2018-11-22 10:37:58 +01:00
|
|
|
|
}
|
2017-08-04 14:24:01 +02:00
|
|
|
|
}
|
|
|
|
|
|
}
|