aboutsummaryrefslogtreecommitdiff
path: root/libjava/java/io/CharArrayReader.java
diff options
context:
space:
mode:
authorTom Tromey <tromey@redhat.com>2001-02-13 18:55:13 +0000
committerTom Tromey <tromey@gcc.gnu.org>2001-02-13 18:55:13 +0000
commitf3b43865acd32bed18eb7316eb8f9916bf8bfc9e (patch)
treec25167f3e73e64441f8cd01df631a5cab6684b6c /libjava/java/io/CharArrayReader.java
parent967eb03e12d367a679c5a33a0fc13297dfadf327 (diff)
downloadgcc-f3b43865acd32bed18eb7316eb8f9916bf8bfc9e.zip
gcc-f3b43865acd32bed18eb7316eb8f9916bf8bfc9e.tar.gz
gcc-f3b43865acd32bed18eb7316eb8f9916bf8bfc9e.tar.bz2
PipedReader.java (ready): Throw IOException if pipe closed.
* java/io/PipedReader.java (ready): Throw IOException if pipe closed. * java/io/FilterReader.java (close): Don't clear `in'. * java/io/CharArrayReader.java (mark): Throw IOException if stream closed. (read, ready, reset, skip): Added exception message. * java/io/BufferedReader.java (mark, reset, ready, read, skip): Perform checkStatus check inside synchronized block. From-SVN: r39641
Diffstat (limited to 'libjava/java/io/CharArrayReader.java')
-rw-r--r--libjava/java/io/CharArrayReader.java16
1 files changed, 9 insertions, 7 deletions
diff --git a/libjava/java/io/CharArrayReader.java b/libjava/java/io/CharArrayReader.java
index 1954036..0a77998 100644
--- a/libjava/java/io/CharArrayReader.java
+++ b/libjava/java/io/CharArrayReader.java
@@ -1,4 +1,4 @@
-/* Copyright (C) 1998, 1999 Free Software Foundation
+/* Copyright (C) 1998, 1999, 2001 Free Software Foundation
This file is part of libgcj.
@@ -63,10 +63,12 @@ public class CharArrayReader extends Reader
}
}
- public void mark(int readAheadLimit)
+ public void mark(int readAheadLimit) throws IOException
{
synchronized (lock)
{
+ if (buf == null)
+ throw new IOException("Stream closed");
// readAheadLimit is ignored per Java Class Lib. book, p. 318.
markedPos = pos;
}
@@ -82,7 +84,7 @@ public class CharArrayReader extends Reader
synchronized (lock)
{
if (buf == null)
- throw new IOException();
+ throw new IOException("Stream closed");
if (pos < 0)
throw new ArrayIndexOutOfBoundsException(pos);
@@ -98,7 +100,7 @@ public class CharArrayReader extends Reader
synchronized (lock)
{
if (buf == null)
- throw new IOException();
+ throw new IOException("Stream closed");
/* Don't need to check pos value, arraycopy will check it. */
if (off < 0 || len < 0 || off + len > b.length)
@@ -117,7 +119,7 @@ public class CharArrayReader extends Reader
public boolean ready() throws IOException
{
if (buf == null)
- throw new IOException();
+ throw new IOException("Stream closed");
return true;
}
@@ -127,7 +129,7 @@ public class CharArrayReader extends Reader
synchronized (lock)
{
if (buf == null)
- throw new IOException();
+ throw new IOException("Stream closed");
pos = markedPos;
}
@@ -138,7 +140,7 @@ public class CharArrayReader extends Reader
synchronized (lock)
{
if (buf == null)
- throw new IOException();
+ throw new IOException("Stream closed");
// Even though the var numChars is a long, in reality it can never
// be larger than an int since the result of subtracting 2 positive