diff options
author | tromey <tromey@138bc75d-0d04-0410-961f-82ee72b054a4> | 1999-04-07 14:42:40 +0000 |
---|---|---|
committer | tromey <tromey@138bc75d-0d04-0410-961f-82ee72b054a4> | 1999-04-07 14:42:40 +0000 |
commit | 2c60951ba0efef23e2b765964b5dc0f1f49438a9 (patch) | |
tree | d96801a16fdf03a5682ef98730fe333a46eef944 /libjava/java/io/PipedOutputStream.java | |
parent | 1135eed2207f8f82c589e42ce113a1c2f0310778 (diff) | |
download | ppe42-gcc-2c60951ba0efef23e2b765964b5dc0f1f49438a9.tar.gz ppe42-gcc-2c60951ba0efef23e2b765964b5dc0f1f49438a9.zip |
Initial revision
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@26263 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libjava/java/io/PipedOutputStream.java')
-rw-r--r-- | libjava/java/io/PipedOutputStream.java | 94 |
1 files changed, 94 insertions, 0 deletions
diff --git a/libjava/java/io/PipedOutputStream.java b/libjava/java/io/PipedOutputStream.java new file mode 100644 index 00000000000..9b069944926 --- /dev/null +++ b/libjava/java/io/PipedOutputStream.java @@ -0,0 +1,94 @@ +// PipedOutputStream.java - Write bytes to a pipe. + +/* Copyright (C) 1998, 1999 Cygnus Solutions + + This file is part of libgcj. + +This software is copyrighted work licensed under the terms of the +Libgcj License. Please consult the file "LIBGCJ_LICENSE" for +details. */ + +package java.io; + +/** + * @author Tom Tromey <tromey@cygnus.com> + * @date September 24, 1998 + */ + +/* Written using "Java Class Libraries", 2nd edition, ISBN 0-201-31002-3 + * "The Java Language Specification", ISBN 0-201-63451-1 + * Status: Believed complete and correct. + */ + +public class PipedOutputStream extends OutputStream +{ + public void close () throws IOException + { + closed = true; + + // Notify PipedInputStream that there is no more data to be had. + destination.receive(-1); + } + + public void connect (PipedInputStream dest) throws IOException + { + if (closed) + throw new IOException("pipe closed"); + + if (destination != null) + if (destination == dest) + return; + else + throw new IOException("pipe already connected"); + + destination = dest; + try + { + dest.connect(this); + } + catch (IOException ex) + { + destination = null; + throw ex; + } + } + + public synchronized void flush () throws IOException + { + // There doesn't seem to be anything to do here. + + // TBD: Should this maybe do a notifyAll as a way for the user + // to wake up the input stream to check for bytes to read? Shouldn't + // be necessary but if there aren't any bytes, other threads will just + // go blocak again anyway so it wouldn't hurt. + } + + public PipedOutputStream () + { + closed = false; + } + + public PipedOutputStream (PipedInputStream dest) throws IOException + { + closed = false; + connect (dest); + } + + public void write (int oneByte) throws IOException + { + if (closed) + throw new IOException (); + destination.receive(oneByte); + } + + // This is mentioned in the JCL book, but we don't really need it. + // If there were a corresponding receive() method on + // PipedInputStream then we could get better performance using + // this. + // public void write (byte[] buffer, int offset, int count) + // throws IOException; + + // Instance variables. + private PipedInputStream destination; + private boolean closed; +} |