From 69c0df6b8f5f6b70d1162bb1950e486cc852c3dc Mon Sep 17 00:00:00 2001 From: Prasanta Sadhukhan Date: Mon, 17 Aug 2020 13:36:36 +0530 Subject: [PATCH] 8250849: Address reliance on default constructors in the javax.swing.plaf APIs Reviewed-by: prr, serb --- .../share/classes/javax/swing/plaf/ButtonUI.java | 4 ++++ .../share/classes/javax/swing/plaf/ColorChooserUI.java | 5 ++++- .../share/classes/javax/swing/plaf/ComboBoxUI.java | 5 +++++ .../share/classes/javax/swing/plaf/DesktopIconUI.java | 4 ++++ .../share/classes/javax/swing/plaf/DesktopPaneUI.java | 4 ++++ .../share/classes/javax/swing/plaf/FileChooserUI.java | 5 +++++ .../share/classes/javax/swing/plaf/InternalFrameUI.java | 4 ++++ .../share/classes/javax/swing/plaf/LabelUI.java | 5 +++++ .../share/classes/javax/swing/plaf/LayerUI.java | 5 +++++ .../share/classes/javax/swing/plaf/ListUI.java | 5 +++++ .../share/classes/javax/swing/plaf/MenuBarUI.java | 7 ++++++- .../share/classes/javax/swing/plaf/MenuItemUI.java | 4 ++++ .../share/classes/javax/swing/plaf/OptionPaneUI.java | 5 +++++ .../share/classes/javax/swing/plaf/PanelUI.java | 4 ++++ .../share/classes/javax/swing/plaf/PopupMenuUI.java | 5 +++++ .../share/classes/javax/swing/plaf/ProgressBarUI.java | 4 ++++ .../share/classes/javax/swing/plaf/RootPaneUI.java | 4 ++++ .../share/classes/javax/swing/plaf/ScrollBarUI.java | 4 ++++ .../share/classes/javax/swing/plaf/ScrollPaneUI.java | 4 ++++ .../share/classes/javax/swing/plaf/SeparatorUI.java | 4 ++++ .../share/classes/javax/swing/plaf/SliderUI.java | 4 ++++ .../share/classes/javax/swing/plaf/SpinnerUI.java | 4 ++++ .../share/classes/javax/swing/plaf/SplitPaneUI.java | 5 +++++ .../share/classes/javax/swing/plaf/TabbedPaneUI.java | 5 +++++ .../share/classes/javax/swing/plaf/TableHeaderUI.java | 4 ++++ .../share/classes/javax/swing/plaf/TableUI.java | 4 ++++ .../share/classes/javax/swing/plaf/TextUI.java | 5 +++++ .../share/classes/javax/swing/plaf/ToolBarUI.java | 4 ++++ .../share/classes/javax/swing/plaf/ToolTipUI.java | 4 ++++ .../share/classes/javax/swing/plaf/TreeUI.java | 5 +++++ .../share/classes/javax/swing/plaf/ViewportUI.java | 4 ++++ 31 files changed, 137 insertions(+), 2 deletions(-) diff --git a/src/java.desktop/share/classes/javax/swing/plaf/ButtonUI.java b/src/java.desktop/share/classes/javax/swing/plaf/ButtonUI.java index fb5d81b049b..6cc735dec7e 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/ButtonUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/ButtonUI.java @@ -36,4 +36,8 @@ import java.awt.Insets; * @author Jeff Dinkins */ public abstract class ButtonUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected ButtonUI() {} } diff --git a/src/java.desktop/share/classes/javax/swing/plaf/ColorChooserUI.java b/src/java.desktop/share/classes/javax/swing/plaf/ColorChooserUI.java index 0b0f5bff937..96c6aef2617 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/ColorChooserUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/ColorChooserUI.java @@ -37,5 +37,8 @@ import javax.swing.colorchooser.*; public abstract class ColorChooserUI extends ComponentUI { - + /** + * Constructor for subclasses to call. + */ + protected ColorChooserUI() {} } diff --git a/src/java.desktop/share/classes/javax/swing/plaf/ComboBoxUI.java b/src/java.desktop/share/classes/javax/swing/plaf/ComboBoxUI.java index 2ba9741c770..8ed5bcf7ed9 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/ComboBoxUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/ComboBoxUI.java @@ -35,6 +35,11 @@ import javax.swing.JComboBox; */ public abstract class ComboBoxUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected ComboBoxUI() {} + /** * Set the visibility of the popup * diff --git a/src/java.desktop/share/classes/javax/swing/plaf/DesktopIconUI.java b/src/java.desktop/share/classes/javax/swing/plaf/DesktopIconUI.java index 455ebb8aeb3..1b8ee136b93 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/DesktopIconUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/DesktopIconUI.java @@ -32,4 +32,8 @@ package javax.swing.plaf; * @author David Kloba */ public abstract class DesktopIconUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected DesktopIconUI() {} } diff --git a/src/java.desktop/share/classes/javax/swing/plaf/DesktopPaneUI.java b/src/java.desktop/share/classes/javax/swing/plaf/DesktopPaneUI.java index 19dce758a25..5af708e7659 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/DesktopPaneUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/DesktopPaneUI.java @@ -32,4 +32,8 @@ package javax.swing.plaf; * @author David Kloba */ public abstract class DesktopPaneUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected DesktopPaneUI() {} } diff --git a/src/java.desktop/share/classes/javax/swing/plaf/FileChooserUI.java b/src/java.desktop/share/classes/javax/swing/plaf/FileChooserUI.java index edd5fd9a45f..62ea29c89f4 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/FileChooserUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/FileChooserUI.java @@ -38,6 +38,11 @@ import java.io.File; public abstract class FileChooserUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected FileChooserUI() {} + /** * Returns an accept-all file filter. * @param fc the file chooser diff --git a/src/java.desktop/share/classes/javax/swing/plaf/InternalFrameUI.java b/src/java.desktop/share/classes/javax/swing/plaf/InternalFrameUI.java index 70509d6fbdd..b8e4f653a2d 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/InternalFrameUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/InternalFrameUI.java @@ -31,4 +31,8 @@ package javax.swing.plaf; * @author David Kloba */ public abstract class InternalFrameUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected InternalFrameUI() {} } diff --git a/src/java.desktop/share/classes/javax/swing/plaf/LabelUI.java b/src/java.desktop/share/classes/javax/swing/plaf/LabelUI.java index 4ed6692021c..b75c4bd4015 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/LabelUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/LabelUI.java @@ -31,4 +31,9 @@ package javax.swing.plaf; * @author Hans Muller */ public abstract class LabelUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected LabelUI() {} } + diff --git a/src/java.desktop/share/classes/javax/swing/plaf/LayerUI.java b/src/java.desktop/share/classes/javax/swing/plaf/LayerUI.java index 8ce8f4e1e51..61fad895c38 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/LayerUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/LayerUI.java @@ -65,6 +65,11 @@ public class LayerUI private final PropertyChangeSupport propertyChangeSupport = new PropertyChangeSupport(this); + /** + * Constructs a {@code LayerUI}. + */ + public LayerUI() {} + /** * Paints the specified component. * Subclasses should override this method and use diff --git a/src/java.desktop/share/classes/javax/swing/plaf/ListUI.java b/src/java.desktop/share/classes/javax/swing/plaf/ListUI.java index 46c1e4b6d75..ebf82ba53f2 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/ListUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/ListUI.java @@ -38,6 +38,11 @@ import java.awt.Rectangle; public abstract class ListUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected ListUI() {} + /** * Returns the cell index in the specified {@code JList} closest to the * given location in the list's coordinate system. To determine if the diff --git a/src/java.desktop/share/classes/javax/swing/plaf/MenuBarUI.java b/src/java.desktop/share/classes/javax/swing/plaf/MenuBarUI.java index 2119676d74b..c19e98f2981 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/MenuBarUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/MenuBarUI.java @@ -36,4 +36,9 @@ import javax.swing.JMenu; * @author David Karlton */ -public abstract class MenuBarUI extends ComponentUI { } +public abstract class MenuBarUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected MenuBarUI() {} +} diff --git a/src/java.desktop/share/classes/javax/swing/plaf/MenuItemUI.java b/src/java.desktop/share/classes/javax/swing/plaf/MenuItemUI.java index d0ffe22de07..869300b5959 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/MenuItemUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/MenuItemUI.java @@ -35,4 +35,8 @@ import java.awt.event.*; * @author Arnaud Weber */ public abstract class MenuItemUI extends ButtonUI { + /** + * Constructor for subclasses to call. + */ + protected MenuItemUI() {} } diff --git a/src/java.desktop/share/classes/javax/swing/plaf/OptionPaneUI.java b/src/java.desktop/share/classes/javax/swing/plaf/OptionPaneUI.java index fc967b84315..1a35b3e6a19 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/OptionPaneUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/OptionPaneUI.java @@ -35,6 +35,11 @@ import javax.swing.JOptionPane; public abstract class OptionPaneUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected OptionPaneUI() {} + /** * Requests the component representing the default value to have * focus. diff --git a/src/java.desktop/share/classes/javax/swing/plaf/PanelUI.java b/src/java.desktop/share/classes/javax/swing/plaf/PanelUI.java index 38b751fcb8a..f92bde46cba 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/PanelUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/PanelUI.java @@ -32,4 +32,8 @@ package javax.swing.plaf; * @author Steve Wilson */ public abstract class PanelUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected PanelUI() {} } diff --git a/src/java.desktop/share/classes/javax/swing/plaf/PopupMenuUI.java b/src/java.desktop/share/classes/javax/swing/plaf/PopupMenuUI.java index ab485a2c4ad..64b12b6e184 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/PopupMenuUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/PopupMenuUI.java @@ -38,6 +38,11 @@ import javax.swing.JPopupMenu; */ public abstract class PopupMenuUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected PopupMenuUI() {} + /** * Returns whether or not the given {@code MouseEvent} is the popup menu * trigger event for the platform diff --git a/src/java.desktop/share/classes/javax/swing/plaf/ProgressBarUI.java b/src/java.desktop/share/classes/javax/swing/plaf/ProgressBarUI.java index 5da378626aa..17e5dd68282 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/ProgressBarUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/ProgressBarUI.java @@ -32,4 +32,8 @@ package javax.swing.plaf; * @author Rob Davis */ public abstract class ProgressBarUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected ProgressBarUI() {} } diff --git a/src/java.desktop/share/classes/javax/swing/plaf/RootPaneUI.java b/src/java.desktop/share/classes/javax/swing/plaf/RootPaneUI.java index e7a13297820..f28ef5d33ed 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/RootPaneUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/RootPaneUI.java @@ -32,4 +32,8 @@ package javax.swing.plaf; * @since 1.3 */ public abstract class RootPaneUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected RootPaneUI() {} } diff --git a/src/java.desktop/share/classes/javax/swing/plaf/ScrollBarUI.java b/src/java.desktop/share/classes/javax/swing/plaf/ScrollBarUI.java index 9a8f08aec10..cb713f97364 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/ScrollBarUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/ScrollBarUI.java @@ -31,4 +31,8 @@ package javax.swing.plaf; * @author David Kloba */ public abstract class ScrollBarUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected ScrollBarUI() {} } diff --git a/src/java.desktop/share/classes/javax/swing/plaf/ScrollPaneUI.java b/src/java.desktop/share/classes/javax/swing/plaf/ScrollPaneUI.java index 7d0c88ccf42..527fc31ca41 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/ScrollPaneUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/ScrollPaneUI.java @@ -33,4 +33,8 @@ package javax.swing.plaf; */ public abstract class ScrollPaneUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected ScrollPaneUI() {} } diff --git a/src/java.desktop/share/classes/javax/swing/plaf/SeparatorUI.java b/src/java.desktop/share/classes/javax/swing/plaf/SeparatorUI.java index 2fb7109d086..2d6745d43dc 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/SeparatorUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/SeparatorUI.java @@ -33,4 +33,8 @@ package javax.swing.plaf; */ public abstract class SeparatorUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected SeparatorUI() {} } diff --git a/src/java.desktop/share/classes/javax/swing/plaf/SliderUI.java b/src/java.desktop/share/classes/javax/swing/plaf/SliderUI.java index d5bcccc1454..8820df95d4d 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/SliderUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/SliderUI.java @@ -31,4 +31,8 @@ package javax.swing.plaf; * @author Hans Muller */ public abstract class SliderUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected SliderUI() {} } diff --git a/src/java.desktop/share/classes/javax/swing/plaf/SpinnerUI.java b/src/java.desktop/share/classes/javax/swing/plaf/SpinnerUI.java index f2df9e31838..b40f4601dc9 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/SpinnerUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/SpinnerUI.java @@ -33,4 +33,8 @@ package javax.swing.plaf; * @since 1.4 */ public abstract class SpinnerUI extends javax.swing.plaf.ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected SpinnerUI() {} } diff --git a/src/java.desktop/share/classes/javax/swing/plaf/SplitPaneUI.java b/src/java.desktop/share/classes/javax/swing/plaf/SplitPaneUI.java index 15afcee9a0d..d0115f60b49 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/SplitPaneUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/SplitPaneUI.java @@ -35,6 +35,11 @@ import java.awt.Graphics; */ public abstract class SplitPaneUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected SplitPaneUI() {} + /** * Messaged to relayout the JSplitPane based on the preferred size * of the children components. diff --git a/src/java.desktop/share/classes/javax/swing/plaf/TabbedPaneUI.java b/src/java.desktop/share/classes/javax/swing/plaf/TabbedPaneUI.java index bfbd0ab6c98..7c2f543bf7f 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/TabbedPaneUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/TabbedPaneUI.java @@ -35,6 +35,11 @@ import javax.swing.JTabbedPane; * @author Amy Fowler */ public abstract class TabbedPaneUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected TabbedPaneUI() {} + /** * Returns the tab for the coordinate. * @param pane the pane diff --git a/src/java.desktop/share/classes/javax/swing/plaf/TableHeaderUI.java b/src/java.desktop/share/classes/javax/swing/plaf/TableHeaderUI.java index 8e391e5e78c..e10998c6e4a 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/TableHeaderUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/TableHeaderUI.java @@ -31,4 +31,8 @@ package javax.swing.plaf; * @author Alan Chung */ public abstract class TableHeaderUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected TableHeaderUI() {} } diff --git a/src/java.desktop/share/classes/javax/swing/plaf/TableUI.java b/src/java.desktop/share/classes/javax/swing/plaf/TableUI.java index 6e5b75db5c1..83246b2e5c8 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/TableUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/TableUI.java @@ -31,4 +31,8 @@ package javax.swing.plaf; * @author Alan Chung */ public abstract class TableUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected TableUI() {} } diff --git a/src/java.desktop/share/classes/javax/swing/plaf/TextUI.java b/src/java.desktop/share/classes/javax/swing/plaf/TextUI.java index 66d215b92b2..cba6691ba58 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/TextUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/TextUI.java @@ -37,6 +37,11 @@ import javax.swing.text.*; */ public abstract class TextUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected TextUI() {} + /** * Converts the given location in the model to a place in * the view coordinate system. diff --git a/src/java.desktop/share/classes/javax/swing/plaf/ToolBarUI.java b/src/java.desktop/share/classes/javax/swing/plaf/ToolBarUI.java index 7aff46f4300..45dc4af016c 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/ToolBarUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/ToolBarUI.java @@ -35,4 +35,8 @@ import javax.swing.JToolBar; */ public abstract class ToolBarUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected ToolBarUI() {} } diff --git a/src/java.desktop/share/classes/javax/swing/plaf/ToolTipUI.java b/src/java.desktop/share/classes/javax/swing/plaf/ToolTipUI.java index 76660cf6849..a9073b909b6 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/ToolTipUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/ToolTipUI.java @@ -31,4 +31,8 @@ package javax.swing.plaf; * @author Dave Moore */ public abstract class ToolTipUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected ToolTipUI() {} } diff --git a/src/java.desktop/share/classes/javax/swing/plaf/TreeUI.java b/src/java.desktop/share/classes/javax/swing/plaf/TreeUI.java index 5968b335402..22e8a10052b 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/TreeUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/TreeUI.java @@ -37,6 +37,11 @@ import javax.swing.tree.TreePath; */ public abstract class TreeUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected TreeUI() {} + /** * Returns the Rectangle enclosing the label portion that the * last item in path will be drawn into. Will return null if diff --git a/src/java.desktop/share/classes/javax/swing/plaf/ViewportUI.java b/src/java.desktop/share/classes/javax/swing/plaf/ViewportUI.java index 826028d63cd..c31e4fc6b1e 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/ViewportUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/ViewportUI.java @@ -32,4 +32,8 @@ package javax.swing.plaf; * @author Rich Schiavi */ public abstract class ViewportUI extends ComponentUI { + /** + * Constructor for subclasses to call. + */ + protected ViewportUI() {} }