Package com.adobe.internal.io
Class InputStreamByteWriter
java.lang.Object
com.adobe.internal.io.InputStreamByteWriter
- All Implemented Interfaces:
ByteReader,ByteWriter
This class provides convenience functionality to take an InputStream
and buffer the bytes from it and create an appropriate ByteReader
implementation to wrap those bytes.
-
Field Summary
Fields inherited from interface com.adobe.internal.io.ByteReader
EOF -
Constructor Summary
ConstructorsConstructorDescriptionInputStreamByteWriter(InputStream inputStream) Creates a new InputStreamByteWriter from the given InputStream.InputStreamByteWriter(InputStream inputStream, RandomAccessFile raf) Creates a new InputStreamByteWriter from the given InputStream. -
Method Summary
Modifier and TypeMethodDescriptionvoidclose()Closes thisByteReaderand releases any system resources associated with this stream.voidflush()Flushes thisByteWriterand forces any buffered output bytes to be written out.longlength()Returns the number of total bytes in the repository that are visible through this API.intread(long position) Read a single byte from the underlying bytes at the given position.intread(long position, byte[] b, int offset, int length) Transfers bytes from the underlying repository into the given destination array.toString()voidwrite(long position, byte[] b, int offset, int length) Write an array of bytes at the position given.voidwrite(long position, int b) Write the byte given at the position given.
-
Constructor Details
-
InputStreamByteWriter
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:
IOException
-
InputStreamByteWriter
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 returnss 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:
IOException
-
-
Method Details
-
read
Description copied from interface:ByteReaderRead a single byte from the underlying bytes at the given position.- Specified by:
readin 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:
IOException- if an error occurs during the read operation- See Also:
-
read
Description copied from interface:ByteReaderTransfers bytes from the underlying repository into the given destination array. Copy up tolengthbytes from the repository starting at the postion given into the given array starting at the given offset.- Specified by:
readin 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:
IOException- if an error occurs during the read operation- See Also:
-
length
Description copied from interface:ByteReaderReturns the number of total bytes in the repository that are visible through this API.- Specified by:
lengthin interfaceByteReader- Returns:
- the number of bytes in the repository.
- Throws:
IOException- if an error occurs while trying to determine the length- See Also:
-
close
Description copied from interface:ByteReaderCloses thisByteReaderand releases any system resources associated with this stream.- Specified by:
closein interfaceByteReader- Throws:
IOException- if an error occurs while trying to close- See Also:
-
toString
-
write
Write the byte given at the position given.- Specified by:
writein interfaceByteWriter- Parameters:
position- the zero-based offset within the byte array.b- the byte to write.- Throws:
IOException
-
write
Write an array of bytes at the position given.- Specified by:
writein interfaceByteWriter- Parameters:
position- the zero-based offset within the byte array.b- the array of bytes to write from.offset- the offset within the byte array to start writing from.length- the number of bytes to write from the byte array.- Throws:
IOException
-
flush
Flushes thisByteWriterand forces any buffered output bytes to be written out.- Specified by:
flushin interfaceByteWriter- Throws:
IOException
-