<Swing Dev> Review rquest for 7055065, NPE from JTable when quit editing with empty value in number culumns

Pavel Porvatov pavel.porvatov at oracle.com
Fri Apr 13 09:59:17 UTC 2012


Hi Jonathan,

The fix looks good. Could you please write an automatic test, put it 
into an appropriate place of repository and make a webrev with fix and test?

Regards, Pavel
> Hello swing-dev,
>
> I've got a patch for bug 7055065, can anybody please help to take a look?
> http://cr.openjdk.java.net/~luchsh/7055065/
>
> And also a simple test case for this issue here.
>
> /*
>  * Copyright (c) 2012 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.
>  */
>
> /*
>  * Portions Copyright (c) 2012 IBM Corporation
>  */
>
> import javax.swing.JFrame;
> import javax.swing.JPanel;
> import javax.swing.JScrollPane;
> import javax.swing.JTable;
> import javax.swing.table.AbstractTableModel;
> import javax.swing.table.TableModel;
> import javax.swing.table.TableRowSorter;
> import java.awt.Dimension;
> import java.awt.GridLayout;
>
> public class TableDemo extends JPanel {
>
>     public TableDemo() {
>         super(new GridLayout(1, 0));
>
>         final String[] columnNames = { "String", "Number" };
>         final Object[][] data = { { "aaaa", new Integer(5) },
>                 { "bbbb", new Integer(3) }, { "cccc", new Integer(2) },
>                 { "dddd", new Integer(20) }, { "eeee", new Integer(10) 
> } };
>         final JTable table = new JTable(data, columnNames);
>
>         table.setPreferredScrollableViewportSize(new Dimension(500, 
> 400));
>         table.setFillsViewportHeight(true);
>         TableModel dataModel = new AbstractTableModel() {
>
>             public int getColumnCount() {
>                 return columnNames.length;
>             }
>             public int getRowCount() {
>                 return data.length;
>             }
>             public Object getValueAt(int row, int col) {
>                 return data[row][col];
>             }
>             public String getColumnName(int column) {
>                 return columnNames[column];
>             }
>             public Class<?> getColumnClass(int c) {
>                 return getValueAt(0, c).getClass();
>             }
>             public boolean isCellEditable(int row, int col) {
>                 return col != 5;
>             }
>             public void setValueAt(Object aValue, int row, int column) {
>                 data[row][column] = aValue;
>             }
>         };
>         table.setModel(dataModel);
>         TableRowSorter<TableModel> sorter = new 
> TableRowSorter<TableModel>(
>                 dataModel);
>         table.setRowSorter(sorter);
>
>         JScrollPane scrollPane = new JScrollPane(table);
>         add(scrollPane);
>     }
>
>     public static void main(String[] args) throws Exception {
>         javax.swing.SwingUtilities.invokeAndWait(new Runnable() {
>             public void run() {
>                 JFrame frame = new JFrame("SimpleTableDemo");
>                 frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
>
>                 TableDemo newContentPane = new TableDemo();
>                 newContentPane.setOpaque(true);
>                 frame.setContentPane(newContentPane);
>
>                 frame.pack();
>                 frame.setVisible(true);
>             }
>         });
>     }
> }
>
> To reproduce the problem,
> please click on one cell from the "Number" column, delete all the 
> content but do not press enter to quit editing status, then click the 
> column title of "Number" column to sort, NPE will be thrown.
>
> The cause of this problem is when trying to quit editing with empty 
> content of a cell  and also try to accept the partially edited value 
> using stopCellEditing(), following two actions will be taken.
> 1, the cellEditor of current table will be set to null.
> 2, the value type of this column does not have a constructor to accept 
> "Object[]" parameter, false will be returned.
> Then swing will try to cancel edition without accepting the partially 
> edited value using cancelCellEditing() which will get null for the 
> value of cellEditor thus lead to this NPE.
>
> The patch is trying to return earlier before the type compatibility 
> check of partially edited values when empty cell values encountered.
>
> Cheers!
> - Jonathan
>




More information about the swing-dev mailing list