Package org.apache.poi.poifs.storage
Class BATBlock
- java.lang.Object
- 
- org.apache.poi.poifs.storage.BATBlock
 
- 
- All Implemented Interfaces:
- BlockWritable
 
 public final class BATBlock extends Object implements BlockWritable A block of block allocation table entries. BATBlocks are created only through a static factory method: createBATBlocks.
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classBATBlock.BATBlockAndIndex
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description static 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 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 BATBlockcreateEmptyBATBlock(POIFSBigBlockSize bigBlockSize, boolean isXBAT)Creates a single BATBlock, with all the values set to empty.static BATBlock.BATBlockAndIndexgetBATBlockAndIndex(int offset, HeaderBlock header, List<BATBlock> bats)Returns the BATBlock that handles the specified offset, and the relative index within it.intgetOccupiedSize()How much of this block is occupied?.intgetOurBlockIndex()Retrieve 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)booleanhasFreeSectors()Does 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 block's data to an OutputStreamvoidwriteData(ByteBuffer block)
 
- 
- 
- 
Method Detail- 
createBATBlockpublic static BATBlock createBATBlock(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.
 - 
createEmptyBATBlockpublic static BATBlock createEmptyBATBlock(POIFSBigBlockSize bigBlockSize, boolean isXBAT) Creates a single BATBlock, with all the values set to empty.
 - 
calculateMaximumSizepublic static long calculateMaximumSize(POIFSBigBlockSize bigBlockSize, int numBATs) 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
 - 
calculateMaximumSizepublic static long calculateMaximumSize(HeaderBlock header) 
 - 
getBATBlockAndIndexpublic 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
 - 
getSBATBlockAndIndexpublic 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
 - 
hasFreeSectorspublic boolean hasFreeSectors() Does this BATBlock have any free sectors in it, or is it full?
 - 
getUsedSectorspublic int getUsedSectors(boolean isAnXBAT) How many sectors in this block are taken? Note that callinghasFreeSectors()is much quicker
 - 
getOccupiedSizepublic int getOccupiedSize() How much of this block is occupied?. This counts the number of sectors up and including the last used sector. Note that this is different fromgetUsedSectors(boolean)which could be smaller as it does not count unused sectors where there are used ones after it (i.e. fragmentation).- Since:
- POI 5.0.0
 
 - 
getValueAtpublic int getValueAt(int relativeOffset) 
 - 
setValueAtpublic void setValueAt(int relativeOffset, int value)
 - 
setOurBlockIndexpublic void setOurBlockIndex(int index) Record where in the file we live
 - 
getOurBlockIndexpublic int getOurBlockIndex() Retrieve where in the file we live
 - 
writeBlockspublic void writeBlocks(OutputStream stream) throws IOException Write the block's data to an OutputStream- Specified by:
- writeBlocksin interface- BlockWritable
- Parameters:
- stream- the OutputStream to which the stored data should be written
- Throws:
- IOException- on problems writing to the specified stream
 
 - 
writeDatapublic void writeData(ByteBuffer block) 
 
- 
 
-