8183518: Premature deprecation of Event/InputEvent/KeyEvent in Java 9

Reviewed-by: prr, psadhukhan
This commit is contained in:
Sergey Bylokhov 2017-12-01 17:44:07 -08:00
parent 6a21c771ec
commit d8efdbc4a2
10 changed files with 99 additions and 46 deletions

View File

@ -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. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * 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.
* <p>
* Menu shortcuts, which are embodied in the
* {@code MenuShortcut} class, are handled by the
* {@code MenuBar} class.
* <p>
* By default, this method returns {@code Event.CTRL_MASK}.
* Toolkit implementations should override this method if the
* <b>Control</b> 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 @Override
@SuppressWarnings("deprecation") @Deprecated(since = "10")
public int getMenuShortcutKeyMask() { public int getMenuShortcutKeyMask() {
return Event.META_MASK; return Event.META_MASK;
} }
@Override
public int getMenuShortcutKeyMaskEx() {
return InputEvent.META_DOWN_MASK;
}
@Override @Override
public Image getImage(final String filename) { public Image getImage(final String filename) {
final Image nsImage = checkForNSImage(filename); final Image nsImage = checkForNSImage(filename);

View File

@ -377,7 +377,6 @@ public class MenuBar extends MenuComponent implements MenuContainer, Accessible
* keydown). Returns true if there is an associated * keydown). Returns true if there is an associated
* keyboard event. * keyboard event.
*/ */
@SuppressWarnings("deprecation")
boolean handleShortcut(KeyEvent e) { boolean handleShortcut(KeyEvent e) {
// Is it a key event? // Is it a key event?
int id = e.getID(); int id = e.getID();
@ -386,8 +385,8 @@ public class MenuBar extends MenuComponent implements MenuContainer, Accessible
} }
// Is the accelerator modifier key pressed? // Is the accelerator modifier key pressed?
int accelKey = Toolkit.getDefaultToolkit().getMenuShortcutKeyMask(); int accelKey = Toolkit.getDefaultToolkit().getMenuShortcutKeyMaskEx();
if ((e.getModifiers() & accelKey) == 0) { if ((e.getModifiersEx() & accelKey) == 0) {
return false; return false;
} }

View File

