-
-
Notifications
You must be signed in to change notification settings - Fork 680
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Shift modifier not working/recognised in conjunction with other modifier keys when inside Zellij session #3789
Comments
Same issue: Fixed by downgrading 0.40.1 |
@imsnif Just FYI this thread was created from a Reddit thread upon your commenting - so another user having same issue. |
Hey @blixenkrone - this issue is on my to-fix (or rather, to investigate and then fix if it's a Zellij issue). My GitHub Sponsors is linked at the top of this repo and here for convenience: https://github.com/sponsors/imsnif - do with this info as you wish. My personal opinion on bounty systems as a full-time OSS dev: please avoid bounty systems and middle-person OSS sponsoring platforms in general. Give directly to maintainers, everything else is noise at best or actively takes money out of our pockets at worst. Not going to expand on this further, just something to think about. Thanks for your report and for caring about OSS sustainability. |
@imsnif Good stuff! I'll have a look at sponsoring. The bounty idea was mostly if we had some way to go 1:1 with user > zellij maintainer, I wasn't about to pay extra for using a middleman service. I'll be using the link you provided. Thanks for the swift response 🙏 |
FWIW, using the method listed here to read input events, it seems to me that the issue may lie in the fact that, for a generic key Also of note, with the procedure replicated outside Zellij (tested in both Alacritty and Kitty), the received event is It also seems that #3817 is a duplicate of this issue. Anyway, thanks for looking into it and working on Zellij! Edit: the behaviour is different in Konsole where the key events sent do not change, whether in Zellij or not. Could it be linked to Kitty’s keyboard enhancement protocol, as it seems to not be supported by Konsole? |
@Iorvethe Good thoughts, thanks for the write up.
I think it's the inverse, but your point still stands. Different key interpretations between applications may be a reason. It's not a full solution though, some of vim/vimlike/helix builtin keybindings still rely on the shift modifier to work properly. We still need an implementation that ensures parity between applications keymaps. |
In a duplicate thread #3817 a short term fix was provided by OP: TL;DR: Basically setting this option in config.kdl: This seemingly does remove the keybinding issue, although I have to properly investigate. While I don't believe this issue should be resolved from doing this config, I believe it can act as an intermediate solution until @imsnif or likeminded can implement a fix. |
Great fix, and easy to apply at that; more than enough for the time being. Thanks! |
Thank you everyone for the helpful and civil discussion - this will surely help others with similar problems. |
Hey, so I had a chance to look into this and I'm sorry to say but at least in my view this is an issue with Helix (or crossterm, depending on how you look at it). Technical explanationZellij uses only the first progressive enhancement level of the Kitty Keyboard Protocol "Disambiguate escape codes" (https://sw.kovidgoyal.net/kitty/keyboard-protocol/#disambiguate). In this enhancement level, we report "The unicode-key-code above is the Unicode codepoint representing the key, as a decimal number. For example, the A key is represented as 97 which is the unicode code for lowercase a. Note that the codepoint used is always the lower-case (or more technically, un-shifted) version of the key. If the user presses, for example, ctrl+shift+a the escape code would be CSI 97;modifiers u. It must not be CSI 65; modifiers u." (reference: https://sw.kovidgoyal.net/kitty/keyboard-protocol/#key-codes). Helix, through crossterm, queries the terminal support for the Kitty Keyboard Protocol. Crossterm however, only returns a This means that there is no room left for the particularities of the protocol. Namely - allowing terminals to only support the first progressive enhancement as Zellij does. It's either on or off. Helix then assumes that if the protocol is on, it can also accept additional progressive enhancement levels such as In this progressive enhancement, Helix expects to receive an uppercase There is unfortunately not much I can do on the Zellij side here. The protocol is extremely explicit on the way the terminal (Zellij in this case) should behave, and we are complying with it. So why does this work in...The reason this works outside of Zellij in terminals that support the kitty keyboard protocol: likely these terminals support the relevant progressive enhancement that Helix is hard-codedly expecting. The reason this works outside of Zellij in terminals that do not support the kitty keyboard protocol (or when disabling the protocol in Zellij): this then falls back to the classic STDIN parsing which happens to support this additional modifier. So - what now?I would recommend Helix (either through crossterm if possible or on its own) query the host terminal to make sure it supports both progressive enhancements it expects and only expect the behavior that the terminal advertizes it supports. I would also recommend crossterm make the query command less ambiguous, supporting the particularities of the protocol's progressive enhancement. Either that or provide an additional query interface that queries the specific progressive enhancement levels. I'm sorry to give such an answer - I'd rather have solved this on the Zellij-side of course rather than kick the ball down the road. But given that we're talking about a protocol that is extremely explicit about the way applications should behave, changing the Zellij behavior would be wrong here and likely cause unexpected side-effects. |
Thank you for your comprehensive and in-depth answer! I agree that, as you suggested, the best way forward would be that applications have a more granular support for the protocol via Out of curiosity, are there specific reasons why the entire protocol wasn’t implemented in Zellij? Or is it because of time constraints and planned for the future? |
Just to be clear, specifically Helix doesn't even need to do this in this case. Until
I chose to implement this protocol in order to solve the pain point of not being able to properly support multiple modifiers (in keybinds for Zellij itself and in applications running inside Zellij). This is provided by the first progressive enhancement. The rest are all nice-to-haves but they solve problems we (to the best of my knowledge) don't currently have or solve on the application level (eg. the different between |
Thanks again, this clears everything out. I will see to open an issue on the Helix repo as well, then. Have a nice day! |
I wrote that function in crossterm (crossterm-rs/crossterm#732). I'm a bit confused by https://sw.kovidgoyal.net/kitty/keyboard-protocol/#detection-of-support-for-this-protocol now:
I read this as saying that support for the protocol is binary on the terminal's side - it either fully supports the protocol or it doesn't, signaled by whether the terminal returns the current values of the flags or not. The explanation of progressive enhancement further confuses me since it seems to suggest that progressive enhancement is intended for the benefit of terminal programs (e.g. Helix) rather than a mechanism for the terminal to partially support the protocol:
But you're saying that the terminal's response to I'm happy to make this change in crossterm and Helix but I'll need to test it out against a bunch of terminals to see if this is consistent. If that's how detection is meant to work we can send a patch to the Kitty docs as well to make this part of detection clearer. |
Hey @the-mikedavis - thanks for popping in :)
I think this is more meant as an answer to the question "what happens if I don't get a response from the terminal to my support query" - as in, if the terminal I'm operating in doesn't know about this protocol at all - I can send this query followed by a device query and safely assume that if I got a response to the device query, I don't need to wait around for a response to the kitty keyboard query because it's not going to come.
Yes, exactly. Just like terminal programs can request specific progressive enhancements, so can terminals elect to only support up to specific progressive enhancements. The query mechanism is there to communicate this difference to applications. You request the specific progressive enhancement you like with eg.
I'm a firm believer that protocol specifications should never change for any reason whatsoever except in a new version of the protocol, but who knows - maybe the maintainer of this protocol believes otherwise. :) Let me know if I can be of any further assistance. |
I misread the above post, thanks for clarifying! I thought you were saying that |
That's what I would do, yes! |
Adding a function to crossterm to query the currently active flags should be a really small change, I don't mind sending a PR to crossterm for that. (Edit: crossterm-rs/crossterm#958) After pushing the flags we want in Helix though and reading that "report alternate keys" is not enabled what I would prefer to do is then pop all the active flags. Without "report alternate keys" we get key events like AltShift9 for Alt( and we would need to translate that on our end. Would you be interested in adding "report alternate keys"? It should fix compatibility with Kakoune as well since AFAIK we request the same flags. I wouldn't be able to commit to a time table but I could take a look at sending a PR at some point - I bet Alacritty and WezTerm have good reference code for this feature. The reason Helix handles this weirdly at the moment (specifically inputs like AltShifts) is that we "canonicalize" key events to always remove the shift modifier. Without the Kitty keyboard protocol enabled or with "report alternate keys" this canonicalization makes sense since the terminal sends uppercase characters but without "report alternate keys" we're dropping the shift modifier which is important. We can also make a small change on our end to make this canonicalization smarter and actually uppercase the character when dropping the shift modifier. It would be a naive uppercase though rather than what is needed to solve things like AltShift9 from above |
Thanks for looking into this and for your work @the-mikedavis ! The issue with "report alternate keys" is that this problem is not exclusive to STDIN parsing. I guess it's the same for you. Users can bind these keys in configurations, we show them in the UI, etc. This means both of us absolutely have to solve this problem in the application layer regardless of whether we solve it on the protocol layer. I'm assuming this is the reason you need to normalize these keys. My thinking is: as long as we're already solving this on the application layer (each of us in their own way) we might as well use the same or similar normalization for whatever comes to us on the wire. In general, integration and collaboration with the ecosystem is important to me and to Zellij, but I am personally not a fan of this protocol for reasons demonstrated very well in this thread. Adding an entire progressive enhancement to Zellij would be committing to a huge amount of complexity. Not just at the time of implementation but also for the future through continued maintenance. In hindsight, if I knew I had to implement this progressive enhancement (and who knows how many more due to similar problems in the protocol's design) I would have elected not to implement this protocol at all. This is not a hard no on my part - I would agree to take on complexity in order to benefit our joint user-base, but unless I'm missing something major (you are of course the expert on your code-base), I think the road of least resistance (by orders of magnitude) is to normalize keypresses on the application layer on both sides rather than commit further to this protocol which will only partially solve our problem. What do you think? |
I’m running After making that change, all my Meta + Shift + combinations worked as expected. I also observed that the issue with dropped characters (if that’s the correct term) occurred in Alacritty and Ghostty but not in WezTerm. I was confident the issue was in Zellij because I routinely run % alacritty -V
alacritty 0.14.1-rc1 (0ccac0f)
% zellij --version
zellij 0.41.1
% wezterm -V
wezterm 20240203-110809-5046fc22 Given that Ghostty is still very new and I regularly build it from source, the version I’m using is quite fluid. I’m sharing this for posterity: % /Applications/Ghostty.app/Contents/MacOS/ghostty +version
Ghostty 1.0.1-swap-option-and-command+ab591bff
Version
- version: 1.0.1-swap-option-and-command+ab591bff
- channel: tip
Build Config
- Zig version: 0.13.0
- build mode : builtin.OptimizeMode.ReleaseFast
- app runtime: apprt.Runtime.none
- font engine: font.main.Backend.coretext
- renderer : renderer.Metal
- libxev : main.Backend.kqueue |
@frobware I'm a long-time Emacs user, but very new to seriously running it in the terminal (I'd like to switch to TTY Emacs as my daily driver specifically for the advantages of terminal multiplexing to ease development on remote servers). I'm seeing the same issue you are, but wanted to confirm how you're configuring Emacs (are you using kkp.el?) The relevant portion of my Emacs config currently looks like this: https://github.com/mjrusso/.emacs.d/blob/02b85ba70338455542316f9027620b9c4a9eecc0/conf/terminal.el#L35-L111 And corresponding Ghostty config: https://github.com/mjrusso/nixos-config/blob/5469957107d854d6b4e5bc61cc222439a2ca69ce/modules/darwin/files.nix#L31-L85 If I use the Kitty Keyboard Protocol instead (swapping in Running
Running
Based on @imsnif's comment here, this reporting seems correct: Zellij doesn't support There is this bit in the kkp.el README that is interesting:
However, this doesn't seem to be related to the problem we're seeing. For example, if I type |
I'm not using kkp. My setup is Alacritty and My ghostty config is very fluid as I explore what I want and what setup would allow me to either consider a switch from Alacritty or, for the moment, to run Ghostty in parallel; my config is dumped here as of "just now": https://gist.github.com/frobware/5c266bb06665320feda254f90b1381fe. But bear in mind I'm also forcefully swapping option and command in my Ghostty build too. But that's not the end of the story as you will still have macOS menubar shortcuts that have bindings to the command key (e.g., Cmd-w), which if you swap as I do, that becomes meta-w. I remove all these keybindings as detailed in ghostty-org/ghostty#4134. I don't have to clear any macOS shortcut menubar items in Alacritty because there are none. \o/ I also use And all of this (this being emacs -nw in a terminal) runs fine in tmux too. I largely use my mac to ssh into a remote dev box where I run emacs in tmux all day. I'm in this thread because I was interested in trying Zellij again as some (lots? all?) of the "chrome" can be turned off and was considering a switch away from tmux. I didn't clear the first hurdle until I saw the comment about setting I hope this was of some help. TL;DR - it is possible to run |
Hi emacs friends! While I can't say for certain, this is very likely a similar issue in emacs (or the... addons? plugins? you're mentioning here? forgive me, I am a total ignoramus when it comes to emacs) to the one discussed with Helix above. To know for sure, you can use the detection method mentioned in the protocol specification: https://sw.kovidgoyal.net/kitty/keyboard-protocol/ Here's an example using some of the key combinations mentioned here: We can see that these key combinations are properly detected by the underlying program inside Zellij. If you find that this is different for you, please attach a similar report to the screenshot above. It will make it easier to troubleshoot the issue (again, I wouldn't know how to start configuring emacs to reproduce this myself). Thanks and happy hacking to everyone! For those following this thread, so far we're waiting for some decisions on the Helix side. More info here: #3789 (comment) As a personal request - if you find that this is indeed the case, you can leave a thumbs up to this comment rather than adding another comment. I don't mean to silence anyone, but this is already a long issue with lots of followers and discussions. Let's try to limit chatter to the strictly necessary to make everyone's life easier. Thanks! |
@frobware thanks for sharing details on your setup! My experience has been that I need to do more configuration work to get all the keybinds I use to work, but that's a topic for another day :) @imsnif thanks for sharing this tool. It wasn't immediately obvious, but (as long as Kitty is installed, PATH is setup correctly, etc.) you can run
Now, in Emacs, repeating the same (typing
(Translating the Emacs speak: What I would like to see in all cases is the following:
So we're seeing the wrong thing when using Zellij (regardless of whether or not KPP is enabled via kkp.el). However, as per the earlier discussion, this isn't a Zellij bug. Thanks for helping narrow this down :) |
Given everything described, the sentence seems to contradict; "we're seeing the wrong thing" so why isn't this a Zellij bug? In Alacritty (with or without tmux), I see |
Dear @frobware - please read the rest of this thread. Specifically #3789 (comment) Otherwise, I'm unsubscribing from this thread. I'm sorry but I don't feel I have a lot more to add to this and the notifications are a bit distracting. If the-mikedavis or any other developer of a related app needs assistance, please tag me. Please only tag me in this case. Thanks! |
This is extremely useful for testing KKP. The following works in any terminal emulator: ``` kitten show-key -m kitty ``` See: zellij-org/zellij#3789 (comment)
OK, I've managed to track down this Emacs issue. In an earlier comment, I wrote:
This actually was the issue all along. I didn't notice it because I was using What's happening is that Emacs is looking for the keybind The solution is exactly as explained in the README: add
I need to go through my config and add all these translations. I wonder if there's an automated way to do it (or there should be existing tables, e.g. how else could everyone be implementing report alternate keys). |
There's really not that many combinations; I went ahead and enumerated them all here (for my English layout): Technically this handles only "shift+alt" modifiers, but I definitely don't have any that use "shift+super", and I don't think I have any other relevant combinations either. |
Basic information
zellij --version
:0.41.1
stty size
:78 150
Issue description
Whenever I am inside a zellij in any terminal (tried 3 different ones), the shift modifier key is not picked up as a modifier key, when used in combination with others.
This is mostly an issue when using terminal editors like vim, since I have a keybinding with
shift+alt+s
to do :w or write_file.As the most minimal example, a use case flow would be:
If I am not inside Zellij, I can do above use flow without issues. The bug seem to only exists when I am within a zellij session.
Minimal reproduction
Terminal: Ghostty
Editor: Helix
1 Enter a zellij session
2 Open a file with Helix (or vim)
3 Hit shift+alt+s
4 Only alt+s gets picked up.
Extra relevant information
1 No /tmp/zellij-log file was produced when running with
$ zellij --debug
for some reason.2 I don't think it makes sense to show this in a video recording, but I am happy to record one if needed.
Thanks for a great tool!
The text was updated successfully, but these errors were encountered: