From e7791e31a0fd6dad53d0c4e8c3b9034315ac81b2 Mon Sep 17 00:00:00 2001 From: Oleksii Holub <1935960+Tyrrrz@users.noreply.github.com> Date: Thu, 30 May 2024 15:40:21 +0300 Subject: [PATCH] Fix crash when attempting to change application whitelist (#305) --- ...plicationWhitelistSettingsTabView.axaml.cs | 19 +++++++++++++++++-- 1 file changed, 17 insertions(+), 2 deletions(-) diff --git a/LightBulb/Views/Components/Settings/ApplicationWhitelistSettingsTabView.axaml.cs b/LightBulb/Views/Components/Settings/ApplicationWhitelistSettingsTabView.axaml.cs index 706468d..7054266 100644 --- a/LightBulb/Views/Components/Settings/ApplicationWhitelistSettingsTabView.axaml.cs +++ b/LightBulb/Views/Components/Settings/ApplicationWhitelistSettingsTabView.axaml.cs @@ -42,10 +42,25 @@ private void UserControl_OnUnloaded(object? sender, RoutedEventArgs args) => private void WhitelistedApplicationsListBox_OnSelectionChanged( object? sender, SelectionChangedEventArgs args - ) => - DataContext.WhitelistedApplications = WhitelistedApplicationsListBox + ) + { + var applications = WhitelistedApplicationsListBox .SelectedItems?.Cast() .ToArray(); + // Don't update the view model if the list hasn't changed. + // This is important to avoid potential infinite loops. + if ( + applications is not null + && DataContext.WhitelistedApplications is not null + && applications.SequenceEqual(DataContext.WhitelistedApplications) + ) + { + return; + } + + DataContext.WhitelistedApplications = applications; + } + public void Dispose() => _eventRoot.Dispose(); }