@ -24,6 +24,7 @@
*/ */
package java.awt; package java.awt;
import java.awt.event.InputEvent;
import java.awt.event.KeyEvent; 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. * only work if the current keyboard layout produces a corresponding letter.
* <p> * <p>
* The accelerator key is platform-dependent and may be obtained * The accelerator key is platform-dependent and may be obtained
* via {@link Toolkit#getMenuShortcutKeyMask}. * via {@link Toolkit#getMenuShortcutKeyMaskEx()}.
* *
* @author Thomas Ball * @author Thomas Ball
* @since 1.1 * @since 1.1
@ -180,16 +181,15 @@ public class MenuShortcut implements java.io.Serializable
* @return a string representation of this MenuShortcut. * @return a string representation of this MenuShortcut.
* @since 1.1 * @since 1.1
*/ */
@SuppressWarnings("deprecation")
public String toString() { public String toString() {
int modifiers = 0; int modifiers = 0;
if (!GraphicsEnvironment.isHeadless()) { if (!GraphicsEnvironment.isHeadless()) {
modifiers = Toolkit.getDefaultToolkit().getMenuShortcutKeyMask(); modifiers = Toolkit.getDefaultToolkit().getMenuShortcutKeyMaskEx();
} }
if (usesShiftModifier()) { if (usesShiftModifier()) {
modifiers |= Event.SHIFT_MASK; modifiers |= InputEvent.SHIFT_DOWN_MASK;
} }
return KeyEvent.getKeyModifiersText(modifiers) + "+" + return InputEvent.getModifiersExText(modifiers) + "+" +
KeyEvent.getKeyText(key); KeyEvent.getKeyText(key);
} }

View File

@ -29,7 +29,23 @@ import java.awt.datatransfer.Clipboard;
import java.awt.dnd.DragGestureListener; import java.awt.dnd.DragGestureListener;
import java.awt.dnd.DragGestureRecognizer; import java.awt.dnd.DragGestureRecognizer;
import java.awt.dnd.DragSource; 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.im.InputMethodHighlight;
import java.awt.image.ColorModel; import java.awt.image.ColorModel;
import java.awt.image.ImageObserver; import java.awt.image.ImageObserver;
@ -40,15 +56,22 @@ import java.beans.PropertyChangeSupport;
import java.io.File; import java.io.File;
import java.io.FileInputStream; import java.io.FileInputStream;
import java.net.URL; import java.net.URL;
import java.security.AccessController;
import java.security.PrivilegedAction;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Arrays;
import java.util.EventListener; import java.util.EventListener;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
import java.util.MissingResourceException; import java.util.MissingResourceException;
import java.util.Properties; import java.util.Properties;
import java.util.ResourceBundle; import java.util.ResourceBundle;
import java.util.StringTokenizer; import java.util.ServiceLoader;
import java.util.Set;
import java.util.WeakHashMap; import java.util.WeakHashMap;
import java.util.stream.Collectors;
import javax.accessibility.AccessibilityProvider;
import sun.awt.AWTAccessor; import sun.awt.AWTAccessor;
import sun.awt.AWTPermissions; import sun.awt.AWTPermissions;
@ -57,14 +80,6 @@ import sun.awt.HeadlessToolkit;
import sun.awt.PeerEvent; import sun.awt.PeerEvent;
import sun.awt.SunToolkit; 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 * This class is the abstract superclass of all actual
* implementations of the Abstract Window Toolkit. Subclasses of * implementations of the Abstract Window Toolkit. Subclasses of
@ -1065,15 +1080,43 @@ public abstract class Toolkit {
* @see java.awt.GraphicsEnvironment#isHeadless * @see java.awt.GraphicsEnvironment#isHeadless
* @see java.awt.MenuBar * @see java.awt.MenuBar
* @see java.awt.MenuShortcut * @see java.awt.MenuShortcut
* @deprecated It is recommended that extended modifier keys and
* {@link #getMenuShortcutKeyMaskEx()} be used instead
* @since 1.1 * @since 1.1
*/ */
@SuppressWarnings("deprecation") @Deprecated(since = "10")
public int getMenuShortcutKeyMask() throws HeadlessException { public int getMenuShortcutKeyMask() throws HeadlessException {
GraphicsEnvironment.checkHeadless(); GraphicsEnvironment.checkHeadless();
return Event.CTRL_MASK; return Event.CTRL_MASK;
} }
/**
* Determines which extended modifier key is the appropriate accelerator
* key for menu shortcuts.
* <p>
* Menu shortcuts, which are embodied in the {@code MenuShortcut} class, are
* handled by the {@code MenuBar} class.
* <p>
* By default, this method returns {@code InputEvent.CTRL_DOWN_MASK}.
* Toolkit implementations should override this method if the
* <b>Control</b> 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 * Returns whether the given locking key on the keyboard is currently in
* its "on" state. * its "on" state.

View File

@ -530,7 +530,6 @@ public class BasicComboPopup extends JPopupMenu implements ComboPopup {
*/ */
protected JList<Object> createList() { protected JList<Object> createList() {
return new JList<Object>( comboBox.getModel() ) { return new JList<Object>( comboBox.getModel() ) {
@SuppressWarnings("deprecation")
public void processMouseEvent(MouseEvent e) { public void processMouseEvent(MouseEvent e) {
if (BasicGraphicsUtils.isMenuShortcutKeyDown(e)) { if (BasicGraphicsUtils.isMenuShortcutKeyDown(e)) {
// Fix for 4234053. Filter out the Control Key from the list. // 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(); Toolkit toolkit = Toolkit.getDefaultToolkit();
MouseEvent newEvent = new MouseEvent( MouseEvent newEvent = new MouseEvent(
(Component)e.getSource(), e.getID(), e.getWhen(), (Component)e.getSource(), e.getID(), e.getWhen(),
e.getModifiers() ^ toolkit.getMenuShortcutKeyMask(), e.getModifiersEx() ^ toolkit.getMenuShortcutKeyMaskEx(),
e.getX(), e.getY(), e.getX(), e.getY(),
e.getXOnScreen(), e.getYOnScreen(), e.getXOnScreen(), e.getYOnScreen(),
e.getClickCount(), e.getClickCount(),

View File

@ -1134,6 +1134,7 @@ public class BasicFileChooserUI extends FileChooserUI {
boolean isTrav = (selectedFile != null && chooser.isTraversable(selectedFile)); boolean isTrav = (selectedFile != null && chooser.isTraversable(selectedFile));
boolean isDirSelEnabled = chooser.isDirectorySelectionEnabled(); boolean isDirSelEnabled = chooser.isDirectorySelectionEnabled();
boolean isFileSelEnabled = chooser.isFileSelectionEnabled(); boolean isFileSelEnabled = chooser.isFileSelectionEnabled();
@SuppressWarnings("deprecation")
boolean isCtrl = (e != null && (e.getModifiers() & boolean isCtrl = (e != null && (e.getModifiers() &
Toolkit.getDefaultToolkit().getMenuShortcutKeyMask()) != 0); Toolkit.getDefaultToolkit().getMenuShortcutKeyMask()) != 0);

View File

@ -382,10 +382,9 @@ public class BasicGraphicsUtils
return c.getComponentOrientation().isLeftToRight(); return c.getComponentOrientation().isLeftToRight();
} }
@SuppressWarnings("deprecation")
static boolean isMenuShortcutKeyDown(InputEvent event) { static boolean isMenuShortcutKeyDown(InputEvent event) {
return (event.getModifiers() & return (event.getModifiersEx() &
Toolkit.getDefaultToolkit().getMenuShortcutKeyMask()) != 0; Toolkit.getDefaultToolkit().getMenuShortcutKeyMaskEx()) != 0;
} }
/** /**

View File

@ -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. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * 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 @Override
@Deprecated(since = "10")
public int getMenuShortcutKeyMask() public int getMenuShortcutKeyMask()
throws HeadlessException { throws HeadlessException {
throw new HeadlessException(); throw new HeadlessException();
} }
@Override
public int getMenuShortcutKeyMaskEx()
throws HeadlessException {
throw new HeadlessException();
}
@Override @Override
public boolean getLockingKeyState(int keyCode) public boolean getLockingKeyState(int keyCode)
throws UnsupportedOperationException { throws UnsupportedOperationException {

View File

@ -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. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * 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.DragGestureRecognizer;
import java.awt.dnd.DragSource; import java.awt.dnd.DragSource;
import java.awt.event.AWTEventListener; import java.awt.event.AWTEventListener;
import java.awt.event.InputEvent;
import java.awt.font.TextAttribute; import java.awt.font.TextAttribute;
import java.awt.im.InputMethodHighlight; import java.awt.im.InputMethodHighlight;
import java.awt.image.ColorModel; import java.awt.image.ColorModel;
@ -128,11 +129,18 @@ public final class HeadlessToolkit extends Toolkit
} }
@Override @Override
@Deprecated(since = "10")
public int getMenuShortcutKeyMask() public int getMenuShortcutKeyMask()
throws HeadlessException { throws HeadlessException {
throw new HeadlessException(); throw new HeadlessException();
} }
@Override
public int getMenuShortcutKeyMaskEx()
throws HeadlessException {
throw new HeadlessException();
}
@Override @Override
public boolean getLockingKeyState(int keyCode) public boolean getLockingKeyState(int keyCode)
throws UnsupportedOperationException { throws UnsupportedOperationException {

View File

@ -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. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -116,6 +116,15 @@ public class HeadlessToolkit {
if (!exceptions) if (!exceptions)
throw new RuntimeException("HeadlessException did not occur when expected"); 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; exceptions = false;
try { try {
boolean state = tk.getLockingKeyState(KeyEvent.VK_CAPS_LOCK); boolean state = tk.getLockingKeyState(KeyEvent.VK_CAPS_LOCK);