diff options
author | Peter Hutterer <peter.hutterer@who-t.net> | 2015-06-11 11:49:24 +1000 |
---|---|---|
committer | Michael Catanzaro <mcatanzaro@gnome.org> | 2015-07-14 16:44:27 -0500 |
commit | 20b6004507d67f26101aa5e5e8c9112d226effba (patch) | |
tree | 688396111863578cfdf23e078d29146b7a3a485d | |
parent | 3fb1135cb770aae2e96b98e109752437100217c0 (diff) | |
download | mutter-20b6004507d67f26101aa5e5e8c9112d226effba.tar.gz |
input-settings-x11: check properties for correctness before changing them
Before submitting a new scroll mode, click method or sendevents mode check if
the value is supported by the device. This avoids BadValue errors when setting
two-finger scrolling on single-finger touchpad devices since we can't easily
handle BadValue (see 9747277b)
https://bugzilla.gnome.org/show_bug.cgi?id=750816
Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
-rw-r--r-- | src/backends/x11/meta-input-settings-x11.c | 49 |
1 files changed, 42 insertions, 7 deletions
diff --git a/src/backends/x11/meta-input-settings-x11.c b/src/backends/x11/meta-input-settings-x11.c index f683c4788..2f4527da7 100644 --- a/src/backends/x11/meta-input-settings-x11.c +++ b/src/backends/x11/meta-input-settings-x11.c @@ -100,6 +100,12 @@ meta_input_settings_x11_set_send_events (MetaInputSettings *settings, GDesktopDeviceSendEvents mode) { guchar values[2] = { 0 }; /* disabled, disabled-on-external-mouse */ + guchar *available; + + available = get_property (device, "libinput Send Events Modes Available", + XA_INTEGER, 8, 2); + if (!available) + return; switch (mode) { @@ -113,8 +119,14 @@ meta_input_settings_x11_set_send_events (MetaInputSettings *settings, break; } - change_property (device, "libinput Send Events Mode Enabled", - XA_INTEGER, 8, &values, 2); + if ((values[0] && !available[0]) || (values[1] && !available[1])) + g_warning ("Device '%s' does not support sendevents mode %d\n", + clutter_input_device_get_device_name (device), mode); + else + change_property (device, "libinput Send Events Mode Enabled", + XA_INTEGER, 8, &values, 2); + + meta_XFree (available); } static void @@ -186,6 +198,12 @@ meta_input_settings_x11_set_scroll_method (MetaInputSettings *setting GDesktopTouchpadScrollMethod mode) { guchar values[3] = { 0 }; /* 2fg, edge, button. The last value is unused */ + guchar *available; + + available = get_property (device, "libinput Scroll Methods Available", + XA_INTEGER, 8, 3); + if (!available) + return; switch (mode) { @@ -201,8 +219,14 @@ meta_input_settings_x11_set_scroll_method (MetaInputSettings *setting g_assert_not_reached (); } - change_property (device, "libinput Scroll Method Enabled", - XA_INTEGER, 8, &values, 3); + if ((values[0] && !available[0]) || (values[1] && !available[1])) + g_warning ("Device '%s' does not support scroll mode %d\n", + clutter_input_device_get_device_name (device), mode); + else + change_property (device, "libinput Scroll Method Enabled", + XA_INTEGER, 8, &values, 3); + + meta_XFree (available); } static void @@ -220,7 +244,12 @@ meta_input_settings_x11_set_click_method (MetaInputSettings *settings, GDesktopTouchpadClickMethod mode) { guchar values[2] = { 0 }; /* buttonareas, clickfinger */ - guchar *defaults; + guchar *defaults, *available; + + available = get_property (device, "libinput Click Methods Available", + XA_INTEGER, 8, 2); + if (!available) + return; switch (mode) { @@ -245,8 +274,14 @@ meta_input_settings_x11_set_click_method (MetaInputSettings *settings, return; } - change_property (device, "libinput Click Method Enabled", - XA_INTEGER, 8, &values, 2); + if ((values[0] && !available[0]) || (values[1] && !available[1])) + g_warning ("Device '%s' does not support click method %d\n", + clutter_input_device_get_device_name (device), mode); + else + change_property (device, "libinput Click Method Enabled", + XA_INTEGER, 8, &values, 2); + + meta_XFree(available); } static void |