Class TarBuffer
- java.lang.Object
-
- org.jboss.shrinkwrap.impl.base.io.tar.TarBuffer
-
public class TarBuffer extends Object
The TarBuffer class implements the tar archive concept of a buffered input stream. This concept goes back to the days of blocked tape drives and special io devices. In the Java universe, the only real function that this class performs is to ensure that files have the correct "block" size, or other tars will complain.You should never have a need to access this class directly. TarBuffers are created by Tar IO Streams.
- Version:
- $Revision: 1.10 $
- Author:
- Timothy Gerard Endres, time@trustice.com.
- See Also:
TarArchive
-
-
Field Summary
Fields Modifier and Type Field Description static intDEFAULT_BLKSIZEstatic intDEFAULT_RCDSIZE
-
Constructor Summary
Constructors Constructor Description TarBuffer(InputStream inStream)TarBuffer(InputStream inStream, int blockSize)TarBuffer(InputStream inStream, int blockSize, int recordSize)TarBuffer(OutputStream outStream)TarBuffer(OutputStream outStream, int blockSize)TarBuffer(OutputStream outStream, int blockSize, int recordSize)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidclose()Close the TarBuffer.intgetBlockSize()Get the TAR Buffer's block size.intgetCurrentBlockNum()Get the current block number, zero based.intgetCurrentRecordNum()Get the current record number, within the current block, zero based.intgetRecordSize()Get the TAR Buffer's record size.booleanisEOFRecord(byte[] record)Determine if an archive record indicate End of Archive.byte[]readRecord()Read a record from the input stream and return the data.voidsetDebug(boolean debug)Set the debugging flag for the buffer.voidskipRecord()Skip over a record on the input stream.voidwriteRecord(byte[] record)Write an archive record to the archive.voidwriteRecord(byte[] buf, int offset)Write an archive record to the archive, where the record may be inside of a larger array buffer.
-
-
-
Field Detail
-
DEFAULT_RCDSIZE
public static final int DEFAULT_RCDSIZE
- See Also:
- Constant Field Values
-
DEFAULT_BLKSIZE
public static final int DEFAULT_BLKSIZE
- See Also:
- Constant Field Values
-
-
Constructor Detail
-
TarBuffer
public TarBuffer(InputStream inStream)
-
TarBuffer
public TarBuffer(InputStream inStream, int blockSize)
-
TarBuffer
public TarBuffer(InputStream inStream, int blockSize, int recordSize)
-
TarBuffer
public TarBuffer(OutputStream outStream)
-
TarBuffer
public TarBuffer(OutputStream outStream, int blockSize)
-
TarBuffer
public TarBuffer(OutputStream outStream, int blockSize, int recordSize)
-
-
Method Detail
-
getBlockSize
public int getBlockSize()
Get the TAR Buffer's block size. Blocks consist of multiple records.
-
getRecordSize
public int getRecordSize()
Get the TAR Buffer's record size.
-
setDebug
public void setDebug(boolean debug)
Set the debugging flag for the buffer.- Parameters:
debug- If true, print debugging output.
-
isEOFRecord
public boolean isEOFRecord(byte[] record)
Determine if an archive record indicate End of Archive. End of archive is indicated by a record that consists entirely of null bytes.- Parameters:
record- The record data to check.
-
skipRecord
public void skipRecord() throws IOExceptionSkip over a record on the input stream.- Throws:
IOException
-
readRecord
public byte[] readRecord() throws IOExceptionRead a record from the input stream and return the data.- Returns:
- The record data.
- Throws:
IOException
-
getCurrentBlockNum
public int getCurrentBlockNum()
Get the current block number, zero based.- Returns:
- The current zero based block number.
-
getCurrentRecordNum
public int getCurrentRecordNum()
Get the current record number, within the current block, zero based. Thus, current offset = (currentBlockNum * recsPerBlk) + currentRecNum.- Returns:
- The current zero based record number.
-
writeRecord
public void writeRecord(byte[] record) throws IOExceptionWrite an archive record to the archive.- Parameters:
record- The record data to write to the archive.- Throws:
IOException
-
writeRecord
public void writeRecord(byte[] buf, int offset) throws IOExceptionWrite an archive record to the archive, where the record may be inside of a larger array buffer. The buffer must be "offset plus record size" long.- Parameters:
buf- The buffer containing the record data to write.offset- The offset of the record data within buf.- Throws:
IOException
-
close
public void close() throws IOExceptionClose the TarBuffer. If this is an output buffer, also flush the current block before closing.- Throws:
IOException
-
-