[input] Include more safety checks
nullptr checks as input events might be processed prior to KWin having been fully started.
This commit is contained in:
parent
7a96c3ee46
commit
c23e106c8b
1 changed files with 17 additions and 13 deletions
|
@ -247,12 +247,14 @@ void InputRedirection::setupLibInput()
|
||||||
LibInput::Connection *conn = LibInput::Connection::create(this);
|
LibInput::Connection *conn = LibInput::Connection::create(this);
|
||||||
if (conn) {
|
if (conn) {
|
||||||
conn->setup();
|
conn->setup();
|
||||||
|
if (screens()) {
|
||||||
conn->setScreenSize(screens()->size());
|
conn->setScreenSize(screens()->size());
|
||||||
connect(screens(), &Screens::sizeChanged, this,
|
connect(screens(), &Screens::sizeChanged, this,
|
||||||
[this, conn] {
|
[this, conn] {
|
||||||
conn->setScreenSize(screens()->size());
|
conn->setScreenSize(screens()->size());
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
}
|
||||||
connect(conn, &LibInput::Connection::pointerButtonChanged, this, &InputRedirection::processPointerButton);
|
connect(conn, &LibInput::Connection::pointerButtonChanged, this, &InputRedirection::processPointerButton);
|
||||||
connect(conn, &LibInput::Connection::pointerAxisChanged, this, &InputRedirection::processPointerAxis);
|
connect(conn, &LibInput::Connection::pointerAxisChanged, this, &InputRedirection::processPointerAxis);
|
||||||
connect(conn, &LibInput::Connection::keyChanged, this, &InputRedirection::processKeyboardKey);
|
connect(conn, &LibInput::Connection::keyChanged, this, &InputRedirection::processKeyboardKey);
|
||||||
|
@ -272,9 +274,9 @@ void InputRedirection::setupLibInput()
|
||||||
connect(conn, &LibInput::Connection::touchMotion, this, &InputRedirection::processTouchMotion);
|
connect(conn, &LibInput::Connection::touchMotion, this, &InputRedirection::processTouchMotion);
|
||||||
connect(conn, &LibInput::Connection::touchCanceled, this, &InputRedirection::cancelTouch);
|
connect(conn, &LibInput::Connection::touchCanceled, this, &InputRedirection::cancelTouch);
|
||||||
connect(conn, &LibInput::Connection::touchFrame, this, &InputRedirection::touchFrame);
|
connect(conn, &LibInput::Connection::touchFrame, this, &InputRedirection::touchFrame);
|
||||||
connect(screens(), &Screens::changed, this, &InputRedirection::updatePointerAfterScreenChange);
|
|
||||||
// set pos to center of all screens
|
// set pos to center of all screens
|
||||||
if (screens()) {
|
if (screens()) {
|
||||||
|
connect(screens(), &Screens::changed, this, &InputRedirection::updatePointerAfterScreenChange);
|
||||||
m_globalPointer = screens()->geometry().center();
|
m_globalPointer = screens()->geometry().center();
|
||||||
emit globalPointerChanged(m_globalPointer);
|
emit globalPointerChanged(m_globalPointer);
|
||||||
// sanitize
|
// sanitize
|
||||||
|
@ -465,7 +467,7 @@ void InputRedirection::processKeyboardKey(uint32_t key, InputRedirection::Keyboa
|
||||||
}
|
}
|
||||||
// TODO: pass to internal parts of KWin
|
// TODO: pass to internal parts of KWin
|
||||||
#ifdef KWIN_BUILD_TABBOX
|
#ifdef KWIN_BUILD_TABBOX
|
||||||
if (TabBox::TabBox::self()->isGrabbed()) {
|
if (TabBox::TabBox::self() && TabBox::TabBox::self()->isGrabbed()) {
|
||||||
if (state == KWin::InputRedirection::KeyboardKeyPressed) {
|
if (state == KWin::InputRedirection::KeyboardKeyPressed) {
|
||||||
TabBox::TabBox::self()->keyPress(m_xkb->modifiers() | m_xkb->toQtKey(m_xkb->toKeysym(key)));
|
TabBox::TabBox::self()->keyPress(m_xkb->modifiers() | m_xkb->toQtKey(m_xkb->toKeysym(key)));
|
||||||
}
|
}
|
||||||
|
@ -481,12 +483,14 @@ void InputRedirection::processKeyboardKey(uint32_t key, InputRedirection::Keyboa
|
||||||
static_cast< EffectsHandlerImpl* >(effects)->grabbedKeyboardEvent(&event);
|
static_cast< EffectsHandlerImpl* >(effects)->grabbedKeyboardEvent(&event);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
if (workspace()) {
|
||||||
if (Client *c = workspace()->getMovingClient()) {
|
if (Client *c = workspace()->getMovingClient()) {
|
||||||
// TODO: this does not yet fully support moving of the Client
|
// TODO: this does not yet fully support moving of the Client
|
||||||
// cursor events change the cursor and on Wayland pointer warping is not possible
|
// cursor events change the cursor and on Wayland pointer warping is not possible
|
||||||
c->keyPressEvent(m_xkb->toQtKey(m_xkb->toKeysym(key)));
|
c->keyPressEvent(m_xkb->toQtKey(m_xkb->toKeysym(key)));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
// process global shortcuts
|
// process global shortcuts
|
||||||
if (state == KeyboardKeyPressed) {
|
if (state == KeyboardKeyPressed) {
|
||||||
if (m_shortcuts->processKey(m_xkb->modifiers(), m_xkb->toKeysym(key))) {
|
if (m_shortcuts->processKey(m_xkb->modifiers(), m_xkb->toKeysym(key))) {
|
||||||
|
|
Loading…
Reference in a new issue