mirror of
https://github.com/openjdk/jdk.git
synced 2026-02-24 09:10:08 +00:00
6794836: BasicSliderUI throws NullPointerExc when JSlider maximum is Integer.MAX_VALUE
Reviewed-by: peterz
This commit is contained in:
parent
d36d789593
commit
798600a691
@ -836,18 +836,24 @@ public class BasicSliderUI extends SliderUI{
|
||||
*/
|
||||
protected Integer getHighestValue() {
|
||||
Dictionary dictionary = slider.getLabelTable();
|
||||
if (dictionary != null) {
|
||||
Enumeration keys = dictionary.keys();
|
||||
int max = slider.getMinimum() - 1;
|
||||
while (keys.hasMoreElements()) {
|
||||
max = Math.max(max, ((Integer)keys.nextElement()).intValue());
|
||||
}
|
||||
if (max == slider.getMinimum() - 1) {
|
||||
return null;
|
||||
}
|
||||
return max;
|
||||
|
||||
if (dictionary == null) {
|
||||
return null;
|
||||
}
|
||||
return null;
|
||||
|
||||
Enumeration keys = dictionary.keys();
|
||||
|
||||
Integer max = null;
|
||||
|
||||
while (keys.hasMoreElements()) {
|
||||
Integer i = (Integer) keys.nextElement();
|
||||
|
||||
if (max == null || i > max) {
|
||||
max = i;
|
||||
}
|
||||
}
|
||||
|
||||
return max;
|
||||
}
|
||||
|
||||
/**
|
||||
@ -859,18 +865,24 @@ public class BasicSliderUI extends SliderUI{
|
||||
*/
|
||||
protected Integer getLowestValue() {
|
||||
Dictionary dictionary = slider.getLabelTable();
|
||||
if (dictionary != null) {
|
||||
Enumeration keys = dictionary.keys();
|
||||
int min = slider.getMaximum() + 1;
|
||||
while (keys.hasMoreElements()) {
|
||||
min = Math.min(min, ((Integer)keys.nextElement()).intValue());
|
||||
}
|
||||
if (min == slider.getMaximum() + 1) {
|
||||
return null;
|
||||
}
|
||||
return min;
|
||||
|
||||
if (dictionary == null) {
|
||||
return null;
|
||||
}
|
||||
return null;
|
||||
|
||||
Enumeration keys = dictionary.keys();
|
||||
|
||||
Integer min = null;
|
||||
|
||||
while (keys.hasMoreElements()) {
|
||||
Integer i = (Integer) keys.nextElement();
|
||||
|
||||
if (min == null || i < min) {
|
||||
min = i;
|
||||
}
|
||||
}
|
||||
|
||||
return min;
|
||||
}
|
||||
|
||||
|
||||
|
||||
80
jdk/test/javax/swing/JSlider/6794836/bug6794836.java
Normal file
80
jdk/test/javax/swing/JSlider/6794836/bug6794836.java
Normal file
@ -0,0 +1,80 @@
|
||||
/*
|
||||
* Copyright 2009 Sun Microsystems, Inc. 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
|
||||
* under the terms of the GNU General Public License version 2 only, as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
* version 2 for more details (a copy is included in the LICENSE file that
|
||||
* accompanied this code).
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License version
|
||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
|
||||
* CA 95054 USA or visit www.sun.com if you need additional information or
|
||||
* have any questions.
|
||||
*/
|
||||
|
||||
/* @test
|
||||
* @bug 6794836
|
||||
* @summary BasicSliderUI throws NullPointerExc when JSlider maximum is Integer.MAX_VALUE
|
||||
* @author Pavel Porvatov
|
||||
* @run main bug6794836
|
||||
*/
|
||||
|
||||
import javax.swing.*;
|
||||
import javax.swing.plaf.basic.BasicSliderUI;
|
||||
import java.lang.reflect.Method;
|
||||
import java.util.Hashtable;
|
||||
|
||||
public class bug6794836 {
|
||||
public static void main(String[] args) throws Exception {
|
||||
new bug6794836().run();
|
||||
}
|
||||
|
||||
public void run() throws Exception {
|
||||
JSlider slider = new JSlider(0, Integer.MAX_VALUE);
|
||||
|
||||
slider.setPaintLabels(true);
|
||||
|
||||
JLabel minLabel = new JLabel("Min");
|
||||
JLabel maxLabel = new JLabel("Max");
|
||||
|
||||
Hashtable<Integer, JLabel> labelTable = new Hashtable<Integer, JLabel>();
|
||||
|
||||
labelTable.put(Integer.MIN_VALUE, minLabel);
|
||||
labelTable.put(Integer.MAX_VALUE, maxLabel);
|
||||
|
||||
slider.setLabelTable(labelTable);
|
||||
|
||||
BasicSliderUI ui = (BasicSliderUI) slider.getUI();
|
||||
|
||||
if (invokeMethod("getHighestValueLabel", ui) != maxLabel) {
|
||||
fail("invalid getHighestValueLabel result");
|
||||
}
|
||||
|
||||
if (invokeMethod("getLowestValueLabel", ui) != minLabel) {
|
||||
fail("invalid getLowestValueLabel result");
|
||||
}
|
||||
|
||||
System.out.println("The bug6794836 test passed");
|
||||
}
|
||||
|
||||
private static Object invokeMethod(String name, BasicSliderUI ui) throws Exception {
|
||||
Method method = BasicSliderUI.class.getDeclaredMethod(name, null);
|
||||
|
||||
method.setAccessible(true);
|
||||
|
||||
return method.invoke(ui, null);
|
||||
}
|
||||
|
||||
private static void fail(String s) {
|
||||
throw new RuntimeException("Test failed: " + s);
|
||||
}
|
||||
}
|
||||
Loading…
x
Reference in New Issue
Block a user