Package proguard.io
Class NonClosingDataEntryWriter
- java.lang.Object
-
- proguard.io.NonClosingDataEntryWriter
-
- All Implemented Interfaces:
java.lang.AutoCloseable,DataEntryWriter
public class NonClosingDataEntryWriter extends java.lang.Object implements DataEntryWriter
ThisDataEntryWriterdelegates to anotherDataEntryWriter, except for anyclose()calls.For example:
DataEntryWriter writer = ... NonClosingDataEntryWriter nonClosingDataEntryWriter = new NonClosingDataEntryWriter(writer); DataEntryWriter writer1 = new NonClosingDataEntryWriter(writer); DataEntryWriter writer2 = writer; ... writer1.close(); ... writer2.close();
-
-
Constructor Summary
Constructors Constructor Description NonClosingDataEntryWriter(DataEntryWriter dataEntryWriter)Creates a new NonClosingDataEntryWriter that won't close its delegate.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidclose()Finishes writing all data entries.booleancreateDirectory(DataEntry dataEntry)Creates a directory.java.io.OutputStreamcreateOutputStream(DataEntry dataEntry)Creates a new output stream for writing data.voidprintln(java.io.PrintWriter pw, java.lang.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.
-
-
-
Constructor Detail
-
NonClosingDataEntryWriter
public NonClosingDataEntryWriter(DataEntryWriter dataEntryWriter)
Creates a new NonClosingDataEntryWriter that won't close its delegate.- Parameters:
dataEntryWriter- the DataEntryWriter to which the writing will be delegated.
-
-
Method Detail
-
createDirectory
public boolean createDirectory(DataEntry dataEntry) throws java.io.IOException
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:
java.io.IOException
-
sameOutputStream
public 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 interfaceDataEntryWriter- Parameters:
dataEntry1- the first data entry.dataEntry2- the second data entry.- Throws:
java.io.IOException
-
createOutputStream
public 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 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:
java.io.IOException
-
close
public 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 interfacejava.lang.AutoCloseable- Specified by:
closein interfaceDataEntryWriter- Throws:
java.io.IOException
-
println
public 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 interfaceDataEntryWriter- Parameters:
pw- the print stream to which the structure should be printed.prefix- a prefix for every printed line.
-
-