Package proguard.io
Class JarWriter
- java.lang.Object
- 
- proguard.io.JarWriter
 
- 
- All Implemented Interfaces:
- java.lang.AutoCloseable,- DataEntryWriter
 - Direct Known Subclasses:
- SignedJarWriter
 
 public class JarWriter extends java.lang.Object implements DataEntryWriter ThisDataEntryWritersends data entries to another given data entry writer, automatically adding a manifest file.You'll typically wrap a ZipWriteror one of its extensions:new JarWriter(new ZipWriter(...))
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description protected static classJarWriter.MyMultiDigestOutputStreamThis FilterOutputStream automatically appends a file digest entry to a given manifest writer, when the stream is closed.
 - 
Field SummaryFields Modifier and Type Field Description protected java.lang.Stringcreatorprotected DataEntrycurrentManifestEntrystatic java.lang.StringDEFAULT_DIGEST_ALGORITHMprotected java.lang.String[]digestAlgorithmsprotected DataEntryWritermanifestEntryWriterprotected DataEntryWriterzipEntryWriter
 - 
Constructor SummaryConstructors Constructor Description JarWriter(java.lang.String[] digestAlgorithms, java.lang.String creator, java.lang.String manifestFileName, StringFunction manifestEntryNameFunction, DataEntryWriter zipEntryWriter, DataEntryWriter manifestEntryWriter)Creates a new JarWriter.JarWriter(java.lang.String[] digestAlgorithms, java.lang.String creator, DataEntryWriter zipEntryWriter)Creates a new JarWriter wth default manifest file name "META-INF/MANIFEST.MF".JarWriter(java.lang.String[] digestAlgorithms, DataEntryWriter zipEntryWriter)Creates a new JarWriter wth default manifest file name "META-INF/MANIFEST.MF".JarWriter(DataEntryWriter zipEntryWriter)Creates a new JarWriter wth default manifest digest "SHA-256" and manifest file name "META-INF/MANIFEST.MF".
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description voidclose()Finishes writing all data entries.booleancreateDirectory(DataEntry dataEntry)Creates a directory.protected java.io.OutputStreamcreateManifestOutputStream(DataEntry manifestEntry)Creates an output stream for the specified manifest file.java.io.OutputStreamcreateOutputStream(DataEntry dataEntry)Creates a new output stream for writing data.protected voidfinish()Writes out the collected manifest file before closing the jar, if any.protected voidfinishIfNecessary(DataEntry dataEntry)Writes out the collected manifest file for the current jar, if we're entering a new jar with this data entry.static voidmain(java.lang.String[] args)Provides a simple test for this class, creating a signed apk file (only v1) with the given name and a few aligned/compressed/uncompressed zip entries.protected voidopenManifestFiles()Prepares streams and writers for capturing digests of a parent entry.voidprintln(java.io.PrintWriter pw, java.lang.String prefix)Prints out the structure of the data entry writer.protected java.io.PrintWriterprintWriter(java.io.OutputStream outputStream)Creates a convenience writer.booleansameOutputStream(DataEntry dataEntry1, DataEntry dataEntry2)Returns whether the two given data entries would result in the same output stream.
 
- 
- 
- 
Field Detail- 
DEFAULT_DIGEST_ALGORITHMpublic static final java.lang.String DEFAULT_DIGEST_ALGORITHM - See Also:
- Constant Field Values
 
 - 
digestAlgorithmsprotected final java.lang.String[] digestAlgorithms 
 - 
creatorprotected final java.lang.String creator 
 - 
zipEntryWriterprotected final DataEntryWriter zipEntryWriter 
 - 
manifestEntryWriterprotected final DataEntryWriter manifestEntryWriter 
 - 
currentManifestEntryprotected DataEntry currentManifestEntry 
 
- 
 - 
Constructor Detail- 
JarWriterpublic JarWriter(DataEntryWriter zipEntryWriter) Creates a new JarWriter wth default manifest digest "SHA-256" and manifest file name "META-INF/MANIFEST.MF".- Parameters:
- zipEntryWriter- the data entry writer that can provide output streams for the jar entries.
 
 - 
JarWriterpublic JarWriter(java.lang.String[] digestAlgorithms, DataEntryWriter zipEntryWriter)Creates a new JarWriter wth default manifest file name "META-INF/MANIFEST.MF".- Parameters:
- digestAlgorithms- the manifest digest algorithms, e.g. "SHA-256".
- zipEntryWriter- the data entry writer that can provide output streams for the jar entries.
 
 - 
JarWriterpublic JarWriter(java.lang.String[] digestAlgorithms, java.lang.String creator, DataEntryWriter zipEntryWriter)Creates a new JarWriter wth default manifest file name "META-INF/MANIFEST.MF".- Parameters:
- digestAlgorithms- the manifest digest algorithms, e.g. "SHA-256".
- creator- the creator to mention in the manifest file.
- zipEntryWriter- the data entry writer that can provide output streams for the jar entries.
 
 - 
