using System; using System.Collections.Generic; using CommandLine; using MemoryPack; namespace ET { public static class Init { private static VProcess vProcess; public static void Start() { try { AppDomain.CurrentDomain.UnhandledException += (sender, e) => { Log.Error(e.ExceptionObject.ToString()); }; // 命令行参数 Parser.Default.ParseArguments(System.Environment.GetCommandLineArgs()) .WithNotParsed(error => throw new Exception($"命令行格式错误! {error}")) .WithParsed(World.Instance.AddSingleton); World.Instance.AddSingleton().ILog = new NLogger(Options.Instance.AppType.ToString(), Options.Instance.Process, "../Config/NLog/NLog.config"); ETTask.ExceptionHandler += Log.Error; World.Instance.AddSingleton(); World.Instance.AddSingleton(); World.Instance.AddSingleton(); ThreadPoolScheduler threadPoolScheduler = World.Instance.AddSingleton(); threadPoolScheduler.ThreadCount = 10; vProcess = VProcessSingleton.Instance.Create(); // 异步方法全部会回掉到主线程 vProcess.AddSingleton(); vProcess.AddSingleton(); vProcess.AddSingleton(); vProcess.AddSingleton(); vProcess.AddSingleton(); Log.Console($"{Parser.Default.FormatCommandLine(Options.Instance)}"); vProcess.AddSingleton().Start(); } catch (Exception e) { Log.Error(e); } } public static void Update() { vProcess.Update(); } public static void LateUpdate() { vProcess.LateUpdate(); } public static void FrameFinishUpdate() { vProcess.FrameFinishUpdate(); } } }