diff --git a/CHANGELOG.md b/CHANGELOG.md index fa54bdb8..40706868 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -31,6 +31,11 @@ ### Deprecated ### Removed ### Fixed + +* Reverted _"Consumed modifiers are no longer sent to the client + application"_ (https://codeberg.org/dnkl/foot/issues/425). + + ### Security ### Contributors diff --git a/input.c b/input.c index 9a26e778..320b1679 100644 --- a/input.c +++ b/input.c @@ -1026,10 +1026,10 @@ key_press_release(struct seat *seat, struct terminal *term, uint32_t serial, */ enum modifier keymap_mods = MOD_NONE; - keymap_mods |= mods & ~consumed & shift ? MOD_SHIFT : MOD_NONE; - keymap_mods |= mods & ~consumed & alt ? MOD_ALT : MOD_NONE; - keymap_mods |= mods & ~consumed & ctrl ? MOD_CTRL : MOD_NONE; - keymap_mods |= mods & ~consumed & meta ? MOD_META : MOD_NONE; + keymap_mods |= seat->kbd.shift ? MOD_SHIFT : MOD_NONE; + keymap_mods |= seat->kbd.alt ? MOD_ALT : MOD_NONE; + keymap_mods |= seat->kbd.ctrl ? MOD_CTRL : MOD_NONE; + keymap_mods |= seat->kbd.meta ? MOD_META : MOD_NONE; const struct key_data *keymap; if (sym == XKB_KEY_Escape && keymap_mods == MOD_NONE && term->modify_escape_key) { @@ -1113,7 +1113,7 @@ key_press_release(struct seat *seat, struct terminal *term, uint32_t serial, } else { - if (mods & ~consumed & alt) { + if (mods & alt) { /* * When the alt modifier is pressed, we do one out of three things: *