Makes UI prettier and also allows to stop debugging a connection

git-svn-id: http://svn.igniterealtime.org/svn/repos/smack/trunk@2203 b35dd754-fafc-0310-a699-88a17e54d16e
This commit is contained in:
Gaston Dombiak 2004-01-12 16:08:03 +00:00 committed by gdombiak
parent 1fa6a8e9fb
commit 878aee9043
1 changed files with 106 additions and 38 deletions

View File

@ -63,6 +63,8 @@ import java.util.Date;
import javax.swing.*; import javax.swing.*;
import javax.swing.event.*; import javax.swing.event.*;
import javax.swing.table.*; import javax.swing.table.*;
import javax.xml.transform.*;
import javax.xml.transform.stream.*;
import org.jivesoftware.smack.*; import org.jivesoftware.smack.*;
import org.jivesoftware.smack.debugger.*; import org.jivesoftware.smack.debugger.*;
@ -88,7 +90,7 @@ public class EnhancedDebugger implements SmackDebugger {
private static ImageIcon iqPacketIcon; private static ImageIcon iqPacketIcon;
private static ImageIcon messagePacketIcon; private static ImageIcon messagePacketIcon;
private static ImageIcon unknownPacketTypeIcon; private static ImageIcon unknownPacketTypeIcon;
{ {
URL url; URL url;
// Load the image icons // Load the image icons
@ -123,7 +125,6 @@ public class EnhancedDebugger implements SmackDebugger {
} }
} }
private JFrame frame = null;
private DefaultTableModel messagesTable = null; private DefaultTableModel messagesTable = null;
private JTextArea messageTextArea = null; private JTextArea messageTextArea = null;
private JFormattedTextField userField = null; private JFormattedTextField userField = null;
@ -228,7 +229,10 @@ public class EnhancedDebugger implements SmackDebugger {
tabbedPane.add("All Packets", allPane); tabbedPane.add("All Packets", allPane);
tabbedPane.setToolTipTextAt(0, "Sent and received packets processed by Smack"); tabbedPane.setToolTipTextAt(0, "Sent and received packets processed by Smack");
messagesTable = new DefaultTableModel(new Object[] { "Hide", "Timestamp", "", "", "Message", "Type", "To", "From" }, 0) { messagesTable =
new DefaultTableModel(
new Object[] { "Hide", "Timestamp", "", "", "Message", "Type", "To", "From" },
0) {
public boolean isCellEditable(int rowIndex, int mColIndex) { public boolean isCellEditable(int rowIndex, int mColIndex) {
return false; return false;
} }
@ -549,93 +553,100 @@ public class EnhancedDebugger implements SmackDebugger {
private void addInformationPanel() { private void addInformationPanel() {
// Create UI elements for connection information. // Create UI elements for connection information.
JPanel informationPanel = new JPanel(); JPanel informationPanel = new JPanel();
informationPanel.setLayout(null); informationPanel.setLayout(new BorderLayout());
// Add the Host information // Add the Host information
JPanel connPanel = new JPanel(); JPanel connPanel = new JPanel();
connPanel.setLayout(null); connPanel.setLayout(new GridBagLayout());
connPanel.setBorder(BorderFactory.createTitledBorder("Connection information")); connPanel.setBorder(BorderFactory.createTitledBorder("Connection information"));
connPanel.setBounds(0, 0, 320, 135);
JLabel label = new JLabel("Host: "); JLabel label = new JLabel("Host: ");
label.setBounds(10, 20, 150, 14);
label.setMinimumSize(new java.awt.Dimension(150, 14)); label.setMinimumSize(new java.awt.Dimension(150, 14));
label.setMaximumSize(new java.awt.Dimension(150, 14)); label.setMaximumSize(new java.awt.Dimension(150, 14));
connPanel.add(label); connPanel.add(
label,
new GridBagConstraints(0, 0, 1, 1, 0.0, 0.0, 21, 0, new Insets(0, 0, 0, 0), 0, 0));
JFormattedTextField field = new JFormattedTextField(connection.getHost()); JFormattedTextField field = new JFormattedTextField(connection.getHost());
field.setBounds(160, 18, 150, 20);
field.setMinimumSize(new java.awt.Dimension(150, 20)); field.setMinimumSize(new java.awt.Dimension(150, 20));
field.setMaximumSize(new java.awt.Dimension(150, 20)); field.setMaximumSize(new java.awt.Dimension(150, 20));
field.setEditable(false); field.setEditable(false);
field.setBorder(null); field.setBorder(null);
connPanel.add(field); connPanel.add(
field,
new GridBagConstraints(1, 0, 1, 1, 1.0, 0.0, 10, 2, new Insets(0, 0, 0, 0), 0, 0));
// Add the Port information // Add the Port information
label = new JLabel("Port: "); label = new JLabel("Port: ");
label.setBounds(10, 42, 150, 14);
label.setMinimumSize(new java.awt.Dimension(150, 14)); label.setMinimumSize(new java.awt.Dimension(150, 14));
label.setMaximumSize(new java.awt.Dimension(150, 14)); label.setMaximumSize(new java.awt.Dimension(150, 14));
connPanel.add(label); connPanel.add(
label,
new GridBagConstraints(0, 1, 1, 1, 0.0, 0.0, 21, 0, new Insets(0, 0, 0, 0), 0, 0));
field = new JFormattedTextField(new Integer(connection.getPort())); field = new JFormattedTextField(new Integer(connection.getPort()));
field.setBounds(160, 40, 150, 20);
field.setMinimumSize(new java.awt.Dimension(150, 20)); field.setMinimumSize(new java.awt.Dimension(150, 20));
field.setMaximumSize(new java.awt.Dimension(150, 20)); field.setMaximumSize(new java.awt.Dimension(150, 20));
field.setEditable(false); field.setEditable(false);
field.setBorder(null); field.setBorder(null);
connPanel.add(field); connPanel.add(
field,
new GridBagConstraints(1, 1, 1, 1, 0.0, 0.0, 10, 2, new Insets(0, 0, 0, 0), 0, 0));
// Add the connection's User information // Add the connection's User information
label = new JLabel("User: "); label = new JLabel("User: ");
label.setBounds(10, 64, 150, 14);
label.setMinimumSize(new java.awt.Dimension(150, 14)); label.setMinimumSize(new java.awt.Dimension(150, 14));
label.setMaximumSize(new java.awt.Dimension(150, 14)); label.setMaximumSize(new java.awt.Dimension(150, 14));
connPanel.add(label); connPanel.add(
label,
new GridBagConstraints(0, 2, 1, 1, 0.0, 0.0, 21, 0, new Insets(0, 0, 0, 0), 0, 0));
userField = new JFormattedTextField(); userField = new JFormattedTextField();
userField.setBounds(160, 62, 150, 20);
userField.setMinimumSize(new java.awt.Dimension(150, 20)); userField.setMinimumSize(new java.awt.Dimension(150, 20));
userField.setMaximumSize(new java.awt.Dimension(150, 20)); userField.setMaximumSize(new java.awt.Dimension(150, 20));
userField.setEditable(false); userField.setEditable(false);
userField.setBorder(null); userField.setBorder(null);
connPanel.add(userField); connPanel.add(
userField,
new GridBagConstraints(1, 2, 1, 1, 0.0, 0.0, 10, 2, new Insets(0, 0, 0, 0), 0, 0));
// Add the connection's creationTime information // Add the connection's creationTime information
label = new JLabel("Creation time: "); label = new JLabel("Creation time: ");
label.setBounds(10, 86, 150, 14);
label.setMinimumSize(new java.awt.Dimension(150, 14)); label.setMinimumSize(new java.awt.Dimension(150, 14));
label.setMaximumSize(new java.awt.Dimension(150, 14)); label.setMaximumSize(new java.awt.Dimension(150, 14));
connPanel.add(label); connPanel.add(
label,
new GridBagConstraints(0, 3, 1, 1, 0.0, 0.0, 21, 0, new Insets(0, 0, 0, 0), 0, 0));
field = new JFormattedTextField(new SimpleDateFormat("yyyy.MM.dd hh:mm:ss aaa")); field = new JFormattedTextField(new SimpleDateFormat("yyyy.MM.dd hh:mm:ss aaa"));
field.setBounds(160, 84, 150, 20);
field.setMinimumSize(new java.awt.Dimension(150, 20)); field.setMinimumSize(new java.awt.Dimension(150, 20));
field.setMaximumSize(new java.awt.Dimension(150, 20)); field.setMaximumSize(new java.awt.Dimension(150, 20));
field.setValue(creationTime); field.setValue(creationTime);
field.setEditable(false); field.setEditable(false);
field.setBorder(null); field.setBorder(null);
connPanel.add(field); connPanel.add(
field,
new GridBagConstraints(1, 3, 1, 1, 0.0, 0.0, 10, 2, new Insets(0, 0, 0, 0), 0, 0));
// Add the connection's creationTime information // Add the connection's creationTime information
label = new JLabel("Status: "); label = new JLabel("Status: ");
label.setBounds(10, 108, 150, 14);
label.setMinimumSize(new java.awt.Dimension(150, 14)); label.setMinimumSize(new java.awt.Dimension(150, 14));
label.setMaximumSize(new java.awt.Dimension(150, 14)); label.setMaximumSize(new java.awt.Dimension(150, 14));
connPanel.add(label); connPanel.add(
label,
new GridBagConstraints(0, 4, 1, 1, 0.0, 0.0, 21, 0, new Insets(0, 0, 0, 0), 0, 0));
statusField = new JFormattedTextField(); statusField = new JFormattedTextField();
statusField.setBounds(160, 106, 150, 20);
statusField.setMinimumSize(new java.awt.Dimension(150, 20)); statusField.setMinimumSize(new java.awt.Dimension(150, 20));
statusField.setMaximumSize(new java.awt.Dimension(150, 20)); statusField.setMaximumSize(new java.awt.Dimension(150, 20));
statusField.setValue("Active"); statusField.setValue("Active");
statusField.setEditable(false); statusField.setEditable(false);
statusField.setBorder(null); statusField.setBorder(null);
connPanel.add(statusField); connPanel.add(
statusField,
new GridBagConstraints(1, 4, 1, 1, 0.0, 0.0, 10, 2, new Insets(0, 0, 0, 0), 0, 0));
// Add the connection panel to the information panel // Add the connection panel to the information panel
informationPanel.add(connPanel); informationPanel.add(connPanel, BorderLayout.NORTH);
// Add the Number of sent packets information // Add the Number of sent packets information
JPanel packetsPanel = new JPanel(); JPanel packetsPanel = new JPanel();
packetsPanel.setLayout(new GridLayout(1, 1)); packetsPanel.setLayout(new GridLayout(1, 1));
//packetsPanel.setLayout(null);
packetsPanel.setBorder(BorderFactory.createTitledBorder("Transmitted Packets")); packetsPanel.setBorder(BorderFactory.createTitledBorder("Transmitted Packets"));
packetsPanel.setBounds(1, 135, 320, 174);
statisticsTable = statisticsTable =
new DefaultTableModel(new Object[][] { { "IQ", new Integer(0), new Integer(0)}, { new DefaultTableModel(new Object[][] { { "IQ", new Integer(0), new Integer(0)}, {
@ -658,7 +669,7 @@ public class EnhancedDebugger implements SmackDebugger {
packetsPanel.add(new JScrollPane(table)); packetsPanel.add(new JScrollPane(table));
// Add the packets panel to the information panel // Add the packets panel to the information panel
informationPanel.add(packetsPanel); informationPanel.add(packetsPanel, BorderLayout.CENTER);
tabbedPane.add("Information", new JScrollPane(informationPanel)); tabbedPane.add("Information", new JScrollPane(informationPanel));
tabbedPane.setToolTipTextAt(4, "Information and statistics about the debugged connection"); tabbedPane.setToolTipTextAt(4, "Information and statistics about the debugged connection");
@ -687,7 +698,7 @@ public class EnhancedDebugger implements SmackDebugger {
public PacketListener getWriterListener() { public PacketListener getWriterListener() {
return writerListener; return writerListener;
} }
/** /**
* Updates the statistics table * Updates the statistics table
*/ */
@ -740,20 +751,20 @@ public class EnhancedDebugger implements SmackDebugger {
} }
else { else {
packetTypeIcon = unknownPacketTypeIcon; packetTypeIcon = unknownPacketTypeIcon;
messageType = packet.getClass().getName()+ " Received"; messageType = packet.getClass().getName() + " Received";
receivedOtherPackets++; receivedOtherPackets++;
} }
messagesTable.addRow( messagesTable.addRow(
new Object[] { new Object[] {
packet.toXML(), formatXML(packet.toXML()),
dateFormatter.format(new Date()), dateFormatter.format(new Date()),
packetReceivedIcon, packetReceivedIcon,
packetTypeIcon, packetTypeIcon,
messageType, messageType,
type, type,
"", "",
from}); from });
// Update the statistics table // Update the statistics table
updateStatistics(); updateStatistics();
} }
@ -790,25 +801,80 @@ public class EnhancedDebugger implements SmackDebugger {
} }
else { else {
packetTypeIcon = unknownPacketTypeIcon; packetTypeIcon = unknownPacketTypeIcon;
messageType = packet.getClass().getName()+ " Sent"; messageType = packet.getClass().getName() + " Sent";
sentOtherPackets++; sentOtherPackets++;
} }
messagesTable.addRow( messagesTable.addRow(
new Object[] { new Object[] {
packet.toXML(), formatXML(packet.toXML()),
dateFormatter.format(new Date()), dateFormatter.format(new Date()),
packetSentIcon, packetSentIcon,
packetTypeIcon, packetTypeIcon,
messageType, messageType,
type, type,
to, to,
""}); "" });
// Update the statistics table // Update the statistics table
updateStatistics(); updateStatistics();
} }
private String formatXML(String str) {
try {
// Use a Transformer for output
TransformerFactory tFactory = TransformerFactory.newInstance();
Transformer transformer = tFactory.newTransformer();
transformer.setOutputProperty(OutputKeys.OMIT_XML_DECLARATION, "yes");
transformer.setOutputProperty(OutputKeys.INDENT, "yes");
transformer.setOutputProperty("{http://xml.apache.org/xslt}indent-amount", "2");
// Transform the requested string into a nice formatted XML string
StreamSource source = new StreamSource(new StringReader(str));
StringWriter sw = new StringWriter();
StreamResult result = new StreamResult(sw);
transformer.transform(source, result);
return sw.toString();
}
catch (TransformerConfigurationException tce) {
// Error generated by the parser
System.out.println("\n** Transformer Factory error");
System.out.println(" " + tce.getMessage());
// Use the contained exception, if any
Throwable x = tce;
if (tce.getException() != null)
x = tce.getException();
x.printStackTrace();
}
catch (TransformerException te) {
// Error generated by the parser
System.out.println("\n** Transformation error");
System.out.println(" " + te.getMessage());
// Use the contained exception, if any
Throwable x = te;
if (te.getException() != null)
x = te.getException();
x.printStackTrace();
}
return str;
}
/**
* Stops debugging the connection. Removes any listener on the connection.
*
*/
void cancel() {
connection.removeConnectionListener(connListener);
connection.removePacketListener(readerListener);
connection.removePacketWriterListener(writerListener);
messagesTable = null;
}
/** /**
* An ad-hoc packet is like any regular packet but with the exception that it's intention is * An ad-hoc packet is like any regular packet but with the exception that it's intention is
* to be used only <b>to send packets</b>.<p> * to be used only <b>to send packets</b>.<p>
@ -879,6 +945,8 @@ public class EnhancedDebugger implements SmackDebugger {
// Set the detail of the packet in the messageTextArea // Set the detail of the packet in the messageTextArea
messageTextArea.setText( messageTextArea.setText(
(String) table.getModel().getValueAt(table.getSelectedRow(), 0)); (String) table.getModel().getValueAt(table.getSelectedRow(), 0));
// Scroll up to the top
messageTextArea.setCaretPosition(0);
} }
} }
} }