Package com.adobe.internal.io
Class InputStreamByteReader
- java.lang.Object
-
- com.adobe.internal.io.InputStreamByteReader
-
- All Implemented Interfaces:
ByteReader
public class InputStreamByteReader extends java.lang.Object
AByteReader
that converts aInputStream
to either an array of bytes or aRandomAccessFile
before wrapping the data with aByteReader
. This class is not threadsafe. It is not safe to pass an instance of this class to multiple threads. It is not safe to pass an instance of this class to multiple users even if in the same thread.
-
-
Field Summary
-
Fields inherited from interface com.adobe.internal.io.ByteReader
EOF
-
-
Constructor Summary
Constructors Constructor Description InputStreamByteReader(java.io.InputStream inputStream)
Creates a new InputStreamByteWriter from the given InputStream.InputStreamByteReader(java.io.InputStream inputStream, java.io.RandomAccessFile raf)
Creates a new InputStreamByteWriter from the given InputStream.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description void
close()
Closes thisByteReader
and releases any system resources associated with this stream.long
length()
Returns the number of total bytes in the repository that are visible through this API.int
read(long position)
Read a single byte from the underlying bytes at the given position.int
read(long position, byte[] b, int offset, int length)
Transfers bytes from the underlying repository into the given destination array.
-
-
-
Constructor Detail
-
InputStreamByteReader
public InputStreamByteReader(java.io.InputStream inputStream) throws java.io.IOException
Creates a new InputStreamByteWriter from the given InputStream. This reads all of the bytes from the InputStream into memory and then wraps those bytes with a ByteArrayByteReader. Once the constructor returns the stream will have been fully read and closed.- Parameters:
inputStream
- the source of the bytes.- Throws:
java.io.IOException
-
InputStreamByteReader
public InputStreamByteReader(java.io.InputStream inputStream, java.io.RandomAccessFile raf) throws java.io.IOException
Creates a new InputStreamByteWriter from the given InputStream. This reads all of the bytes from the InputStream into the RandomAccessFile provided and then wraps that file with a RandomAccessFileByteReader. Once the constructor returns the stream will have been fully read and closed. The provided RandomAccessFile must have read and write access.- Parameters:
inputStream
- the source of the bytes.raf
- the location to buffer those bytes to.- Throws:
java.io.IOException
-
-
Method Detail
-
read
public int read(long position) throws java.io.IOException
Description copied from interface:ByteReader
Read a single byte from the underlying bytes at the given position.- Specified by:
read
in interfaceByteReader
- Parameters:
position
- the position to read the byte from.- Returns:
- the byte at the postion or EOF if the position is outside of the legal range.
- Throws:
java.io.IOException
- if an error occurs during the read operation- See Also:
ByteReader.read(long)
-
read
public int read(long position, byte[] b, int offset, int length) throws java.io.IOException
Description copied from interface:ByteReader
Transfers bytes from the underlying repository into the given destination array. Copy up tolength
bytes from the repository starting at the postion given into the given array starting at the given offset.- Specified by:
read
in interfaceByteReader
- Parameters:
position
- the position to read the byte from.b
- the array to write the bytes into.offset
- the offset in the array at which the first byte is written.length
- the maximum number of bytes to write into the array.- Returns:
- the number of bytes actually written to the array.
- Throws:
java.io.IOException
- if an error occurs during the read operation- See Also:
ByteReader.read(long, byte[], int, int)
-
length
public long length() throws java.io.IOException
Description copied from interface:ByteReader
Returns the number of total bytes in the repository that are visible through this API.- Specified by:
length
in interfaceByteReader
- Returns:
- the number of bytes in the repository.
- Throws:
java.io.IOException
- if an error occurs while trying to determine the length- See Also:
ByteReader.length()
-
close
public void close() throws java.io.IOException
Description copied from interface:ByteReader
Closes thisByteReader
and releases any system resources associated with this stream.- Specified by:
close
in interfaceByteReader
- Throws:
java.io.IOException
- if an error occurs while trying to close- See Also:
ByteReader.close()
-
-