Init.cs 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. using System;
  2. using System.Collections.Generic;
  3. using CommandLine;
  4. using MemoryPack;
  5. namespace ET
  6. {
  7. public static class Init
  8. {
  9. public static void Start()
  10. {
  11. try
  12. {
  13. AppDomain.CurrentDomain.UnhandledException += (sender, e) =>
  14. {
  15. Log.Error(e.ExceptionObject.ToString());
  16. };
  17. // 命令行参数
  18. Parser.Default.ParseArguments<Options>(System.Environment.GetCommandLineArgs())
  19. .WithNotParsed(error => throw new Exception($"命令行格式错误! {error}"))
  20. .WithParsed(World.Instance.AddSingleton);
  21. World.Instance.AddSingleton<Logger>().ILog = new NLogger(Options.Instance.AppType.ToString(), Options.Instance.Process, "../Config/NLog/NLog.config");
  22. ETTask.ExceptionHandler += Log.Error;
  23. World.Instance.AddSingleton<OpcodeType>();
  24. World.Instance.AddSingleton<IdValueGenerater>();
  25. World.Instance.AddSingleton<ObjectPool>();
  26. World.Instance.AddSingleton<WorldActor>();
  27. World.Instance.AddSingleton<CodeLoader>();
  28. World.Instance.AddSingleton<VProcessManager>();
  29. VProcessManager.ThreadPoolScheduler threadPoolScheduler = World.Instance.AddSingleton<VProcessManager.ThreadPoolScheduler, int>(10);
  30. int vProcessId = VProcessManager.Instance.Create();
  31. threadPoolScheduler.Add(vProcessId);
  32. WorldActor.Instance.Send(new ActorId(Options.Instance.Process, vProcessId, 0), null);
  33. Log.Console($"{Parser.Default.FormatCommandLine(Options.Instance)}");
  34. }
  35. catch (Exception e)
  36. {
  37. Log.Error(e);
  38. }
  39. }
  40. }
  41. }