From 839ba6c89542c55178aef8012b7dbeda0eb3d4ef Mon Sep 17 00:00:00 2001 From: Tom Tromey Date: Thu, 11 May 2000 17:05:03 +0000 Subject: ZipInputStream.java (getNextEntry): When reading file headers, don't include `size' in the skip call. * java/util/zip/ZipInputStream.java (getNextEntry): When reading file headers, don't include `size' in the skip call. From-SVN: r33850 --- libjava/ChangeLog | 5 +++++ libjava/java/util/zip/ZipInputStream.java | 10 ++++++++-- 2 files changed, 13 insertions(+), 2 deletions(-) (limited to 'libjava') diff --git a/libjava/ChangeLog b/libjava/ChangeLog index 00330e0..1117267 100644 --- a/libjava/ChangeLog +++ b/libjava/ChangeLog @@ -1,3 +1,8 @@ +2000-05-11 Tom Tromey + + * java/util/zip/ZipInputStream.java (getNextEntry): When reading + file headers, don't include `size' in the skip call. + 2000-05-10 Bryce McKinlay * java/lang/StringBuffer.java (delete): Call arrayCopy() correctly. diff --git a/libjava/java/util/zip/ZipInputStream.java b/libjava/java/util/zip/ZipInputStream.java index df0ef03..492cf67 100644 --- a/libjava/java/util/zip/ZipInputStream.java +++ b/libjava/java/util/zip/ZipInputStream.java @@ -1,4 +1,4 @@ -/* Copyright (C) 1999 Free Software Foundation +/* Copyright (C) 1999, 2000 Free Software Foundation This file is part of libgcj. @@ -52,7 +52,13 @@ public class ZipInputStream extends InflaterInputStream implements ZipConstants int fname_length = readu2(); int extra_length = readu2(); int fcomment_length = readu2(); - in.skip(12+fname_length+extra_length+fcomment_length+size); + // `12' is the number of bytes between the comment length + // field and the end of the fixed part of the header: + // 2 bytes for `disk number start' + // 2 bytes for `internal file attributes' + // 4 bytes for `external file attributes' + // 4 bytes for `relative offset of local header' + in.skip(12 + fname_length + extra_length + fcomment_length); if (in.read() != 'P' || in.read() != 'K') return null; code = in.read(); -- cgit v1.1