LogWindow.java
4.28 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
package org.mote.wiimote.whiteboard.gui;
import java.awt.BorderLayout;
import java.awt.event.KeyAdapter;
import java.awt.event.KeyEvent;
import java.io.PrintWriter;
import java.io.StringWriter;
import java.io.Writer;
import java.util.Calendar;
import java.util.logging.Handler;
import java.util.logging.Level;
import java.util.logging.LogRecord;
import java.util.logging.Logger;
import javax.swing.JDialog;
import javax.swing.JLabel;
import javax.swing.JScrollPane;
import javax.swing.JTextArea;
import net.miginfocom.swing.MigLayout;
import org.jdesktop.application.Action;
import org.jdesktop.application.Application;
import org.mote.wiimote.whiteboard.WiimoteWhiteboard;
import org.mote.wiimote.whiteboard.preferences.WWPreferences;
import org.mote.wiimote.whiteboard.util.Util;
@SuppressWarnings("serial")
public class LogWindow extends JDialog {
private JTextArea log;
private JDialog failedDialog;
public LogWindow() {
super(Application.getInstance(WiimoteWhiteboard.class).getMainFrame(), WiimoteWhiteboard.getProperty("id") + " " + Util.getResourceMap(LogWindow.class).getString("log.Action.text"));
getRootPane().putClientProperty("Window.style", "small");
setLayout(new MigLayout());
log = Util.newComponent(JTextArea.class, "log");
add(new JScrollPane(log), "w 66sp, h 33sp, grow, push");
Logger.getLogger("wiiremotej").addHandler(new LogHandler("WiiRemoteJ: "));
WiimoteWhiteboard.getLogger().addHandler(new LogHandler(""));
log.addKeyListener(new KeyAdapter() {
@Override
public void keyPressed(KeyEvent e) {
if (e.getKeyCode() == KeyEvent.VK_ESCAPE) {
setVisible(false);
}
}
});
Util.getResourceMap(LogWindow.class).injectComponents(this);
pack();
Util.placeDialogWindow(this, getWidth(), getHeight());
failedDialog = Util.newComponent(JDialog.class, "failedDialog");
failedDialog.addKeyListener(new KeyAdapter() {
@Override
public void keyPressed(KeyEvent e) {
if (e.getKeyCode() == KeyEvent.VK_ESCAPE) {
failedDialog.setVisible(false);
}
}
});
failedDialog.setAlwaysOnTop(true);
failedDialog.getRootPane().putClientProperty("Window.style", "small");
failedDialog.getRootPane().putClientProperty("Window.alpha", new Float(0.90));
failedDialog.setLayout(new BorderLayout());
failedDialog.add(Util.newComponent(JLabel.class, "failedLabel"), BorderLayout.CENTER);
Util.getResourceMap(LogWindow.class).injectComponents(failedDialog);
failedDialog.pack();
failedDialog.setBounds(getX()+getWidth()/2-(failedDialog.getWidth()+20)/2, getY()+getHeight()+10, failedDialog.getWidth()+20, failedDialog.getHeight()+20);
}
@Action
public void log() {
setVisible(!isVisible());
}
private class LogHandler extends Handler {
private static final String DIRECT_CONNECTION_TIMEOUT = "Failed to open baseband connection";
private static final String CONNECTION_FAILED = "WiiRemote failed to connect!";
private static final String CONNECTION_SUCCEEDED = "Initial connection complete.";
private final String name;
public LogHandler(String name) {
this.name = name;
setLevel(Level.ALL);
}
@Override
public void close() throws SecurityException {}
@Override
public void flush() {}
@Override
public void publish(LogRecord record) {
Level level = record.getLevel();
String msg = record.getMessage();
Throwable e = record.getThrown();
boolean failed = false;
if (!WWPreferences.WIIMOTE_BT_ADDRESSES.isEmpty() && e != null && e.getCause() != null && e.getCause().getMessage().startsWith(DIRECT_CONNECTION_TIMEOUT))
return;
log.append(String.format("%7s %tT %s%s\n", level.getName(), Calendar.getInstance(), name, msg));
if (e != null) {
log.append(getStackTrace(e));
failed = CONNECTION_FAILED.equals(e.getMessage());
}
log.setCaretPosition(log.getText().length()-1);
if (!failed && level == Level.SEVERE) {
if (!LogWindow.this.isVisible()) {
LogWindow.this.setVisible(true);
}
}
if (CONNECTION_SUCCEEDED.equals(msg)) {
failedDialog.setVisible(false);
} else if (failed) {
failedDialog.setVisible(true);
}
}
}
private static String getStackTrace(Throwable e) {
final Writer result = new StringWriter();
final PrintWriter printWriter = new PrintWriter(result);
e.printStackTrace(printWriter);
return result.toString();
}
}