diff options
author | Tom Tromey <tromey@gcc.gnu.org> | 1999-04-07 14:42:40 +0000 |
---|---|---|
committer | Tom Tromey <tromey@gcc.gnu.org> | 1999-04-07 14:42:40 +0000 |
commit | ee9dd3721be68b9fa63dea9aa5a1d86e66958cde (patch) | |
tree | d96801a16fdf03a5682ef98730fe333a46eef944 /libjava/java/io/PipedWriter.java | |
parent | 140fa895c6b859f827fc4437b91775a82cd105fb (diff) | |
download | gcc-ee9dd3721be68b9fa63dea9aa5a1d86e66958cde.zip gcc-ee9dd3721be68b9fa63dea9aa5a1d86e66958cde.tar.gz gcc-ee9dd3721be68b9fa63dea9aa5a1d86e66958cde.tar.bz2 |
Initial revision
From-SVN: r26263
Diffstat (limited to 'libjava/java/io/PipedWriter.java')
-rw-r--r-- | libjava/java/io/PipedWriter.java | 88 |
1 files changed, 88 insertions, 0 deletions
diff --git a/libjava/java/io/PipedWriter.java b/libjava/java/io/PipedWriter.java new file mode 100644 index 0000000..c914cac --- /dev/null +++ b/libjava/java/io/PipedWriter.java @@ -0,0 +1,88 @@ +// PipedWriter.java - Piped character stream. + +/* 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 25, 1998 + */ + +/* Written using "Java Class Libraries", 2nd edition, ISBN 0-201-31002-3 + * "The Java Language Specification", ISBN 0-201-63451-1 + * Status: Complete to 1.1. + */ + +public class PipedWriter extends Writer +{ + public void close () throws IOException + { + closed = true; + } + + public void connect (PipedReader sink) throws IOException + { + if (closed) + throw new IOException ("already closed"); + if (reader != null) + { + if (reader == sink) + return; + throw new IOException ("already connected"); + } + try + { + reader = sink; + reader.connect(this); + } + catch (IOException e) + { + reader = null; + throw e; + } + } + + public void flush () throws IOException + { + // We'll throw an exception if we're closed, but there's nothing + // else to do here. + if (closed) + throw new IOException ("closed"); + } + + public PipedWriter () + { + super (); + closed = false; + } + + public PipedWriter (PipedReader sink) throws IOException + { + super (); + closed = false; + connect (sink); + } + + public void write (char buffer[], int offset, int count) throws IOException + { + if (closed) + throw new IOException ("closed"); + reader.receive(buffer, offset, count); + } + + boolean isClosed () + { + return closed; + } + + // The associated reader. + private PipedReader reader; + private boolean closed; +} |