mirror of
https://github.com/vrcx-team/VRCX.git
synced 2026-04-06 00:32:02 +02:00
183 lines
6.9 KiB
C#
183 lines
6.9 KiB
C#
// Copyright(c) 2019-2022 pypy, Natsumi and individual contributors.
|
|
// All rights reserved.
|
|
//
|
|
// This work is licensed under the terms of the MIT license.
|
|
// For a copy, see <https://opensource.org/licenses/MIT>.
|
|
|
|
using NLog;
|
|
using NLog.Targets;
|
|
using System;
|
|
using System.IO;
|
|
using System.Threading.Tasks;
|
|
using System.Windows.Forms;
|
|
|
|
namespace VRCX
|
|
{
|
|
public static class Program
|
|
{
|
|
public static string BaseDirectory { get; private set; }
|
|
public static readonly string AppDataDirectory = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData), "VRCX");
|
|
public static string ConfigLocation;
|
|
public static string Version { get; private set; }
|
|
public static bool LaunchDebug;
|
|
public static bool GPUFix;
|
|
private static readonly NLog.Logger logger = NLog.LogManager.GetLogger("VRCX");
|
|
static Program()
|
|
{
|
|
BaseDirectory = AppDomain.CurrentDomain.BaseDirectory;
|
|
ConfigLocation = Path.Combine(Program.AppDataDirectory, "VRCX.sqlite3");
|
|
|
|
if (!Directory.Exists(AppDataDirectory))
|
|
{
|
|
Directory.CreateDirectory(AppDataDirectory);
|
|
|
|
// Migrate config to AppData
|
|
if (File.Exists(Path.Combine(BaseDirectory, "VRCX.json")))
|
|
{
|
|
File.Move(Path.Combine(BaseDirectory, "VRCX.json"), Path.Combine(AppDataDirectory, "VRCX.json"));
|
|
File.Copy(Path.Combine(AppDataDirectory, "VRCX.json"), Path.Combine(AppDataDirectory, "VRCX-backup.json"));
|
|
}
|
|
if (File.Exists(Path.Combine(BaseDirectory, "VRCX.sqlite3")))
|
|
{
|
|
File.Move(Path.Combine(BaseDirectory, "VRCX.sqlite3"), Path.Combine(AppDataDirectory, "VRCX.sqlite3"));
|
|
File.Copy(Path.Combine(AppDataDirectory, "VRCX.sqlite3"), Path.Combine(AppDataDirectory, "VRCX-backup.sqlite3"));
|
|
}
|
|
}
|
|
|
|
// Migrate cache to userdata for Cef 115 update
|
|
var oldCachePath = Path.Combine(AppDataDirectory, "cache");
|
|
if (Directory.Exists(oldCachePath))
|
|
{
|
|
var newCachePath = Path.Combine(AppDataDirectory, "userdata", "cache");
|
|
if (Directory.Exists(newCachePath))
|
|
Directory.Delete(newCachePath, true);
|
|
Directory.Move(oldCachePath, newCachePath);
|
|
}
|
|
}
|
|
|
|
private static void ConfigureLogger()
|
|
{
|
|
NLog.LogManager.Setup().LoadConfiguration(builder =>
|
|
{
|
|
|
|
var fileTarget = new FileTarget("fileTarget")
|
|
{
|
|
FileName = Path.Combine(AppDataDirectory, "logs", "VRCX.log"),
|
|
//Layout = "${longdate} [${level:uppercase=true}] ${logger} - ${message} ${exception:format=tostring}",
|
|
// Layout with padding between the level/logger and message so that the message always starts at the same column
|
|
Layout = "${longdate} [${level:uppercase=true:padding=-5}] ${logger:padding=-20} - ${message} ${exception:format=tostring}",
|
|
ArchiveFileName = Path.Combine(AppDataDirectory, "logs", "VRCX.{#}.log"),
|
|
ArchiveNumbering = ArchiveNumberingMode.DateAndSequence,
|
|
ArchiveEvery = FileArchivePeriod.Day,
|
|
MaxArchiveFiles = 4,
|
|
MaxArchiveDays = 7,
|
|
ArchiveAboveSize = 10000000,
|
|
ArchiveOldFileOnStartup = true,
|
|
ConcurrentWrites = true,
|
|
KeepFileOpen = true,
|
|
AutoFlush = true,
|
|
Encoding = System.Text.Encoding.UTF8
|
|
};
|
|
|
|
if (Program.LaunchDebug)
|
|
{
|
|
builder.ForLogger().FilterMinLevel(LogLevel.Debug).WriteTo(fileTarget);
|
|
}
|
|
else
|
|
{
|
|
#if DEBUG
|
|
// Archive maximum of 3 files 10MB each, kept for a maximum of 7 days
|
|
builder.ForLogger().FilterMinLevel(LogLevel.Debug).WriteTo(fileTarget);
|
|
#else
|
|
builder.ForLogger().FilterMinLevel(LogLevel.Debug).WriteTo(fileTarget);
|
|
#endif
|
|
}
|
|
});
|
|
}
|
|
|
|
[STAThread]
|
|
private static void Main()
|
|
{
|
|
ConfigureLogger();
|
|
|
|
try
|
|
{
|
|
Run();
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
logger.Fatal(e, "Unhandled Exception, program dying");
|
|
MessageBox.Show(e.ToString(), "PLEASE REPORT IN https://vrcx.pypy.moe/discord", MessageBoxButtons.OK, MessageBoxIcon.Error);
|
|
Environment.Exit(0);
|
|
}
|
|
}
|
|
|
|
private static void GetVersion()
|
|
{
|
|
var buildName = "VRCX";
|
|
try
|
|
{
|
|
Version = $"{buildName} {File.ReadAllText(Path.Combine(BaseDirectory, "Version"))}";
|
|
}
|
|
catch (Exception)
|
|
{
|
|
Version = $"{buildName} Build";
|
|
}
|
|
}
|
|
|
|
private static void Run()
|
|
{
|
|
Update.Check();
|
|
StartupArgs.ArgsCheck();
|
|
GetVersion();
|
|
|
|
Application.EnableVisualStyles();
|
|
Application.SetCompatibleTextRenderingDefault(false);
|
|
|
|
logger.Info("{0} Starting...", Version);
|
|
|
|
// I'll re-do this whole function eventually I swear
|
|
var worldDBServer = new WorldDBManager("http://127.0.0.1:22500/");
|
|
Task.Run(worldDBServer.Start);
|
|
|
|
ProcessMonitor.Instance.Init();
|
|
SQLiteLegacy.Instance.Init();
|
|
VRCXStorage.Load();
|
|
LoadFromConfig();
|
|
CpuMonitor.Instance.Init();
|
|
Discord.Instance.Init();
|
|
WebApi.Instance.Init();
|
|
LogWatcher.Instance.Init();
|
|
AutoAppLaunchManager.Instance.Init();
|
|
|
|
CefService.Instance.Init();
|
|
IPCServer.Instance.Init();
|
|
VRCXVR.Instance.Init();
|
|
Application.Run(new MainForm());
|
|
logger.Info("{0} Exiting...", Version);
|
|
WebApi.Instance.SaveCookies();
|
|
VRCXVR.Instance.Exit();
|
|
CefService.Instance.Exit();
|
|
|
|
AutoAppLaunchManager.Instance.Exit();
|
|
LogWatcher.Instance.Exit();
|
|
WebApi.Instance.Exit();
|
|
worldDBServer.Stop();
|
|
|
|
Discord.Instance.Exit();
|
|
CpuMonitor.Instance.Exit();
|
|
VRCXStorage.Save();
|
|
SQLiteLegacy.Instance.Exit();
|
|
ProcessMonitor.Instance.Exit();
|
|
}
|
|
|
|
/// <summary>
|
|
/// Sets GPUFix to true if it is not already set and the VRCX_GPUFix key in the database is true.
|
|
/// </summary>
|
|
private static void LoadFromConfig()
|
|
{
|
|
if (!GPUFix)
|
|
GPUFix = VRCXStorage.Instance.Get("VRCX_GPUFix") == "true";
|
|
}
|
|
}
|
|
} |