mirror of
https://codeberg.org/Mercury-IM/Smack
synced 2024-11-26 16:22:06 +01:00
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:
parent
1fa6a8e9fb
commit
878aee9043
1 changed files with 106 additions and 38 deletions
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue