Program.cs 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. using Gtk;
  2. using Ryujinx.Common.Logging;
  3. using Ryujinx.Configuration;
  4. using Ryujinx.Debugger.Profiler;
  5. using Ryujinx.Ui;
  6. using OpenTK;
  7. using System;
  8. using System.IO;
  9. namespace Ryujinx
  10. {
  11. class Program
  12. {
  13. static void Main(string[] args)
  14. {
  15. Toolkit.Init(new ToolkitOptions
  16. {
  17. Backend = PlatformBackend.PreferNative,
  18. EnableHighResolution = true
  19. });
  20. Console.Title = "Ryujinx Console";
  21. string systemPath = Environment.GetEnvironmentVariable("Path", EnvironmentVariableTarget.Machine);
  22. Environment.SetEnvironmentVariable("Path", $"{Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "bin")};{systemPath}");
  23. GLib.ExceptionManager.UnhandledException += Glib_UnhandledException;
  24. // Initialize the configuration
  25. ConfigurationState.Initialize();
  26. // Initialize the logger system
  27. LoggerModule.Initialize();
  28. // Initialize Discord integration
  29. DiscordIntegrationModule.Initialize();
  30. string configurationPath = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "Config.json");
  31. // Now load the configuration as the other subsystems are now registered
  32. if (File.Exists(configurationPath))
  33. {
  34. ConfigurationFileFormat configurationFileFormat = ConfigurationFileFormat.Load(configurationPath);
  35. ConfigurationState.Instance.Load(configurationFileFormat);
  36. }
  37. else
  38. {
  39. // No configuration, we load the default values and save it on disk
  40. ConfigurationState.Instance.LoadDefault();
  41. ConfigurationState.Instance.ToFileFormat().SaveConfig(configurationPath);
  42. }
  43. Profile.Initialize();
  44. Application.Init();
  45. string appDataPath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData), "Ryujinx", "system", "prod.keys");
  46. string userProfilePath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.UserProfile), ".switch", "prod.keys");
  47. if (!File.Exists(appDataPath) && !File.Exists(userProfilePath) && !Migration.IsMigrationNeeded())
  48. {
  49. GtkDialog.CreateWarningDialog("Key file was not found", "Please refer to `KEYS.md` for more info");
  50. }
  51. MainWindow mainWindow = new MainWindow();
  52. mainWindow.Show();
  53. if (args.Length == 1)
  54. {
  55. mainWindow.LoadApplication(args[0]);
  56. }
  57. Application.Run();
  58. }
  59. private static void Glib_UnhandledException(GLib.UnhandledExceptionArgs e)
  60. {
  61. Exception exception = e.ExceptionObject as Exception;
  62. Logger.PrintError(LogClass.Application, $"Unhandled exception caught: {exception}");
  63. if (e.IsTerminating)
  64. {
  65. Logger.Shutdown();
  66. }
  67. }
  68. }
  69. }