提交 3e28ab1d 编写于 作者: E emcmanus

Merge

...@@ -44,3 +44,4 @@ build.jdk.version = 1.7.0 ...@@ -44,3 +44,4 @@ build.jdk.version = 1.7.0
build.release = ${build.jdk.version}-opensource build.release = ${build.jdk.version}-opensource
build.number = b00 build.number = b00
jconsole.version = ${build.release}-${user.name}-${build.number} jconsole.version = ${build.release}-${user.name}-${build.number}
jconsole.args = -debug
...@@ -30,9 +30,9 @@ ...@@ -30,9 +30,9 @@
--> -->
<project name="jconsole" default="build" basedir="."> <project name="jconsole" default="build" basedir=".">
<import file="../common/shared.xml"/> <import file="../common/shared.xml"/>
<target name="-pre-compile"> <target name="-pre-compile">
<copy <copy
file="${root}/src/share/classes/sun/tools/jconsole/Version-template.java" file="${root}/src/share/classes/sun/tools/jconsole/Version-template.java"
...@@ -42,7 +42,7 @@ ...@@ -42,7 +42,7 @@
token="@@jconsole_version@@" token="@@jconsole_version@@"
value="${jconsole.version}"/> value="${jconsole.version}"/>
</target> </target>
<target name="-post-compile"> <target name="-post-compile">
<mkdir dir="${dist.dir}/lib"/> <mkdir dir="${dist.dir}/lib"/>
<jar destfile="${dist.dir}/lib/jconsole.jar" <jar destfile="${dist.dir}/lib/jconsole.jar"
...@@ -55,18 +55,19 @@ ...@@ -55,18 +55,19 @@
</fileset> </fileset>
</jar> </jar>
</target> </target>
<target name="run" depends="-init,build"> <target name="run" depends="-init,build">
<property name="jvm.args" value=""/> <property name="jvm.args" value=""/>
<java classname="sun.tools.jconsole.JConsole" <java classname="sun.tools.jconsole.JConsole"
fork="true" fork="true"
classpath="${classes.dir}:${bootstrap.jdk}/lib/tools.jar"> classpath="${classes.dir}:${bootstrap.jdk}/lib/tools.jar">
<jvmarg line="${jvm.args}"/> <jvmarg line="${jvm.args}"/>
<arg line="${jconsole.args}"/>
</java> </java>
</target> </target>
<target name="clean" depends="-init,shared.clean"> <target name="clean" depends="-init,shared.clean">
<delete file="${dist.dir}/lib/jconsole.jar"/> <delete file="${dist.dir}/lib/jconsole.jar"/>
</target> </target>
</project> </project>
...@@ -25,71 +25,78 @@ ...@@ -25,71 +25,78 @@
package sun.tools.jconsole.inspector; package sun.tools.jconsole.inspector;
import java.util.*;
import java.awt.event.*;
import javax.swing.table.*;
import javax.swing.event.*;
// Imports for picking up mouse events from the JTable. // Imports for picking up mouse events from the JTable.
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent; import java.awt.event.MouseEvent;
import java.awt.event.InputEvent; import java.awt.event.MouseListener;
import java.util.Vector;
import javax.swing.JTable; import javax.swing.JTable;
import javax.swing.event.TableModelEvent;
import javax.swing.event.TableModelListener;
import javax.swing.table.DefaultTableModel;
import javax.swing.table.JTableHeader; import javax.swing.table.JTableHeader;
import javax.swing.table.TableColumnModel; import javax.swing.table.TableColumnModel;
import sun.tools.jconsole.JConsole;
@SuppressWarnings("serial") @SuppressWarnings("serial")
public class TableSorter extends DefaultTableModel implements MouseListener { public class TableSorter extends DefaultTableModel implements MouseListener {
private boolean ascending = true; private boolean ascending = true;
private TableColumnModel columnModel; private TableColumnModel columnModel;
private JTable tableView; private JTable tableView;
private Vector<TableModelListener> listenerList; private Vector<TableModelListener> evtListenerList;
private int sortColumn = 0; private int sortColumn = 0;
private int[] invertedIndex; private int[] invertedIndex;
public TableSorter() { public TableSorter() {
super(); super();
listenerList = new Vector<TableModelListener>(); evtListenerList = new Vector<TableModelListener>();
} }
public TableSorter(Object[] columnNames, int numRows) { public TableSorter(Object[] columnNames, int numRows) {
super(columnNames,numRows); super(columnNames,numRows);
listenerList = new Vector<TableModelListener>(); evtListenerList = new Vector<TableModelListener>();
} }
@Override
public void newDataAvailable(TableModelEvent e) { public void newDataAvailable(TableModelEvent e) {
super.newDataAvailable(e); super.newDataAvailable(e);
invertedIndex = new int[getRowCount()]; invertedIndex = new int[getRowCount()];
for (int i=0;i<invertedIndex.length;i++) { for (int i = 0; i < invertedIndex.length; i++) {
invertedIndex[i] = i; invertedIndex[i] = i;
} }
sort(this.sortColumn); sort(this.sortColumn, this.ascending);
} }
@Override
public void addTableModelListener(TableModelListener l) { public void addTableModelListener(TableModelListener l) {
listenerList.add(l); evtListenerList.add(l);
super.addTableModelListener(l); super.addTableModelListener(l);
} }
@Override
public void removeTableModelListener(TableModelListener l) { public void removeTableModelListener(TableModelListener l) {
listenerList.remove(l); evtListenerList.remove(l);
super.removeTableModelListener(l); super.removeTableModelListener(l);
} }
private void removeListeners() { private void removeListeners() {
for(TableModelListener tnl : listenerList) for(TableModelListener tnl : evtListenerList)
super.removeTableModelListener(tnl); super.removeTableModelListener(tnl);
} }
private void restoreListeners() { private void restoreListeners() {
for(TableModelListener tnl : listenerList) for(TableModelListener tnl : evtListenerList)
super.addTableModelListener(tnl); super.addTableModelListener(tnl);
} }
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
public int compare(Object o1, Object o2) { private int compare(Object o1, Object o2) {
// take care of the case where both o1 & o2 are null. Needed to keep
// the method symetric. Without this quickSort gives surprising results.
if (o1 == o2)
return 0;
if (o1==null) if (o1==null)
return 1; return 1;
if (o2==null) if (o2==null)
...@@ -104,18 +111,40 @@ public class TableSorter extends DefaultTableModel implements MouseListener { ...@@ -104,18 +111,40 @@ public class TableSorter extends DefaultTableModel implements MouseListener {
} }
} }
public void sort(int column) { private void sort(int column, boolean isAscending) {
final XMBeanAttributes attrs =
(tableView instanceof XMBeanAttributes)
?(XMBeanAttributes) tableView
:null;
// We cannot sort rows when a cell is being
// edited - so we're going to cancel cell editing here if needed.
// This might happen when the user is editing a row, and clicks on
// another row without validating. In that case there are two events
// that compete: one is the validation of the value that was previously
// edited, the other is the mouse click that opens the new editor.
//
// When we reach here the previous value is already validated, and the
// old editor is closed, but the new editor might have opened.
// It's this new editor that wil be cancelled here, if needed.
//
if (attrs != null && attrs.isEditing())
attrs.cancelCellEditing();
// remove registered listeners // remove registered listeners
removeListeners(); removeListeners();
// do the sort // do the sort
//n2sort(column);
quickSort(0,getRowCount()-1,column); if (JConsole.isDebug()) {
System.err.println("sorting table against column="+column
+" ascending="+isAscending);
}
quickSort(0,getRowCount()-1,column,isAscending);
// restore registered listeners // restore registered listeners
restoreListeners(); restoreListeners();
this.sortColumn = column;
// update row heights in XMBeanAttributes (required by expandable cells) // update row heights in XMBeanAttributes (required by expandable cells)
if (tableView instanceof XMBeanAttributes) { if (attrs != null) {
XMBeanAttributes attrs = (XMBeanAttributes) tableView;
for (int i = 0; i < getRowCount(); i++) { for (int i = 0; i < getRowCount(); i++) {
Vector data = (Vector) dataVector.elementAt(i); Vector data = (Vector) dataVector.elementAt(i);
attrs.updateRowHeight(data.elementAt(1), i); attrs.updateRowHeight(data.elementAt(1), i);
...@@ -123,21 +152,21 @@ public class TableSorter extends DefaultTableModel implements MouseListener { ...@@ -123,21 +152,21 @@ public class TableSorter extends DefaultTableModel implements MouseListener {
} }
} }
private synchronized boolean compareS(Object s1, Object s2) { private boolean compareS(Object s1, Object s2, boolean isAscending) {
if (ascending) if (isAscending)
return (compare(s1,s2) > 0); return (compare(s1,s2) > 0);
else else
return (compare(s1,s2) < 0); return (compare(s1,s2) < 0);
} }
private synchronized boolean compareG(Object s1, Object s2) { private boolean compareG(Object s1, Object s2, boolean isAscending) {
if (ascending) if (isAscending)
return (compare(s1,s2) < 0); return (compare(s1,s2) < 0);
else else
return (compare(s1,s2) > 0); return (compare(s1,s2) > 0);
} }
private synchronized void quickSort(int lo0,int hi0, int key) { private void quickSort(int lo0,int hi0, int key, boolean isAscending) {
int lo = lo0; int lo = lo0;
int hi = hi0; int hi = hi0;
Object mid; Object mid;
...@@ -153,14 +182,14 @@ public class TableSorter extends DefaultTableModel implements MouseListener { ...@@ -153,14 +182,14 @@ public class TableSorter extends DefaultTableModel implements MouseListener {
* from the left Index. * from the left Index.
*/ */
while( ( lo < hi0 ) && while( ( lo < hi0 ) &&
( compareS(mid,getValueAt(lo,key)) )) ( compareS(mid,getValueAt(lo,key), isAscending) ))
++lo; ++lo;
/* find an element that is smaller than or equal to /* find an element that is smaller than or equal to
* the partition element starting from the right Index. * the partition element starting from the right Index.
*/ */
while( ( hi > lo0 ) && while( ( hi > lo0 ) &&
( compareG(mid,getValueAt(hi,key)) )) ( compareG(mid,getValueAt(hi,key), isAscending) ))
--hi; --hi;
// if the indexes have not crossed, swap // if the indexes have not crossed, swap
...@@ -177,27 +206,17 @@ public class TableSorter extends DefaultTableModel implements MouseListener { ...@@ -177,27 +206,17 @@ public class TableSorter extends DefaultTableModel implements MouseListener {
* must now sort the left partition. * must now sort the left partition.
*/ */
if( lo0 < hi ) if( lo0 < hi )
quickSort(lo0, hi , key); quickSort(lo0, hi , key, isAscending);
/* If the left index has not reached the right /* If the left index has not reached the right
* side of array * side of array
* must now sort the right partition. * must now sort the right partition.
*/ */
if( lo <= hi0 ) if( lo <= hi0 )
quickSort(lo, hi0 , key); quickSort(lo, hi0 , key, isAscending);
} }
} }
public void n2sort(int column) {
for (int i = 0; i < getRowCount(); i++) {
for (int j = i+1; j < getRowCount(); j++) {
if (compare(getValueAt(i,column),getValueAt(j,column)) == -1) {
swap(i, j, column);
}
}
}
}
private Vector getRow(int row) { private Vector getRow(int row) {
return (Vector) dataVector.elementAt(row); return (Vector) dataVector.elementAt(row);
} }
...@@ -207,7 +226,7 @@ public class TableSorter extends DefaultTableModel implements MouseListener { ...@@ -207,7 +226,7 @@ public class TableSorter extends DefaultTableModel implements MouseListener {
dataVector.setElementAt(data,row); dataVector.setElementAt(data,row);
} }
public void swap(int i, int j, int column) { private void swap(int i, int j, int column) {
Vector data = getRow(i); Vector data = getRow(i);
setRow(getRow(j),i); setRow(getRow(j),i);
setRow(data,j); setRow(data,j);
...@@ -223,11 +242,12 @@ public class TableSorter extends DefaultTableModel implements MouseListener { ...@@ -223,11 +242,12 @@ public class TableSorter extends DefaultTableModel implements MouseListener {
public void sortByColumn(int column, boolean ascending) { public void sortByColumn(int column, boolean ascending) {
this.ascending = ascending; this.ascending = ascending;
sort(column); this.sortColumn = column;
sort(column,ascending);
} }
public int[] getInvertedIndex() { public int getIndexOfRow(int row) {
return invertedIndex; return invertedIndex[row];
} }
// Add a mouse listener to the Table to trigger a table sort // Add a mouse listener to the Table to trigger a table sort
...@@ -243,6 +263,14 @@ public class TableSorter extends DefaultTableModel implements MouseListener { ...@@ -243,6 +263,14 @@ public class TableSorter extends DefaultTableModel implements MouseListener {
int viewColumn = columnModel.getColumnIndexAtX(e.getX()); int viewColumn = columnModel.getColumnIndexAtX(e.getX());
int column = tableView.convertColumnIndexToModel(viewColumn); int column = tableView.convertColumnIndexToModel(viewColumn);
if (e.getClickCount() == 1 && column != -1) { if (e.getClickCount() == 1 && column != -1) {
if (tableView instanceof XTable) {
XTable attrs = (XTable) tableView;
// inform the table view that the rows are going to be sorted
// against the values in a given column. This gives the
// chance to the table view to close its editor - if needed.
//
attrs.sortRequested(column);
}
tableView.invalidate(); tableView.invalidate();
sortByColumn(column); sortByColumn(column);
tableView.validate(); tableView.validate();
......
...@@ -37,6 +37,7 @@ public class XPlotter extends Plotter { ...@@ -37,6 +37,7 @@ public class XPlotter extends Plotter {
super(unit); super(unit);
this.table = table; this.table = table;
} }
@Override
public void addValues(long time, long... values) { public void addValues(long time, long... values) {
super.addValues(time, values); super.addValues(time, values);
table.repaint(); table.repaint();
......
...@@ -25,18 +25,39 @@ ...@@ -25,18 +25,39 @@
package sun.tools.jconsole.inspector; package sun.tools.jconsole.inspector;
import java.awt.*;
import java.awt.event.*; import java.awt.BorderLayout;
import java.io.*; import java.awt.Color;
import javax.management.*; import java.awt.Component;
import javax.swing.*; import java.awt.Dimension;
import javax.swing.border.*; import java.awt.event.ActionEvent;
import javax.swing.tree.*; import java.awt.event.ActionListener;
import java.io.IOException;
import javax.management.IntrospectionException;
import javax.management.NotificationListener;
import javax.management.MBeanInfo;
import javax.management.InstanceNotFoundException;
import javax.management.ReflectionException;
import javax.management.MBeanAttributeInfo;
import javax.management.MBeanOperationInfo;
import javax.management.MBeanNotificationInfo;
import javax.management.Notification;
import javax.swing.BorderFactory;
import javax.swing.JButton;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTextArea;
import javax.swing.SwingWorker;
import javax.swing.border.LineBorder;
import javax.swing.tree.DefaultMutableTreeNode;
import javax.swing.tree.DefaultTreeModel;
import sun.tools.jconsole.*; import sun.tools.jconsole.*;
import sun.tools.jconsole.inspector.XNodeInfo.Type; import sun.tools.jconsole.inspector.XNodeInfo.Type;
import static sun.tools.jconsole.Resources.*; import static sun.tools.jconsole.Resources.*;
import static sun.tools.jconsole.Utilities.*;
@SuppressWarnings("serial") @SuppressWarnings("serial")
public class XSheet extends JPanel public class XSheet extends JPanel
...@@ -344,34 +365,41 @@ public class XSheet extends JPanel ...@@ -344,34 +365,41 @@ public class XSheet extends JPanel
return; return;
} }
mbean = (XMBean) uo.getData(); mbean = (XMBean) uo.getData();
SwingWorker<Void, Void> sw = new SwingWorker<Void, Void>() { final XMBean xmb = mbean;
SwingWorker<MBeanInfo,Void> sw = new SwingWorker<MBeanInfo,Void>() {
@Override @Override
public Void doInBackground() throws InstanceNotFoundException, public MBeanInfo doInBackground() throws InstanceNotFoundException,
IntrospectionException, ReflectionException, IOException { IntrospectionException, ReflectionException, IOException {
mbeanAttributes.loadAttributes(mbean, mbean.getMBeanInfo()); MBeanInfo mbi = xmb.getMBeanInfo();
return null; return mbi;
} }
@Override @Override
protected void done() { protected void done() {
try { try {
get(); MBeanInfo mbi = get();
if (!isSelectedNode(node, currentNode)) { if (mbi != null && mbi.getAttributes() != null &&
return; mbi.getAttributes().length > 0) {
mbeanAttributes.loadAttributes(xmb, mbi);
if (!isSelectedNode(node, currentNode)) {
return;
}
invalidate();
mainPanel.removeAll();
JPanel borderPanel = new JPanel(new BorderLayout());
borderPanel.setBorder(BorderFactory.createTitledBorder(
Resources.getText("Attribute values")));
borderPanel.add(new JScrollPane(mbeanAttributes));
mainPanel.add(borderPanel, BorderLayout.CENTER);
// add the refresh button to the south panel
southPanel.removeAll();
southPanel.add(refreshButton, BorderLayout.SOUTH);
southPanel.setVisible(true);
refreshButton.setEnabled(true);
validate();
repaint();
} }
invalidate();
mainPanel.removeAll();
JPanel borderPanel = new JPanel(new BorderLayout());
borderPanel.setBorder(BorderFactory.createTitledBorder(
Resources.getText("Attribute values")));
borderPanel.add(new JScrollPane(mbeanAttributes));
mainPanel.add(borderPanel, BorderLayout.CENTER);
// add the refresh button to the south panel
southPanel.removeAll();
southPanel.add(refreshButton, BorderLayout.SOUTH);
southPanel.setVisible(true);
refreshButton.setEnabled(true);
validate();
repaint();
} catch (Exception e) { } catch (Exception e) {
Throwable t = Utils.getActualException(e); Throwable t = Utils.getActualException(e);
if (JConsole.isDebug()) { if (JConsole.isDebug()) {
...@@ -704,13 +732,7 @@ public class XSheet extends JPanel ...@@ -704,13 +732,7 @@ public class XSheet extends JPanel
JButton button = (JButton) e.getSource(); JButton button = (JButton) e.getSource();
// Refresh button // Refresh button
if (button == refreshButton) { if (button == refreshButton) {
new SwingWorker<Void, Void>() { refreshAttributes();
@Override
public Void doInBackground() {
refreshAttributes();
return null;
}
}.execute();
return; return;
} }
// Clear button // Clear button
......
...@@ -25,10 +25,13 @@ ...@@ -25,10 +25,13 @@
package sun.tools.jconsole.inspector; package sun.tools.jconsole.inspector;
import javax.swing.*; import java.awt.Color;
import javax.swing.table.*; import java.awt.Component;
import java.awt.*; import java.awt.Font;
import java.io.*; import javax.swing.JTable;
import javax.swing.table.DefaultTableCellRenderer;
import javax.swing.table.DefaultTableModel;
import javax.swing.table.TableCellRenderer;
public abstract class XTable extends JTable { public abstract class XTable extends JTable {
static final int NAME_COLUMN = 0; static final int NAME_COLUMN = 0;
...@@ -38,8 +41,9 @@ public abstract class XTable extends JTable { ...@@ -38,8 +41,9 @@ public abstract class XTable extends JTable {
public XTable () { public XTable () {
super(); super();
TableSorter sorter; @SuppressWarnings("serial")
setModel(sorter = new TableSorter()); final TableSorter sorter = new TableSorter();
setModel(sorter);
sorter.addMouseListenerToHeaderInTable(this); sorter.addMouseListenerToHeaderInTable(this);
setRowSelectionAllowed(false); setRowSelectionAllowed(false);
setColumnSelectionAllowed(false); setColumnSelectionAllowed(false);
...@@ -54,6 +58,14 @@ public abstract class XTable extends JTable { ...@@ -54,6 +58,14 @@ public abstract class XTable extends JTable {
return editableColor; return editableColor;
} }
/**
* Called by TableSorter if a mouse event requests to sort the rows.
* @param column the column against which the rows are sorted
*/
void sortRequested(int column) {
// This is a hook for subclasses
}
/** /**
* This returns the select index as the table was at initialization * This returns the select index as the table was at initialization
*/ */
...@@ -67,7 +79,7 @@ public abstract class XTable extends JTable { ...@@ -67,7 +79,7 @@ public abstract class XTable extends JTable {
public int convertRowToIndex(int row) { public int convertRowToIndex(int row) {
if (row == -1) return row; if (row == -1) return row;
if (getModel() instanceof TableSorter) { if (getModel() instanceof TableSorter) {
return (((TableSorter) getModel()).getInvertedIndex()[row]); return ((TableSorter) getModel()).getIndexOfRow(row);
} else { } else {
return row; return row;
} }
...@@ -97,6 +109,7 @@ public abstract class XTable extends JTable { ...@@ -97,6 +109,7 @@ public abstract class XTable extends JTable {
//JTable re-implementation //JTable re-implementation
//attribute can be editable even if unavailable //attribute can be editable even if unavailable
@Override
public boolean isCellEditable(int row, int col) { public boolean isCellEditable(int row, int col) {
return ((isTableEditable() && isColumnEditable(col) return ((isTableEditable() && isColumnEditable(col)
&& isWritable(row) && isWritable(row)
...@@ -118,6 +131,7 @@ public abstract class XTable extends JTable { ...@@ -118,6 +131,7 @@ public abstract class XTable extends JTable {
* This method sets read write rows to be blue, and other rows to be their * This method sets read write rows to be blue, and other rows to be their
* default rendered colour. * default rendered colour.
*/ */
@Override
public TableCellRenderer getCellRenderer(int row, int column) { public TableCellRenderer getCellRenderer(int row, int column) {
DefaultTableCellRenderer tcr = DefaultTableCellRenderer tcr =
(DefaultTableCellRenderer) super.getCellRenderer(row,column); (DefaultTableCellRenderer) super.getCellRenderer(row,column);
...@@ -146,6 +160,7 @@ public abstract class XTable extends JTable { ...@@ -146,6 +160,7 @@ public abstract class XTable extends JTable {
return tcr; return tcr;
} }
@Override
public Component prepareRenderer(TableCellRenderer renderer, public Component prepareRenderer(TableCellRenderer renderer,
int row, int column) { int row, int column) {
Component comp = super.prepareRenderer(renderer, row, column); Component comp = super.prepareRenderer(renderer, row, column);
......
...@@ -26,22 +26,30 @@ ...@@ -26,22 +26,30 @@
package sun.tools.jconsole.inspector; package sun.tools.jconsole.inspector;
import java.awt.Component; import java.awt.Component;
import java.awt.event.ActionEvent;
import java.awt.event.FocusAdapter;
import java.awt.event.FocusEvent;
import java.awt.event.FocusListener;
import java.util.EventObject; import java.util.EventObject;
import java.awt.event.*; import javax.swing.JMenuItem;
import java.awt.dnd.DragSourceDropEvent; import javax.swing.JTable;
import javax.swing.*; import javax.swing.JTextField;
import javax.swing.event.*; import javax.swing.event.CellEditorListener;
import javax.swing.table.*; import javax.swing.event.ChangeEvent;
import javax.swing.event.EventListenerList;
import javax.swing.table.TableCellEditor;
@SuppressWarnings("serial") @SuppressWarnings("serial")
public class XTextFieldEditor extends XTextField implements TableCellEditor { public class XTextFieldEditor extends XTextField implements TableCellEditor {
protected EventListenerList listenerList = new EventListenerList(); protected EventListenerList evtListenerList = new EventListenerList();
protected ChangeEvent changeEvent = new ChangeEvent(this); protected ChangeEvent changeEvent = new ChangeEvent(this);
private FocusListener editorFocusListener = new FocusAdapter() { private FocusListener editorFocusListener = new FocusAdapter() {
@Override
public void focusLost(FocusEvent e) { public void focusLost(FocusEvent e) {
fireEditingStopped(); // fireEditingStopped();
// must not call fireEditingStopped() here!
} }
}; };
...@@ -51,6 +59,7 @@ public class XTextFieldEditor extends XTextField implements TableCellEditor { ...@@ -51,6 +59,7 @@ public class XTextFieldEditor extends XTextField implements TableCellEditor {
} }
//edition stopped ou JMenuItem selection & JTextField selection //edition stopped ou JMenuItem selection & JTextField selection
@Override
public void actionPerformed(ActionEvent e) { public void actionPerformed(ActionEvent e) {
super.actionPerformed(e); super.actionPerformed(e);
if ((e.getSource() instanceof JMenuItem) || if ((e.getSource() instanceof JMenuItem) ||
...@@ -67,16 +76,16 @@ public class XTextFieldEditor extends XTextField implements TableCellEditor { ...@@ -67,16 +76,16 @@ public class XTextFieldEditor extends XTextField implements TableCellEditor {
//TableCellEditor implementation //TableCellEditor implementation
public void addCellEditorListener(CellEditorListener listener) { public void addCellEditorListener(CellEditorListener listener) {
listenerList.add(CellEditorListener.class,listener); evtListenerList.add(CellEditorListener.class,listener);
} }
public void removeCellEditorListener(CellEditorListener listener) { public void removeCellEditorListener(CellEditorListener listener) {
listenerList.remove(CellEditorListener.class, listener); evtListenerList.remove(CellEditorListener.class, listener);
} }
protected void fireEditingStopped() { protected void fireEditingStopped() {
CellEditorListener listener; CellEditorListener listener;
Object[] listeners = listenerList.getListenerList(); Object[] listeners = evtListenerList.getListenerList();
for (int i=0;i< listeners.length;i++) { for (int i=0;i< listeners.length;i++) {
if (listeners[i] == CellEditorListener.class) { if (listeners[i] == CellEditorListener.class) {
listener = (CellEditorListener) listeners[i+1]; listener = (CellEditorListener) listeners[i+1];
...@@ -87,7 +96,7 @@ public class XTextFieldEditor extends XTextField implements TableCellEditor { ...@@ -87,7 +96,7 @@ public class XTextFieldEditor extends XTextField implements TableCellEditor {
protected void fireEditingCanceled() { protected void fireEditingCanceled() {
CellEditorListener listener; CellEditorListener listener;
Object[] listeners = listenerList.getListenerList(); Object[] listeners = evtListenerList.getListenerList();
for (int i=0;i< listeners.length;i++) { for (int i=0;i< listeners.length;i++) {
if (listeners[i] == CellEditorListener.class) { if (listeners[i] == CellEditorListener.class) {
listener = (CellEditorListener) listeners[i+1]; listener = (CellEditorListener) listeners[i+1];
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册