2015-03-13 18:52:59 +00:00
|
|
|
/* Copyright (c) 2008-2015, Avian Contributors
|
2008-02-19 18:06:52 +00:00
|
|
|
|
|
|
|
Permission to use, copy, modify, and/or distribute this software
|
|
|
|
for any purpose with or without fee is hereby granted, provided
|
|
|
|
that the above copyright notice and this permission notice appear
|
|
|
|
in all copies.
|
|
|
|
|
|
|
|
There is NO WARRANTY for this software. See license.txt for
|
|
|
|
details. */
|
|
|
|
|
2007-07-25 00:34:45 +00:00
|
|
|
package java.io;
|
|
|
|
|
|
|
|
public class BufferedInputStream extends InputStream {
|
|
|
|
private final InputStream in;
|
|
|
|
private final byte[] buffer;
|
|
|
|
private int position;
|
|
|
|
private int limit;
|
|
|
|
|
|
|
|
public BufferedInputStream(InputStream in, int size) {
|
|
|
|
this.in = in;
|
|
|
|
this.buffer = new byte[size];
|
|
|
|
}
|
|
|
|
|
|
|
|
public BufferedInputStream(InputStream in) {
|
2010-01-10 01:20:15 +00:00
|
|
|
this(in, 4096);
|
2007-07-25 00:34:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
private void fill() throws IOException {
|
|
|
|
position = 0;
|
|
|
|
limit = in.read(buffer);
|
|
|
|
}
|
|
|
|
|
|
|
|
public int read() throws IOException {
|
|
|
|
if (position >= limit) {
|
|
|
|
fill();
|
|
|
|
if (limit == -1) {
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2008-09-02 20:54:34 +00:00
|
|
|
return buffer[position++] & 0xFF;
|
2007-07-25 00:34:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public int read(byte[] b, int offset, int length) throws IOException {
|
|
|
|
int count = 0;
|
|
|
|
|
|
|
|
if (position < limit) {
|
|
|
|
int remaining = limit - position;
|
|
|
|
if (remaining > length) {
|
|
|
|
remaining = length;
|
|
|
|
}
|
|
|
|
|
|
|
|
System.arraycopy(buffer, position, b, offset, remaining);
|
|
|
|
|
|
|
|
count += remaining;
|
|
|
|
position += remaining;
|
|
|
|
offset += remaining;
|
|
|
|
length -= remaining;
|
|
|
|
}
|
|
|
|
|
2010-09-17 22:08:42 +00:00
|
|
|
while (length > 0) {
|
2007-07-25 00:34:45 +00:00
|
|
|
int c = in.read(b, offset, length);
|
|
|
|
if (c == -1) {
|
|
|
|
if (count == 0) {
|
|
|
|
count = -1;
|
|
|
|
}
|
2010-09-17 22:08:42 +00:00
|
|
|
break;
|
2007-07-25 00:34:45 +00:00
|
|
|
} else {
|
2011-02-09 01:56:25 +00:00
|
|
|
offset += c;
|
2007-07-25 00:34:45 +00:00
|
|
|
count += c;
|
2010-12-01 22:41:55 +00:00
|
|
|
length -= c;
|
2010-09-17 22:08:42 +00:00
|
|
|
|
|
|
|
if (in.available() <= 0) {
|
|
|
|
break;
|
|
|
|
}
|
2007-07-25 00:34:45 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return count;
|
|
|
|
}
|
|
|
|
|
2010-08-05 00:35:16 +00:00
|
|
|
public int available() throws IOException {
|
|
|
|
return in.available() + (limit - position);
|
|
|
|
}
|
|
|
|
|
2007-07-25 00:34:45 +00:00
|
|
|
public void close() throws IOException {
|
|
|
|
in.close();
|
|
|
|
}
|
|
|
|
}
|