Package com.adobe.internal.io
Class FilterByteWriter
- java.lang.Object
-
- com.adobe.internal.io.FilterByteWriter
-
- All Implemented Interfaces:
ByteReader,ByteWriter
- Direct Known Subclasses:
RangedByteWriter
public abstract class FilterByteWriter extends java.lang.Object implements ByteWriter
Filters wrap existing ByteWriters and will do conversion or other data mangling.
-
-
Field Summary
-
Fields inherited from interface com.adobe.internal.io.ByteReader
EOF
-
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidclose()Closes thisByteReaderand releases any system resources associated with this stream.voidflush()Flushes thisByteWriterand forces any unwritten buffered output bytes to be written out to the underlying repository.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.voidsetCloseOriginal(boolean closeOriginal)Changes whether the original ByteWriter is closed when this FilterByteWriter is closed.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.
-
-
-
Method Detail
-
setCloseOriginal
public void setCloseOriginal(boolean closeOriginal)
Changes whether the original ByteWriter is closed when this FilterByteWriter is closed. By default this is true.- Parameters:
closeOriginal- close original ByteWriter or not
-
flush
public void flush() throws java.io.IOExceptionDescription copied from interface:ByteWriterFlushes thisByteWriterand forces any unwritten buffered output bytes to be written out to the underlying repository.- Specified by:
flushin interfaceByteWriter- Throws:
java.io.IOException- if an error occurs while trying to flush the buffer
-
write
public void write(long position, int b) throws java.io.IOExceptionDescription copied from interface:ByteWriterWrite the byte given at the position given. If during the write operation the byte to be written is beyond the end of the virtual array visible through this interface then the length of that virtual array becomes the position of the byte written plus one (because of zero based counting).length of virtual array = max(length of virtual array, position of byte written + 1)- Specified by:
writein interfaceByteWriter- Parameters:
position- the zero-based offset within the byte array.b- the byte to write.- Throws:
java.io.IOException- if an error occurs during the write operation
-
write
public void write(long position, byte[] b, int offset, int length) throws java.io.IOExceptionDescription copied from interface:ByteWriterWrite an array of bytes at the position given. If during the write operation any of the bytes are to be written beyond the end of the virtual array visible through this interface then the length of that virtual array becomes the position of the byte written plus one (because of zero based counting). for each byte written :length of virtual array = max(length of virtual array, position of byte written + 1)- 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:
java.io.IOException- if an error occurs during the write operation
-
close
public void close() throws java.io.IOExceptionDescription copied from interface:ByteReaderCloses thisByteReaderand releases any system resources associated with this stream.- Specified by:
closein interfaceByteReader- Throws:
java.io.IOException- if an error occurs while trying to close
-
length
public long length() throws java.io.IOExceptionDescription 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:
java.io.IOException- if an error occurs while trying to determine the length
-
read
public int read(long position) throws java.io.IOExceptionDescription 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:
java.io.IOException- if an error occurs during the read operation
-
read
public int read(long position, byte[] b, int offset, int length) throws java.io.IOExceptionDescription 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:
java.io.IOException- if an error occurs during the read operation
-
-