home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
PC World Komputer 1997 May
/
Pcwk0597.iso
/
sybase
/
starbuck
/
java.z
/
PipedOutputStream.java
< prev
next >
Wrap
Text File
|
1996-05-03
|
3KB
|
113 lines
/*
* @(#)PipedOutputStream.java 1.10 96/02/26 James Gosling
*
* Copyright (c) 1994 Sun Microsystems, Inc. All Rights Reserved.
*
* Permission to use, copy, modify, and distribute this software
* and its documentation for NON-COMMERCIAL purposes and without
* fee is hereby granted provided that this copyright notice
* appears in all copies. Please refer to the file "copyright.html"
* for further important copyright and licensing information.
*
* SUN MAKES NO REPRESENTATIONS OR WARRANTIES ABOUT THE SUITABILITY OF
* THE SOFTWARE, EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED
* TO THE IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
* PARTICULAR PURPOSE, OR NON-INFRINGEMENT. SUN SHALL NOT BE LIABLE FOR
* ANY DAMAGES SUFFERED BY LICENSEE AS A RESULT OF USING, MODIFYING OR
* DISTRIBUTING THIS SOFTWARE OR ITS DERIVATIVES.
*/
package java.io;
import java.io.*;
/**
* Piped output stream, must be connected to a PipedInputStream.
* A thread reading from a PipedInputStream receives data from
* a thread writing to the PipedOutputStream it is connected to.
* @see PipedInputStream
* @version 96/02/26
* @author James Gosling
*/
public
class PipedOutputStream extends OutputStream {
/* REMIND: identification of the read and write sides needs to be
more sophisticated. Either using thread groups (but what about
pipes within a thread?) or using finalization (but it may be a
long time until the next GC). */
private PipedInputStream sink;
/**
* Creates an output file connected to the specified
* PipedInputStream.
* @param snk The InputStream to connect to.
*/
public PipedOutputStream(PipedInputStream snk) throws IOException {
connect(snk);
}
/**
* Creates an output file that isn't connected to anything (yet).
* It must be connected before being used.
*/
public PipedOutputStream() {
}
/**
* Connect this output stream to a receiver.
* @param snk The InputStream to connect to.
*/
public void connect(PipedInputStream snk) throws IOException {
sink = snk;
snk.closed = false;
snk.in = -1;
snk.out = 0;
}
/**
* Write a byte. This method will block until the byte is actually
* written.
* @param b the byte to be written
* @exception IOException If an I/O error has occurred.
*/
public void write(int b) throws IOException {
sink.receive(b);
}
/**
* Writes a sub array of bytes.
* @param b the data to be written
* @param off the start offset in the data
* @param len the number of bytes that are written
* @exception IOException If an I/O error has occurred.
*/
public void write(byte b[], int off, int len) throws IOException {
sink.receive(b, off, len);
}
/**
* Flushes the stream. This will notify any readers that bytes are
* waiting in the pipe.
* @exception IOException If an I/O error has occurred.
*/
public synchronized void flush() throws IOException {
if (sink != null) {
synchronized (sink) {
sink.notifyAll();
}
}
}
/**
* Closes the stream. This method must be called
* to release any resources associated with the
* stream.
* @exception IOException If an I/O error has occurred.
*/
public void close() throws IOException {
if (sink != null) {
sink.receivedLast();
}
}
}