Package sk.iway.iwcm.system.zip
Class InflaterInputStream
java.lang.Object
java.io.InputStream
java.io.FilterInputStream
sk.iway.iwcm.system.zip.InflaterInputStream
- All Implemented Interfaces:
Closeable
,AutoCloseable
- Direct Known Subclasses:
ZipInputStream
This class implements a stream filter for uncompressing data in the
"deflate" compression format. It is also used as the basis for other
decompression filters, such as GZIPInputStream.
- See Also:
-
Field Summary
FieldsModifier and TypeFieldDescriptionprotected byte[]
Input buffer for decompression.protected Inflater
Decompressor for this stream.protected int
Length of input buffer.Fields inherited from class java.io.FilterInputStream
in
-
Constructor Summary
ConstructorsConstructorDescriptionCreates a new input stream with a default decompressor and buffer size.InflaterInputStream
(InputStream in, Inflater inf) Creates a new input stream with the specified decompressor and a default buffer size.InflaterInputStream
(InputStream in, Inflater inf, int size) Creates a new input stream with the specified decompressor and buffer size. -
Method Summary
Modifier and TypeMethodDescriptionint
Returns 0 after EOF has reached, otherwise always return 1.void
close()
Closes the input stream.protected void
fill()
Fills input buffer with more data to decompress.int
read()
Reads a byte of uncompressed data.int
read
(byte[] b, int off, int len) Reads uncompressed data into an array of bytes.long
skip
(long n) Skips specified number of bytes of uncompressed data.Methods inherited from class java.io.FilterInputStream
mark, markSupported, read, reset
Methods inherited from class java.io.InputStream
nullInputStream, readAllBytes, readNBytes, readNBytes, skipNBytes, transferTo
-
Field Details
-
inf
Decompressor for this stream. -
buf
protected byte[] bufInput buffer for decompression. -
len
protected int lenLength of input buffer.
-
-
Constructor Details
-
InflaterInputStream
Creates a new input stream with the specified decompressor and buffer size.- Parameters:
in
- the input streaminf
- the decompressor ("inflater")size
- the input buffer size- Throws:
IllegalArgumentException
- if size is <= 0
-
InflaterInputStream
Creates a new input stream with the specified decompressor and a default buffer size.- Parameters:
in
- the input streaminf
- the decompressor ("inflater")
-
InflaterInputStream
Creates a new input stream with a default decompressor and buffer size.- Parameters:
in
- the input stream
-
-
Method Details
-
read
Reads a byte of uncompressed data. This method will block until enough input is available for decompression.- Overrides:
read
in classFilterInputStream
- Returns:
- the byte read, or -1 if end of compressed input is reached
- Throws:
IOException
- if an I/O error has occurred
-
read
Reads uncompressed data into an array of bytes. This method will block until some input can be decompressed.- Overrides:
read
in classFilterInputStream
- Parameters:
b
- the buffer into which the data is readoff
- the start offset of the datalen
- the maximum number of bytes read- Returns:
- the actual number of bytes read, or -1 if the end of the compressed input is reached or a preset dictionary is needed
- Throws:
ZipException
- if a ZIP format error has occurredIOException
- if an I/O error has occurred
-
available
Returns 0 after EOF has reached, otherwise always return 1.Programs should not count on this method to return the actual number of bytes that could be read without blocking.
- Overrides:
available
in classFilterInputStream
- Returns:
- 1 before EOF and 0 after EOF.
- Throws:
IOException
- if an I/O error occurs.
-
skip
Skips specified number of bytes of uncompressed data.- Overrides:
skip
in classFilterInputStream
- Parameters:
n
- the number of bytes to skip- Returns:
- the actual number of bytes skipped.
- Throws:
IOException
- if an I/O error has occurredIllegalArgumentException
- if n < 0
-
close
Closes the input stream.- Specified by:
close
in interfaceAutoCloseable
- Specified by:
close
in interfaceCloseable
- Overrides:
close
in classFilterInputStream
- Throws:
IOException
- if an I/O error has occurred
-
fill
Fills input buffer with more data to decompress.- Throws:
IOException
- if an I/O error has occurred
-