diff options
author | Tom Tromey <tromey@cygnus.com> | 1999-05-22 18:08:46 +0000 |
---|---|---|
committer | Tom Tromey <tromey@gcc.gnu.org> | 1999-05-22 18:08:46 +0000 |
commit | 93d627acaaea8f139ddeead526be0ece47691a6e (patch) | |
tree | 6128e2388588a5c77d006bb9db245ed589d04041 /libjava/java/util/zip/natDeflater.cc | |
parent | 5256aa37b4d72f98157015eae9b53aba21789d3b (diff) | |
download | gcc-93d627acaaea8f139ddeead526be0ece47691a6e.zip gcc-93d627acaaea8f139ddeead526be0ece47691a6e.tar.gz gcc-93d627acaaea8f139ddeead526be0ece47691a6e.tar.bz2 |
ZipInputStream.java (fill): New method.
* 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.
From-SVN: r27105
Diffstat (limited to 'libjava/java/util/zip/natDeflater.cc')
-rw-r--r-- | libjava/java/util/zip/natDeflater.cc | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/libjava/java/util/zip/natDeflater.cc b/libjava/java/util/zip/natDeflater.cc index 58d873a..566f918 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; } |