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

Last change on this file since 845 was 845, checked in by sherbold, 12 years ago
  • beautification of SWT GUI
  • Property svn:mime-type set to text/plain
File size: 3.2 KB
Line 
1package de.ugoe.cs.quest.ui.swt;
2
3import java.io.ByteArrayOutputStream;
4import java.io.PrintStream;
5import java.io.UnsupportedEncodingException;
6import java.util.logging.Level;
7
8import org.eclipse.swt.SWT;
9import org.eclipse.swt.custom.StyleRange;
10import org.eclipse.swt.custom.StyledText;
11import org.eclipse.swt.widgets.MessageBox;
12
13import de.ugoe.cs.util.StringTools;
14import de.ugoe.cs.util.console.Console;
15import de.ugoe.cs.util.console.listener.ICommandListener;
16import de.ugoe.cs.util.console.listener.IErrorListener;
17import de.ugoe.cs.util.console.listener.IExceptionListener;
18import de.ugoe.cs.util.console.listener.IOutputListener;
19import de.ugoe.cs.util.console.listener.ITraceListener;
20
21public class SWTConsole implements IOutputListener, IErrorListener, ITraceListener,
22    ICommandListener, IExceptionListener
23{
24
25    private StyledText output;
26   
27    private Level traceLevel;
28
29    public SWTConsole(StyledText styledText, Level traceLevel) {
30        Console.getInstance().registerOutputListener(this);
31        Console.getInstance().registerErrorListener(this);
32        Console.getInstance().registerTraceListener(this);
33        Console.getInstance().registerCommandListener(this);
34        Console.getInstance().registerExceptionListener(this);
35        this.output = styledText;
36        this.traceLevel = traceLevel;
37    }
38
39    @Override
40    public void outputMsg(String newMessage) {
41        output.append(newMessage);
42    }
43
44    @Override
45    public void errorMsg(String errMessage) {
46        appendColored("[ERROR] " + errMessage, SWT.COLOR_RED);
47    }
48
49    @Override
50    public void traceMsg(String traceMessage, Level level) {
51        if( level.intValue()>=traceLevel.intValue()) {
52            int color = SWT.COLOR_BLUE;
53            if( level==Level.SEVERE ) {
54                color = SWT.COLOR_RED;
55            }
56            appendColored("[" + level.toString() + "] " + traceMessage, color);
57        }
58    }
59
60    @Override
61    public void commandNotification(String command) {
62        output.append("> " + command + StringTools.ENDLINE);
63    }
64
65    private void appendColored(String str, int id) {
66        StyleRange styleRange = new StyleRange();
67        styleRange.start = output.getText().length();
68        styleRange.length = str.length();
69        styleRange.foreground = output.getDisplay().getSystemColor(id);
70        output.append(str);
71        output.setStyleRange(styleRange);
72    }
73
74    @Override
75    public void logException(Exception e) {
76        MessageBox messageBox = new MessageBox(output.getShell(), SWT.ERROR);
77        messageBox.setText("Error");
78        messageBox.setMessage(e.getMessage());
79        messageBox.open();
80       
81        ByteArrayOutputStream baos = new ByteArrayOutputStream();
82        PrintStream ps = new PrintStream(baos);
83        e.printStackTrace(ps);       
84        String stackTrace = null;
85        try {
86            stackTrace = baos.toString("UTF-8");
87        }
88        catch (UnsupportedEncodingException e1) {
89        }
90        if( stackTrace!=null ) {
91            appendColored(stackTrace, SWT.COLOR_RED);
92        } else {
93            appendColored(e.getMessage(), SWT.COLOR_RED);
94        }
95       
96    }
97}
Note: See TracBrowser for help on using the repository browser.