Package proguard.io
Class DexDataEntryWriter
java.lang.Object
proguard.io.DexDataEntryWriter
- All Implemented Interfaces:
AutoCloseable,DataEntryWriter
- Direct Known Subclasses:
D8BasedDexDataEntryWriter
This DataEntryWriter finds received class entries in the given class pool, collects them in a dex
file, and writes it out to the given data entry writer. For resource entries, it returns valid
output streams. For class entries, it returns output streams that must not be used.
- See Also:
-
Field Summary
FieldsModifier and TypeFieldDescriptionprotected final DataEntryWriterprotected final Stringprotected final DataEntryWriter -
Constructor Summary
ConstructorsConstructorDescriptionDexDataEntryWriter(ClassPool classPool, StringMatcher classNameFilter, String dexFileName, boolean forceDex, DataEntryReader extraDexDataEntryVisitor, DataEntryWriter dexDataEntryWriter, DataEntryWriter otherDataEntryWriter) Creates a new DexDataEntryWriter. -
Method Summary
Modifier and TypeMethodDescriptionvoidclose()Finishes writing all data entries.booleancreateDirectory(DataEntry dataEntry) Creates a directory.createOutputStream(DataEntry dataEntry) Creates a new output stream for writing data.voidprintln(PrintWriter pw, String prefix) Prints out the structure of the data entry writer.booleansameOutputStream(DataEntry dataEntry1, DataEntry dataEntry2) Returns whether the two given data entries would result in the same output stream.protected abstract voidwriteDex(OutputStream outputStream) Creates a new Dex instance from the collected classes.
-
Field Details
-
dexFileName
-
dexDataEntryWriter
-
otherDataEntryWriter
-
-
Constructor Details
-
DexDataEntryWriter
public DexDataEntryWriter(ClassPool classPool, StringMatcher classNameFilter, String dexFileName, boolean forceDex, DataEntryReader extraDexDataEntryVisitor, DataEntryWriter dexDataEntryWriter, DataEntryWriter otherDataEntryWriter) Creates a new DexDataEntryWriter.- Parameters:
classPool- the class pool from which classes are collected.classNameFilter- an optional filter for classes to be written.dexFileName- the dex file name.forceDex- specifies whether the dex files should always be written, even if they don't contain any code.dexDataEntryWriter- the writer to which the converted dex file is written.otherDataEntryWriter- the writer to which other data entries are written.
-
-
Method Details
-
createDirectory
Description copied from interface:DataEntryWriterCreates a directory.- Specified by:
createDirectoryin interfaceDataEntryWriter- Parameters:
dataEntry- the data entry for which the directory is to be created.- Returns:
- whether the directory has been created.
- Throws:
IOException
-
sameOutputStream
Description copied from interface:DataEntryWriterReturns whether the two given data entries would result in the same output stream.- Specified by:
sameOutputStreamin interfaceDataEntryWriter- Parameters:
dataEntry1- the first data entry.dataEntry2- the second data entry.- Throws:
IOException
-
createOutputStream
Description copied from interface:DataEntryWriterCreates a new output stream for writing data. The caller is responsible for closing the stream.- Specified by:
createOutputStreamin interfaceDataEntryWriter- 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:
IOException
-
close
Description 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 interfaceAutoCloseable- Specified by:
closein interfaceDataEntryWriter- Throws:
IOException
-
println
Description copied from interface:DataEntryWriterPrints out the structure of the data entry writer.- Specified by:
printlnin interfaceDataEntryWriter- Parameters:
pw- the print stream to which the structure should be printed.prefix- a prefix for every printed line.
-
writeDex
Creates a new Dex instance from the collected classes.- Throws:
IOException
-