Class BATBlock
java.lang.Object
org.docx4j.org.apache.poi.poifs.storage.BATBlock
- All Implemented Interfaces:
BlockWritable
A block of block allocation table entries. BATBlocks are created
only through a static factory method: createBATBlocks.
-
Nested Class Summary
Nested Classes -
Field Summary
FieldsModifier and TypeFieldDescriptionprotected POIFSBigBlockSizeEither 512 bytes (POIFSConstants.SMALLER_BIG_BLOCK_SIZE) or 4096 bytes (POIFSConstants.LARGER_BIG_BLOCK_SIZE) -
Method Summary
Modifier and TypeMethodDescriptionstatic longcalculateMaximumSize(POIFSBigBlockSize bigBlockSize, int numBATs) Calculates the maximum size of a file which is addressable given the number of FAT (BAT) sectors specified.static longcalculateMaximumSize(HeaderBlock header) static intcalculateStorageRequirements(POIFSBigBlockSize bigBlockSize, int entryCount) Calculate how many BATBlocks are needed to hold a specified number of BAT entries.static intcalculateXBATStorageRequirements(POIFSBigBlockSize bigBlockSize, int entryCount) Calculate how many XBATBlocks are needed to hold a specified number of BAT entries.static BATBlockcreateBATBlock(POIFSBigBlockSize bigBlockSize, ByteBuffer data) Create a single BATBlock from the byte buffer, which must hold at least one big block of data to be read.static BATBlock[]createBATBlocks(POIFSBigBlockSize bigBlockSize, int[] entries) Create an array of BATBlocks from an array of int block allocation table entriesstatic BATBlockcreateEmptyBATBlock(POIFSBigBlockSize bigBlockSize, boolean isXBAT) Creates a single BATBlock, with all the values set to empty.static BATBlock[]createXBATBlocks(POIFSBigBlockSize bigBlockSize, int[] entries, int startBlock) Create an array of XBATBlocks from an array of int block allocation table entriesprotected voiddoWriteData(OutputStream stream, byte[] data) Default implementation of write for extending classes that contain their data in a simple array of bytes.static BATBlock.BATBlockAndIndexgetBATBlockAndIndex(int offset, HeaderBlock header, List<BATBlock> bats) Returns the BATBlock that handles the specified offset, and the relative index within it.intRetrieve where in the file we livestatic BATBlock.BATBlockAndIndexgetSBATBlockAndIndex(int offset, HeaderBlock header, List<BATBlock> sbats) Returns the BATBlock that handles the specified offset, and the relative index within it, for the mini stream.intgetUsedSectors(boolean isAnXBAT) How many sectors in this block are taken? Note that callinghasFreeSectors()is much quickerintgetValueAt(int relativeOffset) booleanDoes this BATBlock have any free sectors in it, or is it full?voidsetOurBlockIndex(int index) Record where in the file we livevoidsetValueAt(int relativeOffset, int value) voidwriteBlocks(OutputStream stream) Write the storage to an OutputStream
-
Field Details
-
bigBlockSize
Either 512 bytes (POIFSConstants.SMALLER_BIG_BLOCK_SIZE) or 4096 bytes (POIFSConstants.LARGER_BIG_BLOCK_SIZE)
-
-
Method Details
-
createBATBlock
Create a single BATBlock from the byte buffer, which must hold at least one big block of data to be read. -
createEmptyBATBlock
Creates a single BATBlock, with all the values set to empty. -
createBATBlocks
Create an array of BATBlocks from an array of int block allocation table entries- Parameters:
entries- the array of int entries- Returns:
- the newly created array of BATBlocks
-
createXBATBlocks
public static BATBlock[] createXBATBlocks(POIFSBigBlockSize bigBlockSize, int[] entries, int startBlock) Create an array of XBATBlocks from an array of int block allocation table entries- Parameters:
entries- the array of int entriesstartBlock- the start block of the array of XBAT blocks- Returns:
- the newly created array of BATBlocks
-
calculateStorageRequirements
Calculate how many BATBlocks are needed to hold a specified number of BAT entries.- Parameters:
entryCount- the number of entries- Returns:
- the number of BATBlocks needed
-
calculateXBATStorageRequirements
Calculate how many XBATBlocks are needed to hold a specified number of BAT entries.- Parameters:
entryCount- the number of entries- Returns:
- the number of XBATBlocks needed
-
calculateMaximumSize
Calculates the maximum size of a file which is addressable given the number of FAT (BAT) sectors specified. (We don't care if those BAT blocks come from the 109 in the header, or from header + XBATS, it won't affect the calculation) The actual file size will be between [size of fatCount-1 blocks] and [size of fatCount blocks]. For 512 byte block sizes, this means we may over-estimate by up to 65kb. For 4096 byte block sizes, this means we may over-estimate by up to 4mb -
calculateMaximumSize
-
getBATBlockAndIndex
public static BATBlock.BATBlockAndIndex getBATBlockAndIndex(int offset, HeaderBlock header, List<BATBlock> bats) Returns the BATBlock that handles the specified offset, and the relative index within it. The List of BATBlocks must be in sequential order -
getSBATBlockAndIndex
public static BATBlock.BATBlockAndIndex getSBATBlockAndIndex(int offset, HeaderBlock header, List<BATBlock> sbats) Returns the BATBlock that handles the specified offset, and the relative index within it, for the mini stream. The List of BATBlocks must be in sequential order -
hasFreeSectors
public boolean hasFreeSectors()Does this BATBlock have any free sectors in it, or is it full? -
getUsedSectors
public int getUsedSectors(boolean isAnXBAT) How many sectors in this block are taken? Note that callinghasFreeSectors()is much quicker -
getValueAt
public int getValueAt(int relativeOffset) -
setValueAt
public void setValueAt(int relativeOffset, int value) -
setOurBlockIndex
public void setOurBlockIndex(int index) Record where in the file we live -
getOurBlockIndex
public int getOurBlockIndex()Retrieve where in the file we live -
doWriteData
Default implementation of write for extending classes that contain their data in a simple array of bytes.- Parameters:
stream- the OutputStream to which the data should be written.data- the byte array of to be written.- Throws:
IOException- on problems writing to the specified stream.
-
writeBlocks
Write the storage to an OutputStream- Specified by:
writeBlocksin interfaceBlockWritable- Parameters:
stream- the OutputStream to which the stored data should be written- Throws:
IOException- on problems writing to the specified stream
-