JarWriterpublic JarWriter(java.lang.String[] digestAlgorithms, java.lang.String creator, java.lang.String manifestFileName, StringFunction manifestEntryNameFunction, DataEntryWriter zipEntryWriter, DataEntryWriter manifestEntryWriter)Creates a new JarWriter.- Parameters:
- digestAlgorithms- the manifest digest algorithms, e.g. "SHA-256".
- creator- the creator to mention in the manifest file.
- manifestFileName- the manifest file name, e.g. "META-INF/MANIFEST.MF".
- manifestEntryNameFunction- the function to transform entry names in the manifest (not in the jar).
- zipEntryWriter- the data entry writer that can provide output streams for the jar entries.
- manifestEntryWriter- the data entry writer that can provide an output stream for the manifest file.
 
 
- 
 - 
Method Detail- 
createDirectorypublic boolean createDirectory(DataEntry dataEntry) throws java.io.IOException Description copied from interface:DataEntryWriterCreates a directory.- Specified by:
- createDirectoryin interface- DataEntryWriter
- Parameters:
- dataEntry- the data entry for which the directory is to be created.
- Returns:
- whether the directory has been created.
- Throws:
- java.io.IOException
 
 - 
sameOutputStreampublic boolean sameOutputStream(DataEntry dataEntry1, DataEntry dataEntry2) throws java.io.IOException Description copied from interface:DataEntryWriterReturns whether the two given data entries would result in the same output stream.- Specified by:
- sameOutputStreamin interface- DataEntryWriter
- Parameters:
- dataEntry1- the first data entry.
- dataEntry2- the second data entry.
- Throws:
- java.io.IOException
 
 - 
createOutputStreampublic java.io.OutputStream createOutputStream(DataEntry dataEntry) throws java.io.IOException Description copied from interface:DataEntryWriterCreates a new output stream for writing data. The caller is responsible for closing the stream.- Specified by:
- createOutputStreamin interface- DataEntryWriter
- Parameters:
- dataEntry- the data entry for which the output stream is to be created.
- Returns:
- the output stream. The stream may be nullto indicate that the data entry should not be written.
- Throws:
- java.io.IOException
 
 - 
closepublic void close() throws java.io.IOExceptionDescription copied from interface:DataEntryWriterFinishes writing all data entries.Implementations typically create graphs of writers that can split and merge again, possibly even with cycles. For splits and merges, implementations need to be idempotent; once closed, subsequent attempts to close a writer have no effect. If needed, the wrapper NonClosingDataEntryWritercan avoid closing a branch prematurely.For cycles, implementations must perform any custom behavior, then delegate DataEntryWriter.close()invocations, and only finally clean up. It is possible that delegates callDataEntryWriter.createOutputStream(DataEntry)whileDataEntryWriter.close()is in progress.- Specified by:
- closein interface- java.lang.AutoCloseable
- Specified by:
- closein interface- DataEntryWriter
- Throws:
- java.io.IOException
 
 - 
printlnpublic void println(java.io.PrintWriter pw, java.lang.String prefix)Description copied from interface:DataEntryWriterPrints out the structure of the data entry writer.- Specified by:
- printlnin interface- DataEntryWriter
- Parameters:
- pw- the print stream to which the structure should be printed.
- prefix- a prefix for every printed line.
 
 - 
openManifestFilesprotected void openManifestFiles() throws java.io.IOExceptionPrepares streams and writers for capturing digests of a parent entry.- Throws:
- java.io.IOException
 
 - 
createManifestOutputStreamprotected java.io.OutputStream createManifestOutputStream(DataEntry manifestEntry) throws java.io.IOException Creates an output stream for the specified manifest file.- Throws:
- java.io.IOException
 
 - 
finishIfNecessaryprotected void finishIfNecessary(DataEntry dataEntry) throws java.io.IOException Writes out the collected manifest file for the current jar, if we're entering a new jar with this data entry.- Throws:
- java.io.IOException
 
 - 
finishprotected void finish() throws java.io.IOExceptionWrites out the collected manifest file before closing the jar, if any.- Throws:
- java.io.IOException
 
 - 
printWriterprotected java.io.PrintWriter printWriter(java.io.OutputStream outputStream) throws java.io.IOExceptionCreates a convenience writer.- Parameters:
- outputStream- the underlying output stream.
- Throws:
- java.io.IOException
 
 - 
mainpublic static void main(java.lang.String[] args) Provides a simple test for this class, creating a signed apk file (only v1) with the given name and a few aligned/compressed/uncompressed zip entries. Arguments: jar_filename Verify the jar with: jarsigner -verify -verbose /tmp/test.jar
 
- 
 
-