aboutsummaryrefslogtreecommitdiff
path: root/libjava/java/io
diff options
context:
space:
mode:
authorDavid Daney <ddaney@avtrex.com>2005-03-15 16:46:51 +0000
committerDavid Daney <daney@gcc.gnu.org>2005-03-15 16:46:51 +0000
commit6dcd18b9aa78af93366156bb253d4bfaa89a3e8d (patch)
tree91fdc7ab4a90e289342eb60ae6b642f5dfe516af /libjava/java/io
parent4f51c6e7ca17e29ad16c1d346d26fa16e16df3ad (diff)
downloadgcc-6dcd18b9aa78af93366156bb253d4bfaa89a3e8d.zip
gcc-6dcd18b9aa78af93366156bb253d4bfaa89a3e8d.tar.gz
gcc-6dcd18b9aa78af93366156bb253d4bfaa89a3e8d.tar.bz2
natPlainSocketImplPosix.cc (read_helper): Handle count == 0 case.
2005-03-15 David Daney <ddaney@avtrex.com> * gnu/java/net/natPlainSocketImplPosix.cc (read_helper): Handle count == 0 case. 2005-03-15 David Daney <ddaney@avtrex.com> * java/io/BufferedInputStream.java (available): Use 'in' instead of 'super' for underlying stream access. (close): Ditto. (read(byte[], int, int)): Ditto. (refill): Ditto. (skip): Call skip on underlying stream when possible. From-SVN: r96516
Diffstat (limited to 'libjava/java/io')
-rw-r--r--libjava/java/io/BufferedInputStream.java22
1 files changed, 16 insertions, 6 deletions
diff --git a/libjava/java/io/BufferedInputStream.java b/libjava/java/io/BufferedInputStream.java
index bbb38c4..ce166b3 100644
--- a/libjava/java/io/BufferedInputStream.java
+++ b/libjava/java/io/BufferedInputStream.java
@@ -158,7 +158,7 @@ public class BufferedInputStream extends FilterInputStream
*/
public synchronized int available() throws IOException
{
- return count - pos + super.available();
+ return count - pos + in.available();
}
/**
@@ -173,7 +173,7 @@ public class BufferedInputStream extends FilterInputStream
buf = null;
pos = count = 0;
markpos = -1;
- super.close();
+ in.close();
}
/**
@@ -273,7 +273,7 @@ public class BufferedInputStream extends FilterInputStream
off += totalBytesRead;
len -= totalBytesRead;
- while (len > 0 && super.available() > 0 && refill())
+ while (len > 0 && in.available() > 0 && refill())
{
int remain = Math.min(count - pos, len);
System.arraycopy(buf, pos, b, off, remain);
@@ -327,8 +327,18 @@ public class BufferedInputStream extends FilterInputStream
while (n > 0L)
{
- if (pos >= count && !refill())
- break;
+ if (pos >= count)
+ {
+ if (markpos == -1)
+ {
+ // Buffer is empty and no mark is set, skip on the
+ // underlying stream.
+ n -= in.skip(n);
+ break;
+ }
+ else if (!refill())
+ break;
+ }
int numread = (int) Math.min((long) (count - pos), n);
pos += numread;
@@ -369,7 +379,7 @@ public class BufferedInputStream extends FilterInputStream
markpos = 0;
}
- int numread = super.read(buf, count, bufferSize);
+ int numread = in.read(buf, count, bufferSize);
if (numread <= 0) // EOF
return false;