80 lines
2.5 KiB
C#
Raw Normal View History

2021-07-07 13:36:25 +02:00
using System;
using System.Diagnostics;
2021-07-07 13:36:25 +02:00
using System.IO;
using System.Threading;
using System.Threading.Tasks;
2021-07-07 13:36:25 +02:00
2022-05-22 15:55:26 +08:00
namespace RageCoop.Server
2021-07-07 13:36:25 +02:00
{
class Program
{
public static bool ReadyToStop = false;
2021-07-07 13:36:25 +02:00
static void Main(string[] args)
{
var mainLogger= new Core.Logger()
2022-05-31 19:35:01 -08:00
{
LogPath="RageCoop.Server.log",
UseConsole=true,
};
2021-07-07 13:36:25 +02:00
try
{
#if DEBUG
new Thread(async () =>
{
do
{
2022-04-06 02:18:24 +02:00
Console.Title = string.Format("RAGECOOP [{0,5:P2}] [{1:F}MB]", await GetCpuUsageForProcess(), Process.GetCurrentProcess().PrivateMemorySize64 * 0.000001);
Thread.Sleep(500);
} while (true);
}).Start();
#else
2022-04-06 02:18:24 +02:00
Console.Title = "RAGECOOP";
#endif
2021-07-07 13:36:25 +02:00
Console.CancelKeyPress += delegate(object sender, ConsoleCancelEventArgs e)
{
if (e.SpecialKey == ConsoleSpecialKey.ControlC)
{
2022-06-22 10:03:45 +08:00
if (!ReadyToStop)
{
e.Cancel = true;
ReadyToStop = true;
}
else
{
Environment.Exit(1);
}
}
};
2022-06-24 18:25:24 +08:00
_ = new Server(Util.Read<ServerSettings>("Settings.xml"), mainLogger);
2021-07-07 13:36:25 +02:00
}
catch (Exception e)
{
mainLogger.Error(e);
mainLogger.Error($"Fatal error occurred, server shutting down.");
Thread.Sleep(3000);
2021-07-07 13:36:25 +02:00
}
mainLogger.Dispose();
2021-07-07 13:36:25 +02:00
}
#if DEBUG
private static async Task<double> GetCpuUsageForProcess()
{
DateTime startTime = DateTime.UtcNow;
TimeSpan startCpuUsage = Process.GetCurrentProcess().TotalProcessorTime;
await Task.Delay(500);
DateTime endTime = DateTime.UtcNow;
TimeSpan endCpuUsage = Process.GetCurrentProcess().TotalProcessorTime;
double cpuUsedMs = (endCpuUsage - startCpuUsage).TotalMilliseconds;
double totalMsPassed = (endTime - startTime).TotalMilliseconds;
double cpuUsageTotal = cpuUsedMs / (Environment.ProcessorCount * totalMsPassed);
return cpuUsageTotal * 100;
}
#endif
2021-07-07 13:36:25 +02:00
}
}