Skip to content

Commit e02595b

Browse files
committed
Add an event for reporting on stdout/stderr output
This event, though it is a SciJavaEvent, is _not_ intended for publication via the EventService, but rather via the ConsoleService.
1 parent 3a81640 commit e02595b

File tree

1 file changed

+124
-0
lines changed

1 file changed

+124
-0
lines changed
Lines changed: 124 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,124 @@
1+
/*
2+
* #%L
3+
* SciJava Common shared library for SciJava software.
4+
* %%
5+
* Copyright (C) 2009 - 2015 Board of Regents of the University of
6+
* Wisconsin-Madison, Broad Institute of MIT and Harvard, and Max Planck
7+
* Institute of Molecular Cell Biology and Genetics.
8+
* %%
9+
* Redistribution and use in source and binary forms, with or without
10+
* modification, are permitted provided that the following conditions are met:
11+
*
12+
* 1. Redistributions of source code must retain the above copyright notice,
13+
* this list of conditions and the following disclaimer.
14+
* 2. Redistributions in binary form must reproduce the above copyright notice,
15+
* this list of conditions and the following disclaimer in the documentation
16+
* and/or other materials provided with the distribution.
17+
*
18+
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
19+
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20+
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21+
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
22+
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23+
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24+
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25+
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26+
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27+
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28+
* POSSIBILITY OF SUCH DAMAGE.
29+
* #L%
30+
*/
31+
32+
package org.scijava.console;
33+
34+
import org.scijava.Context;
35+
import org.scijava.event.EventService;
36+
import org.scijava.event.SciJavaEvent;
37+
38+
/**
39+
* An event indicating output occurred on {@code stdout} or {@code stderr}.
40+
* <p>
41+
* NB: This event is published <em>on the calling thread</em> by
42+
* {@link ConsoleService#notifyListeners(OutputEvent)}, <em>not</em> on a
43+
* dedicated event dispatch thread by the {@link EventService}. This is done to
44+
* avoid the overhead of the event service's synchronized pub/sub
45+
* implementation, as well as to avoid potential infinite output loops caused by
46+
* debugging output surrounding event publication.
47+
* </p>
48+
*
49+
* @author Curtis Rueden
50+
*/
51+
public class OutputEvent extends SciJavaEvent {
52+
53+
/** Possible output sources. */
54+
public enum Source {
55+
STDOUT, STDERR
56+
}
57+
58+
/** The source of the output. */
59+
private final Source source;
60+
61+
/** The output string. */
62+
private final String output;
63+
64+
/**
65+
* Whether the output was produced within this specific SciJava
66+
* {@link Context}.
67+
*/
68+
private final boolean contextual;
69+
70+
/**
71+
* Creates a new output event.
72+
*
73+
* @param source The source of the output.
74+
* @param output The output string.
75+
* @param contextual Whether the output was produced within this specific
76+
* SciJava {@link Context}.
77+
*/
78+
public OutputEvent(final Context context, final Source source,
79+
final String output, final boolean contextual)
80+
{
81+
this.source = source;
82+
this.output = output;
83+
this.contextual = contextual;
84+
setContext(context);
85+
setCallingThread(Thread.currentThread());
86+
}
87+
88+
/** Gets the source of the output. */
89+
public Source getSource() {
90+
return source;
91+
}
92+
93+
/** Gets the output string. */
94+
public String getOutput() {
95+
return output;
96+
}
97+
98+
/**
99+
* Returns true if the output was produced outside of a specific SciJava
100+
* {@link Context}.
101+
*/
102+
public boolean isContextual() {
103+
return contextual;
104+
}
105+
106+
/** Returns true of the source of the output is {@code stdout}. */
107+
public boolean isStdout() {
108+
return source == Source.STDOUT;
109+
}
110+
111+
/** Returns true of the source of the output is {@code stderr}. */
112+
public boolean isStderr() {
113+
return source == Source.STDERR;
114+
}
115+
116+
// -- Object methods --
117+
118+
@Override
119+
public String toString() {
120+
return super.toString() + "\n\tsource = " + source + "\n\toutput = " +
121+
output + "\n\tcontextual = " + contextual;
122+
}
123+
124+
}

0 commit comments

Comments
 (0)