diff options
author | Guilhem Lavaux <guilhem@kaffe.org> | 2003-12-28 11:54:17 +0000 |
---|---|---|
committer | Michael Koch <mkoch@gcc.gnu.org> | 2003-12-28 11:54:17 +0000 |
commit | 920be544c9470f7606623a82b1ca8b5ace4d58cd (patch) | |
tree | 41837312c288c51281dc7c93eade8553e241f38a /libjava/java/io/BufferedReader.java | |
parent | 07dc48e01452222a461e6660d242cf497b3f584d (diff) | |
download | gcc-920be544c9470f7606623a82b1ca8b5ace4d58cd.zip gcc-920be544c9470f7606623a82b1ca8b5ace4d58cd.tar.gz gcc-920be544c9470f7606623a82b1ca8b5ace4d58cd.tar.bz2 |
2003-12-28 Guilhem Lavaux <guilhem@kaffe.org>
* java/io/LineNumberReader.java
(mark): Improved error checking.
(read): Likewise.
(skip): Likewise. Skip is now really eating the specified number of
characters.
* java/io/CharArrayReader.java (read): It should throw
IndexOutOfBoundsException and not ArrayIndexOutOfBoundsException (see
mauve).
* java/io/BufferedReader.java (readLine): Make readLine() really block
until either EOF is reached or a true error happens.
From-SVN: r75180
Diffstat (limited to 'libjava/java/io/BufferedReader.java')
-rw-r--r-- | libjava/java/io/BufferedReader.java | 15 |
1 files changed, 11 insertions, 4 deletions
diff --git a/libjava/java/io/BufferedReader.java b/libjava/java/io/BufferedReader.java index 73fb47c..e29c8dd 100644 --- a/libjava/java/io/BufferedReader.java +++ b/libjava/java/io/BufferedReader.java @@ -460,12 +460,19 @@ public class BufferedReader extends Reader boolean eof = false; for (;;) { - int ch = read(); - if (ch < 0) + // readLine should block. So we must not return until a -1 is reached. + if (pos >= limit) { - eof = true; - break; + // here count == 0 isn't sufficient to give a failure. + int count = fill(); + if (count < 0) + { + eof = true; + break; + } + continue; } + int ch = buffer[pos++]; if (ch == '\n' || ch == '\r') { // Check here if a '\r' was the last char in the buffer; if so, |