Program.cs 2.8 KB

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