You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
162 lines
5.1 KiB
162 lines
5.1 KiB
/*
|
|
* Copyright (c) 1994, 2011, Oracle and/or its affiliates. All rights reserved.
|
|
* ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
|
|
*
|
|
*
|
|
*
|
|
*
|
|
*
|
|
*
|
|
*
|
|
*
|
|
*
|
|
*
|
|
*
|
|
*
|
|
*
|
|
*
|
|
*
|
|
*
|
|
*
|
|
*
|
|
*
|
|
*
|
|
*/
|
|
|
|
package java.io;
|
|
|
|
/**
|
|
* This class is the superclass of all classes that filter output
|
|
* streams. These streams sit on top of an already existing output
|
|
* stream (the <i>underlying</i> output stream) which it uses as its
|
|
* basic sink of data, but possibly transforming the data along the
|
|
* way or providing additional functionality.
|
|
* <p>
|
|
* The class <code>FilterOutputStream</code> itself simply overrides
|
|
* all methods of <code>OutputStream</code> with versions that pass
|
|
* all requests to the underlying output stream. Subclasses of
|
|
* <code>FilterOutputStream</code> may further override some of these
|
|
* methods as well as provide additional methods and fields.
|
|
*
|
|
* @author Jonathan Payne
|
|
* @since JDK1.0
|
|
*/
|
|
public
|
|
class FilterOutputStream extends OutputStream {
|
|
/**
|
|
* The underlying output stream to be filtered.
|
|
*/
|
|
protected OutputStream out;
|
|
|
|
/**
|
|
* Creates an output stream filter built on top of the specified
|
|
* underlying output stream.
|
|
*
|
|
* @param out the underlying output stream to be assigned to
|
|
* the field <tt>this.out</tt> for later use, or
|
|
* <code>null</code> if this instance is to be
|
|
* created without an underlying stream.
|
|
*/
|
|
public FilterOutputStream(OutputStream out) {
|
|
this.out = out;
|
|
}
|
|
|
|
/**
|
|
* Writes the specified <code>byte</code> to this output stream.
|
|
* <p>
|
|
* The <code>write</code> method of <code>FilterOutputStream</code>
|
|
* calls the <code>write</code> method of its underlying output stream,
|
|
* that is, it performs <tt>out.write(b)</tt>.
|
|
* <p>
|
|
* Implements the abstract <tt>write</tt> method of <tt>OutputStream</tt>.
|
|
*
|
|
* @param b the <code>byte</code>.
|
|
* @exception IOException if an I/O error occurs.
|
|
*/
|
|
public void write(int b) throws IOException {
|
|
out.write(b);
|
|
}
|
|
|
|
/**
|
|
* Writes <code>b.length</code> bytes to this output stream.
|
|
* <p>
|
|
* The <code>write</code> method of <code>FilterOutputStream</code>
|
|
* calls its <code>write</code> method of three arguments with the
|
|
* arguments <code>b</code>, <code>0</code>, and
|
|
* <code>b.length</code>.
|
|
* <p>
|
|
* Note that this method does not call the one-argument
|
|
* <code>write</code> method of its underlying stream with the single
|
|
* argument <code>b</code>.
|
|
*
|
|
* @param b the data to be written.
|
|
* @exception IOException if an I/O error occurs.
|
|
* @see java.io.FilterOutputStream#write(byte[], int, int)
|
|
*/
|
|
public void write(byte b[]) throws IOException {
|
|
write(b, 0, b.length);
|
|
}
|
|
|
|
/**
|
|
* Writes <code>len</code> bytes from the specified
|
|
* <code>byte</code> array starting at offset <code>off</code> to
|
|
* this output stream.
|
|
* <p>
|
|
* The <code>write</code> method of <code>FilterOutputStream</code>
|
|
* calls the <code>write</code> method of one argument on each
|
|
* <code>byte</code> to output.
|
|
* <p>
|
|
* Note that this method does not call the <code>write</code> method
|
|
* of its underlying input stream with the same arguments. Subclasses
|
|
* of <code>FilterOutputStream</code> should provide a more efficient
|
|
* implementation of this method.
|
|
*
|
|
* @param b the data.
|
|
* @param off the start offset in the data.
|
|
* @param len the number of bytes to write.
|
|
* @exception IOException if an I/O error occurs.
|
|
* @see java.io.FilterOutputStream#write(int)
|
|
*/
|
|
public void write(byte b[], int off, int len) throws IOException {
|
|
if ((off | len | (b.length - (len + off)) | (off + len)) < 0)
|
|
throw new IndexOutOfBoundsException();
|
|
|
|
for (int i = 0 ; i < len ; i++) {
|
|
write(b[off + i]);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Flushes this output stream and forces any buffered output bytes
|
|
* to be written out to the stream.
|
|
* <p>
|
|
* The <code>flush</code> method of <code>FilterOutputStream</code>
|
|
* calls the <code>flush</code> method of its underlying output stream.
|
|
*
|
|
* @exception IOException if an I/O error occurs.
|
|
* @see java.io.FilterOutputStream#out
|
|
*/
|
|
public void flush() throws IOException {
|
|
out.flush();
|
|
}
|
|
|
|
/**
|
|
* Closes this output stream and releases any system resources
|
|
* associated with the stream.
|
|
* <p>
|
|
* The <code>close</code> method of <code>FilterOutputStream</code>
|
|
* calls its <code>flush</code> method, and then calls the
|
|
* <code>close</code> method of its underlying output stream.
|
|
*
|
|
* @exception IOException if an I/O error occurs.
|
|
* @see java.io.FilterOutputStream#flush()
|
|
* @see java.io.FilterOutputStream#out
|
|
*/
|
|
@SuppressWarnings("try")
|
|
public void close() throws IOException {
|
|
try (OutputStream ostream = out) {
|
|
flush();
|
|
}
|
|
}
|
|
}
|