java.io.FilterOutputStream Maven / Gradle / Ivy
/*
This is not an official specification document, and usage is restricted.
NOTICE
(c) 2005-2007 Sun Microsystems, Inc. All Rights Reserved.
Neither this file nor any files generated from it describe a complete
specification, and they may only be used as described below. For
example, no permission is given for you to incorporate this file, in
whole or in part, in an implementation of a Java specification.
Sun Microsystems Inc. owns the copyright in this file and it is provided
to you for informative, as opposed to normative, use. The file and any
files generated from it may be used to generate other informative
documentation, such as a unified set of documents of API signatures for
a platform that includes technologies expressed as Java APIs. The file
may also be used to produce "compilation stubs," which allow
applications to be compiled and validated for such platforms.
Any work generated from this file, such as unified javadocs or compiled
stub files, must be accompanied by this notice in its entirety.
This work corresponds to the API signatures of JSR 219: Foundation
Profile 1.1. In the event of a discrepency between this work and the
JSR 219 specification, which is available at
http://www.jcp.org/en/jsr/detail?id=219, the latter takes precedence.
*/
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 underlying output stream) which it uses as its
* basic sink of data, but possibly transforming the data along the
* way or providing additional functionality.
*
* The class FilterOutputStream
itself simply overrides
* all methods of OutputStream
with versions that pass
* all requests to the underlying output stream. Subclasses of
* FilterOutputStream
may further override some of these
* methods as well as provide additional methods and fields.
*
* @author Jonathan Payne
* @version 1.28, 02/02/00
* @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 this.out for later use, or
* null
if this instance is to be
* created without an underlying stream.
*/
public FilterOutputStream(OutputStream out) {
}
/**
* Writes the specified byte
to this output stream.
*
* The write
method of FilterOutputStream
* calls the write
method of its underlying output stream,
* that is, it performs out.write(b).
*
* Implements the abstract write method of OutputStream.
*
* @param b the byte
.
* @exception IOException if an I/O error occurs.
*/
public void write(int b) throws IOException { }
/**
* Writes b.length
bytes to this output stream.
*
* The write
method of FilterOutputStream
* calls its write
method of three arguments with the
* arguments b
, 0
, and
* b.length
.
*
* Note that this method does not call the one-argument
* write
method of its underlying stream with the single
* argument b
.
*
* @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 { }
/**
* Writes len
bytes from the specified
* byte
array starting at offset off
to
* this output stream.
*
* The write
method of FilterOutputStream
* calls the write
method of one argument on each
* byte
to output.
*
* Note that this method does not call the write
method
* of its underlying input stream with the same arguments. Subclasses
* of FilterOutputStream
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 { }
/**
* Flushes this output stream and forces any buffered output bytes
* to be written out to the stream.
*
* The flush
method of FilterOutputStream
* calls the flush
method of its underlying output stream.
*
* @exception IOException if an I/O error occurs.
* @see java.io.FilterOutputStream#out
*/
public void flush() throws IOException { }
/**
* Closes this output stream and releases any system resources
* associated with the stream.
*
* The close
method of FilterOutputStream
* calls its flush
method, and then calls the
* close
method of its underlying output stream.
*
* @exception IOException if an I/O error occurs.
* @see java.io.FilterOutputStream#flush()
* @see java.io.FilterOutputStream#out
*/
public void close() throws IOException { }
}