Program.cs 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. using Gtk;
  2. using Ryujinx.Common.Logging;
  3. using Ryujinx.Configuration;
  4. using Ryujinx.Debugger.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.CreateWarningDialog("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. }