source: trunk/quest-jfcmonitor/src/main/java/de/ugoe/cs/quest/jfcmonitor/Runner.java @ 851

Last change on this file since 851 was 851, checked in by fglaser, 12 years ago
  • JFCMonitor: Added new ContainerListener? that listens on component added and component removed events
  • small refactorings
  • Property svn:mime-type set to text/plain
File size: 3.9 KB
Line 
1
2package de.ugoe.cs.quest.jfcmonitor;
3
4import java.awt.AWTEvent;
5import java.awt.Toolkit;
6import java.awt.event.AWTEventListener;
7import java.awt.event.FocusEvent;
8import java.io.FileOutputStream;
9import java.io.IOException;
10import java.io.OutputStreamWriter;
11import java.io.UnsupportedEncodingException;
12import java.util.Arrays;
13
14/**
15 * <p>
16 * Start-up class of the application.
17 * </p>
18 * <p>
19 * Launches the application under test in the same JVM.
20 * </p>
21 *
22 * @author Steffen Herbold, Fabian Glaser
23 * @version 1.0
24 */
25public class Runner {
26
27    /**
28     * <p>
29     * Debugging variable. If set to true, the logging is also written to the console.
30     * </p>
31     */
32    private final static boolean stdOutputWrite = true;
33
34    /**
35     * <p>
36     * Main method of the application.
37     * </p>
38     *
39     * @param args
40     *            the first parameter defines the Jar file that contains the start-up information of
41     *            the application under test. The remaining parameters are passed on the toe
42     *            application under test.
43     */
44    public static void main(String[] args) {
45        String logfileName = "jfcmonitor_" + System.currentTimeMillis() + ".log";
46
47        FileOutputStream fis;
48        OutputStreamWriter writer;
49        try {
50            // the writer is not closed explicitly!
51            fis = new FileOutputStream(logfileName, true);
52            writer = new OutputStreamWriter(fis, "UTF-8");
53        }
54        catch (IOException e) {
55            System.err.println("JFCMONITOR -- failure opening logfile: " + e.getMessage());
56            return;
57        }
58
59        JFCMonitorOutputWriter jfcWriter = new JFCMonitorOutputWriter(writer);
60        AWTEventListener listenerFile = new JFCListener(jfcWriter);
61        Toolkit.getDefaultToolkit().addAWTEventListener(listenerFile, AWTEvent.KEY_EVENT_MASK);
62        Toolkit.getDefaultToolkit().addAWTEventListener(listenerFile, AWTEvent.MOUSE_EVENT_MASK);
63        Toolkit.getDefaultToolkit().addAWTEventListener(listenerFile, FocusEvent.FOCUS_EVENT_MASK);
64        Toolkit.getDefaultToolkit().addAWTEventListener(new WindowMonitor(jfcWriter),
65                                                        AWTEvent.WINDOW_EVENT_MASK);
66        JFCComponent.addPropertyChangeListener(new JFCNameChangeListener(jfcWriter));
67
68        if (stdOutputWrite) {
69            AWTEventListener listenerStdOut;
70            try {
71                OutputStreamWriter stdOutputWriter = new OutputStreamWriter(System.out, "UTF-8");
72                JFCMonitorOutputWriter stdJfcWriter = new JFCMonitorOutputWriter(stdOutputWriter);
73                listenerStdOut = new JFCListener(stdJfcWriter);
74                Toolkit.getDefaultToolkit().addAWTEventListener(listenerStdOut,
75                                                                AWTEvent.KEY_EVENT_MASK);
76                Toolkit.getDefaultToolkit().addAWTEventListener(listenerStdOut,
77                                                                AWTEvent.MOUSE_EVENT_MASK);
78                Toolkit.getDefaultToolkit().addAWTEventListener(listenerStdOut,
79                                                                FocusEvent.FOCUS_EVENT_MASK);
80                Toolkit.getDefaultToolkit().addAWTEventListener(new WindowMonitor(stdJfcWriter),
81                        AWTEvent.WINDOW_EVENT_MASK);
82                JFCComponent.addPropertyChangeListener(new JFCNameChangeListener(stdJfcWriter));
83                JFCComponent.addContainerListener(new JFCContainerListener(stdJfcWriter));
84            }
85            catch (UnsupportedEncodingException e) {
86                System.err
87                    .println("JFCMONITOR -- failure to create OutputStreamWriter with UTF-8 encoding to System.out");
88            }
89        }
90
91        JarLauncher launcher = new JarLauncher(args[0], Arrays.copyOfRange(args, 1, args.length));
92        launcher.exec();
93    }
94}
Note: See TracBrowser for help on using the repository browser.