From ab4c3507fba86e674e2eafa2e7f2b89f2e41a9de Mon Sep 17 00:00:00 2001 From: Leonhard Kargl Date: Wed, 8 Jan 2025 16:50:12 +0100 Subject: [PATCH] HotcornerControl/CustomCommand: Fix infinite loop --- src/Views/Multitasking.vala | 71 ++++++++++++++++++------------------- 1 file changed, 35 insertions(+), 36 deletions(-) diff --git a/src/Views/Multitasking.vala b/src/Views/Multitasking.vala index a382598c..5548abc4 100644 --- a/src/Views/Multitasking.vala +++ b/src/Views/Multitasking.vala @@ -164,46 +164,45 @@ public class PantheonShell.Multitasking : Switchboard.SettingsPage { null, null ); - get_command_string (); - - settings.changed["hotcorner-custom-command"].connect (() => { - get_command_string (); - }); - - command_entry.changed.connect (() => { - var this_command = "hotcorner-%s:%s".printf (position, command_entry.text); - - var setting_string = settings.get_string ("hotcorner-custom-command"); - - var found = false; - string[] commands = setting_string.split (";;"); - for (int i = 0; i < commands.length ; i++) { - if (commands[i].has_prefix ("hotcorner-" + position)) { - found = true; - commands[i] = this_command; + settings.bind_with_mapping ( + "hotcorner-custom-command", + command_entry, + "text", + DEFAULT, + (value, variant, instance) => { + string[] commands = ((string) variant).split (";;"); + foreach (unowned string command in commands) { + if (command.has_prefix ("hotcorner-" + ((HotcornerControl) instance).position)) { + value.set_string (command.replace ("hotcorner-%s:".printf (((HotcornerControl) instance).position), "")); + return true; + } } - } - - if (!found) { - commands += this_command; - } - - settings.set_string ("hotcorner-custom-command", string.joinv (";;", commands)); - }); - } - private void get_command_string () { - var setting_string = settings.get_string ("hotcorner-custom-command"); - var this_command = ""; + value.set_string (""); + return true; + }, + (value, expected_type, instance) => { + var this_command = "hotcorner-%s:%s".printf (((HotcornerControl) instance).position, value.get_string ()); + + var setting_string = settings.get_string ("hotcorner-custom-command"); + + var found = false; + string[] commands = setting_string.split (";;"); + for (int i = 0; i < commands.length ; i++) { + if (commands[i].has_prefix ("hotcorner-" + ((HotcornerControl) instance).position)) { + found = true; + commands[i] = this_command; + } + } - string[] commands = setting_string.split (";;"); - foreach (unowned string command in commands) { - if (command.has_prefix ("hotcorner-" + position)) { - this_command = command.replace ("hotcorner-%s:".printf (position), ""); - } - } + if (!found) { + commands += this_command; + } - command_entry.text = this_command; + return new Variant.string (string.joinv (";;", commands)); + }, + this, null + ); } } }