Bug 1266437 - Drop "OS" modifier r=smaug,m_kato,karlt,Gijs
On Windows, Windows logo key was mapped to "OS" modifier, and on Linux, it's same and the key is called "Super" and "Hyper". That conformed to the older UI Events spec. However, UI Events declares that they should be mapped to "Meta" now and Chrome handles it as the spec in Windows and Linux. Therefore, we should align the behavior to them. Note that we've treated the legacy "Meta" modifier on Linux as DOM "Meta" modifier state, and we'll keep this as-is because in Sun/Solaris keyboard layout, they keys are mapped to the legacy "Meta". Finally, the following check only `IsMeta()` but not `IsOS()`. I think that they should've checked `IsOS()` too. Therefore, they will behave differently in Windows and Linux. * https://searchfox.org/mozilla-central/rev/9a4666e63199bd1bcfc9095f6efec3488c358458/dom/base/Element.cpp#3287-3288 * https://searchfox.org/mozilla-central/rev/9a4666e63199bd1bcfc9095f6efec3488c358458/dom/html/HTMLInputElement.cpp#3762-3764 * https://searchfox.org/mozilla-central/rev/9a4666e63199bd1bcfc9095f6efec3488c358458/dom/html/HTMLInputElement.cpp#3796-3806 * https://searchfox.org/mozilla-central/rev/9a4666e63199bd1bcfc9095f6efec3488c358458/dom/html/HTMLLabelElement.cpp#127-128 * https://searchfox.org/mozilla-central/rev/9a4666e63199bd1bcfc9095f6efec3488c358458/widget/gtk/nsGtkKeyUtils.cpp#1461-1462 Note that `KEY_NAME_INDEX_OS` will be removed in the patch for bug 1232918. Differential Revision: https://phabricator.services.mozilla.com/D183480
This commit is contained in:
@@ -450,8 +450,7 @@ bool nsContentUtils::sIsHandlingKeyBoardEvent = false;
|
||||
|
||||
nsString* nsContentUtils::sShiftText = nullptr;
|
||||
nsString* nsContentUtils::sControlText = nullptr;
|
||||
nsString* nsContentUtils::sMetaText = nullptr;
|
||||
nsString* nsContentUtils::sOSText = nullptr;
|
||||
nsString* nsContentUtils::sCommandOrWinText = nullptr;
|
||||
nsString* nsContentUtils::sAltText = nullptr;
|
||||
nsString* nsContentUtils::sModifierSeparator = nullptr;
|
||||
|
||||
@@ -882,16 +881,11 @@ void nsContentUtils::GetControlText(nsAString& text) {
|
||||
text.Assign(*sControlText);
|
||||
}
|
||||
|
||||
void nsContentUtils::GetMetaText(nsAString& text) {
|
||||
if (!sMetaText) InitializeModifierStrings();
|
||||
text.Assign(*sMetaText);
|
||||
}
|
||||
|
||||
void nsContentUtils::GetOSText(nsAString& text) {
|
||||
if (!sOSText) {
|
||||
void nsContentUtils::GetCommandOrWinText(nsAString& text) {
|
||||
if (!sCommandOrWinText) {
|
||||
InitializeModifierStrings();
|
||||
}
|
||||
text.Assign(*sOSText);
|
||||
text.Assign(*sCommandOrWinText);
|
||||
}
|
||||
|
||||
void nsContentUtils::GetAltText(nsAString& text) {
|
||||
@@ -920,8 +914,7 @@ void nsContentUtils::InitializeModifierStrings() {
|
||||
NS_SUCCEEDED(rv) && bundle,
|
||||
"chrome://global/locale/platformKeys.properties could not be loaded");
|
||||
nsAutoString shiftModifier;
|
||||
nsAutoString metaModifier;
|
||||
nsAutoString osModifier;
|
||||
nsAutoString commandOrWinModifier;
|
||||
nsAutoString altModifier;
|
||||
nsAutoString controlModifier;
|
||||
nsAutoString modifierSeparator;
|
||||
@@ -929,16 +922,14 @@ void nsContentUtils::InitializeModifierStrings() {
|
||||
// macs use symbols for each modifier key, so fetch each from the bundle,
|
||||
// which also covers i18n
|
||||
bundle->GetStringFromName("VK_SHIFT", shiftModifier);
|
||||
bundle->GetStringFromName("VK_META", metaModifier);
|
||||
bundle->GetStringFromName("VK_WIN", osModifier);
|
||||
bundle->GetStringFromName("VK_COMMAND_OR_WIN", commandOrWinModifier);
|
||||
bundle->GetStringFromName("VK_ALT", altModifier);
|
||||
bundle->GetStringFromName("VK_CONTROL", controlModifier);
|
||||
bundle->GetStringFromName("MODIFIER_SEPARATOR", modifierSeparator);
|
||||
}
|
||||
// if any of these don't exist, we get an empty string
|
||||
sShiftText = new nsString(shiftModifier);
|
||||
sMetaText = new nsString(metaModifier);
|
||||
sOSText = new nsString(osModifier);
|
||||
sCommandOrWinText = new nsString(commandOrWinModifier);
|
||||
sAltText = new nsString(altModifier);
|
||||
sControlText = new nsString(controlModifier);
|
||||
sModifierSeparator = new nsString(modifierSeparator);
|
||||
@@ -1935,10 +1926,8 @@ void nsContentUtils::Shutdown() {
|
||||
sShiftText = nullptr;
|
||||
delete sControlText;
|
||||
sControlText = nullptr;
|
||||
delete sMetaText;
|
||||
sMetaText = nullptr;
|
||||
delete sOSText;
|
||||
sOSText = nullptr;
|
||||
delete sCommandOrWinText;
|
||||
sCommandOrWinText = nullptr;
|
||||
delete sAltText;
|
||||
sAltText = nullptr;
|
||||
delete sModifierSeparator;
|
||||
@@ -8492,9 +8481,6 @@ Modifiers nsContentUtils::GetWidgetModifiers(int32_t aModifiers) {
|
||||
if (aModifiers & nsIDOMWindowUtils::MODIFIER_SYMBOLLOCK) {
|
||||
result |= mozilla::MODIFIER_SYMBOLLOCK;
|
||||
}
|
||||
if (aModifiers & nsIDOMWindowUtils::MODIFIER_OS) {
|
||||
result |= mozilla::MODIFIER_OS;
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user