From e6a0c6cf4da15f775226a59bfe30c27bcfabe482 Mon Sep 17 00:00:00 2001 From: Prasanta Sadhukhan Date: Wed, 19 Aug 2020 11:49:54 +0530 Subject: [PATCH] 8250852: Address reliance on default constructors in the javax.swing.plaf.basic APIs Reviewed-by: serb, aivanov --- .../javax/swing/plaf/basic/BasicLabelUI.java | 5 ++++ .../javax/swing/plaf/basic/BasicListUI.java | 30 +++++++++++++++++++ .../swing/plaf/basic/BasicLookAndFeel.java | 5 ++++ .../swing/plaf/basic/BasicMenuBarUI.java | 5 ++++ .../swing/plaf/basic/BasicMenuItemUI.java | 5 ++++ .../javax/swing/plaf/basic/BasicMenuUI.java | 5 ++++ .../swing/plaf/basic/BasicOptionPaneUI.java | 10 +++++++ .../javax/swing/plaf/basic/BasicPanelUI.java | 5 ++++ .../plaf/basic/BasicPasswordFieldUI.java | 5 ++++ .../plaf/basic/BasicPopupMenuSeparatorUI.java | 5 ++++ .../swing/plaf/basic/BasicProgressBarUI.java | 10 +++++++ .../basic/BasicRadioButtonMenuItemUI.java | 5 ++++ .../swing/plaf/basic/BasicRadioButtonUI.java | 5 ++++ .../swing/plaf/basic/BasicRootPaneUI.java | 5 ++++ .../swing/plaf/basic/BasicScrollBarUI.java | 10 +++++++ .../swing/plaf/basic/BasicScrollPaneUI.java | 21 +++++++++++++ .../swing/plaf/basic/BasicSeparatorUI.java | 5 ++++ .../javax/swing/plaf/basic/BasicSliderUI.java | 30 +++++++++++++++++++ .../swing/plaf/basic/BasicSpinnerUI.java | 4 +++ .../swing/plaf/basic/BasicSplitPaneUI.java | 24 +++++++++++++++ 20 files changed, 199 insertions(+) diff --git a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicLabelUI.java b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicLabelUI.java index 5c506ac8ab5..9ddc0387e54 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicLabelUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicLabelUI.java @@ -71,6 +71,11 @@ public class BasicLabelUI extends LabelUI implements PropertyChangeListener private Rectangle paintIconR = new Rectangle(); private Rectangle paintTextR = new Rectangle(); + /** + * Constructs a {@code BasicLabelUI}. + */ + public BasicLabelUI() {} + static void loadActionMap(LazyActionMap map) { map.put(new Actions(Actions.PRESS)); map.put(new Actions(Actions.RELEASE)); diff --git a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicListUI.java b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicListUI.java index 37493e0eb9f..b64c2c43bd2 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicListUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicListUI.java @@ -199,6 +199,11 @@ public class BasicListUI extends ListUI private static final int DROP_LINE_THICKNESS = 2; + /** + * Constructs a {@code BasicListUI}. + */ + public BasicListUI() {} + static void loadActionMap(LazyActionMap map) { map.put(new Actions(Actions.SELECT_PREVIOUS_COLUMN)); map.put(new Actions(Actions.SELECT_PREVIOUS_COLUMN_EXTEND)); @@ -1577,6 +1582,11 @@ public class BasicListUI extends ListUI @SuppressWarnings("serial") // Same-version serialization only public class MouseInputHandler implements MouseInputListener { + /** + * Constructs a {@code MouseInputHandler}. + */ + public MouseInputHandler() {} + public void mouseClicked(MouseEvent e) { getHandler().mouseClicked(e); } @@ -1640,6 +1650,11 @@ public class BasicListUI extends ListUI */ public class FocusHandler implements FocusListener { + /** + * Constructs a {@code FocusHandler}. + */ + public FocusHandler() {} + /** * Repaints focused cells. */ @@ -1691,6 +1706,11 @@ public class BasicListUI extends ListUI @SuppressWarnings("serial") // Same-version serialization only public class ListSelectionHandler implements ListSelectionListener { + /** + * Constructs a {@code ListSelectionHandler}. + */ + public ListSelectionHandler() {} + public void valueChanged(ListSelectionEvent e) { getHandler().valueChanged(e); @@ -1752,6 +1772,11 @@ public class BasicListUI extends ListUI @SuppressWarnings("serial") // Same-version serialization only public class ListDataHandler implements ListDataListener { + /** + * Constructs a {@code ListDataHandler}. + */ + public ListDataHandler() {} + public void intervalAdded(ListDataEvent e) { getHandler().intervalAdded(e); } @@ -1820,6 +1845,11 @@ public class BasicListUI extends ListUI @SuppressWarnings("serial") // Same-version serialization only public class PropertyChangeHandler implements PropertyChangeListener { + /** + * Constructs a {@code PropertyChangeHandler}. + */ + public PropertyChangeHandler() {} + public void propertyChange(PropertyChangeEvent e) { getHandler().propertyChange(e); diff --git a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicLookAndFeel.java b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicLookAndFeel.java index 02749f742ef..8c709c72070 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicLookAndFeel.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicLookAndFeel.java @@ -127,6 +127,11 @@ public abstract class BasicLookAndFeel extends LookAndFeel implements Serializab */ private PropertyChangeListener disposer = null; + /** + * Constructor for subclasses to call. + */ + protected BasicLookAndFeel() {} + /** * Returns the look and feel defaults. The returned {@code UIDefaults} * is populated by invoking, in order, {@code initClassDefaults}, diff --git a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicMenuBarUI.java b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicMenuBarUI.java index a5ec104c320..2079aafd3a2 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicMenuBarUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicMenuBarUI.java @@ -71,6 +71,11 @@ public class BasicMenuBarUI extends MenuBarUI { protected ChangeListener changeListener; private Handler handler; + /** + * Constructs a {@code BasicMenuBarUI}. + */ + public BasicMenuBarUI() {} + /** * Returns a new instance of {@code BasicMenuBarUI}. * diff --git a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicMenuItemUI.java b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicMenuItemUI.java index 4da1141d2aa..3d036358e6d 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicMenuItemUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicMenuItemUI.java @@ -131,6 +131,11 @@ public class BasicMenuItemUI extends MenuItemUI private static final boolean VERBOSE = false; // show reuse hits/misses private static final boolean DEBUG = false; // show bad params, misc. + /** + * Constructs a {@code BasicMenuItemUI}. + */ + public BasicMenuItemUI() {} + static void loadActionMap(LazyActionMap map) { // NOTE: BasicMenuUI also calls into this method. map.put(new Actions(Actions.CLICK)); diff --git a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicMenuUI.java b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicMenuUI.java index 9c0acd10129..ba60b557d82 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicMenuUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicMenuUI.java @@ -70,6 +70,11 @@ public class BasicMenuUI extends BasicMenuItemUI private static boolean crossMenuMnemonic = true; + /** + * Constructs a {@code BasicMenuUI}. + */ + public BasicMenuUI() {} + /** * Constructs a new instance of {@code BasicMenuUI}. * diff --git a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicOptionPaneUI.java b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicOptionPaneUI.java index b3a12edb5fb..427823573a6 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicOptionPaneUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicOptionPaneUI.java @@ -127,6 +127,11 @@ public class BasicOptionPaneUI extends OptionPaneUI { } } + /** + * Constructs a {@code BasicOptionPaneUI}. + */ + public BasicOptionPaneUI() {} + static void loadActionMap(LazyActionMap map) { map.put(new Actions(Actions.CLOSE)); BasicLookAndFeel.installAudioActionMap(map); @@ -1257,6 +1262,11 @@ public class BasicOptionPaneUI extends OptionPaneUI { * Instantiate it only within subclasses of {@code BasicOptionPaneUI}. */ public class PropertyChangeHandler implements PropertyChangeListener { + /** + * Constructs a {@code PropertyChangeHandler}. + */ + public PropertyChangeHandler() {} + /** * If the source of the PropertyChangeEvent e equals the * optionPane and is one of the ICON_PROPERTY, MESSAGE_PROPERTY, diff --git a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicPanelUI.java b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicPanelUI.java index 46929bcca69..839c8d4e68b 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicPanelUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicPanelUI.java @@ -43,6 +43,11 @@ public class BasicPanelUI extends PanelUI { // Shared UI object private static PanelUI panelUI; + /** + * Constructs a {@code BasicPanelUI}. + */ + public BasicPanelUI() {} + /** * Returns an instance of {@code BasicPanelUI}. * diff --git a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicPasswordFieldUI.java b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicPasswordFieldUI.java index 7f27d6ee0f5..6a78e2d6871 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicPasswordFieldUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicPasswordFieldUI.java @@ -42,6 +42,11 @@ import javax.swing.plaf.*; */ public class BasicPasswordFieldUI extends BasicTextFieldUI { + /** + * Constructs a {@code BasicPasswordFieldUI}. + */ + public BasicPasswordFieldUI() {} + /** * Creates a UI for a JPasswordField. * diff --git a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicPopupMenuSeparatorUI.java b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicPopupMenuSeparatorUI.java index 9122beae1f0..3884e3c05b7 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicPopupMenuSeparatorUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicPopupMenuSeparatorUI.java @@ -42,6 +42,11 @@ import javax.swing.plaf.ComponentUI; public class BasicPopupMenuSeparatorUI extends BasicSeparatorUI { + /** + * Constructs a {@code BasicPopupMenuSeparatorUI}. + */ + public BasicPopupMenuSeparatorUI() {} + /** * Returns a new instance of {@code BasicPopupMenuSeparatorUI}. * diff --git a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicProgressBarUI.java b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicProgressBarUI.java index a3b668115ee..dfcf4023ce0 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicProgressBarUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicProgressBarUI.java @@ -133,6 +133,11 @@ public class BasicProgressBarUI extends ProgressBarUI { private int maxPosition = 0; //maximum X (horiz) or Y box location + /** + * Constructs a {@code BasicProgressBarUI}. + */ + public BasicProgressBarUI() {} + /** * Returns a new instance of {@code BasicProgressBarUI}. * @@ -1288,6 +1293,11 @@ public class BasicProgressBarUI extends ProgressBarUI { * Instantiate it only within subclasses of {@code BasicProgressBarUI}. */ public class ChangeHandler implements ChangeListener { + /** + * Constructs a {@code ChangeHandler}. + */ + public ChangeHandler() {} + // NOTE: This class exists only for backward compatibility. All // its functionality has been moved into Handler. If you need to add // new functionality add it to the Handler, but make sure this diff --git a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicRadioButtonMenuItemUI.java b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicRadioButtonMenuItemUI.java index 2957543d367..c19c5d0a511 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicRadioButtonMenuItemUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicRadioButtonMenuItemUI.java @@ -39,6 +39,11 @@ import javax.swing.border.*; */ public class BasicRadioButtonMenuItemUI extends BasicMenuItemUI { + /** + * Constructs a {@code BasicRadioButtonMenuItemUI}. + */ + public BasicRadioButtonMenuItemUI() {} + /** * Returns a new instance of {@code BasicRadioButtonMenuItemUI}. * diff --git a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicRadioButtonUI.java b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicRadioButtonUI.java index 670cc124060..89edf4842ca 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicRadioButtonUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicRadioButtonUI.java @@ -61,6 +61,11 @@ public class BasicRadioButtonUI extends BasicToggleButtonUI // Create PLAF // ******************************** + /** + * Constructs a {@code BasicRadioButtonUI}. + */ + public BasicRadioButtonUI() {} + /** * Returns an instance of {@code BasicRadioButtonUI}. * diff --git a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicRootPaneUI.java b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicRootPaneUI.java index e42c25badba..3639f5cb180 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicRootPaneUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicRootPaneUI.java @@ -48,6 +48,11 @@ public class BasicRootPaneUI extends RootPaneUI implements PropertyChangeListener { private static RootPaneUI rootPaneUI = new BasicRootPaneUI(); + /** + * Constructs a {@code BasicRootPaneUI}. + */ + public BasicRootPaneUI() {} + /** * Returns a new instance of {@code BasicRootPaneUI}. * diff --git a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicScrollBarUI.java b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicScrollBarUI.java index d7f0b662faf..b63274d4836 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicScrollBarUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicScrollBarUI.java @@ -163,6 +163,11 @@ public class BasicScrollBarUI */ protected int decrGap; + /** + * Constructs a {@code BasicScrollBarUI}. + */ + public BasicScrollBarUI() {} + static void loadActionMap(LazyActionMap map) { map.put(new Actions(Actions.POSITIVE_UNIT_INCREMENT)); map.put(new Actions(Actions.POSITIVE_BLOCK_INCREMENT)); @@ -1645,6 +1650,11 @@ public class BasicScrollBarUI /** Property change handler */ public class PropertyChangeHandler implements PropertyChangeListener { + /** + * Constructs a {@code PropertyChangeHandler}. + */ + public PropertyChangeHandler() {} + // NOTE: This class exists only for backward compatibility. All // its functionality has been moved into Handler. If you need to add // new functionality add it to the Handler, but make sure this diff --git a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicScrollPaneUI.java b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicScrollPaneUI.java index 2a3df571977..7f80f4e51fa 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicScrollPaneUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicScrollPaneUI.java @@ -98,6 +98,11 @@ public class BasicScrollPaneUI */ private boolean setValueCalled = false; + /** + * Constructs a {@code BasicScrollPaneUI}. + */ + public BasicScrollPaneUI() {} + /** * Returns a new instance of {@code BasicScrollPaneUI}. * @@ -494,6 +499,10 @@ public class BasicScrollPaneUI */ public class ViewportChangeHandler implements ChangeListener { + /** + * Constructs a {@code ViewportChangeHandler}. + */ + public ViewportChangeHandler() {} // NOTE: This class exists only for backward compatibility. All // its functionality has been moved into Handler. If you need to add @@ -520,6 +529,10 @@ public class BasicScrollPaneUI */ public class HSBChangeListener implements ChangeListener { + /** + * Constructs a {@code HSBChangeListener}. + */ + public HSBChangeListener() {} // NOTE: This class exists only for backward compatibility. All // its functionality has been moved into Handler. If you need to add @@ -555,6 +568,10 @@ public class BasicScrollPaneUI */ public class VSBChangeListener implements ChangeListener { + /** + * Constructs a {@code VSBChangeListener}. + */ + public VSBChangeListener() {} // NOTE: This class exists only for backward compatibility. All // its functionality has been moved into Handler. If you need to add @@ -751,6 +768,10 @@ public class BasicScrollPaneUI */ public class PropertyChangeHandler implements PropertyChangeListener { + /** + * Constructs a {@code PropertyChangeHandler}. + */ + public PropertyChangeHandler() {} // NOTE: This class exists only for backward compatibility. All // its functionality has been moved into Handler. If you need to add diff --git a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicSeparatorUI.java b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicSeparatorUI.java index 8df41cb647a..0580765e1c0 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicSeparatorUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicSeparatorUI.java @@ -55,6 +55,11 @@ public class BasicSeparatorUI extends SeparatorUI */ protected Color highlight; + /** + * Constructs a {@code BasicSeparatorUI}. + */ + public BasicSeparatorUI() {} + /** * Returns a new instance of {@code BasicSeparatorUI}. * diff --git a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicSliderUI.java b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicSliderUI.java index 6cdfb4c1416..df4f0584272 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicSliderUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicSliderUI.java @@ -116,6 +116,11 @@ public class BasicSliderUI extends SliderUI{ */ private boolean sameLabelBaselines; + /** + * Constructs a {@code BasicSliderUI}. + */ + public BasicSliderUI() {} + /** * Returns the shadow color. * @return the shadow color @@ -918,6 +923,11 @@ public class BasicSliderUI extends SliderUI{ * A property change handler. */ public class PropertyChangeHandler implements PropertyChangeListener { + /** + * Constructs a {@code PropertyChangeHandler}. + */ + public PropertyChangeHandler() {} + // NOTE: This class exists only for backward compatibility. All // its functionality has been moved into Handler. If you need to add // new functionality add it to the Handler, but make sure this @@ -1863,6 +1873,11 @@ public class BasicSliderUI extends SliderUI{ * Instantiate it only within subclasses of Foo. */ public class ChangeHandler implements ChangeListener { + /** + * Constructs a {@code ChangeHandler}. + */ + public ChangeHandler() {} + // NOTE: This class exists only for backward compatibility. All // its functionality has been moved into Handler. If you need to add // new functionality add it to the Handler, but make sure this @@ -1889,6 +1904,11 @@ public class BasicSliderUI extends SliderUI{ /** Current mouse y. */ protected transient int currentMouseY; + /** + * Constructs a {@code TrackListener}. + */ + public TrackListener() {} + /** * {@inheritDoc} */ @@ -2200,6 +2220,11 @@ public class BasicSliderUI extends SliderUI{ * Instantiate it only within subclasses of Foo. */ public class ComponentHandler extends ComponentAdapter { + /** + * Constructs a {@code ComponentHandler}. + */ + public ComponentHandler() {} + // NOTE: This class exists only for backward compatibility. All // its functionality has been moved into Handler. If you need to add // new functionality add it to the Handler, but make sure this @@ -2216,6 +2241,11 @@ public class BasicSliderUI extends SliderUI{ * Instantiate it only within subclasses of Foo. */ public class FocusHandler implements FocusListener { + /** + * Constructs a {@code FocusHandler}. + */ + public FocusHandler() {} + // NOTE: This class exists only for backward compatibility. All // its functionality has been moved into Handler. If you need to add // new functionality add it to the Handler, but make sure this diff --git a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicSpinnerUI.java b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicSpinnerUI.java index b11b041c1a9..42202c5d1d4 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicSpinnerUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicSpinnerUI.java @@ -80,6 +80,10 @@ public class BasicSpinnerUI extends SpinnerUI */ private static final Dimension zeroSize = new Dimension(0, 0); + /** + * Constructs a {@code BasicSpinnerUI}. + */ + public BasicSpinnerUI() {} /** * Returns a new instance of BasicSpinnerUI. SpinnerListUI diff --git a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicSplitPaneUI.java b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicSplitPaneUI.java index 79a41312374..643c5419f74 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicSplitPaneUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicSplitPaneUI.java @@ -286,6 +286,10 @@ public class BasicSplitPaneUI extends SplitPaneUI /** If true, setDividerLocation does nothing. */ boolean ignoreDividerLocationChange; + /** + * Constructs a {@code BasicSplitPaneUI}. + */ + public BasicSplitPaneUI() {} /** * Creates a new instance of {@code BasicSplitPaneUI}. @@ -734,6 +738,11 @@ public class BasicSplitPaneUI extends SplitPaneUI */ public class FocusHandler extends FocusAdapter { + /** + * Constructs a {@code FocusHandler}. + */ + public FocusHandler() {} + // NOTE: This class exists only for backward compatibility. All // its functionality has been moved into Handler. If you need to add // new functionality add it to the Handler, but make sure this @@ -774,6 +783,11 @@ public class BasicSplitPaneUI extends SplitPaneUI */ public class KeyboardDownRightHandler implements ActionListener { + /** + * Constructs a {@code KeyboardDownRightHandler}. + */ + public KeyboardDownRightHandler() {} + public void actionPerformed(ActionEvent ev) { if (dividerKeyboardResize) { splitPane.setDividerLocation(getDividerLocation(splitPane) + @@ -792,6 +806,11 @@ public class BasicSplitPaneUI extends SplitPaneUI */ public class KeyboardHomeHandler implements ActionListener { + /** + * Constructs a {@code KeyboardHomeHandler}. + */ + public KeyboardHomeHandler() {} + public void actionPerformed(ActionEvent ev) { if (dividerKeyboardResize) { splitPane.setDividerLocation(0); @@ -809,6 +828,11 @@ public class BasicSplitPaneUI extends SplitPaneUI */ public class KeyboardEndHandler implements ActionListener { + /** + * Constructs a {@code KeyboardEndHandler}. + */ + public KeyboardEndHandler() {} + public void actionPerformed(ActionEvent ev) { if (dividerKeyboardResize) { Insets insets = splitPane.getInsets();