Package weka.core
Class Tee
- All Implemented Interfaces:
Closeable,Flushable,Appendable,AutoCloseable,RevisionHandler
This class pipelines print/println's to several PrintStreams. Useful for
redirecting System.out and System.err to files etc.
E.g., for redirecting stderr/stdout to files with timestamps and:
E.g., for redirecting stderr/stdout to files with timestamps and:
import java.io.*;
import weka.core.Tee;
...
// stdout
Tee teeOut = new Tee(System.out);
teeOut.add(new PrintStream(new FileOutputStream("out.txt")), true);
System.setOut(teeOut);
// stderr
Tee teeErr = new Tee(System.err);
teeErr.add(new PrintStream(new FileOutputStream("err.txt")), true);
System.setOut(teeErr);
...
- Version:
- $Revision: 5057 $
- Author:
- FracPete (fracpete at waikato dot ac dot nz)
-
Constructor Summary
ConstructorsConstructorDescriptionTee()initializes the object, with a default printstream.Tee(PrintStream def) initializes the object with the given default printstream, e.g., System.out. -
Method Summary
Modifier and TypeMethodDescriptionvoidadd(PrintStream p) adds the given PrintStream to the list of streams, with NO timestamp and NO prefix.voidadd(PrintStream p, boolean timestamp) adds the given PrintStream to the list of streams, with NO prefix.voidadd(PrintStream p, boolean timestamp, String prefix) adds the given PrintStream to the list of streams.voidclear()removes all streams and places the default printstream, if any, again in the list.booleanchecks whether the given PrintStream is already in the list.voidflush()flushes all the printstreams.get(int index) returns the specified PrintStream from the list.returns the default printstrean, can be NULL.Returns the revision string.voidprint(boolean x) prints the given boolean to the streams.voidprint(char x) prints the given char to the streams.voidprint(char[] x) prints the given char array to the streams.voidprint(double x) prints the given double to the streams.voidprint(float x) prints the given float to the streams.voidprint(int x) prints the given int to the streams.voidprint(long x) prints the given long to the streams.voidprints the given object to the streams.voidprints the given string to the streams.voidprintln()prints a new line to the streams.voidprintln(boolean x) prints the given boolean to the streams.voidprintln(char x) prints the given char to the streams.voidprintln(char[] x) prints the given char array to the streams.voidprintln(double x) prints the given double to the streams.voidprintln(float x) prints the given float to the streams.voidprintln(int x) prints the given int to the streams.voidprintln(long x) prints the given long to the streams.voidprints the given object to the streams (for Throwables we print the stack trace).voidprints the given string to the streams.remove(int index) removes the given PrintStream from the list.removes the given PrintStream from the list.intsize()returns the number of streams currently in the list.toString()returns only the classname and the number of streams.voidwrite(byte[] buf, int off, int len) Writeslenbytes from the specified byte array starting at offsetoffto this stream.voidwrite(int b) Writes the specified byte to this stream.Methods inherited from class java.io.PrintStream
append, append, append, checkError, close, format, format, printf, printf, write, writeBytesMethods inherited from class java.io.OutputStream
nullOutputStream
-
Constructor Details
-
Tee
public Tee()initializes the object, with a default printstream. -
Tee
initializes the object with the given default printstream, e.g., System.out.- Parameters:
def- the default printstream, remains also after calling clear()
-
-
Method Details
-
clear
public void clear()removes all streams and places the default printstream, if any, again in the list.- See Also:
-
getDefault
returns the default printstrean, can be NULL.- Returns:
- the default printstream
- See Also:
-
m_Default
-
add
adds the given PrintStream to the list of streams, with NO timestamp and NO prefix.- Parameters:
p- the printstream to add
-
add
adds the given PrintStream to the list of streams, with NO prefix.- Parameters:
p- the printstream to addtimestamp- whether to use timestamps or not
-
add
adds the given PrintStream to the list of streams.- Parameters:
p- the printstream to addtimestamp- whether to use timestamps or notprefix- the prefix to use
-
get
returns the specified PrintStream from the list.- Parameters:
index- the index of the PrintStream to return- Returns:
- the specified PrintStream, or null if invalid index
-
remove
removes the given PrintStream from the list.- Parameters:
p- the PrintStream to remove- Returns:
- returns the removed PrintStream if it could be removed, null otherwise
-
remove
removes the given PrintStream from the list.- Parameters:
index- the index of the PrintStream to remove- Returns:
- returns the removed PrintStream if it could be removed, null otherwise
-
contains
checks whether the given PrintStream is already in the list.- Parameters:
p- the PrintStream to look for- Returns:
- true if the PrintStream is in the list
-
size
public int size()returns the number of streams currently in the list.- Returns:
- the number of streams in the list
-
flush
public void flush()flushes all the printstreams.- Specified by:
flushin interfaceFlushable- Overrides:
flushin classPrintStream
-
print
public void print(int x) prints the given int to the streams.- Overrides:
printin classPrintStream- Parameters:
x- the object to print
-
print
public void print(long x) prints the given long to the streams.- Overrides:
printin classPrintStream- Parameters:
x- the object to print
-
print
public void print(float x) prints the given float to the streams.- Overrides:
printin classPrintStream- Parameters:
x- the object to print
-
print
public void print(double x) prints the given double to the streams.- Overrides:
printin classPrintStream- Parameters:
x- the object to print
-
print
public void print(boolean x) prints the given boolean to the streams.- Overrides:
printin classPrintStream- Parameters:
x- the object to print
-
print
public void print(char x) prints the given char to the streams.- Overrides:
printin classPrintStream- Parameters:
x- the object to print
-
print
public void print(char[] x) prints the given char array to the streams.- Overrides:
printin classPrintStream- Parameters:
x- the object to print
-
print
prints the given string to the streams.- Overrides:
printin classPrintStream- Parameters:
x- the object to print
-
print
prints the given object to the streams.- Overrides:
printin classPrintStream- Parameters:
x- the object to print
-
println
public void println()prints a new line to the streams.- Overrides:
printlnin classPrintStream
-
println
public void println(int x) prints the given int to the streams.- Overrides:
printlnin classPrintStream- Parameters:
x- the object to print
-
println
public void println(long x) prints the given long to the streams.- Overrides:
printlnin classPrintStream- Parameters:
x- the object to print
-
println
public void println(float x) prints the given float to the streams.- Overrides:
printlnin classPrintStream- Parameters:
x- the object to print
-
println
public void println(double x) prints the given double to the streams.- Overrides:
printlnin classPrintStream- Parameters:
x- the object to print
-
println
public void println(boolean x) prints the given boolean to the streams.- Overrides:
printlnin classPrintStream- Parameters:
x- the object to print
-
println
public void println(char x) prints the given char to the streams.- Overrides:
printlnin classPrintStream- Parameters:
x- the object to print
-
println
public void println(char[] x) prints the given char array to the streams.- Overrides:
printlnin classPrintStream- Parameters:
x- the object to print
-
println
prints the given string to the streams.- Overrides:
printlnin classPrintStream- Parameters:
x- the object to print
-
println
prints the given object to the streams (for Throwables we print the stack trace).- Overrides:
printlnin classPrintStream- Parameters:
x- the object to print
-
write
public void write(byte[] buf, int off, int len) Writeslenbytes from the specified byte array starting at offsetoffto this stream. If automatic flushing is enabled then theflushmethod will be invoked.Note that the bytes will be written as given; to write characters that will be translated according to the platform's default character encoding, use the
print(char)orprintln(char)methods.- Overrides:
writein classPrintStream- Parameters:
buf- A byte arrayoff- Offset from which to start taking byteslen- Number of bytes to write
-
write
public void write(int b) Writes the specified byte to this stream. If the byte is a newline and automatic flushing is enabled then theflushmethod will be invoked.Note that the byte is written as given; to write a character that will be translated according to the platform's default character encoding, use the
print(char)orprintln(char)methods.- Overrides:
writein classPrintStream- Parameters:
b- The byte to be written- See Also:
-
toString
returns only the classname and the number of streams. -
getRevision
Returns the revision string.- Specified by:
getRevisionin interfaceRevisionHandler- Returns:
- the revision
-