Send enter and modifiers events if wl_keyboard is bound by focused client

We need to send out these events; otherwise the client may have
incorrect state for the new wl_keyboard object.
This commit is contained in:
Vlad Zahorodnii 2021-02-13 17:00:09 +02:00
parent 13fa83c7a6
commit 377385fa6e

View file

@ -26,12 +26,25 @@ KeyboardInterfacePrivate::KeyboardInterfacePrivate(SeatInterface *s)
void KeyboardInterfacePrivate::keyboard_bind_resource(Resource *resource) void KeyboardInterfacePrivate::keyboard_bind_resource(Resource *resource)
{ {
const ClientConnection *focusedClient = focusedSurface ? focusedSurface->client() : nullptr;
if (resource->version() >= WL_KEYBOARD_REPEAT_INFO_SINCE_VERSION) { if (resource->version() >= WL_KEYBOARD_REPEAT_INFO_SINCE_VERSION) {
send_repeat_info(resource->handle, keyRepeat.charactersPerSecond, keyRepeat.delay); send_repeat_info(resource->handle, keyRepeat.charactersPerSecond, keyRepeat.delay);
} }
if (!keymap.isNull()) { if (!keymap.isNull()) {
send_keymap(resource->handle, keymap_format::keymap_format_xkb_v1, keymap->handle(), keymap->size()); send_keymap(resource->handle, keymap_format::keymap_format_xkb_v1, keymap->handle(), keymap->size());
} }
if (focusedClient && focusedClient->client() == resource->client()) {
const QVector<quint32> keys = pressedKeys();
const QByteArray keysData = QByteArray::fromRawData(reinterpret_cast<const char *>(keys.data()),
sizeof(quint32) * keys.count());
const quint32 serial = seat->display()->nextSerial();
send_enter(resource->handle, serial, focusedSurface->resource(), keysData);
send_modifiers(resource->handle, serial, modifiers.depressed, modifiers.latched,
modifiers.locked, modifiers.group);
}
} }
QList<KeyboardInterfacePrivate::Resource *> KeyboardInterfacePrivate::keyboardsForClient(ClientConnection *client) const QList<KeyboardInterfacePrivate::Resource *> KeyboardInterfacePrivate::keyboardsForClient(ClientConnection *client) const