public class CpioArchiveOutputStream extends ArchiveOutputStream implements CpioConstants
An entry can be written by creating an instance of CpioArchiveEntry and fill it with the necessary values and put it into the CPIO stream. Afterwards write the contents of the file into the CPIO stream. Either close the stream by calling finish() or put a next entry into the cpio stream.
CpioArchiveOutputStream out = new CpioArchiveOutputStream(
new FileOutputStream(new File("test.cpio")));
CpioArchiveEntry entry = new CpioArchiveEntry();
entry.setName("testfile");
String contents = "12345";
entry.setFileSize(contents.length());
entry.setMode(CpioConstants.C_ISREG); // regular file
... set other attributes, e.g. time, number of links
out.putArchiveEntry(entry);
out.write(testContents.getBytes());
out.close();
Note: This implementation should be compatible to cpio 2.5
This class uses mutable fields and is not considered threadsafe.
based on code from the jRPM project (jrpm.sourceforge.net)
BLOCK_SIZE, C_IRGRP, C_IROTH, C_IRUSR, C_ISBLK, C_ISCHR, C_ISDIR, C_ISFIFO, C_ISGID, C_ISLNK, C_ISNWK, C_ISREG, C_ISSOCK, C_ISUID, C_ISVTX, C_IWGRP, C_IWOTH, C_IWUSR, C_IXGRP, C_IXOTH, C_IXUSR, CPIO_TRAILER, FORMAT_NEW, FORMAT_NEW_CRC, FORMAT_NEW_MASK, FORMAT_OLD_ASCII, FORMAT_OLD_BINARY, FORMAT_OLD_MASK, MAGIC_NEW, MAGIC_NEW_CRC, MAGIC_OLD_ASCII, MAGIC_OLD_BINARY, S_IFMT| Constructor and Description |
|---|
CpioArchiveOutputStream(java.io.OutputStream out)
Construct the cpio output stream.
|
CpioArchiveOutputStream(java.io.OutputStream out,
short format)
Construct the cpio output stream with a specified format, a
blocksize of
BLOCK_SIZE and
using ASCII as the file name encoding. |
CpioArchiveOutputStream(java.io.OutputStream out,
short format,
int blockSize)
Construct the cpio output stream with a specified format using
ASCII as the file name encoding.
|
CpioArchiveOutputStream(java.io.OutputStream out,
short format,
int blockSize,
java.lang.String encoding)
Construct the cpio output stream with a specified format using
ASCII as the file name encoding.
|
CpioArchiveOutputStream(java.io.OutputStream out,
java.lang.String encoding)
Construct the cpio output stream.
|
| Modifier and Type | Method and Description |
|---|---|
void |
close()
Closes the CPIO output stream as well as the stream being filtered.
|
void |
closeArchiveEntry()
Closes the archive entry, writing any trailer information that may
be required.
|
ArchiveEntry |
createArchiveEntry(java.io.File inputFile,
java.lang.String entryName)
Creates a new ArchiveEntry.
|
ArchiveEntry |
createArchiveEntry(java.nio.file.Path inputPath,
java.lang.String entryName,
java.nio.file.LinkOption... options)
Creates a new ArchiveEntry.
|
void |
finish()
Finishes writing the contents of the CPIO output stream without closing
the underlying stream.
|
void |
putArchiveEntry(ArchiveEntry entry)
Begins writing a new CPIO file entry and positions the stream to the
start of the entry data.
|
void |
write(byte[] b,
int off,
int len)
Writes an array of bytes to the current CPIO entry data.
|
canWriteEntryData, getBytesWritten, getCount, writepublic CpioArchiveOutputStream(java.io.OutputStream out,
short format)
BLOCK_SIZE and
using ASCII as the file name encoding.out - The cpio streamformat - The format of the streampublic CpioArchiveOutputStream(java.io.OutputStream out,
short format,
int blockSize)
out - The cpio streamformat - The format of the streamblockSize - The block size of the archive.public CpioArchiveOutputStream(java.io.OutputStream out,
short format,
int blockSize,
java.lang.String encoding)
out - The cpio streamformat - The format of the streamblockSize - The block size of the archive.encoding - The encoding of file names to write - use null for
the platform's default.public CpioArchiveOutputStream(java.io.OutputStream out)
out - The cpio streampublic CpioArchiveOutputStream(java.io.OutputStream out,
java.lang.String encoding)
out - The cpio streamencoding - The encoding of file names to write - use null for
the platform's default.public void putArchiveEntry(ArchiveEntry entry) throws java.io.IOException
putArchiveEntry in class ArchiveOutputStreamentry - the CPIO cpioEntry to be writtenjava.io.IOException - if an I/O error has occurred or if a CPIO file error has
occurredjava.lang.ClassCastException - if entry is not an instance of CpioArchiveEntrypublic void closeArchiveEntry()
throws java.io.IOException
ArchiveOutputStreamcloseArchiveEntry in class ArchiveOutputStreamjava.io.IOException - if an I/O error occurspublic void write(byte[] b,
int off,
int len)
throws java.io.IOException
write in class java.io.OutputStreamb - the data to be writtenoff - the start offset in the datalen - the number of bytes that are writtenjava.io.IOException - if an I/O error has occurred or if a CPIO file error has
occurredpublic void finish()
throws java.io.IOException
finish in class ArchiveOutputStreamjava.io.IOException - if an I/O exception has occurred or if a CPIO file error has
occurredpublic void close()
throws java.io.IOException
close in interface java.io.Closeableclose in interface java.lang.AutoCloseableclose in class java.io.OutputStreamjava.io.IOException - if an I/O error has occurred or if a CPIO file error has
occurredpublic ArchiveEntry createArchiveEntry(java.io.File inputFile, java.lang.String entryName) throws java.io.IOException
createArchiveEntry in class ArchiveOutputStreaminputFile - the file to create the entry fromentryName - name to use for the entryjava.io.IOException - if an I/O error occursArchiveOutputStream.createArchiveEntry(java.io.File, String)public ArchiveEntry createArchiveEntry(java.nio.file.Path inputPath, java.lang.String entryName, java.nio.file.LinkOption... options) throws java.io.IOException
createArchiveEntry in class ArchiveOutputStreaminputPath - the file to create the entry fromentryName - name to use for the entryoptions - options indicating how symbolic links are handled.java.io.IOException - if an I/O error occursArchiveOutputStream.createArchiveEntry(java.io.File, String)Copyright © 2010 - 2023 Adobe. All Rights Reserved