|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectde.intarsys.tools.randomaccess.AbstractRandomAccess
de.intarsys.tools.randomaccess.RandomAccessFilter
public class RandomAccessFilter
Filter implementation for random access.
Field Summary | |
---|---|
protected IRandomAccess |
random
|
Constructor Summary | |
---|---|
RandomAccessFilter(IRandomAccess random)
|
Method Summary | |
---|---|
void |
close()
Closes this random access data container and releases any system resources associated with the stream. |
void |
flush()
Force changes to be made persistent. |
long |
getLength()
Returns the length of this data container. |
long |
getOffset()
Returns the current offset in this data container. |
protected IRandomAccess |
getRandom()
|
boolean |
isReadOnly()
true if this is a read only data container. |
int |
read()
Reads a byte of data from this data container. |
int |
read(byte[] buffer)
Reads up to buffer.length bytes of data from this data
container into an array of bytes. |
int |
read(byte[] buffer,
int start,
int numBytes)
Reads up to len bytes of data from this data container into
an array of bytes. |
void |
seek(long offset)
Sets the offset, measured from the beginning of the data container at which the next read or write occurs. |
void |
seekBy(long delta)
Sets the offset, measured from the current offset at which the next read or write occurs. |
void |
setLength(long newLength)
Assign the length. |
void |
write(byte[] buffer)
Writes b.length bytes from the specified byte array,
starting at the current offset. |
void |
write(byte[] buffer,
int start,
int numBytes)
Writes len bytes from the specified byte array starting at
start . |
void |
write(int b)
Writes the specified byte . |
Methods inherited from class de.intarsys.tools.randomaccess.AbstractRandomAccess |
---|
asInputStream, asOutputStream, getPositionStack, mark, reset |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
protected IRandomAccess random
Constructor Detail |
---|
public RandomAccessFilter(IRandomAccess random)
Method Detail |
---|
public void seek(long offset) throws java.io.IOException
IRandomAccess
offset
- the offset position, measured in bytes from the beginning of
the data container
java.io.IOException
- if offset
is less than 0
or if
an I/O error occurs.public void seekBy(long delta) throws java.io.IOException
IRandomAccess
delta
- the amount of bytes by which to change the current offset
position
java.io.IOException
- if the resulting offset
is less than
0
or if an I/O error occurs.public int read() throws java.io.IOException
IRandomAccess
0x00-0x0ff
). This method
blocks if no input is yet available.
This method behaves in exactly the same way as the
InputStream.read()
method of InputStream
.
-1
if the end of the data
container has been reached.
java.io.IOException
- if an I/O error occurs. Not thrown if the end of the data
container has been reached.public long getOffset() throws java.io.IOException
IRandomAccess
java.io.IOException
- if an I/O error occurs.public long getLength() throws java.io.IOException
IRandomAccess
java.io.IOException
- if an I/O error occurs.protected IRandomAccess getRandom()
public void setLength(long newLength) throws java.io.IOException
IRandomAccess
java.io.IOException
public int read(byte[] buffer) throws java.io.IOException
IRandomAccess
buffer.length
bytes of data from this data
container into an array of bytes. This method blocks until at least one
byte of input is available.
This method behaves in the exactly the same way as the
InputStream.read(byte[])
method of InputStream
.
buffer
- the buffer into which the data is read.
-1
if there is no more data because the end of this
data container has been reached.
java.io.IOException
- if an I/O error occurs.public int read(byte[] buffer, int start, int numBytes) throws java.io.IOException
IRandomAccess
len
bytes of data from this data container into
an array of bytes. This method blocks until at least one byte of input is
available.
buffer
- the buffer into which the data is read.start
- the start offset of the data.numBytes
- the maximum number of bytes read.
-1
if there is no more data because the end of the
file has been reached.
java.io.IOException
- if an I/O error occurs.public void close() throws java.io.IOException
IRandomAccess
java.io.IOException
- if an I/O error occurs.public void flush() throws java.io.IOException
IRandomAccess
java.io.IOException
public boolean isReadOnly()
IRandomAccess
true
if this is a read only data container.
true
if this is a read only data container.public void write(int b) throws java.io.IOException
IRandomAccess
b
- the byte
to be written.
java.io.IOException
- if an I/O error occurs.public void write(byte[] buffer) throws java.io.IOException
IRandomAccess
b.length
bytes from the specified byte array,
starting at the current offset.
buffer
- the data.
java.io.IOException
- if an I/O error occurs.public void write(byte[] buffer, int start, int numBytes) throws java.io.IOException
IRandomAccess
len
bytes from the specified byte array starting at
start
.
buffer
- the data.start
- the start offset in the data.numBytes
- the number of bytes to write.
java.io.IOException
- if an I/O error occurs.
|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |