From d8efdbc4a2ed501022469ad9290bccb69de2e26b Mon Sep 17 00:00:00 2001 From: Sergey Bylokhov Date: Fri, 1 Dec 2017 17:44:07 -0800 Subject: [PATCH] 8183518: Premature deprecation of Event/InputEvent/KeyEvent in Java 9 Reviewed-by: prr, psadhukhan --- .../classes/sun/lwawt/macosx/LWCToolkit.java | 26 ++------ .../share/classes/java/awt/MenuBar.java | 5 +- .../share/classes/java/awt/MenuShortcut.java | 10 +-- .../share/classes/java/awt/Toolkit.java | 65 +++++++++++++++---- .../swing/plaf/basic/BasicComboPopup.java | 3 +- .../swing/plaf/basic/BasicFileChooserUI.java | 1 + .../swing/plaf/basic/BasicGraphicsUtils.java | 5 +- .../share/classes/sun/awt/HToolkit.java | 9 ++- .../classes/sun/awt/HeadlessToolkit.java | 10 ++- .../awt/Toolkit/Headless/HeadlessToolkit.java | 11 +++- 10 files changed, 99 insertions(+), 46 deletions(-) diff --git a/src/java.desktop/macosx/classes/sun/lwawt/macosx/LWCToolkit.java b/src/java.desktop/macosx/classes/sun/lwawt/macosx/LWCToolkit.java index 6f5e5c85c9a..1203de32f84 100644 --- a/src/java.desktop/macosx/classes/sun/lwawt/macosx/LWCToolkit.java +++ b/src/java.desktop/macosx/classes/sun/lwawt/macosx/LWCToolkit.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 2017, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -502,29 +502,17 @@ public final class LWCToolkit extends LWToolkit { } } - /** - * Determines which modifier key is the appropriate accelerator - * key for menu shortcuts. - *

- * Menu shortcuts, which are embodied in the - * {@code MenuShortcut} class, are handled by the - * {@code MenuBar} class. - *

- * By default, this method returns {@code Event.CTRL_MASK}. - * Toolkit implementations should override this method if the - * Control key isn't the correct key for accelerators. - * @return the modifier mask on the {@code Event} class - * that is used for menu shortcuts on this toolkit. - * @see java.awt.MenuBar - * @see java.awt.MenuShortcut - * @since 1.1 - */ @Override - @SuppressWarnings("deprecation") + @Deprecated(since = "10") public int getMenuShortcutKeyMask() { return Event.META_MASK; } + @Override + public int getMenuShortcutKeyMaskEx() { + return InputEvent.META_DOWN_MASK; + } + @Override public Image getImage(final String filename) { final Image nsImage = checkForNSImage(filename); diff --git a/src/java.desktop/share/classes/java/awt/MenuBar.java b/src/java.desktop/share/classes/java/awt/MenuBar.java index 6a6d3043bc4..1c7f1e9b3e5 100644 --- a/src/java.desktop/share/classes/java/awt/MenuBar.java +++ b/src/java.desktop/share/classes/java/awt/MenuBar.java @@ -377,7 +377,6 @@ public class MenuBar extends MenuComponent implements MenuContainer, Accessible * keydown). Returns true if there is an associated * keyboard event. */ - @SuppressWarnings("deprecation") boolean handleShortcut(KeyEvent e) { // Is it a key event? int id = e.getID(); @@ -386,8 +385,8 @@ public class MenuBar extends MenuComponent implements MenuContainer, Accessible } // Is the accelerator modifier key pressed? - int accelKey = Toolkit.getDefaultToolkit().getMenuShortcutKeyMask(); - if ((e.getModifiers() & accelKey) == 0) { + int accelKey = Toolkit.getDefaultToolkit().getMenuShortcutKeyMaskEx(); + if ((e.getModifiersEx() & accelKey) == 0) { return false; } diff --git a/src/java.desktop/share/classes/java/awt/MenuShortcut.java b/src/java.desktop/share/classes/java/awt/MenuShortcut.java index 0704b32c000..3b3f5269279 100644 --- a/src/java.desktop/share/classes/java/awt/MenuShortcut.java +++ b/src/java.desktop/share/classes/java/awt/MenuShortcut.java @@ -24,6 +24,7 @@ */ package java.awt; +import java.awt.event.InputEvent; import java.awt.event.KeyEvent; /** @@ -51,7 +52,7 @@ import java.awt.event.KeyEvent; * only work if the current keyboard layout produces a corresponding letter. *

* The accelerator key is platform-dependent and may be obtained - * via {@link Toolkit#getMenuShortcutKeyMask}. + * via {@link Toolkit#getMenuShortcutKeyMaskEx()}. * * @author Thomas Ball * @since 1.1 @@ -180,16 +181,15 @@ public class MenuShortcut implements java.io.Serializable * @return a string representation of this MenuShortcut. * @since 1.1 */ - @SuppressWarnings("deprecation") public String toString() { int modifiers = 0; if (!GraphicsEnvironment.isHeadless()) { - modifiers = Toolkit.getDefaultToolkit().getMenuShortcutKeyMask(); + modifiers = Toolkit.getDefaultToolkit().getMenuShortcutKeyMaskEx(); } if (usesShiftModifier()) { - modifiers |= Event.SHIFT_MASK; + modifiers |= InputEvent.SHIFT_DOWN_MASK; } - return KeyEvent.getKeyModifiersText(modifiers) + "+" + + return InputEvent.getModifiersExText(modifiers) + "+" + KeyEvent.getKeyText(key); } diff --git a/src/java.desktop/share/classes/java/awt/Toolkit.java b/src/java.desktop/share/classes/java/awt/Toolkit.java index baa74568fcb..489ee4ff695 100644 --- a/src/java.desktop/share/classes/java/awt/Toolkit.java +++ b/src/java.desktop/share/classes/java/awt/Toolkit.java @@ -29,7 +29,23 @@ import java.awt.datatransfer.Clipboard; import java.awt.dnd.DragGestureListener; import java.awt.dnd.DragGestureRecognizer; import java.awt.dnd.DragSource; -import java.awt.event.*; +import java.awt.event.AWTEventListener; +import java.awt.event.AWTEventListenerProxy; +import java.awt.event.ActionEvent; +import java.awt.event.AdjustmentEvent; +import java.awt.event.ComponentEvent; +import java.awt.event.ContainerEvent; +import java.awt.event.FocusEvent; +import java.awt.event.HierarchyEvent; +import java.awt.event.InputEvent; +import java.awt.event.InputMethodEvent; +import java.awt.event.InvocationEvent; +import java.awt.event.ItemEvent; +import java.awt.event.KeyEvent; +import java.awt.event.MouseEvent; +import java.awt.event.PaintEvent; +import java.awt.event.TextEvent; +import java.awt.event.WindowEvent; import java.awt.im.InputMethodHighlight; import java.awt.image.ColorModel; import java.awt.image.ImageObserver; @@ -40,15 +56,22 @@ import java.beans.PropertyChangeSupport; import java.io.File; import java.io.FileInputStream; import java.net.URL; +import java.security.AccessController; +import java.security.PrivilegedAction; import java.util.ArrayList; +import java.util.Arrays; import java.util.EventListener; import java.util.HashMap; import java.util.Map; import java.util.MissingResourceException; import java.util.Properties; import java.util.ResourceBundle; -import java.util.StringTokenizer; +import java.util.ServiceLoader; +import java.util.Set; import java.util.WeakHashMap; +import java.util.stream.Collectors; + +import javax.accessibility.AccessibilityProvider; import sun.awt.AWTAccessor; import sun.awt.AWTPermissions; @@ -57,14 +80,6 @@ import sun.awt.HeadlessToolkit; import sun.awt.PeerEvent; import sun.awt.SunToolkit; -import java.security.AccessController; -import java.security.PrivilegedAction; -import java.util.Arrays; -import java.util.ServiceLoader; -import java.util.Set; -import java.util.stream.Collectors; -import javax.accessibility.AccessibilityProvider; - /** * This class is the abstract superclass of all actual * implementations of the Abstract Window Toolkit. Subclasses of @@ -1065,15 +1080,43 @@ public abstract class Toolkit { * @see java.awt.GraphicsEnvironment#isHeadless * @see java.awt.MenuBar * @see java.awt.MenuShortcut + * @deprecated It is recommended that extended modifier keys and + * {@link #getMenuShortcutKeyMaskEx()} be used instead * @since 1.1 */ - @SuppressWarnings("deprecation") + @Deprecated(since = "10") public int getMenuShortcutKeyMask() throws HeadlessException { GraphicsEnvironment.checkHeadless(); return Event.CTRL_MASK; } + /** + * Determines which extended modifier key is the appropriate accelerator + * key for menu shortcuts. + *

+ * Menu shortcuts, which are embodied in the {@code MenuShortcut} class, are + * handled by the {@code MenuBar} class. + *

+ * By default, this method returns {@code InputEvent.CTRL_DOWN_MASK}. + * Toolkit implementations should override this method if the + * Control key isn't the correct key for accelerators. + * + * @return the modifier mask on the {@code InputEvent} class that is used + * for menu shortcuts on this toolkit + * @throws HeadlessException if GraphicsEnvironment.isHeadless() returns + * true + * @see java.awt.GraphicsEnvironment#isHeadless + * @see java.awt.MenuBar + * @see java.awt.MenuShortcut + * @since 10 + */ + public int getMenuShortcutKeyMaskEx() throws HeadlessException { + GraphicsEnvironment.checkHeadless(); + + return InputEvent.CTRL_DOWN_MASK; + } + /** * Returns whether the given locking key on the keyboard is currently in * its "on" state. diff --git a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicComboPopup.java b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicComboPopup.java index 6376f0f1f45..60c6f572bf9 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicComboPopup.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicComboPopup.java @@ -530,7 +530,6 @@ public class BasicComboPopup extends JPopupMenu implements ComboPopup { */ protected JList createList() { return new JList( comboBox.getModel() ) { - @SuppressWarnings("deprecation") public void processMouseEvent(MouseEvent e) { if (BasicGraphicsUtils.isMenuShortcutKeyDown(e)) { // Fix for 4234053. Filter out the Control Key from the list. @@ -538,7 +537,7 @@ public class BasicComboPopup extends JPopupMenu implements ComboPopup { Toolkit toolkit = Toolkit.getDefaultToolkit(); MouseEvent newEvent = new MouseEvent( (Component)e.getSource(), e.getID(), e.getWhen(), - e.getModifiers() ^ toolkit.getMenuShortcutKeyMask(), + e.getModifiersEx() ^ toolkit.getMenuShortcutKeyMaskEx(), e.getX(), e.getY(), e.getXOnScreen(), e.getYOnScreen(), e.getClickCount(), diff --git a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicFileChooserUI.java b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicFileChooserUI.java index d58a5286f65..8ed05e07861 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicFileChooserUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicFileChooserUI.java @@ -1134,6 +1134,7 @@ public class BasicFileChooserUI extends FileChooserUI { boolean isTrav = (selectedFile != null && chooser.isTraversable(selectedFile)); boolean isDirSelEnabled = chooser.isDirectorySelectionEnabled(); boolean isFileSelEnabled = chooser.isFileSelectionEnabled(); + @SuppressWarnings("deprecation") boolean isCtrl = (e != null && (e.getModifiers() & Toolkit.getDefaultToolkit().getMenuShortcutKeyMask()) != 0); diff --git a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicGraphicsUtils.java b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicGraphicsUtils.java index 4122573a7d2..26c4b6f73fe 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicGraphicsUtils.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicGraphicsUtils.java @@ -382,10 +382,9 @@ public class BasicGraphicsUtils return c.getComponentOrientation().isLeftToRight(); } - @SuppressWarnings("deprecation") static boolean isMenuShortcutKeyDown(InputEvent event) { - return (event.getModifiers() & - Toolkit.getDefaultToolkit().getMenuShortcutKeyMask()) != 0; + return (event.getModifiersEx() & + Toolkit.getDefaultToolkit().getMenuShortcutKeyMaskEx()) != 0; } /** diff --git a/src/java.desktop/share/classes/sun/awt/HToolkit.java b/src/java.desktop/share/classes/sun/awt/HToolkit.java index 31ecb3ac736..00262b12a42 100644 --- a/src/java.desktop/share/classes/sun/awt/HToolkit.java +++ b/src/java.desktop/share/classes/sun/awt/HToolkit.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 2017, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -130,11 +130,18 @@ public final class HToolkit extends SunToolkit implements ComponentFactory { } @Override + @Deprecated(since = "10") public int getMenuShortcutKeyMask() throws HeadlessException { throw new HeadlessException(); } + @Override + public int getMenuShortcutKeyMaskEx() + throws HeadlessException { + throw new HeadlessException(); + } + @Override public boolean getLockingKeyState(int keyCode) throws UnsupportedOperationException { diff --git a/src/java.desktop/share/classes/sun/awt/HeadlessToolkit.java b/src/java.desktop/share/classes/sun/awt/HeadlessToolkit.java index d603c87bf81..b3d902409f4 100644 --- a/src/java.desktop/share/classes/sun/awt/HeadlessToolkit.java +++ b/src/java.desktop/share/classes/sun/awt/HeadlessToolkit.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -31,6 +31,7 @@ import java.awt.dnd.DragGestureListener; import java.awt.dnd.DragGestureRecognizer; import java.awt.dnd.DragSource; import java.awt.event.AWTEventListener; +import java.awt.event.InputEvent; import java.awt.font.TextAttribute; import java.awt.im.InputMethodHighlight; import java.awt.image.ColorModel; @@ -128,11 +129,18 @@ public final class HeadlessToolkit extends Toolkit } @Override + @Deprecated(since = "10") public int getMenuShortcutKeyMask() throws HeadlessException { throw new HeadlessException(); } + @Override + public int getMenuShortcutKeyMaskEx() + throws HeadlessException { + throw new HeadlessException(); + } + @Override public boolean getLockingKeyState(int keyCode) throws UnsupportedOperationException { diff --git a/test/jdk/java/awt/Toolkit/Headless/HeadlessToolkit.java b/test/jdk/java/awt/Toolkit/Headless/HeadlessToolkit.java index 1f7ceeeea00..0076bdb2067 100644 --- a/test/jdk/java/awt/Toolkit/Headless/HeadlessToolkit.java +++ b/test/jdk/java/awt/Toolkit/Headless/HeadlessToolkit.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2007, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2007, 2017, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -116,6 +116,15 @@ public class HeadlessToolkit { if (!exceptions) throw new RuntimeException("HeadlessException did not occur when expected"); + exceptions = false; + try { + int km = tk.getMenuShortcutKeyMaskEx(); + } catch (HeadlessException e) { + exceptions = true; + } + if (!exceptions) + throw new RuntimeException("HeadlessException did not occur when expected"); + exceptions = false; try { boolean state = tk.getLockingKeyState(KeyEvent.VK_CAPS_LOCK);