aboutsummaryrefslogtreecommitdiff
path: root/libjava/java/io/PipedOutputStream.java
diff options
context:
space:
mode:
Diffstat (limited to 'libjava/java/io/PipedOutputStream.java')
-rw-r--r--libjava/java/io/PipedOutputStream.java94
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 0000000..9b06994
--- /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;
+}