aboutsummaryrefslogtreecommitdiff
path: root/libjava/java/io/BufferedReader.java
diff options
context:
space:
mode:
authorGuilhem Lavaux <guilhem@kaffe.org>2003-12-28 11:54:17 +0000
committerMichael Koch <mkoch@gcc.gnu.org>2003-12-28 11:54:17 +0000
commit920be544c9470f7606623a82b1ca8b5ace4d58cd (patch)
tree41837312c288c51281dc7c93eade8553e241f38a /libjava/java/io/BufferedReader.java
parent07dc48e01452222a461e6660d242cf497b3f584d (diff)
downloadgcc-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.java15
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,