- Add upstream patch to fix screenlocker focus on multiscreen systems:
* 0001-Implement-manual-focus-on-click.patch OBS-URL: https://build.opensuse.org/package/show/KDE:Frameworks5/kscreenlocker?expand=0&rev=70
This commit is contained in:
parent
7568e68ccb
commit
1d761ea675
145
0001-Implement-manual-focus-on-click.patch
Normal file
145
0001-Implement-manual-focus-on-click.patch
Normal file
@ -0,0 +1,145 @@
|
|||||||
|
From f8043de10b5dd94b9b931a92f3aa7167188786c9 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Fabian Vogt <fabian@ritter-vogt.de>
|
||||||
|
Date: Mon, 27 Feb 2017 16:29:29 +0100
|
||||||
|
Subject: [PATCH] Implement manual focus on click
|
||||||
|
|
||||||
|
Summary:
|
||||||
|
Currently only the first created screenlock window gets focus.
|
||||||
|
On clicks, no focus events are sent, which makes it impossible to input
|
||||||
|
passwords. This patch now makes it possible to focus to a different
|
||||||
|
screenlock window (on a different monitor, for example) using a mouse
|
||||||
|
button press.
|
||||||
|
This should also fix newly created screenlock windows stealing the focus
|
||||||
|
of already displayed ones as only the first window gains automatic focus.
|
||||||
|
|
||||||
|
BUG: 348789
|
||||||
|
BUG: 374289
|
||||||
|
|
||||||
|
Test Plan:
|
||||||
|
Locked the screen, now I can use the password input on the secondary screen
|
||||||
|
as well.
|
||||||
|
|
||||||
|
Reviewers: #plasma, graesslin, broulik
|
||||||
|
|
||||||
|
Reviewed By: #plasma, graesslin
|
||||||
|
|
||||||
|
Subscribers: hein, plasma-devel
|
||||||
|
|
||||||
|
Tags: #plasma
|
||||||
|
|
||||||
|
Differential Revision: https://phabricator.kde.org/D4821
|
||||||
|
---
|
||||||
|
greeter/greeterapp.cpp | 1 -
|
||||||
|
x11locker.cpp | 26 ++++++++++++++++++++++++--
|
||||||
|
x11locker.h | 2 ++
|
||||||
|
3 files changed, 26 insertions(+), 3 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/greeter/greeterapp.cpp b/greeter/greeterapp.cpp
|
||||||
|
index 47fcb03..bcfcbdf 100644
|
||||||
|
--- a/greeter/greeterapp.cpp
|
||||||
|
+++ b/greeter/greeterapp.cpp
|
||||||
|
@@ -372,7 +372,6 @@ void UnlockApp::getFocus()
|
||||||
|
// this loop is required to make the qml/graphicsscene properly handle the shared keyboard input
|
||||||
|
// ie. "type something into the box of every greeter"
|
||||||
|
foreach (KQuickAddons::QuickViewSharedEngine *view, m_views) {
|
||||||
|
- view->requestActivate();
|
||||||
|
if (!m_testing) {
|
||||||
|
view->setKeyboardGrabEnabled(true); // TODO - check whether this still works in master!
|
||||||
|
}
|
||||||
|
diff --git a/x11locker.cpp b/x11locker.cpp
|
||||||
|
index b2d2ea4..6967a67 100644
|
||||||
|
--- a/x11locker.cpp
|
||||||
|
+++ b/x11locker.cpp
|
||||||
|
@@ -51,6 +51,7 @@ namespace ScreenLocker
|
||||||
|
X11Locker::X11Locker(QObject *parent)
|
||||||
|
: AbstractLocker(parent)
|
||||||
|
, QAbstractNativeEventFilter()
|
||||||
|
+ , m_focusedLockWindow(XCB_WINDOW_NONE)
|
||||||
|
{
|
||||||
|
initialize();
|
||||||
|
}
|
||||||
|
@@ -229,8 +230,12 @@ void X11Locker::removeVRoot(Window win)
|
||||||
|
XDeleteProperty (QX11Info::display(), win, gXA_VROOT);
|
||||||
|
}
|
||||||
|
|
||||||
|
-static void fakeFocusIn( WId window )
|
||||||
|
+void X11Locker::fakeFocusIn( WId window )
|
||||||
|
{
|
||||||
|
+ if (window == m_focusedLockWindow) {
|
||||||
|
+ return;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
// We have keyboard grab, so this application will
|
||||||
|
// get keyboard events even without having focus.
|
||||||
|
// Fake FocusIn to make Qt realize it has the active
|
||||||
|
@@ -244,6 +249,8 @@ static void fakeFocusIn( WId window )
|
||||||
|
ev.xfocus.detail = NotifyAncestor;
|
||||||
|
XSendEvent( QX11Info::display(), window, False, NoEventMask, &ev );
|
||||||
|
XFlush(QX11Info::display());
|
||||||
|
+
|
||||||
|
+ m_focusedLockWindow = window;
|
||||||
|
}
|
||||||
|
|
||||||
|
template< typename T>
|
||||||
|
@@ -308,6 +315,11 @@ bool X11Locker::nativeEventFilter(const QByteArray &eventType, void *message, lo
|
||||||
|
(x>=x_return && x<=x_return+(int)width_return)
|
||||||
|
&&
|
||||||
|
(y>=y_return && y<=y_return+(int)height_return) ) {
|
||||||
|
+ // We need to do our own focus handling (see comment in fakeFocusIn).
|
||||||
|
+ // For now: Focus on clicks inside the window
|
||||||
|
+ if (responseType == XCB_BUTTON_PRESS) {
|
||||||
|
+ fakeFocusIn(window);
|
||||||
|
+ }
|
||||||
|
const int targetX = x - x_return;
|
||||||
|
const int targetY = y - y_return;
|
||||||
|
if (responseType == XCB_KEY_PRESS || responseType == XCB_KEY_RELEASE) {
|
||||||
|
@@ -386,6 +398,10 @@ bool X11Locker::nativeEventFilter(const QByteArray &eventType, void *message, lo
|
||||||
|
else
|
||||||
|
qDebug() << "Unknown toplevel for MapNotify";
|
||||||
|
m_lockWindows.removeAll(xu->event);
|
||||||
|
+ if (m_focusedLockWindow == xu->event && !m_lockWindows.empty()) {
|
||||||
|
+ // The currently focused window vanished, just focus the first one in the list
|
||||||
|
+ fakeFocusIn(m_lockWindows[0]);
|
||||||
|
+ }
|
||||||
|
ret = true;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
@@ -508,8 +524,14 @@ void X11Locker::addAllowedWindow(quint32 window)
|
||||||
|
// not yet shown and we have a lock window, so we show our own window
|
||||||
|
m_background->show();
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+ if (m_lockWindows.empty()) {
|
||||||
|
+ // Make sure to focus the first window
|
||||||
|
+ m_focusedLockWindow = XCB_WINDOW_NONE;
|
||||||
|
+ fakeFocusIn(window);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
m_lockWindows.prepend(window);
|
||||||
|
- fakeFocusIn(window);
|
||||||
|
stayOnTop();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
diff --git a/x11locker.h b/x11locker.h
|
||||||
|
index 9a14699..d8e83d6 100644
|
||||||
|
--- a/x11locker.h
|
||||||
|
+++ b/x11locker.h
|
||||||
|
@@ -60,6 +60,7 @@ private:
|
||||||
|
void setVRoot(Window win, Window vr);
|
||||||
|
void removeVRoot(Window win);
|
||||||
|
int findWindowInfo(Window w);
|
||||||
|
+ void fakeFocusIn(WId window);
|
||||||
|
void stayOnTop() override;
|
||||||
|
struct WindowInfo
|
||||||
|
{
|
||||||
|
@@ -69,6 +70,7 @@ private:
|
||||||
|
QList<WindowInfo> m_windowInfo;
|
||||||
|
QList<WId> m_lockWindows;
|
||||||
|
QList<quint32> m_allowedWindows;
|
||||||
|
+ WId m_focusedLockWindow;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
--
|
||||||
|
2.11.1
|
||||||
|
|
@ -1,3 +1,9 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Wed Mar 1 18:28:36 UTC 2017 - fabian@ritter-vogt.de
|
||||||
|
|
||||||
|
- Add upstream patch to fix screenlocker focus on multiscreen systems:
|
||||||
|
* 0001-Implement-manual-focus-on-click.patch
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Tue Feb 28 19:54:41 CET 2017 - fabian@ritter-vogt.de
|
Tue Feb 28 19:54:41 CET 2017 - fabian@ritter-vogt.de
|
||||||
|
|
||||||
|
@ -27,6 +27,8 @@ Url: https://projects.kde.org/kscreenlocker
|
|||||||
Source: http://download.kde.org/stable/plasma/%{version}/kscreenlocker-%{version}.tar.xz
|
Source: http://download.kde.org/stable/plasma/%{version}/kscreenlocker-%{version}.tar.xz
|
||||||
# PATCH-FIX-OPENSUSE fix-wayland-version-requirement.diff -- Changes wayland requirement from 1.3 to 1.2.1
|
# PATCH-FIX-OPENSUSE fix-wayland-version-requirement.diff -- Changes wayland requirement from 1.3 to 1.2.1
|
||||||
Patch0: fix-wayland-version-requirement.diff
|
Patch0: fix-wayland-version-requirement.diff
|
||||||
|
# PATCH-FIX-UPSTREAM 0001-Implement-manual-focus-on-click.patch
|
||||||
|
Patch100: 0001-Implement-manual-focus-on-click.patch
|
||||||
BuildRequires: cmake >= 2.8.12
|
BuildRequires: cmake >= 2.8.12
|
||||||
BuildRequires: extra-cmake-modules >= 1.8.0
|
BuildRequires: extra-cmake-modules >= 1.8.0
|
||||||
BuildRequires: kf5-filesystem
|
BuildRequires: kf5-filesystem
|
||||||
@ -91,6 +93,7 @@ Development files for Library and components for secure lock screen architecture
|
|||||||
# SLE12 has a patched 1.2.1 wayland with all features KDE needs from up to 1.7.0
|
# SLE12 has a patched 1.2.1 wayland with all features KDE needs from up to 1.7.0
|
||||||
%patch0 -p1
|
%patch0 -p1
|
||||||
%endif
|
%endif
|
||||||
|
%patch100 -p1
|
||||||
|
|
||||||
%build
|
%build
|
||||||
%cmake_kf5 -d build -- -DKDE4_COMMON_PAM_SERVICE=xdm -DCMAKE_INSTALL_LOCALEDIR=%{_kf5_localedir}
|
%cmake_kf5 -d build -- -DKDE4_COMMON_PAM_SERVICE=xdm -DCMAKE_INSTALL_LOCALEDIR=%{_kf5_localedir}
|
||||||
|
Loading…
Reference in New Issue
Block a user