From 7f2fb049f5392fcefca326a3754170cb7f9d8403 Mon Sep 17 00:00:00 2001 From: Ac_K Date: Tue, 26 Sep 2023 07:17:55 +0200 Subject: [PATCH] Ava: Fix regressions by rewriting CheckLaunchState (#5728) --- .../UI/Windows/MainWindow.axaml.cs | 38 +++++++++++++------ 1 file changed, 26 insertions(+), 12 deletions(-) diff --git a/src/Ryujinx.Ava/UI/Windows/MainWindow.axaml.cs b/src/Ryujinx.Ava/UI/Windows/MainWindow.axaml.cs index 3596c9aa..c78f4160 100644 --- a/src/Ryujinx.Ava/UI/Windows/MainWindow.axaml.cs +++ b/src/Ryujinx.Ava/UI/Windows/MainWindow.axaml.cs @@ -265,32 +265,46 @@ namespace Ryujinx.Ava.UI.Windows private void CheckLaunchState() { - if (ShowKeyErrorOnLoad) - { - ShowKeyErrorOnLoad = false; - - UserErrorDialog.ShowUserErrorDialog(UserError.NoKeys).Wait(); - } - if (OperatingSystem.IsLinux() && LinuxHelper.VmMaxMapCount < LinuxHelper.RecommendedVmMaxMapCount) { Logger.Warning?.Print(LogClass.Application, $"The value of vm.max_map_count is lower than {LinuxHelper.RecommendedVmMaxMapCount}. ({LinuxHelper.VmMaxMapCount})"); if (LinuxHelper.PkExecPath is not null) { - ShowVmMaxMapCountDialog().Wait(); + Dispatcher.UIThread.Post(async () => + { + if (OperatingSystem.IsLinux()) + { + await ShowVmMaxMapCountDialog(); + } + }); } else { - ShowVmMaxMapCountWarning().Wait(); + Dispatcher.UIThread.Post(async () => + { + if (OperatingSystem.IsLinux()) + { + await ShowVmMaxMapCountWarning(); + } + }); } } - if (_deferLoad) + if (!ShowKeyErrorOnLoad) { - _deferLoad = false; + if (_deferLoad) + { + _deferLoad = false; - ViewModel.LoadApplication(_launchPath, _startFullscreen).Wait(); + ViewModel.LoadApplication(_launchPath, _startFullscreen).Wait(); + } + } + else + { + ShowKeyErrorOnLoad = false; + + Dispatcher.UIThread.Post(async () => await UserErrorDialog.ShowUserErrorDialog(UserError.NoKeys)); } if (ConfigurationState.Instance.CheckUpdatesOnStart.Value && Updater.CanUpdate(false))