libinput 1.9rc1
This commit is contained in:
parent
cdbbf32d3a
commit
01d21ba8fd
1
.gitignore
vendored
1
.gitignore
vendored
@ -6,3 +6,4 @@
|
|||||||
/libinput-1.8.0.tar.xz
|
/libinput-1.8.0.tar.xz
|
||||||
/libinput-1.8.1.tar.xz
|
/libinput-1.8.1.tar.xz
|
||||||
/libinput-1.8.2.tar.xz
|
/libinput-1.8.2.tar.xz
|
||||||
|
/libinput-1.8.901.tar.xz
|
||||||
|
@ -1,186 +0,0 @@
|
|||||||
From 03f13ce6e854b3ff5d4b8971405a97afd66eef8e Mon Sep 17 00:00:00 2001
|
|
||||||
From: Peter Hutterer <peter.hutterer@who-t.net>
|
|
||||||
Date: Tue, 5 Sep 2017 14:38:53 +1000
|
|
||||||
Subject: [PATCH libinput] touchpad: don't resume a disabled touchpad
|
|
||||||
|
|
||||||
Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
|
|
||||||
---
|
|
||||||
src/evdev-mt-touchpad.c | 44 ++++++++++++++++++----------
|
|
||||||
test/test-lid.c | 78 +++++++++++++++++++++++++++++++++++++++++++++++++
|
|
||||||
2 files changed, 107 insertions(+), 15 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/src/evdev-mt-touchpad.c b/src/evdev-mt-touchpad.c
|
|
||||||
index 5b8fb1ec..c0a78255 100644
|
|
||||||
--- a/src/evdev-mt-touchpad.c
|
|
||||||
+++ b/src/evdev-mt-touchpad.c
|
|
||||||
@@ -1426,6 +1426,31 @@ tp_resume(struct tp_dispatch *tp, struct evdev_device *device)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
+#define NO_EXCLUDED_DEVICE NULL
|
|
||||||
+static void
|
|
||||||
+tp_resume_conditional(struct tp_dispatch *tp,
|
|
||||||
+ struct evdev_device *device,
|
|
||||||
+ struct evdev_device *excluded_device)
|
|
||||||
+{
|
|
||||||
+ if (tp->sendevents.current_mode == LIBINPUT_CONFIG_SEND_EVENTS_DISABLED)
|
|
||||||
+ return;
|
|
||||||
+
|
|
||||||
+ if (tp->sendevents.current_mode ==
|
|
||||||
+ LIBINPUT_CONFIG_SEND_EVENTS_DISABLED_ON_EXTERNAL_MOUSE) {
|
|
||||||
+ struct libinput_device *dev;
|
|
||||||
+
|
|
||||||
+ list_for_each(dev, &device->base.seat->devices_list, link) {
|
|
||||||
+ struct evdev_device *d = evdev_device(dev);
|
|
||||||
+ if (d != excluded_device &&
|
|
||||||
+ (d->tags & EVDEV_TAG_EXTERNAL_MOUSE)) {
|
|
||||||
+ return;
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ tp_resume(tp, device);
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
static void
|
|
||||||
tp_trackpoint_timeout(uint64_t now, void *data)
|
|
||||||
{
|
|
||||||
@@ -1667,7 +1692,7 @@ tp_lid_switch_event(uint64_t time, struct libinput_event *event, void *data)
|
|
||||||
swev = libinput_event_get_switch_event(event);
|
|
||||||
switch (libinput_event_switch_get_switch_state(swev)) {
|
|
||||||
case LIBINPUT_SWITCH_STATE_OFF:
|
|
||||||
- tp_resume(tp, tp->device);
|
|
||||||
+ tp_resume_conditional(tp, tp->device, NO_EXCLUDED_DEVICE);
|
|
||||||
evdev_log_debug(tp->device, "lid: resume touchpad\n");
|
|
||||||
break;
|
|
||||||
case LIBINPUT_SWITCH_STATE_ON:
|
|
||||||
@@ -1722,7 +1747,6 @@ tp_interface_device_removed(struct evdev_device *device,
|
|
||||||
struct evdev_device *removed_device)
|
|
||||||
{
|
|
||||||
struct tp_dispatch *tp = (struct tp_dispatch*)device->dispatch;
|
|
||||||
- struct libinput_device *dev;
|
|
||||||
|
|
||||||
if (removed_device == tp->buttons.trackpoint) {
|
|
||||||
/* Clear any pending releases for the trackpoint */
|
|
||||||
@@ -1749,19 +1773,9 @@ tp_interface_device_removed(struct evdev_device *device,
|
|
||||||
tp->lid_switch.lid_switch = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
- if (tp->sendevents.current_mode !=
|
|
||||||
- LIBINPUT_CONFIG_SEND_EVENTS_DISABLED_ON_EXTERNAL_MOUSE)
|
|
||||||
- return;
|
|
||||||
-
|
|
||||||
- list_for_each(dev, &device->base.seat->devices_list, link) {
|
|
||||||
- struct evdev_device *d = evdev_device(dev);
|
|
||||||
- if (d != removed_device &&
|
|
||||||
- (d->tags & EVDEV_TAG_EXTERNAL_MOUSE)) {
|
|
||||||
- return;
|
|
||||||
- }
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
- tp_resume(tp, device);
|
|
||||||
+ /* removed_device is still in the device list at this point, so we
|
|
||||||
+ * need to exclude it from the tp_resume_conditional */
|
|
||||||
+ tp_resume_conditional(tp, device, removed_device);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void
|
|
||||||
diff --git a/test/test-lid.c b/test/test-lid.c
|
|
||||||
index 4bf4c059..7e42f53d 100644
|
|
||||||
--- a/test/test-lid.c
|
|
||||||
+++ b/test/test-lid.c
|
|
||||||
@@ -342,6 +342,81 @@ START_TEST(lid_disable_touchpad_already_open)
|
|
||||||
}
|
|
||||||
END_TEST
|
|
||||||
|
|
||||||
+START_TEST(lid_dont_resume_disabled_touchpad)
|
|
||||||
+{
|
|
||||||
+ struct litest_device *sw = litest_current_device();
|
|
||||||
+ struct litest_device *touchpad;
|
|
||||||
+ struct libinput *li = sw->libinput;
|
|
||||||
+
|
|
||||||
+ touchpad = lid_init_paired_touchpad(li);
|
|
||||||
+ litest_disable_tap(touchpad->libinput_device);
|
|
||||||
+ libinput_device_config_send_events_set_mode(touchpad->libinput_device,
|
|
||||||
+ LIBINPUT_CONFIG_SEND_EVENTS_DISABLED);
|
|
||||||
+ litest_drain_events(li);
|
|
||||||
+
|
|
||||||
+ /* switch is on - no events */
|
|
||||||
+ litest_lid_action(sw, LIBINPUT_SWITCH_STATE_ON);
|
|
||||||
+ litest_assert_only_typed_events(li, LIBINPUT_EVENT_SWITCH_TOGGLE);
|
|
||||||
+
|
|
||||||
+ litest_touch_down(touchpad, 0, 50, 50);
|
|
||||||
+ litest_touch_move_to(touchpad, 0, 50, 50, 70, 50, 10, 1);
|
|
||||||
+ litest_touch_up(touchpad, 0);
|
|
||||||
+ litest_assert_empty_queue(li);
|
|
||||||
+
|
|
||||||
+ /* switch is off - motion events */
|
|
||||||
+ litest_lid_action(sw, LIBINPUT_SWITCH_STATE_OFF);
|
|
||||||
+ litest_assert_only_typed_events(li, LIBINPUT_EVENT_SWITCH_TOGGLE);
|
|
||||||
+
|
|
||||||
+ litest_touch_down(touchpad, 0, 50, 50);
|
|
||||||
+ litest_touch_move_to(touchpad, 0, 50, 50, 70, 50, 10, 1);
|
|
||||||
+ litest_touch_up(touchpad, 0);
|
|
||||||
+ litest_assert_empty_queue(li);
|
|
||||||
+
|
|
||||||
+ litest_delete_device(touchpad);
|
|
||||||
+}
|
|
||||||
+END_TEST
|
|
||||||
+
|
|
||||||
+START_TEST(lid_dont_resume_disabled_touchpad_external_mouse)
|
|
||||||
+{
|
|
||||||
+ struct litest_device *sw = litest_current_device();
|
|
||||||
+ struct litest_device *touchpad, *mouse;
|
|
||||||
+ struct libinput *li = sw->libinput;
|
|
||||||
+
|
|
||||||
+ touchpad = lid_init_paired_touchpad(li);
|
|
||||||
+ mouse = litest_add_device(li, LITEST_MOUSE);
|
|
||||||
+ litest_disable_tap(touchpad->libinput_device);
|
|
||||||
+ libinput_device_config_send_events_set_mode(touchpad->libinput_device,
|
|
||||||
+ LIBINPUT_CONFIG_SEND_EVENTS_DISABLED_ON_EXTERNAL_MOUSE);
|
|
||||||
+ litest_drain_events(li);
|
|
||||||
+
|
|
||||||
+ litest_touch_down(touchpad, 0, 50, 50);
|
|
||||||
+ litest_touch_move_to(touchpad, 0, 50, 50, 70, 50, 10, 1);
|
|
||||||
+ litest_touch_up(touchpad, 0);
|
|
||||||
+ litest_assert_empty_queue(li);
|
|
||||||
+
|
|
||||||
+ /* switch is on - no events */
|
|
||||||
+ litest_lid_action(sw, LIBINPUT_SWITCH_STATE_ON);
|
|
||||||
+ litest_assert_only_typed_events(li, LIBINPUT_EVENT_SWITCH_TOGGLE);
|
|
||||||
+
|
|
||||||
+ litest_touch_down(touchpad, 0, 50, 50);
|
|
||||||
+ litest_touch_move_to(touchpad, 0, 50, 50, 70, 50, 10, 1);
|
|
||||||
+ litest_touch_up(touchpad, 0);
|
|
||||||
+ litest_assert_empty_queue(li);
|
|
||||||
+
|
|
||||||
+ /* switch is off - motion events */
|
|
||||||
+ litest_lid_action(sw, LIBINPUT_SWITCH_STATE_OFF);
|
|
||||||
+ litest_assert_only_typed_events(li, LIBINPUT_EVENT_SWITCH_TOGGLE);
|
|
||||||
+
|
|
||||||
+ litest_touch_down(touchpad, 0, 50, 50);
|
|
||||||
+ litest_touch_move_to(touchpad, 0, 50, 50, 70, 50, 10, 1);
|
|
||||||
+ litest_touch_up(touchpad, 0);
|
|
||||||
+ litest_assert_empty_queue(li);
|
|
||||||
+
|
|
||||||
+ litest_delete_device(touchpad);
|
|
||||||
+ litest_delete_device(mouse);
|
|
||||||
+}
|
|
||||||
+END_TEST
|
|
||||||
+
|
|
||||||
START_TEST(lid_open_on_key)
|
|
||||||
{
|
|
||||||
struct litest_device *sw = litest_current_device();
|
|
||||||
@@ -568,6 +643,9 @@ litest_setup_tests_lid(void)
|
|
||||||
litest_add("lid:disable_touchpad", lid_disable_touchpad_edge_scroll_interrupt, LITEST_SWITCH, LITEST_ANY);
|
|
||||||
litest_add("lid:disable_touchpad", lid_disable_touchpad_already_open, LITEST_SWITCH, LITEST_ANY);
|
|
||||||
|
|
||||||
+ litest_add("switch:touchpad", lid_dont_resume_disabled_touchpad, LITEST_SWITCH, LITEST_ANY);
|
|
||||||
+ litest_add("switch:touchpad", lid_dont_resume_disabled_touchpad_external_mouse, LITEST_SWITCH, LITEST_ANY);
|
|
||||||
+
|
|
||||||
litest_add("lid:keyboard", lid_open_on_key, LITEST_SWITCH, LITEST_ANY);
|
|
||||||
litest_add("lid:keyboard", lid_open_on_key_touchpad_enabled, LITEST_SWITCH, LITEST_ANY);
|
|
||||||
|
|
||||||
--
|
|
||||||
2.13.5
|
|
||||||
|
|
@ -4,7 +4,7 @@
|
|||||||
%global gitversion 58abea394
|
%global gitversion 58abea394
|
||||||
|
|
||||||
Name: libinput
|
Name: libinput
|
||||||
Version: 1.8.2
|
Version: 1.8.901
|
||||||
Release: 1%{?gitdate:.%{gitdate}git%{gitversion}}%{?dist}
|
Release: 1%{?gitdate:.%{gitdate}git%{gitversion}}%{?dist}
|
||||||
Summary: Input device library
|
Summary: Input device library
|
||||||
|
|
||||||
@ -18,8 +18,6 @@ Source2: commitid
|
|||||||
Source0: http://www.freedesktop.org/software/libinput/libinput-%{version}.tar.xz
|
Source0: http://www.freedesktop.org/software/libinput/libinput-%{version}.tar.xz
|
||||||
%endif
|
%endif
|
||||||
|
|
||||||
Patch02: 0001-touchpad-don-t-resume-a-disabled-touchpad.patch
|
|
||||||
|
|
||||||
BuildRequires: git-core
|
BuildRequires: git-core
|
||||||
BuildRequires: gcc
|
BuildRequires: gcc
|
||||||
BuildRequires: meson
|
BuildRequires: meson
|
||||||
@ -90,9 +88,15 @@ git am -p1 %{patches} < /dev/null
|
|||||||
%{_libexecdir}/libinput/libinput-list-devices
|
%{_libexecdir}/libinput/libinput-list-devices
|
||||||
%{_libexecdir}/libinput/libinput-measure
|
%{_libexecdir}/libinput/libinput-measure
|
||||||
%{_libexecdir}/libinput/libinput-measure-touchpad-tap
|
%{_libexecdir}/libinput/libinput-measure-touchpad-tap
|
||||||
|
%{_libexecdir}/libinput/libinput-measure-touch-size
|
||||||
|
%{_libexecdir}/libinput/libinput-measure-touchpad-pressure
|
||||||
|
%{_libexecdir}/libinput/libinput-measure-trackpoint-range
|
||||||
%{_mandir}/man1/libinput.1*
|
%{_mandir}/man1/libinput.1*
|
||||||
%{_mandir}/man1/libinput-measure.1*
|
%{_mandir}/man1/libinput-measure.1*
|
||||||
%{_mandir}/man1/libinput-measure-touchpad-tap.1*
|
%{_mandir}/man1/libinput-measure-touchpad-tap.1*
|
||||||
|
%{_mandir}/man1/libinput-measure-touch-size.1.gz
|
||||||
|
%{_mandir}/man1/libinput-measure-touchpad-pressure.1.gz
|
||||||
|
%{_mandir}/man1/libinput-measure-trackpoint-range.1.gz
|
||||||
%{_mandir}/man1/libinput-list-devices.1*
|
%{_mandir}/man1/libinput-list-devices.1*
|
||||||
%{_mandir}/man1/libinput-debug-events.1*
|
%{_mandir}/man1/libinput-debug-events.1*
|
||||||
%{_bindir}/libinput-list-devices
|
%{_bindir}/libinput-list-devices
|
||||||
@ -105,6 +109,9 @@ git am -p1 %{patches} < /dev/null
|
|||||||
|
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Thu Sep 28 2017 Peter Hutterer <peter.hutterer@redhat.com> 1.8.901-1
|
||||||
|
- libinput 1.9rc1
|
||||||
|
|
||||||
* Thu Sep 07 2017 Peter Hutterer <peter.hutterer@redhat.com> 1.8.2-1
|
* Thu Sep 07 2017 Peter Hutterer <peter.hutterer@redhat.com> 1.8.2-1
|
||||||
- libinput 1.8.2
|
- libinput 1.8.2
|
||||||
|
|
||||||
|
2
sources
2
sources
@ -1 +1 @@
|
|||||||
SHA512 (libinput-1.8.2.tar.xz) = 555a7680cc8aaf62c5370a865f3aff0a933d42d94a3d8861c072666b02c9e1be45ea39de9a749a9575cdfb613b6150e412e18559d94d4919f21ca4680a3c76a7
|
SHA512 (libinput-1.8.901.tar.xz) = cae85d300af1dc898847c67b4f10a1871c9c752645cae8cfbd04d8430ebad1aceba1f0102628ff8a005044df56201dbfaa946d8672a4f02bd84dbe8cdddaec7c
|
||||||
|
Loading…
Reference in New Issue
Block a user