public class POIFSStream
extends java.lang.Object
implements java.lang.Iterable<java.nio.ByteBuffer>
POIFSFileSystem
. It can supply an iterator
to read blocks, and way to write out to existing and
new blocks.
Most users will want a higher level version of this,
which deals with properties to track which stream
this is.
This only works on big block streams, it doesn't
handle small block ones.
This uses the new NIO code
TODO Implement a streaming write method, and appendModifier and Type | Class and Description |
---|---|
protected class |
POIFSStream.StreamBlockByteBuffer |
Constructor and Description |
---|
POIFSStream(BlockStore blockStore)
Constructor for a new stream.
|
POIFSStream(BlockStore blockStore,
int startBlock)
Constructor for an existing stream.
|
Modifier and Type | Method and Description |
---|---|
void |
free()
Frees all blocks in the stream
|
java.io.OutputStream |
getOutputStream() |
int |
getStartBlock()
What block does this stream start at?
Will be
POIFSConstants.END_OF_CHAIN for a
new stream that hasn't been written to yet. |
java.util.Iterator<java.nio.ByteBuffer> |
iterator()
Returns an iterator that'll supply one
ByteBuffer
per block in the stream. |
public POIFSStream(BlockStore blockStore, int startBlock)
HeaderBlock
or a Property
)public POIFSStream(BlockStore blockStore)
public int getStartBlock()
POIFSConstants.END_OF_CHAIN
for a
new stream that hasn't been written to yet.public java.util.Iterator<java.nio.ByteBuffer> iterator()
ByteBuffer
per block in the stream.iterator
in interface java.lang.Iterable<java.nio.ByteBuffer>
public java.io.OutputStream getOutputStream() throws java.io.IOException
java.io.IOException
public void free() throws java.io.IOException
java.io.IOException
Copyright 2022 The Apache Software Foundation or its licensors, as applicable.