summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authortromey <tromey@138bc75d-0d04-0410-961f-82ee72b054a4>1999-05-22 18:08:46 +0000
committertromey <tromey@138bc75d-0d04-0410-961f-82ee72b054a4>1999-05-22 18:08:46 +0000
commit5128a3111fc77771864dcf70c872d7ac7bf835e4 (patch)
tree6128e2388588a5c77d006bb9db245ed589d04041
parent2f02c5fc098c7270554e3b3c1cb9dc3b973bc580 (diff)
downloadgcc-5128a3111fc77771864dcf70c872d7ac7bf835e4.tar.gz
* java/util/zip/ZipInputStream.java (fill): New method.
(compressed_len): New instance variable. (getNextStream): Set it. (read): Reset inflater on EOF. Only read via `super' if entry is deflated. (skip): Only skip via `super' if entry is deflated. * java/util/zip/Deflater.java (last_input_count): Removed. * java/util/zip/natDeflater.cc (deflate): Return 0 if input array is length 0. (needsInput): Don't use last_input_count. (setInput): Don't set last_input_count. * java/util/zip/natInflater.cc (getRemaining): Return correct result. (inflate): Return 0 if input array is length 0. (setInput): Don't set last_input_count. * java/util/zip/Inflater.java (last_input_count): Removed. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@27105 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r--libjava/ChangeLog19
-rw-r--r--libjava/java/util/zip/Deflater.java3
-rw-r--r--libjava/java/util/zip/Inflater.java3
-rw-r--r--libjava/java/util/zip/ZipInputStream.java49
-rw-r--r--libjava/java/util/zip/natDeflater.cc6
-rw-r--r--libjava/java/util/zip/natInflater.cc6
6 files changed, 68 insertions, 18 deletions
diff --git a/libjava/ChangeLog b/libjava/ChangeLog
index 225d397a924..791fa6f1534 100644
--- a/libjava/ChangeLog
+++ b/libjava/ChangeLog
@@ -1,3 +1,22 @@
+1999-05-22 Tom Tromey <tromey@cygnus.com>
+
+ * java/util/zip/ZipInputStream.java (fill): New method.
+ (compressed_len): New instance variable.
+ (getNextStream): Set it.
+ (read): Reset inflater on EOF. Only read via `super' if entry is
+ deflated.
+ (skip): Only skip via `super' if entry is deflated.
+ * java/util/zip/Deflater.java (last_input_count): Removed.
+ * java/util/zip/natDeflater.cc (deflate): Return 0 if input array
+ is length 0.
+ (needsInput): Don't use last_input_count.
+ (setInput): Don't set last_input_count.
+ * java/util/zip/natInflater.cc (getRemaining): Return correct
+ result.
+ (inflate): Return 0 if input array is length 0.
+ (setInput): Don't set last_input_count.
+ * java/util/zip/Inflater.java (last_input_count): Removed.
+
1999-05-21 Tom Tromey <tromey@cygnus.com>
* Makefile.in: Rebuilt.
diff --git a/libjava/java/util/zip/Deflater.java b/libjava/java/util/zip/Deflater.java
index 70855c5a3bc..3c45b285544 100644
--- a/libjava/java/util/zip/Deflater.java
+++ b/libjava/java/util/zip/Deflater.java
@@ -124,9 +124,6 @@ public class Deflater
// True if finished.
private boolean is_finished;
- // Total number of bytes made available at last setInput.
- private int last_input_count;
-
// `Flush' flag to pass to next call to deflate.
private int flush_flag;
}
diff --git a/libjava/java/util/zip/Inflater.java b/libjava/java/util/zip/Inflater.java
index 724b5b4a1b5..8e9fc6ab4b2 100644
--- a/libjava/java/util/zip/Inflater.java
+++ b/libjava/java/util/zip/Inflater.java
@@ -95,7 +95,4 @@ public class Inflater
// True if dictionary needed.
private boolean dict_needed;
-
- // Total number of bytes made available at last setInput.
- private int last_input_count;
}
diff --git a/libjava/java/util/zip/ZipInputStream.java b/libjava/java/util/zip/ZipInputStream.java
index f2e042b8faf..224e7859cfc 100644
--- a/libjava/java/util/zip/ZipInputStream.java
+++ b/libjava/java/util/zip/ZipInputStream.java
@@ -28,13 +28,9 @@ import java.io.*;
public class ZipInputStream extends InflaterInputStream
{
- ZipEntry current;
- int current_flags;
- int avail;
-
public ZipInputStream (InputStream in)
{
- super(in);
+ super (in, new Inflater (true));
}
public ZipEntry getNextEntry () throws IOException
@@ -101,15 +97,41 @@ public class ZipInputStream extends InflaterInputStream
entry.time = ZipEntry.timeFromDOS(moddate, modtime);
current = entry;
avail = uncompressedSize;
+ compressed_bytes = compressedSize;
return entry;
}
+ // We override fill to let us control how much data gets read from
+ // the underlying input stream. This lets us avoid having to push
+ // back data.
+ protected void fill () throws IOException
+ {
+ int count = buf.length;
+ if (count > compressed_bytes)
+ count = compressed_bytes;
+ len = in.read(buf, 0, count);
+ if (len != -1)
+ {
+ compressed_bytes -= len;
+ inf.setInput(buf, 0, len);
+ }
+ }
+
public int read (byte[] b, int off, int len) throws IOException
{
if (len > avail)
len = avail;
- int count = super.read(b, off, len);
- if (count > 0)
+ int count;
+ if (current.method == Deflater.DEFLATED)
+ count = super.read(b, off, len);
+ else
+ count = in.read(b, off, len);
+ if (count == -1 || avail == 0)
+ {
+ inf.reset();
+ count = -1;
+ }
+ else
avail -= count;
return count;
}
@@ -118,7 +140,11 @@ public class ZipInputStream extends InflaterInputStream
{
if (n > avail)
n = avail;
- long count = super.skip(n);
+ long count;
+ if (current.method == Deflater.DEFLATED)
+ count = super.skip(n);
+ else
+ count = in.skip(n);
avail = avail - (int) count;
return count;
}
@@ -187,4 +213,11 @@ public class ZipInputStream extends InflaterInputStream
current = null;
super.close();
}
+
+ private ZipEntry current;
+ private int current_flags;
+ // Number of uncompressed bytes to be read.
+ private int avail;
+ // Number of bytes we can read from underlying stream.
+ private int compressed_bytes;
}
diff --git a/libjava/java/util/zip/natDeflater.cc b/libjava/java/util/zip/natDeflater.cc
index 58d873a970a..566f918a77a 100644
--- a/libjava/java/util/zip/natDeflater.cc
+++ b/libjava/java/util/zip/natDeflater.cc
@@ -41,6 +41,9 @@ java::util::zip::Deflater::deflate (jbyteArray buf, jint off, jint len)
if (off < 0 || len < 0 || off + len > buf->length)
_Jv_Throw (new java::lang::ArrayIndexOutOfBoundsException);
+ if (len == 0)
+ return 0;
+
s->next_out = (Bytef *) (elements (buf) + off);
s->avail_out = len;
@@ -111,7 +114,7 @@ java::util::zip::Deflater::needsInput ()
{
JvSynchronize sync (this);
z_streamp s = (z_streamp) zstream;
- return s->avail_in - last_input_count == 0;
+ return s->avail_in == 0;
}
void
@@ -150,7 +153,6 @@ java::util::zip::Deflater::setInput (jbyteArray buf, jint off, jint len)
if (off < 0 || len < 0 || off + len > buf->length)
_Jv_Throw (new java::lang::ArrayIndexOutOfBoundsException);
- last_input_count = len;
s->next_in = (Bytef *) (elements (buf) + off);
s->avail_in = len;
}
diff --git a/libjava/java/util/zip/natInflater.cc b/libjava/java/util/zip/natInflater.cc
index 4b83835e662..6fc9e3deaab 100644
--- a/libjava/java/util/zip/natInflater.cc
+++ b/libjava/java/util/zip/natInflater.cc
@@ -68,7 +68,7 @@ java::util::zip::Inflater::getRemaining ()
{
JvSynchronize sync (this);
z_streamp s = (z_streamp) zstream;
- return s->avail_in - last_input_count;
+ return s->avail_in;
}
jint
@@ -98,6 +98,9 @@ java::util::zip::Inflater::inflate (jbyteArray buf, jint off, jint len)
if (off < 0 || len < 0 || off + len > buf->length)
_Jv_Throw (new java::lang::ArrayIndexOutOfBoundsException);
+ if (len == 0)
+ return 0;
+
s->next_out = (Bytef *) (elements (buf) + off);
s->avail_out = len;
@@ -169,7 +172,6 @@ java::util::zip::Inflater::setInput (jbyteArray buf, jint off, jint len)
if (off < 0 || len < 0 || off + len > buf->length)
_Jv_Throw (new java::lang::ArrayIndexOutOfBoundsException);
- last_input_count = len;
s->next_in = (Bytef *) (elements (buf) + off);
s->avail_in = len;
}