8013442: No file filter selected in file type combo box when using JFileChooser
Reviewed-by: alexsch
This commit is contained in:
parent
153bde4dbb
commit
f94d68550a
@ -1146,10 +1146,26 @@ public class JFileChooser extends JComponent implements Accessible {
|
|||||||
* @see #resetChoosableFileFilters
|
* @see #resetChoosableFileFilters
|
||||||
*/
|
*/
|
||||||
public boolean removeChoosableFileFilter(FileFilter f) {
|
public boolean removeChoosableFileFilter(FileFilter f) {
|
||||||
if(filters.contains(f)) {
|
int index = filters.indexOf(f);
|
||||||
|
if (index >= 0) {
|
||||||
if(getFileFilter() == f) {
|
if(getFileFilter() == f) {
|
||||||
|
if (isAcceptAllFileFilterUsed()) {
|
||||||
|
// choose default filter if it is used
|
||||||
|
setFileFilter(getAcceptAllFileFilter());
|
||||||
|
}
|
||||||
|
else if (index > 0) {
|
||||||
|
// choose the first filter, because it is not removed
|
||||||
|
setFileFilter(filters.get(0));
|
||||||
|
}
|
||||||
|
else if (filters.size() > 1) {
|
||||||
|
// choose the second filter, because the first one is removed
|
||||||
|
setFileFilter(filters.get(1));
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// no more filters
|
||||||
setFileFilter(null);
|
setFileFilter(null);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
FileFilter[] oldValue = getChoosableFileFilters();
|
FileFilter[] oldValue = getChoosableFileFilters();
|
||||||
filters.removeElement(f);
|
filters.removeElement(f);
|
||||||
firePropertyChange(CHOOSABLE_FILE_FILTER_CHANGED_PROPERTY, oldValue, getChoosableFileFilters());
|
firePropertyChange(CHOOSABLE_FILE_FILTER_CHANGED_PROPERTY, oldValue, getChoosableFileFilters());
|
||||||
|
122
jdk/test/javax/swing/JFileChooser/8013442/Test8013442.java
Normal file
122
jdk/test/javax/swing/JFileChooser/8013442/Test8013442.java
Normal file
@ -0,0 +1,122 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2013, 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
|
||||||
|
* 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 Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
* @bug 8013442
|
||||||
|
* @summary Tests that at least one file filter is selected
|
||||||
|
* @author Sergey Malenkov
|
||||||
|
*/
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.util.concurrent.CountDownLatch;
|
||||||
|
import javax.swing.JFileChooser;
|
||||||
|
import javax.swing.JFrame;
|
||||||
|
import javax.swing.SwingUtilities;
|
||||||
|
import javax.swing.UIManager;
|
||||||
|
import javax.swing.UIManager.LookAndFeelInfo;
|
||||||
|
import javax.swing.filechooser.FileFilter;
|
||||||
|
|
||||||
|
public class Test8013442 extends FileFilter implements Runnable, Thread.UncaughtExceptionHandler {
|
||||||
|
private static final CountDownLatch LATCH = new CountDownLatch(1);
|
||||||
|
|
||||||
|
public static void main(String[] args) throws InterruptedException {
|
||||||
|
SwingUtilities.invokeLater(new Test8013442());
|
||||||
|
LATCH.await(); // workaround for jtreg
|
||||||
|
}
|
||||||
|
|
||||||
|
private int index;
|
||||||
|
private LookAndFeelInfo[] infos;
|
||||||
|
private JFileChooser chooser;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean accept(File file) {
|
||||||
|
return !file.isFile() || file.getName().toLowerCase().endsWith(".txt");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getDescription() {
|
||||||
|
return "Text files";
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
if (this.infos == null) {
|
||||||
|
this.infos = UIManager.getInstalledLookAndFeels();
|
||||||
|
Thread.currentThread().setUncaughtExceptionHandler(this);
|
||||||
|
}
|
||||||
|
if (this.infos.length == this.index) {
|
||||||
|
LATCH.countDown(); // release main thread
|
||||||
|
} else if (this.chooser == null) {
|
||||||
|
// change LaF before creation of Swing components
|
||||||
|
LookAndFeelInfo info = this.infos[this.index];
|
||||||
|
System.out.println(info.getName());
|
||||||
|
try {
|
||||||
|
UIManager.setLookAndFeel(info.getClassName());
|
||||||
|
}
|
||||||
|
catch (Exception exception) {
|
||||||
|
throw new Error("could not change look and feel", exception);
|
||||||
|
}
|
||||||
|
// create and show new file chooser
|
||||||
|
JFrame frame = new JFrame(getClass().getSimpleName());
|
||||||
|
frame.add(this.chooser = new JFileChooser());
|
||||||
|
frame.setSize(800, 600);
|
||||||
|
frame.setLocationRelativeTo(null);
|
||||||
|
frame.setVisible(true);
|
||||||
|
SwingUtilities.invokeLater(this);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
int count = this.chooser.getChoosableFileFilters().length;
|
||||||
|
System.out.println("count = " + count + "; " + this.chooser.isAcceptAllFileFilterUsed());
|
||||||
|
if (count == 0) {
|
||||||
|
if (null != this.chooser.getFileFilter()) {
|
||||||
|
throw new Error("file filter is selected");
|
||||||
|
}
|
||||||
|
// close window and stop testing file chooser for current LaF
|
||||||
|
SwingUtilities.getWindowAncestor(this.chooser).dispose();
|
||||||
|
this.chooser = null;
|
||||||
|
this.index++;
|
||||||
|
} else {
|
||||||
|
if (null == this.chooser.getFileFilter()) {
|
||||||
|
throw new Error("file filter is not selected");
|
||||||
|
}
|
||||||
|
if (count == 2) {
|
||||||
|
// remove default file filter
|
||||||
|
this.chooser.setAcceptAllFileFilterUsed(false);
|
||||||
|
} else if (this.chooser.isAcceptAllFileFilterUsed()) {
|
||||||
|
// remove add file filter
|
||||||
|
this.chooser.addChoosableFileFilter(this);
|
||||||
|
} else {
|
||||||
|
// remove custom file filter
|
||||||
|
this.chooser.removeChoosableFileFilter(this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
SwingUtilities.invokeLater(this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void uncaughtException(Thread thread, Throwable throwable) {
|
||||||
|
throwable.printStackTrace();
|
||||||
|
System.exit(1);
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user