mirror of
git://gcc.gnu.org/git/gcc.git
synced 2025-01-25 09:13:59 +08:00
8559f9bb2f
2000-08-20 Mark Wielaard <mark@klomp.org> * java/util/zip/Adler32.java: Make private variables really private * java/util/zip/CRC32.java: Make private variables really private * java/util/zip/CheckedInputStream.java: skip() could skip to much bytes * java/util/zip/InflaterInputStream.java: skip() could skip to much bytes * java/util/zip/ZipEntry.java: setCompressedSize() didn't check input * java/util/zip/ZipFile.java: size() new 1.2 method * java/util/zip/ZipInputStream.java: Use createZipEntry not new ZipEntry. since 1.2 available() always returns just 1 or 0 when closed From-SVN: r35826
82 lines
1.5 KiB
Java
82 lines
1.5 KiB
Java
// CheckedInputStream.java - Compute checksum of data being read.
|
|
|
|
/* Copyright (C) 1999 Free Software Foundation
|
|
|
|
This file is part of libgcj.
|
|
|
|
This software is copyrighted work licensed under the terms of the
|
|
Libgcj License. Please consult the file "LIBGCJ_LICENSE" for
|
|
details. */
|
|
|
|
package java.util.zip;
|
|
|
|
import java.io.FilterInputStream;
|
|
import java.io.InputStream;
|
|
import java.io.IOException;
|
|
|
|
/**
|
|
* @author Tom Tromey
|
|
* @date May 17, 1999
|
|
*/
|
|
|
|
/* Written using on-line Java Platform 1.2 API Specification
|
|
* and JCL book.
|
|
* Believed complete and correct.
|
|
*/
|
|
|
|
public class CheckedInputStream extends FilterInputStream
|
|
{
|
|
public CheckedInputStream (InputStream in, Checksum sum)
|
|
{
|
|
super (in);
|
|
this.sum = sum;
|
|
}
|
|
|
|
public Checksum getChecksum ()
|
|
{
|
|
return sum;
|
|
}
|
|
|
|
public int read () throws IOException
|
|
{
|
|
int x = in.read();
|
|
if (x != -1)
|
|
sum.update(x);
|
|
return x;
|
|
}
|
|
|
|
public int read (byte[] buf, int off, int len) throws IOException
|
|
{
|
|
int r = in.read(buf, off, len);
|
|
if (r != -1)
|
|
sum.update(buf, off, r);
|
|
return r;
|
|
}
|
|
|
|
public long skip (long n) throws IOException
|
|
{
|
|
if (n == 0)
|
|
return 0;
|
|
|
|
int min = (int) Math.min(n, 1024);
|
|
byte[] buf = new byte[min];
|
|
|
|
long s = 0;
|
|
while (n > 0)
|
|
{
|
|
int r = in.read(buf, 0, min);
|
|
if (r == -1)
|
|
break;
|
|
n -= r;
|
|
s += r;
|
|
min = (int) Math.min(n, 1024);
|
|
sum.update(buf, 0, r);
|
|
}
|
|
|
|
return s;
|
|
}
|
|
|
|
// The checksum object.
|
|
private Checksum sum;
|
|
}
|