-
Notifications
You must be signed in to change notification settings - Fork 932
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
Align NamedKey
and KeyCode
more closely with the W3C specs
#4018
base: master
Are you sure you want to change the base?
Conversation
I recall there being more of a discussion about it, but I don't recall where. I'll have a look when i have time. |
I found #1788, searching for "super" and "meta" with all items in that thread expanded reveals #1788 (comment). While I can see the arguments in there (the "alt" key was commonly called "meta"), I don't think they really holds for our use-case (we have a distinct "alt" keys, so there should be no confusion). Regardless of my desire to use CC @chrisduerr |
Also, I found #1788 (comment) regarding
One argument for why these are different might be that space is a normal, printable character, while tab is a control character? Though that's mostly post-rationalization on my part. |
The meta key can be one of many keys. Especially for Linux users this very frequently refers to the alt key. I see no reason why there would be a requirement to align with the web standard over other platform's standards and if all are considered equal then the most logical solution should be chosen. I have little doubt that super is least likely to cause any confusion compared to alternatives like "meta" or "hyper", which are just historically highly inaccurate. |
Hmm, I read the Wikipedia articles on these, and I can see that "super" is superior (hehe) in the sense that it's likely what you will want to show the user in your documentation - but you will want to do special handling here anyhow, e.g. neither "meta" nor "super" is a nice name to show the user on macOS. Looking more widely:
I guess we could choose to emit
I think my core argument is that all are not considered equal, and that the web standard, however flawed, makes sense to align to, for the simple reason that it's a tried and tested way to make cross-platform applications. |
This is not in the W3C spec, and doesn't make sense to special-case.
040e621
to
3bd40d7
Compare
I still don't feel strongly about renaming Super to Meta. What @chrisduerr said made sense at that time, but with that said, I don't mind if this rename happens. In fact here's an argument for renaming: I remember it being clumsy trying to avoid calling functions and variables Regarding the question about |
/// Used to enable "super" modifier function for interpreting concurrent or subsequent keyboard | ||
/// Used to enable "meta" modifier function for interpreting concurrent or subsequent keyboard | ||
/// input. This key value is used for the "Windows Logo" key and the Apple `Command` or `⌘` | ||
/// key. | ||
/// | ||
/// Note: In some contexts (e.g. the Web) this is referred to as the "Meta" key. | ||
Super, | ||
Meta, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I suggest adding that this is referred to as Super
in some contexts. Having this in the documentation makes it easier to search.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We could add a doc alias of "super" so that people searching the docs for super will find it?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Maybe alias it the other way (meta to super) around to not break things in the first place? Especially given that meta means so many different things on platforms and to get it wrong will be very easy.
f61c465
to
c04e6a1
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Super is the label you likely see on the keyboard. Meta is often an Alt
on Linux
and I don't think I've seen anyone referring to meta as super
, so I don't see a point in renaming at this point.
One could add an alias(somehow), but I don't like to change its name at this point, especially users will likely not have a clue what it is.
Possibly, though not on keyboards manufactured with macOS and/or Windows in mind, so I don't think we need to use the same label in source code.
I feel like I outlined a lot of cases in #4018 (comment) where people are referring to the key as "meta"? In any case, my issue is not really the naming (I superficially agree that "super" is the better name), but that we diverge from the web specification which we otherwise try to follow. My main motivation here is because aligning with the web standard is needed to do #4026. If y'all have other suggestions for how to integrate |
This is inconsistent with the W3C spec, and while it's arguably not the best name, it's worse that Winit is diverging and choosing a different name. --- Full list of changes: KeyCode: - SuperLeft -> MetaLeft - SuperRight -> MetaRight - Meta -> Super NamedKey::Meta is swapped with NamedKey::Super. ModifiersState::SUPER is renamed to ModifiersState::META. ModifiersState::super_key is renamed to ModifiersState::meta_key. ModifiersKeys::LSUPER and RSUPER are renamed to LMETA and RMETA.
c04e6a1
to
6d46d52
Compare
I think every breaking change should be minded. There's already many people complaining that winit breaks things too much. |
Fair point! Would it help if we kept We can't really do something similar with |
Steps can be taken to make the impact of breaking changes minimal or avoid a breaking change entirely. Of course this makes sense whenever possible. However any breaking change, no matter how small, will be a strain on library consumers. The only way to avoid that is to not break things unless absolutely necessary. |
I personally don't think that we should change it at this point, like we had it as I'm also not entirely sure if raw keyboard-types should be used transparently and not wrapped by us and e.g. provide a conversion for it under feature or something (especially given that winit-core will be very light). |
Yeah, I recognize that's an option, but it's just so... Unsatisfying! Especially given that the types ( I've nominated the issue, let's discuss it next meeting, whenever that happens. |
I think that it's a big issue is that Here's a suggestion for completely avoiding breaking changes: Introduce a new key event called |
In Neovide we rely on It might not be needed if
Notice, that no text is given, and I'm not sure if there should be, so it could also be considered works as intended. |
Do you mean Ctrl+Space?
Hmm, I think that this PR might incidentally change that? Though I'm not entirely sure, I'd suggest you open a new issue. |
Yes
I'm not sure what's expected actually, I think the current behaviour is actually fine. On Windows you can actually have a keymap that produces characters combined with CTRL, see #3696 (comment). And on macOS combining Option with space should actually produce non-breaking spaces #4059. |
Remove
NamedKey::Space
and rename uses of "super" to "meta".These differences from the W3C specifications were introduced in #2662, though I can't find any discussion about it other than in #2662 (comment). It seems like it was left mostly as an unresolved question?
I don't have any preference for either name, but I believe it is more confusing than helping that Winit is diverging and choosing to prefer "super" when the spec prefers "meta". Besides, it is blocking integration with
keyboard-types
.Part of #2394.
Beware that this could break in confusing ways if someone was matching on
NamedKey::Super
, but we haveModifiersState
for a reason, which I think most users will be using anyhow (and there it'll break loudly becauseModifiersState::SUPER
is gone).CC @maroider @ArturKovacs @dhardy whom previously worked on this.
changelog
module if knowledge of this change could be valuable to users