source: trunk/quest-ui-swt/src/main/java/de/ugoe/cs/quest/ui/swt/SWTConsole.java @ 828

Last change on this file since 828 was 828, checked in by sherbold, 12 years ago
  • minor SWT GUI change
  • JFCLogParser now reports missing KEYDOWN events as severe warnings using the trace mechanism instead of errors
  • Property svn:mime-type set to text/plain
File size: 2.1 KB
Line 
1package de.ugoe.cs.quest.ui.swt;
2
3import java.util.logging.Level;
4
5import org.eclipse.swt.SWT;
6import org.eclipse.swt.custom.StyleRange;
7import org.eclipse.swt.custom.StyledText;
8
9import de.ugoe.cs.util.StringTools;
10import de.ugoe.cs.util.console.Console;
11import de.ugoe.cs.util.console.listener.ICommandListener;
12import de.ugoe.cs.util.console.listener.IErrorListener;
13import de.ugoe.cs.util.console.listener.IOutputListener;
14import de.ugoe.cs.util.console.listener.ITraceListener;
15
16public class SWTConsole implements IOutputListener, IErrorListener, ITraceListener,
17    ICommandListener
18{
19
20    private StyledText output;
21   
22    private Level traceLevel;
23
24    public SWTConsole(StyledText styledText, Level traceLevel) {
25        Console.getInstance().registerOutputListener(this);
26        Console.getInstance().registerErrorListener(this);
27        Console.getInstance().registerTraceListener(this);
28        Console.getInstance().registerCommandListener(this);
29        this.output = styledText;
30        this.traceLevel = traceLevel;
31    }
32
33    @Override
34    public void outputMsg(String newMessage) {
35        output.append(newMessage);
36    }
37
38    @Override
39    public void errorMsg(String errMessage) {
40        appendColored("[ERROR] " + errMessage, SWT.COLOR_RED);
41    }
42
43    @Override
44    public void traceMsg(String traceMessage, Level level) {
45        if( level.intValue()>=traceLevel.intValue()) {
46            int color = SWT.COLOR_BLUE;
47            if( level==Level.SEVERE ) {
48                color = SWT.COLOR_RED;
49            }
50            appendColored("[" + level.toString() + "] " + traceMessage, color);
51        }
52    }
53
54    @Override
55    public void commandNotification(String command) {
56        output.append("> " + command + StringTools.ENDLINE);
57    }
58
59    private void appendColored(String str, int id) {
60        StyleRange styleRange = new StyleRange();
61        styleRange.start = output.getText().length();
62        styleRange.length = str.length();
63        styleRange.foreground = output.getDisplay().getSystemColor(id);
64        output.append(str);
65        output.setStyleRange(styleRange);
66    }
67}
Note: See TracBrowser for help on using the repository browser.